Skip to content

kazuya-goto/autofistr

Repository files navigation

autofistr

autofistr is a build support tool for FrontISTR. FrontISTR will be built with both MPI and OpenMP enabled and with most of the usefull external libraries, such as METIS, ParMETIS, Scotch, MUMPS, Trilinos/ML. If you have REVOCAP_Refiner downloaded in the top directory, it will be built together as well.

Please make sure that you accept all the license agreements of FrontISTR and its external packages before you use this tool.

The newest version is available at https://gitlab.com/kgoto/autofistr.

System Requirements

  1. Operating Systems: Linux, Mac OS X

  2. Compilers: Intel, GCC, FUJITSU

cmake

The build system uses cmake >= 2.8.11. If supported version of cmake is not found, cmake source archive will be downloaded and built automatically.

Editing Makefile.in

Build type

  • RELEASE : optimized build
  • DEBUG : debug build

Compiler

On Linux, Intel Compiler, GCC and FUJITSU Compiler are supported. On Mac OS X, GCC is supported.

MPI

Intel MPI, OpenMPI, MPICH and FUJITSU MPI are supported.

Intel MPI, OpenMPI and MPICH can be used with either Intel Compiler or GCC. FUJITSU MPI can be used only with FUJITSU Compiler.

If you specified to use OpenMPI or MPICH and it is not found in your PATH, source archive of the specified MPI will be downloaded and built automatically.

BLAS/LAPACK/ScaLAPACK

Any BLAS/LAPACK/ScaLAPACK can be used; e.g. Intel MKL, OpenBLAS, ATLAS, FUJITSU SSL2.

If you want to use BLAS/LAPACK/ScaLAPACK already installed on your system, set BLASLAPACK = SYSTEM and make sure that BLASLIB/LAPACKLIB/SCALAPACKLIB are correctly set in Makefile.in.

Intel MKL, OpenBLAS and ATLAS can be used with either Intel Compiler or GCC. FUJITSU SSL2 can be used only with FUJITSU Compiler.

If you choose to use OpenBLAS or ATLAS, netlib ScaLAPACK will be downloaded and built automatically.

Number of Jobs

cmake supports parallel build. You can specify the number of parallel job for the build.

Other Options

If fistrbuild = old is set, the old style build with setup.sh is used instead of cmake.

If metisversion = 4 is set, metis4/parmetis3 is used instead of metis5/parmetis4.

Download FrontISTR (Optional)

If you want to use specific version of FrontISTR, download and extract the source archive before running make. Souce tree has to be found with the name FrontISTR at the same level with Makefile.

If you skip this process, the current master branch will be downloaded from GitLab automatically.

Download REVOCAP_Refiner (Optional)

If you want to use REVOCAP_Refiner, download REVOCAP_Refiner-1.1.04.tar.gz from www.frontistr.org. The archive has to be found at the same level with Makefile.

Running make

On normal systems (desktop, laptop, workstations, etc.), you can just type `make' and wait. Everything will be done automatically.

On supercomputers having different architecture for front-end node and compute nodes, you will have to first run 'make download' on front-end node. Then, start an interactive job and run 'make' on compute node, or create a job script to just run make and submit the job.

Setting PATH

If all process was successful, you will see message to set environment variables such as PATH, so please follow the instruction.

Running FrontISTR

If MPICH or OpenMPI was downloaded and built, make sure that you use mpirun that is built by this tool when running FrontISTR.

To DO

  • Update support of REVOCAP_Refiner
  • Add support to use BLAS and LAPACK on the system while download and build netlib ScaLAPACK
  • Add support for PGI compiler

License

This project is licensed under the MIT License.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published