Skip to content

T64 Debian using Gcc

Glen Hansen edited this page Aug 10, 2014 · 8 revisions

This set of build instructions builds the tpetra branch of Albany in 64 bit mode, in other words with support of a > 2.1 billion word address space to handle problems with very large numbers of degrees of freedom.

The compilers are gcc 4.7.2, OpenMPI 1.6.3, and Debian linux.

Build supporting packages

Trilinos requires a set of "third party libraries" (TPLs) to support Albany. The actual libraries needed depends on the final Albany configuration desired. These instructions build a superset, all the libraries needed to support any Albany configuration.

Notes: In this example

  • The TPLs are installed in /users/ghansen

Building ZLib

  • Version 1.2.8

      cd /fasttmp/ghansen
      wget http://zlib.net/zlib-1.2.8.tar.gz
      tar -xvf zlib-1.2.8.tar.gz
      cd zlib-1.2.8
      mkdir build
      cd build
      cmake \
      -DCMAKE_C_COMPILER=mpicc \
      -DCMAKE_C_FLAGS="-O3" \
      -DCMAKE_INSTALL_PREFIX=/users/ghansen \
      ..
    
      make -j 8
      make install
    

Building HDF5

  • Version 1.8.12

      cd /fasttmp/ghansen
      wget http://www.hdfgroup.org/ftp/HDF5/current/src/hdf5-1.8.13.tar.gz
      tar -xvf hdf5-1.8.13.tar.gz
      cd hdf5-1.8.13
      ./configure CC=mpicc CXX=mpicxx FC=mpif90 CXXFLAGS="-fPIC -O3" CFLAGS="-fPIC -O3" \
      FFLAGS="-fPIC -O3" --enable-parallel --with-zlib=/users/ghansen --prefix=/users/ghansen
      make -j 4
      make install
    

Building Netcdf

  • Version of the day from the git repo. Note that hdf5-1.8.13 made some changes that are not reflected in the latest release, so we are using the votd for now.

      cd /fasttmp/ghansen
      git clone https://github.com/Unidata/netcdf-c.git
      cd netcdf-c
    
  • Edit the file include/netcdf.h. Make the following edits near line 228:

      #define NC_MAX_DIMS    65536    /* max dimensions per file */
      #define NC_MAX_ATTRS    8192    
      #define NC_MAX_VARS   524288    /* max variables per file */
      #define NC_MAX_NAME   256 
      #define NC_MAX_VAR_DIMS      8     /* max per variable dimensions */
    
  • Now, configure using CMake and build:

      autoreconf -i -f
      ./configure --prefix=/users/ghansen CC=mpicc FC=mpif90 CXX=mpicxx \
      CFLAGS="-I/users/ghansen/include -O3" LDFLAGS="-L/users/ghansen/lib -O3" \
      --disable-fsync --disable-cdmremote --disable-dap --disable-shared --disable-doxygen --enable-netcdf-4 
      make -j 4 
      make install
    

Building boost

  • Version 1.56.0

  • Build boost with the commands

      cd /fasttmp/ghansen
      wget http://sourceforge.net/projects/boost/files/boost/1.56.0/boost_1_56_0.tar.gz/download
      tar -xvf download
      cd boost_1_56_0
      rm ~/user-config.jam
      echo "using gcc : 4.7.2 : /users/ghansen/bin/g++ ;" >> ~/user-config.jam
      echo "using mpi : /users/ghansen/bin/mpicxx ;" >> ~/user-config.jam
      ./bootstrap.sh --with-libraries=signals,regex,filesystem,system,mpi,serialization,thread,program_options,exception --prefix=/users/ghansen
      ./b2 -j 4
      ./b2 -j 4 install
    

Building ParMetis

  • Version 4.0.3

      cd /fasttmp/ghansen
      wget http://glaros.dtc.umn.edu/gkhome/fetch/sw/parmetis/parmetis-4.0.3.tar.gz
      tar -xvf parmetis-4.0.3.tar.gz
      cd parmetis-4.0.3
    
  • Edit metis.h to use an IDXTYPEWIDTH of 64

      cd metis/include
      vi metis.h
      #define IDXTYPEWIDTH 64
    
  • Run CMake to build parmetis

      cd /fasttmp/ghansen/parmetis-4.0.3
      cd build2
      cd build2
      export metis=/fasttmp/ghansen/parmetis-4.0.3/metis
      cmake \
      -DCMAKE_INSTALL_PREFIX=/users/ghansen \
      -DMETIS_PATH=$metis \
      -DGKLIB_PATH=$metis/GKlib \
      -DCMAKE_C_COMPILER=mpicc \
      -DCMAKE_CXX_COMPILER=mpicxx \
      ..
      make -j 4
      make install
    
      cp libmetis/libmetis.a /users/ghansen/lib
      cp $metis/include/metis.h /users/ghansen/include
    

SuperLU

  • Version 4.3

  • Build paths

      mkdir /users/ghansen/SuperLU_4.3
      mkdir /users/ghansen/SuperLU_4.3/include
      mkdir /users/ghansen/SuperLU_4.3/lib
    
  • Edit make.inc for your machine and environment

      PLAT = _linux
      SuperLUroot = /users/ghansen/SuperLU_4.3
      SUPERLULIB      = $(SuperLUroot)/lib/libsuperlu_4.3.a
      TMGLIB          = libtmglib.a
      BLASDEF     = -DUSE_VENDOR_BLAS
      BLASLIB     = -L/usr/lib -lblas
      LIBS        = $(SUPERLULIB) $(BLASLIB)
      ARCH         = ar
      ARCHFLAGS    = cr
      RANLIB       = ranlib
      CC           = gcc
      CFLAGS       = -O3
      NOOPTS       =
      FORTRAN      = gfortran
      FFLAGS       = -O3
      LOADER       = $(CC)
      LOADOPTS     =
      CDEFS        = -DAdd_
      MATLAB       = /usr/sww/matlab
    
  • Build SuperLU

      make -j 4
      cd SRC
      cp *.h /users/ghansen/SuperLU_4.3/include		
    

Build HWLOC

  • Version 1.8

      ./configure CC=mpicc CXX=mpicxx --prefix=/users/ghansen
      make -j 4
      make install
    

Build Trilinos

Notes: In this example

  • The Trilinos source is installed in /lore/ghansen/Trilinos, using a command like

      cd /users/ghansen/Trilinos
      git clone https://software.sandia.gov/trilinos/repositories/publicTrilinos
    
  • The SCOREC tools are installed as a subdirectory of Trilinos, and are build automatically by the Trilinos build process. The commands to do this are

      cd /users/ghansen/Trilinos/publicTrilinos
      git clone https://github.com/SCOREC/core.git SCOREC
    
  • do-configure script

      #!/bin/sh
      #
      export TRILINOS_HOME=/lore/ghansen/Trilinos/publicTrilinos
      BUILD_DIR=`pwd`
      INSTALL_DIR=/users/ghansen/Trilinos/MPI_REL
      LIB_DIR=/users/ghansen
      MPI_BASE_DIR=/users/ghansen
      SUPERLUDIR=${LIB_DIR}/SuperLU_4.3
      
      export BOOST_ROOT=$BOOST_DIR
      EXTRA_ARGS=$@
      cmake \
          -D Trilinos_CONFIGURE_OPTIONS_FILE:FILEPATH=$TRILINOS_HOME/sampleScripts/AlbanySettings.cmake \
          -D CMAKE_BUILD_TYPE:STRING=RELEASE \
          -D Trilinos_EXTRA_REPOSITORIES:STRING=SCOREC \
          -D Trilinos_ENABLE_SCOREC:BOOL=ON \
          -D SCOREC_DISABLE_STRONG_WARNINGS:BOOL=ON \
      	-D Trilinos_ENABLE_SCORECpumi_geom_parasolid:BOOL=ON \
          -D Teuchos_ENABLE_COMPLEX:BOOL=OFF \
      \
      	-D TPL_ENABLE_Parasolid:BOOL=ON \
      	-D Parasolid_INCLUDE_DIRS:PATH="/usr/local/parasolid/25.1.181" \
      	-D Parasolid_LIBRARY_DIRS:PATH="/usr/local/parasolid/25.1.181/shared_object" \
      \
      	-D Zoltan_ENABLE_ULLONG_IDS:BOOL=ON \
      	-D Teuchos_ENABLE_LONG_LONG_INT:BOOL=ON \
      	-D ZOLTAN_BUILD_ZFDRIVE:BOOL=OFF \
      \
          -D Trilinos_ENABLE_ThyraTpetraAdapters:BOOL=ON \
          -D Trilinos_ENABLE_Ifpack2:BOOL=ON \
          -D Trilinos_ENABLE_Amesos2:BOOL=ON \
          -D Trilinos_ENABLE_MueLu:BOOL=ON \
      \
          -D TPL_ENABLE_MPI:BOOL=ON \
          -D MPI_BASE_DIR:PATH=$MPI_BASE_DIR \
      \
          -D Trilinos_ENABLE_Kokkos:BOOL=ON \
          -D Trilinos_ENABLE_KokkosCore:BOOL=ON \
          -D Trilinos_ENABLE_KokkosContainers:BOOL=ON \
          -D Trilinos_ENABLE_KokkosLinAlg:BOOL=ON \
          -D Trilinos_ENABLE_KokkosCompat:BOOL=ON \
          -D TPL_ENABLE_Matio:BOOL=OFF \
      \
          -D CMAKE_VERBOSE_MAKEFILE:BOOL=OFF \
          -D Trilinos_VERBOSE_CONFIGURE:BOOL=OFF \
      \
          -D Boost_INCLUDE_DIRS:PATH=$LIB_DIR/include \
          -D BoostAlbLib_INCLUDE_DIRS:PATH=$LIB_DIR/include \
          -D Boost_LIBRARY_DIRS:PATH=$LIB_DIR/lib \
          -D BoostAlbLib_LIBRARY_DIRS:PATH=$LIB_DIR/lib \
      \
          -D Trilinos_ENABLE_TriKota:BOOL=OFF \
          -D TriKota_ENABLE_DakotaCMake:BOOL=OFF \
          -D ENABLE_DAKOTA_TESTS:BOOL=OFF \
      \
          -D TPL_ENABLE_Netcdf:STRING=ON \
          -D Netcdf_INCLUDE_DIRS:PATH="${LIB_DIR}/include" \
          -D Netcdf_LIBRARY_DIRS:PATH="${LIB_DIR}/lib" \
          -D TPL_ENABLE_HDF5:STRING=ON \
          -D HDF5_INCLUDE_DIRS:PATH="${LIB_DIR}/include" \
          -D TPL_HDF5_LIBRARIES:PATH="${LIB_DIR}/lib/libnetcdf.a;${LIB_DIR}/lib/libhdf5_hl.a;${LIB_DIR}/lib/libhdf5.a;${LIB_DIR}/lib/libz.a" \
          -D TPL_ENABLE_Zlib:STRING=ON \
          -D Zlib_INCLUDE_DIRS:PATH="${LIB_DIR}/include" \
          -D TPL_Zlib_LIBRARIES:PATH="${LIB_DIR}/lib/libz.a" \
      \
          -D TPL_ENABLE_ParMETIS:STRING=ON \
          -D ParMETIS_INCLUDE_DIRS:PATH="${LIB_DIR}/include" \
          -D ParMETIS_LIBRARY_DIRS:PATH="${LIB_DIR}/lib" \
      \
          -D TPL_ENABLE_SuperLU:STRING=ON \
          -D SuperLU_INCLUDE_DIRS:STRING="${SUPERLUDIR}/include" \
          -D SuperLU_LIBRARY_DIRS:STRING="${SUPERLUDIR}/lib" \
      \
          -D CMAKE_INSTALL_PREFIX:PATH=${INSTALL_DIR} \
      \
      $EXTRA_ARGS \
      ${TRILINOS_HOME}
    

NOTE: If you use the MKL libraries, please make sure you use the 32 bit Intel library mkl_intel_lp64, NOT the 64 bit version mkl_intel_ilp64. Both Lapack and Blas functions are called within Albany's local (on rank) address space, which is the local ordinal (LO) size, typically int.

To build Trilinos, use an out-of-source build. I usually make a build directory that matches the configuration of Trilinos that I am building in the Trilinos root directory:

    mkdir /lore/ghansen/tri_build
	cd /lore/ghansen/tri_build
	mkdir MPI_REL
  • Place the above do-configure file into the MPI_REL directory, change directories into MPI_REL, and perform the configure, build, and install:

      cd MPI_REL
      ./do-configure
      make -j 4
      make -j 4 install
    

Build Albany

  • CMake configure script:

      #!/bin/sh
      
      export ALB_64BIT_INT=ON
      export ALB_ENABLE_SCOREC=ON
      export ALB_ENABLE_LCM=ON
      export ALB_ENABLE_LAME=ON
      export ALB_ENABLE_HYDRIDE=ON
      export ALB_ENABLE_QCAD=ON
      export ALB_ENABLE_MOR=ON
      export ALB_ENABLE_ASCR=ON
      export ALB_ENABLE_AERAS=ON
      export ALB_ENABLE_FELIX=ON
      export ALB_ENABLE_AlbanyCI=OFF
      export ALB_DEBUG=OFF
      export ALB_ENABLE_CHECK_FPE=OFF
      export ALB_ENABLE_SPECULATIVE=OFF
      export ALB_ENABLE_SG_MP=ON
      export ALB_ENABLE_PERF_TESTS=ON
      export TRILINOS_INSTALL_DIR=/users/ghansen/Trilinos/MPI_REL
      
      export ALB_VERBOSE=OFF
      
      cmake \
            -D ALBANY_TRILINOS_DIR:FILEPATH="$TRILINOS_INSTALL_DIR" \
            -D ENABLE_LCM:BOOL=${ALB_ENABLE_LCM} \
            -D ENABLE_AERAS:BOOL=${ALB_ENABLE_AERAS} \
            -D ENABLE_QCAD:BOOL=${ALB_ENABLE_QCAD} \
            -D ENABLE_HYDRIDE:BOOL=${ALB_ENABLE_HYDRIDE} \
            -D ENABLE_LCM_SPECULATIVE:BOOL=${ALB_ENABLE_SPECULATIVE} \
            -D ENABLE_LAME:BOOL=${ALB_ENABLE_LAME} \
            -D CMAKE_VERBOSE_MAKEFILE:BOOL=${ALB_VERBOSE} \
            -D ENABLE_DEBUGGING:BOOL=${ALB_DEBUG} \
            -D ENABLE_CHECK_FPE:BOOL=${ALB_ENABLE_CHECK_FPE} \
            -D ENABLE_SCOREC:BOOL=${ALB_ENABLE_SCOREC} \
            -D ENABLE_FELIX:BOOL=${ALB_ENABLE_FELIX} \
            -D ENABLE_MOR:BOOL=${ALB_ENABLE_MOR} \
            -D ENABLE_ALBANY_CI:BOOL=${ALB_ENABLE_AlbanyCI} \
            -D ENABLE_ASCR:BOOL=${ALB_ENABLE_ASCR} \
            -D ENABLE_SG_MP:BOOL=${ALB_ENABLE_SG_MP} \
            -D ENABLE_PERFORMANCE_TESTS:BOOL=${ALB_ENABLE_PERF_TESTS} \
            -D ENABLE_64BIT_INT:BOOL=${ALB_64BIT_INT} \
            -D ALBANY_CTEST_TIMEOUT:INTEGER=70 \
      \
      ..
    

Clone the Albany repo in a suitable place:

	cd /users/ghansen
	git clone https://github.com/gahansen/Albany.git
  • Create an out-of-source build directory

      cd Albany
      mkdir build
    
  • Place the above configure script into the build directory, then configure, build, and test

      cd build
      ./buildAlbany
      make -j 4
      ctest
    
Clone this wiki locally