welcome: please sign in
location: Diff for "Installation"
Differences between revisions 32 and 37 (spanning 5 versions)
Revision 32 as of 2013-12-05 06:28:30
Size: 3570
Editor: 10
Comment:
Revision 37 as of 2015-12-02 00:26:44
Size: 4405
Editor: bsuo
Comment:
Deletions are marked like this. Additions are marked like this.
Line 19: Line 19:
  . If you use bash shell, you can set fortran and c compiler:
  {{{
  $export FC=ifort
  $export CC=gcc
  }}}
  . Tips: If you ignored this step, the configure script will pick up the gfortran and gcc compiler as default.
    If you use bash shell, you can set fortran and c compiler:
{{{
$export FC=ifort
$export CC=gcc
$export CXX=g++
}}}
 Tips: If you ignored this step, the configure script will pick up the gfortran and gcc compiler as default.
Line 27: Line 29:
  . For flaxibality reason, we ask users to set blas and lapack libraries.
  {{{
  $export MATHLIB="-LMathLibDir -llapackname -lblasname"
  }}}
The external Blas and Lapack library is needed for compling BDF. Also C language Blas and Lapack are required.
 It is easer to use Intel MKL. You only need set "MATHLIB" and "MATHINCLUDE" as
{{{
$export MATHLIB="-lmkl_intel_ilp64 -lmkl_sequential -lmkl_core -lpthread"
$export MATHINCLUDE="-I/opt/intel/mkl/include"
}}}

However, you may choose to use Blas and Lapack from netlib. You may download lapack library from http://www.netlib.org/lapack/lapack-3.6.0.tgz.
Do not forget also compile lapacke, which is a C interface for lapack library.

Then, you need set "MATHLIB" and "MATHINCLUDE"
{{{
$export MATHLIB="-L/Users/aaa/mathlib/lapack -llapack64 -lblas64"
$export MATHINCLUDE="-I/Users/aaa/mathlib/lapack/lapacke/include"
}}}
Line 34: Line 47:
  After setting compiler and mathematic library. You can configure BDF by command configure in BDF root directory.
  {{{
  $./configure
  }}}
After setting compiler and mathematic library. You can configure BDF by command configure in BDF root directory.
{{{
$./configure
}}}
Line 40: Line 53:
  Configure support several parameters.
  {{{
  --enable-debug=yes[no] Compile BDF in debug mode.
  --enable-i8=yes[no] Compile BDF with 64 bit integrals.
  --enable-openmp=yes[no] Compile BDF with OpenMP supporting.
  --enable-mpi=yes[no] Compile BDF with MPI supporting.
  --enable-parallel=yes[no] Compiler BDF with MPI and OpenMP support.
  }}}
Configure support several parameters.
{{{
 --enable-debug=yes[no] Compile BDF in debug mode.
 --enable-i8=yes[no] Compile BDF with 64 bit integrals.
 --enable-openmp=yes[no] Compile BDF with OpenMP supporting.
 --enable-mpi=yes[no] Compile BDF with MPI supporting.
 --enable-parallel=yes[no] Compiler BDF with MPI and OpenMP support.
}}}
Line 50: Line 63:
  {{{
  $make
  }}}
{{{
 $make
}}}
Line 58: Line 71:
  {{{
   $./configure --enable-parallel=yes
  }}}
{{{
 $./configure --enable-parallel=yes
}}}
Line 63: Line 76:
  {{{
   $./configure --enable-mpi=yes
  }}}
{{{
 $./configure --enable-mpi=yes
}}}
Line 68: Line 81:
  {{{
   $./configure --enable-openmp=yes
  }}}
{{{
 $./configure --enable-openmp=yes
}}}
Line 75: Line 88:
  1. A 64bit machine with intel compiler and MKL library.
  {{{
  $export FC=ifort
  $export CC=gcc
  $export MATHLIB="-lmkl_intel_ilp64 -lmkl_sequential -lmkl_core -lpthread"
  $./configure --enabale-i8=yes --enable-openmp=yes
  $make
  
}}}
1. A 64bit machine with intel compiler and MKL library.
{{{
  export FC=ifort
  export CC=gcc
  export CXX=g++
  
export MATHLIB="-lmkl_intel_ilp64 -lmkl_sequential -lmkl_core -lpthread"
  export MATHINLCUDE="I/opt/intel/mkl/include"
  
./configure --enabale-i8=yes --enable-openmp=yes --enable-mkl=yes
  make
}}}
Line 84: Line 99:
  1. A Mac laptop with gfortran, gcc and user compiled lapack and blas library
  {{{
2. A Mac laptop with gfortran, gcc and user compiled lapack and blas library
{{{
Line 88: Line 103:
  $export CXX=g++
Line 89: Line 105:
  $export MATHINCLUDE="-I/Users/mike/mathlib/lapack-3.6.0/lapacke/include"
Line 91: Line 108:
  }}} }}}
Line 93: Line 110:
  1. A Linux cluster with fort, icc, openmpi and intel MKL library.
  {{{
  Check MPI flags by using command
  
3. A Linux cluster with fort, icc, openmpi and intel MKL library.

 Check MPI flags by using command
{{{
Line 98: Line 115:
 
  You may get such output.
   
}}}

You may get such output.
{{{
Line 102: Line 120:
}}}
Line 103: Line 122:
  You can set BDF compiler and MPILIB as  You can compile bdf package as
{{{
Line 107: Line 126:
  $export CXX=icpc
Line 108: Line 128:
  $export MATHINLCUDE="I/opt/intel/mkl/include"
Line 109: Line 130:
  $./configure --enabale-i8=yes --enable-parallel=yes   $./configure --enabale-i8=yes --enable-parallel=yes --enable-mkl=yes
Line 111: Line 132:
}}}
Line 112: Line 134:
  If you only want to evoke MPI, just use

  $./configure --enabale-i8=yes --enable-mpi=yes
  }}}
 If you only want to evoke MPI, just use
{{{
  $./configure --enabale-i8=yes --enable-mpi=yes --enable-mkl=yes
}}}

Installation

System requirements

In principle, BDF supports all Unix-like platforms. However, we strongly propose you to use BDF at Linux platform together Intel Fortran and C compiler because BDF package is developed and thoroughly tested on such platforms. System requirements of BDF is summarized as following lines:

 OS: Linux, Mac, FreeBSD, Unix
 Compiler: Fortran 90 compiler such as Intel, gfortran, g95
 Support softwares: Python, make
 Parallel environments: MPI

Configure and compile BDF package

Several steps are needed to install BDF package.

1. Set fortran and C compiler.

  • If you use bash shell, you can set fortran and c compiler:

$export FC=ifort
$export CC=gcc
$export CXX=g++
  • Tips: If you ignored this step, the configure script will pick up the gfortran and gcc compiler as default.

2. Set blas and lapack library. The external Blas and Lapack library is needed for compling BDF. Also C language Blas and Lapack are required.

  • It is easer to use Intel MKL. You only need set "MATHLIB" and "MATHINCLUDE" as

$export MATHLIB="-lmkl_intel_ilp64 -lmkl_sequential -lmkl_core -lpthread"
$export MATHINCLUDE="-I/opt/intel/mkl/include"

However, you may choose to use Blas and Lapack from netlib. You may download lapack library from http://www.netlib.org/lapack/lapack-3.6.0.tgz. Do not forget also compile lapacke, which is a C interface for lapack library.

Then, you need set "MATHLIB" and "MATHINCLUDE"

$export MATHLIB="-L/Users/aaa/mathlib/lapack -llapack64 -lblas64"
$export MATHINCLUDE="-I/Users/aaa/mathlib/lapack/lapacke/include"

3. Configure BDF package.

After setting compiler and mathematic library. You can configure BDF by command configure in BDF root directory.

$./configure

Configure support several parameters.

 --enable-debug=yes[no]     Compile BDF in debug mode.
 --enable-i8=yes[no]            Compile BDF with 64 bit integrals.
 --enable-openmp=yes[no]  Compile BDF with OpenMP supporting.
 --enable-mpi=yes[no]         Compile BDF with MPI supporting.
 --enable-parallel=yes[no]   Compiler BDF with MPI and OpenMP support.

4. Compile BDF package.

 $make 

Compile parallel bdf

Some of BDF modules support parallel calculation. You can compiler BDF as parallel mode. At present, we support MPI and OpenMP.

1. MPI and OpenMP hybrid.

 $./configure  --enable-parallel=yes

2. Only MPI.

 $./configure  --enable-mpi=yes

3. Only OpenMP.

 $./configure  --enable-openmp=yes

Examples of some typical installations

1. A 64bit machine with intel compiler and MKL library.

  export FC=ifort
  export CC=gcc
  export CXX=g++
  export MATHLIB="-lmkl_intel_ilp64 -lmkl_sequential -lmkl_core -lpthread"
  export MATHINLCUDE="I/opt/intel/mkl/include"
  ./configure --enabale-i8=yes --enable-openmp=yes --enable-mkl=yes
  make

2. A Mac laptop with gfortran, gcc and user compiled lapack and blas library

  $export FC=gfortran 
  $export CC=gcc 
  $export CXX=g++
  $export MATHILIB="-L/Users/mike/mathlib -lblas -llapack" 
  $export MATHINCLUDE="-I/Users/mike/mathlib/lapack-3.6.0/lapacke/include"
  $./configure --enabale-i8=yes --enable-openmp=yes 
  $make

3. A Linux cluster with fort, icc, openmpi and intel MKL library.

  • Check MPI flags by using command

  $mpif90 --shownme

  • You may get such output.

  ifort -I/opt/openmpi/include -I/opt/openmpi/lib -L/opt/openmpi/lib -lmpi_f90 -lmpi_f77 -lmpi -ldl -lm -Wl,--export-dynamic -lrt -lnsl -lutil
  • You can compile bdf package as

  $export FC=ifort
  $export CC=icc
  $export CXX=icpc
  $export MATHLIB="-lmkl_intel_ilp64 -lmkl_sequential -lmkl_core -lpthread"
  $export MATHINLCUDE="I/opt/intel/mkl/include"
  $export MPILIB="-I/opt/openmpi/include -I/opt/openmpi/lib -L/opt/openmpi/lib -lmpi_f90 -lmpi_f77 -lmpi -ldl -lm -Wl,--export-dynamic -lrt -lnsl -lutil"
  $./configure --enabale-i8=yes --enable-parallel=yes --enable-mkl=yes
  $make
  • If you only want to evoke MPI, just use

  $./configure --enabale-i8=yes --enable-mpi=yes --enable-mkl=yes

Set system variables of BDF package

Installation (last edited 2021-07-22 05:07:26 by bsuo)