Code Compilation on Sapelo2: Difference between revisions

From Research Computing Center Wiki
Jump to navigation Jump to search
No edit summary
m (Reverted edits by Moses (talk) to last revision by Shtsai)
Tag: Rollback
Line 1: Line 1:
[[Category:Sapelo2]]
[[Category:Sapelo2]]


==Where should I compile my code?==  
===Where should I compile my code?===


<blockquote>'''IMPORTANT NOTE: Please do NOT compile code on the login node. Instead, please first start an interactive session with interact command and compile the code on the interactive node.'''</blockquote>Code compilation can be done in an interactive session. To start an interactive session, first login into Sapelo2 and from there issue the <code>interact</code> command
<blockquote style="background-color: lightyellow; border: solid thin grey;">  
<pre class="gcommand">
'''IMPORTANT NOTE:''' Please do not compile code on the login node. Instead, please first start an interactive session with qlogin and compile the code on the interactive node.  
interact
</blockquote>
</pre>
 
 
<!--
If you plan to run the code on an AMD node, you can start an interactive session on an AMD node to compile the code. To start an interactive on an AMD node, use the command
If you plan to run the code on an AMD node, you can start an interactive session on an AMD node to compile the code. To start an interactive on an AMD node, use the command
<pre class="gcommand">
<pre class="gcommand">
interact --constraint AMD
qlogin_amd
</pre>
</pre>


If you plan to run the code on an Intel node, you can start an interactive session on an Intel node to compile the code. To start an interactive on an Intel node, use the command
If you plan to run the code on an Intel node, you can start an interactive session on an Intel node to compile the code. To start an interactive on an Intel node, use the command
<pre class="gcommand">
<pre class="gcommand">
interact --constraint Intel
qlogin_intel
</pre>
</pre>
-->
Code compilation can be done on an interactive session. To start an interactive session, first login into Sapelo2 and from there issue the <code>qlogin</code> command.
For information on how to access the compute node interactively for code compilation, please see [[Running Jobs on Sapelo2 using Slurm | Running Jobs on the Slurm test cluster]].


For detailed information on how to access the compute node interactively for code compilation, please see [[Running Jobs on Sapelo2]].


----
----
==Compilers==


A number of Fortran and C/C++ compilers, as well as Java and scripting languages such as Perl and Python, are available on Sapelo2.


=== Summary of main Fortran and C/C++ compilers installed ===
===Compilers===
 
A number of Fortran and C/C++ compilers, as well as Java and scripting languages such as Perl and Python, are available on the Slurm test cluster.
 
'''Summary of main Fortran and C/C++ compilers installed:'''
 
{|  width="100%" border="1"  cellspacing="0" cellpadding="2" align="center" class="wikitable unsortable"
{|  width="100%" border="1"  cellspacing="0" cellpadding="2" align="center" class="wikitable unsortable"
|-
|-
Line 35: Line 44:
|-
|-


| Fortran77 || pgfortran
| Fortran77 || pgf77 || ifort || || mpif77|| .f
| ifort || gfortran
| mpif77|| .f
|-
|-
| Fortran90 || pgfortran
| Fortran90 || pgf90 || ifort || gfortran|| mpif90|| .f90
| ifort || gfortran|| mpif90|| .f90
|-
|-
| Fortran95 || pgfortran
| Fortran95 || pgf95 || ifort || gfortran || mpifort || .f95
| ifort || gfortran || mpifort || .f95
|-
|Fortran2003
|pgfortran
|ifort
|gfortran
|mpifort
|.f
|-
|-
| C || pgcc || icc || gcc || mpicc || .c
| C || pgcc || icc || gcc || mpicc || .c
|-
|-
| C++ || pgc++ || icpc || g++ || mpicxx || .C, .cpp, .cc
| C++ || pgCC || icpc || g++ || mpicxx || .C, .cpp, .cc
|-
|-


Line 61: Line 59:
The various compiler suites are provided by their environment modules.  
The various compiler suites are provided by their environment modules.  


=== GNU compiler suites ===
'''GNU compiler suites''':
 
The following command will show all the modules that provide GCC compiler suites:
The following command will show all the modules that provide GCC compiler suites:
<pre class="gcommand">
<pre class="gcommand">
Line 70: Line 69:
<pre class="gcomment">
<pre class="gcomment">
[shtsai@b1-1 ~]$ module spider GCC
[shtsai@b1-1 ~]$ module spider GCC
-----------------------------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------------
   GCC:
   GCC:
Line 82: Line 82:
         GCC/8.3.0
         GCC/8.3.0
         GCC/9.2.0
         GCC/9.2.0
        GCC/9.3.0
        GCC/10.2.0
        GCC/10.3.0
     Other possible modules matches:
     Other possible modules matches:
         GCCcore  gcccuda
         GCCcore  gcccuda
-----------------------------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------------
</pre>
</pre>


Line 96: Line 95:
*Version 8.3.0, with binutils 2.32, provided by the GCC/8.3.0 module, includes C, C++, and Fortran compilers.
*Version 8.3.0, with binutils 2.32, provided by the GCC/8.3.0 module, includes C, C++, and Fortran compilers.
*Version 9.2.0, with binutils 2.32, provided by the GCC/9.2.0 module, includes C, C++, and Fortran compilers.
*Version 9.2.0, with binutils 2.32, provided by the GCC/9.2.0 module, includes C, C++, and Fortran compilers.
*Version 9.3.0, with binutils 2.34, provided by the GCC/9.3.0 module, includes C, C++, and Fortran compilers.
*Version 10.2.0, with binutils 2.35, provided by the GCC/10.2.0 module, includes C, C++, and Fortran compilers.
*Version 10.3.0, with binutils 2.36.1, provided by the GCC/10.3.0 module, includes C, C++, and Fortran compilers.


We suggest that you run the<code> module spider GCC</code> command to check an updated list of GCC compilers available on the cluster.
We suggest that you run the <code> module spider GCC</code> command to check an updated list of GCC compilers available on the cluster.
 
 
'''PGI compiler suites''':


=== PGI compiler suites ===
The following command will show all the modules that provide PGI compiler suites:
The following command will show all the modules that provide PGI compiler suites:
<pre class="gcommand">
<pre class="gcommand">
Line 111: Line 109:
<pre class="gcomment">
<pre class="gcomment">
[shtsai@b1-1 ~]$  module spider PGI
[shtsai@b1-1 ~]$  module spider PGI
-----------------------------------------------------------------------------------------------------------------
 
   PGI:
------------------------------------------------------------------------------------------------------------------
-----------------------------------------------------------------------------------------------------------------
   PGI: PGI/19.10-GCC-8.3.0-2.32
------------------------------------------------------------------------------------------------------------------
     Description:
     Description:
       C, C++ and Fortran compilers from The Portland Group - PGI
       C, C++ and Fortran compilers from The Portland Group - PGI


    Versions:
 
        PGI/17.9
    This module can be loaded directly: module load PGI/19.10-GCC-8.3.0-2.32
        PGI/19.10-GCC-8.3.0-2.32
 
-----------------------------------------------------------------------------------------------------------------
    Help:
      Description
      ===========
      C, C++ and Fortran compilers from The Portland Group - PGI
     
     
      More information
      ================
      - Homepage: https://www.pgroup.com/
</pre>
</pre>


This output indicates that the PGI v.17.9 and PGI v. 19.10 compiler suites are available currently.
This output indicates that the PGI v. 19.10 compiler suite is available currently.


We suggest that you run the <code>module spider PGI</code> command to check an updated list of PGI compilers available on the cluster.
We suggest that you run the <code>module spider PGI</code> command to check an updated list of PGI compilers available on the cluster.


=== Intel compiler suites ===
 
'''Intel compiler suites''':
 
The following command will show all the modules that provide Intel compiler suites:
The following command will show all the modules that provide Intel compiler suites:
<pre class="gcommand">
<pre class="gcommand">
Line 135: Line 144:
Sample output of this command
Sample output of this command
<pre class="gcomment">
<pre class="gcomment">
[shtsai@b1-1 ~]$ ml spider iccifort
 
-----------------------------------------------------------------------------------------------------------------------------------
[shtsai@b1-1 ~]$ module spider iccifort
 
-------------------------------------------------------------------------------------------------------------------------
   iccifort:
   iccifort:
-----------------------------------------------------------------------------------------------------------------------------------
-------------------------------------------------------------------------------------------------------------------------
     Description:
     Description:
       Intel C, C++ & Fortran compilers
       Intel C, C++ & Fortran compilers
Line 147: Line 158:
         iccifort/2018.1.163-GCC-6.4.0-2.28
         iccifort/2018.1.163-GCC-6.4.0-2.28
         iccifort/2019.5.281
         iccifort/2019.5.281
        iccifort/2020.4.304
 
-----------------------------------------------------------------------------------------------------------------------------------
-------------------------------------------------------------------------------------------------------------------------
  For detailed information about a specific "iccifort" package (including how to load the modules) use the module's full name.
  Note that names that have a trailing (E) are extensions provided by other modules.
  For example:
 
    $ module spider iccifort/2019.5.281
-------------------------------------------------------------------------------------------------------------------------
 
</pre>
</pre>


Line 157: Line 175:
*Version 2018.0.1.163, provided by the iccifort/2018.1.163-GCC-6.4.0-2.28 module.
*Version 2018.0.1.163, provided by the iccifort/2018.1.163-GCC-6.4.0-2.28 module.
*Version 2019.5.281, provided by the iccifort/2019.5.281
*Version 2019.5.281, provided by the iccifort/2019.5.281
*Version 2020.4.304, provided by the iccifort/2020.4.304


We suggest that you run the <code>module spider iccifort</code> command to check an updated list of Intel compilers available on the cluster.
We suggest that you run the <code>module spider iccifort</code> command to check an updated list of Intel compilers available on the cluster.


=== LLVM compiler suites ===
 
'''LLVM compiler suites'''':
 
The following command will show all the modules that provide LLVM compilers:
The following command will show all the modules that provide LLVM compilers:
<pre class="gcommand">
<pre class="gcommand">
module spider LLVM
module spider LLVM
</pre>
</pre>
Sample output of this command
<pre class="gcomment">
[shtsai@b1-1 ~]$ module spider LLVM
------------------------------------------------------------------------------------------------------------------------------------
  LLVM:
------------------------------------------------------------------------------------------------------------------------------------
    Description:
      The LLVM Core libraries provide a modern source- and target-independent optimizer, along with code generation support for many popular CPUs (as well as some less common ones!) These libraries are
      built around a well specified code representation known as the LLVM intermediate representation ("LLVM IR"). The LLVM Core libraries are well documented, and it is particularly easy to invent your own
      language (or port an existing compiler) to use LLVM as an optimizer and code generator.


    Versions:
==== How to load a compiler module ====
        LLVM/8.0.1-GCCcore-8.3.0
        LLVM/9.0.0-GCCcore-8.3.0
        LLVM/9.0.1-GCCcore-8.3.0
        LLVM/10.0.1-GCCcore-10.2.0
        LLVM/11.0.0-GCCcore-10.2.0
-----------------------------------------------------------------------------------------------------------------------------------
</pre>


=== How to load a compiler module ===
To use any of the compiler suite, please first load the corresponding module. For example, to use the GNU 8.3.0 compiler suite, load the module with
 
<pre class="gcommand">
To use any of the compiler suite, please first load the corresponding module. For example, to use the GNU 8.3.0 compiler suite, load the module with<pre class="gcommand">
module load GCC/8.3.0
module load GCC/8.3.0
</pre>
</pre>
Once this module is loaded the gcc, g++, and gfortran for GCC v. 8.3.0 will be available in your path.
Once this module is loaded the gcc, g++, and gfortran for GCC v. 8.3.0 will be available in your path.


Please note that you can only have one compiler module loaded at a time.
Please note that you can only have one compiler module loaded at a time. For more information about Environment Modules, please see [[lmod-Sapelo2|lmod]].


=== Some commonly used compiler options ===
====Some commonly used compiler options====
 
'''PGI compiler suite:'''


==== PGI compiler suite ====
{|  width="100%" border="1"  cellspacing="0" cellpadding="2" align="center" class="wikitable unsortable"
{|  width="100%" border="1"  cellspacing="0" cellpadding="2" align="center" class="wikitable unsortable"
|-
|-
Line 232: Line 234:
When using optimization options, please check if your code becomes more efficient (in some cases optimization options will slow the code down) and if it still generates correct results. Many other compiler options are available. For more information on the PGI compilers, you can view the manual pages with the commands '''man pgf90''', '''man pgcc''', etc, after loading the PGI module.
When using optimization options, please check if your code becomes more efficient (in some cases optimization options will slow the code down) and if it still generates correct results. Many other compiler options are available. For more information on the PGI compilers, you can view the manual pages with the commands '''man pgf90''', '''man pgcc''', etc, after loading the PGI module.


==== Intel compiler suite ====
 
'''Intel compiler suite:'''
 
{|  width="100%" border="1"  cellspacing="0" cellpadding="2" align="center" class="wikitable unsortable"
{|  width="100%" border="1"  cellspacing="0" cellpadding="2" align="center" class="wikitable unsortable"
|-
|-
Line 249: Line 253:
| -Mbounds || Performs runtime array bound check, recommended for code debugging
| -Mbounds || Performs runtime array bound check, recommended for code debugging
|}
|}


----
----
[[#top|Back to Top]]
[[#top|Back to Top]]


== Compiler Toolchains ==
 
On Sapelo2 we use the [https://easybuild.readthedocs.io/en/latest/ EasyBuild] framework to install software applications. The EasyBuild toolchains are also available for users to compile their own code. Each toolchain provides a compiler suite and some basic libraries, such as MPI, BLAS, LAPACK, FFTW, etc.  
===Compiler Toolchains===
 
On the Slurm test cluster we use the [https://easybuild.readthedocs.io/en/latest/ EasyBuild] framework to install software applications. The EasyBuild toolchains are also available for users to compile their own code. Each toolchain provides a compiler suite and some basic libraries, such as MPI, BLAS, LAPACK, FFTW, etc.  


More information about compiler toolchains, please [[Available Toolchains and Toolchain Compatibility]].
More information about compiler toolchains, please [[Available Toolchains and Toolchain Compatibility]].


=== foss toolchains ===
 
'''foss toolchains:'''
 
Most software applications are installed with the '''foss''' toolchain, where '''foss''' is short for “Free and Open Source Software”.
Most software applications are installed with the '''foss''' toolchain, where '''foss''' is short for “Free and Open Source Software”.


Line 274: Line 283:
module spider foss
module spider foss
</pre>
</pre>


When you load a foss toolchain, all it components will be loaded. For example:
When you load a foss toolchain, all it components will be loaded. For example:
Line 290: Line 300:


</pre>
</pre>
'''intel toolchains:'''


=== intel toolchains ===
The intel toolchain consists of
The intel toolchain consists of


Line 317: Line 329:
</pre>
</pre>


=== iomkl toolchains ===
 
'''iomkl toolchains:'''
 
The iomkl toolchain consists of
The iomkl toolchain consists of


Line 352: Line 366:




=== gmvolf toolchains ===
'''gmvolf toolchains:'''
 
The gmvolf toolchain consists of:
The gmvolf toolchain consists of:


Line 366: Line 381:
module spider gmvolf
module spider gmvolf
</pre>
</pre>


----
----
[[#top|Back to Top]]
[[#top|Back to Top]]


== Linking with libraries ==
=== Linking with libraries ===
 
Some library packages are installed along with some compiler toolchains. Examples of these are OpenBLAS, MKL, FFTW, etc. Other libraries are installed as a separate module, for example, Boost and GSL.  
Some library packages are installed along with some compiler toolchains. Examples of these are OpenBLAS, MKL, FFTW, etc. Other libraries are installed as a separate module, for example, Boost and GSL.  


Line 392: Line 409:
[shtsai@b1-1 ~]$  
[shtsai@b1-1 ~]$  
</pre>
</pre>




Line 404: Line 420:


<code> -L${EBROOTGSL}/lib -lgsl -lgslcblas </code>
<code> -L${EBROOTGSL}/lib -lgsl -lgslcblas </code>


'''Example of program compilation that uses GCC 8.3.0 and GSL v. 2.6:'''
'''Example of program compilation that uses GCC 8.3.0 and GSL v. 2.6:'''
Line 413: Line 430:
</pre>
</pre>


Users can include the compilation option e.g. '''-Wl,-rpath=${EBROOTGSL}/lib''' to include the library directory in the '''runtime path'''. If this option is not included, then at runtime the user has to load the GSL module again, in order to define the environment variable LD_LIBRARY_PATH.
Users can include the compilation option e.g. -Wl,-rpath=${EBROOTGSL}/lib to include the library directory in the runtime path. If this option is not included, then at runtime the user has to load the GSL module again, in order to define the environment variable LD_LIBRARY_PATH.
----
[[#top|Back to Top]]

Revision as of 14:14, 5 November 2021


Where should I compile my code?

IMPORTANT NOTE: Please do not compile code on the login node. Instead, please first start an interactive session with qlogin and compile the code on the interactive node.


Code compilation can be done on an interactive session. To start an interactive session, first login into Sapelo2 and from there issue the qlogin command.

For information on how to access the compute node interactively for code compilation, please see Running Jobs on the Slurm test cluster.




Compilers

A number of Fortran and C/C++ compilers, as well as Java and scripting languages such as Perl and Python, are available on the Slurm test cluster.

Summary of main Fortran and C/C++ compilers installed:

Portland Group (PGI) Intel GNU OpenMPI File extension
Fortran77 pgf77 ifort mpif77 .f
Fortran90 pgf90 ifort gfortran mpif90 .f90
Fortran95 pgf95 ifort gfortran mpifort .f95
C pgcc icc gcc mpicc .c
C++ pgCC icpc g++ mpicxx .C, .cpp, .cc

The various compiler suites are provided by their environment modules.

GNU compiler suites:

The following command will show all the modules that provide GCC compiler suites:

module spider GCC

Sample partial output of this command:

[shtsai@b1-1 ~]$ module spider GCC

-----------------------------------------------------------------------------------------------------------------
  GCC:
-----------------------------------------------------------------------------------------------------------------
    Description:
      The GNU Compiler Collection includes front ends for C, C++, Objective-C, Fortran, Java, and Ada, as well as
      libraries for these languages (libstdc++, libgcj,...).

     Versions:
        GCC/6.4.0-2.28
        GCC/7.3.0-2.30
        GCC/8.3.0
        GCC/9.2.0
     Other possible modules matches:
        GCCcore  gcccuda

-----------------------------------------------------------------------------------------------------------------
 

This output indicates that the following versions of GCC compilers are available:

  • Version 6.4.0, with binutils 2.28, provided by the GCC/6.4.0-2.28 module, includes C, C++, and Fortran compilers.
  • Version 7.3.0, with binutils 2.30, provided by the GCC/7.2.0-2.30 module, includes C, C++, and Fortran compilers.
  • Version 8.3.0, with binutils 2.32, provided by the GCC/8.3.0 module, includes C, C++, and Fortran compilers.
  • Version 9.2.0, with binutils 2.32, provided by the GCC/9.2.0 module, includes C, C++, and Fortran compilers.

We suggest that you run the module spider GCC command to check an updated list of GCC compilers available on the cluster.


PGI compiler suites:

The following command will show all the modules that provide PGI compiler suites:

module spider PGI

Sample output of this command

[shtsai@b1-1 ~]$  module spider PGI

------------------------------------------------------------------------------------------------------------------
  PGI: PGI/19.10-GCC-8.3.0-2.32
------------------------------------------------------------------------------------------------------------------
    Description:
      C, C++ and Fortran compilers from The Portland Group - PGI


    This module can be loaded directly: module load PGI/19.10-GCC-8.3.0-2.32

    Help:
      Description
      ===========
      C, C++ and Fortran compilers from The Portland Group - PGI
      
      
      More information
      ================
       - Homepage: https://www.pgroup.com/

This output indicates that the PGI v. 19.10 compiler suite is available currently.

We suggest that you run the module spider PGI command to check an updated list of PGI compilers available on the cluster.


Intel compiler suites:

The following command will show all the modules that provide Intel compiler suites:

module spider iccifort

Sample output of this command


[shtsai@b1-1 ~]$ module spider iccifort

-------------------------------------------------------------------------------------------------------------------------
  iccifort:
-------------------------------------------------------------------------------------------------------------------------
    Description:
      Intel C, C++ & Fortran compilers

     Versions:
        iccifort/2013_sp1.0.080
        iccifort/2015.2.164-GCC-4.8.5
        iccifort/2018.1.163-GCC-6.4.0-2.28
        iccifort/2019.5.281

-------------------------------------------------------------------------------------------------------------------------
  For detailed information about a specific "iccifort" package (including how to load the modules) use the module's full name.
  Note that names that have a trailing (E) are extensions provided by other modules.
  For example:

     $ module spider iccifort/2019.5.281
-------------------------------------------------------------------------------------------------------------------------

This output indicates that the following versions of the Intel compiler suites are available:

  • Version 13 SP1, provided by the iccifort/2013_sp1.0.080 module.
  • Version 15.2, provided by the iccifort/2015.2.164-GCC-4.8.5 module.
  • Version 2018.0.1.163, provided by the iccifort/2018.1.163-GCC-6.4.0-2.28 module.
  • Version 2019.5.281, provided by the iccifort/2019.5.281

We suggest that you run the module spider iccifort command to check an updated list of Intel compilers available on the cluster.


LLVM compiler suites':

The following command will show all the modules that provide LLVM compilers:

module spider LLVM

How to load a compiler module

To use any of the compiler suite, please first load the corresponding module. For example, to use the GNU 8.3.0 compiler suite, load the module with

module load GCC/8.3.0

Once this module is loaded the gcc, g++, and gfortran for GCC v. 8.3.0 will be available in your path.

Please note that you can only have one compiler module loaded at a time. For more information about Environment Modules, please see lmod.

Some commonly used compiler options

PGI compiler suite:

Option Description
-O0 Specifies no optimization, recommended for code debugging
-O1 Specifies local optimization
-O2 Specifies global optimization (this is the default, same as using -O)
-O3 Includes -O1, -O2 and more aggressive optimization. Use with care.
-fast Chooses generally good optimization options for the platform. Type pgcc -fast -help to see the equivalent options.
-Mbounds Performs runtime array bound check, recommended for code debugging
-g Produces symbolic debug information in the object files.
-r8 Interpret REAL variables as DOUBLE PRECISION.
-B Allow C++ style comments in C source code; these begin with ‘//’ and continue until the end of the current line. pgcc only.
-Kieee Perform floating-point operations in strict conformance with the IEEE 754 standard. The default compilation is -Knoieee, which uses faster but very slightly less accurate methods.
-mp Interpret OpenMP directives to explicitly parallelize regions of code for execution by multiple threads
-acc Enable OpenACC pragmas and directives to explicitly parallelize regions of code for execution by accelerator devices. Use with the -ta option

NOTE When using optimization options, please check if your code becomes more efficient (in some cases optimization options will slow the code down) and if it still generates correct results. Many other compiler options are available. For more information on the PGI compilers, you can view the manual pages with the commands man pgf90, man pgcc, etc, after loading the PGI module.


Intel compiler suite:

Option Description
-O0 Specifies no optimization, recommended for code debugging
-O2 Enables optimizations for speed. This is the generally recommended optimization level.
-O3 Performs -O2 optimizations and more aggressive loop transformations. Use with care.
-fast Chooses generally good optimization options for the platform. Type pgcc -fast -help to see the equivalent options.
-Mbounds Performs runtime array bound check, recommended for code debugging



Back to Top


Compiler Toolchains

On the Slurm test cluster we use the EasyBuild framework to install software applications. The EasyBuild toolchains are also available for users to compile their own code. Each toolchain provides a compiler suite and some basic libraries, such as MPI, BLAS, LAPACK, FFTW, etc.

More information about compiler toolchains, please Available Toolchains and Toolchain Compatibility.


foss toolchains:

Most software applications are installed with the foss toolchain, where foss is short for “Free and Open Source Software”.

The foss toolchain consists of:

You can check the foss toolchain modules that are installed on the cluster with the command

module spider foss


When you load a foss toolchain, all it components will be loaded. For example:

[shtsai@b1-1 ~]$ module list
No modules loaded
[shtsai@b1-1 ~]$ module load foss/2019b
[shtsai@b1-1 ~]$ module list

Currently Loaded Modules:
  1) GCCcore/8.3.0                  6) XZ/5.2.4-GCCcore-8.3.0           11) OpenBLAS/0.3.7-GCC-8.3.0
  2) zlib/1.2.11-GCCcore-8.3.0      7) libxml2/2.9.9-GCCcore-8.3.0      12) gompi/2019b
  3) binutils/2.32-GCCcore-8.3.0    8) libpciaccess/0.14-GCCcore-8.3.0  13) FFTW/3.3.8-gompi-2019b
  4) GCC/8.3.0                      9) hwloc/1.11.12-GCCcore-8.3.0      14) ScaLAPACK/2.0.2-gompi-2019b
  5) numactl/2.0.12-GCCcore-8.3.0  10) OpenMPI/3.1.4-GCC-8.3.0          15) foss/2019b


intel toolchains:

The intel toolchain consists of

  • the Intel compiler suite
  • the Intel MPI libraries
  • the Intel Math Kernel Libraries (MKL)

You can check the intel toolchain modules that are installed on the cluster with the command

module spider intel

When you load an intel toolchain, all it components will be loaded. For example:

[shtsai@b1-1 ~]$ module list
No modules loaded
[shtsai@b1-1 ~]$ module load intel/2019b
[shtsai@b1-1 ~]$ module list

Currently Loaded Modules:
  1) GCCcore/8.3.0                 4) iccifort/2019.5.281                   7) imkl/2019.5.281-iimpi-2019b
  2) zlib/1.2.11-GCCcore-8.3.0     5) impi/2018.5.288-iccifort-2019.5.281   8) intel/2019b
  3) binutils/2.32-GCCcore-8.3.0   6) iimpi/2019b


iomkl toolchains:

The iomkl toolchain consists of

  • the Intel compiler suite
  • the OpenMPI libraries
  • the Intel Math Kernel Libraries (MKL)

You can check the iomkl toolchain modules that are installed on the cluster with the command

module spider iomkl

Th iomkl toolchains available on the cluster include:

  • iomkl/2013_sp1.0.080, includes the Intel 2013.SP1 compiler suite, OpenMPI 1.8.4, MKL 11.1.1.106
  • iomkl/2015.02, includes the Intel 2015.2.164 compiler suite, OpenMPI 1.8.4, MKL 11.2.2.164
  • iomkl/2018a, includes the Intel 2018.1.163 compiler suite, OpenMPI 2.1.2, MKL 2018.1.163


gmvolf toolchains:

The gmvolf toolchain consists of:

You can check the gmvolf toolchain modules that are installed on the cluster with the command

module spider gmvolf



Back to Top

Linking with libraries

Some library packages are installed along with some compiler toolchains. Examples of these are OpenBLAS, MKL, FFTW, etc. Other libraries are installed as a separate module, for example, Boost and GSL.

If you want to compile a code that uses a library that is not included with compiler toolchain, you will have to load a library module that uses a compatible toolchain. For example, if you want to compile your code with GCC 8.3.0 (or with the foss/2019b toolchain), and you need to use GSL, you can load the GSL/2.6-GCC-8.3.0 module.

Also note that when you load a module for a library or an application, the full path to its installation directory will be stored in an environment variable called EBROOTNAME, where NAME is the name of the application or library. For example, when you load a GSL module, the directory where the GSL libraries are installed will be in an environment variable called EBROOTGSL.

For example:

[shtsai@b1-1 ~]$ module list
No modules loaded
[shtsai@b1-1 ~]$ module load GCC/8.3.0
[shtsai@b1-1 ~]$ echo $EBROOTGCC
/apps/eb/GCCcore/8.3.0
[shtsai@b1-1 ~]$ echo $EBROOTGSL

[shtsai@b1-1 ~]$ module load GSL/2.6-GCC-8.3.0
[shtsai@b1-1 ~]$ echo $EBROOTGSL
/apps/eb/GSL/2.6-GCC-8.3.0
[shtsai@b1-1 ~]$ 


As shown in the example above, when you load an GSL module, an environment variable called EBROOTGSL is defined, and it points to the installation path for GSL.

When you compile your code, you can add the compiler option:

-I${EBROOTGSL}/include

and the linker option

-L${EBROOTGSL}/lib -lgsl -lgslcblas


Example of program compilation that uses GCC 8.3.0 and GSL v. 2.6:

module load GSL/2.6-GCC-8.3.0

gcc -O program.c I${EBROOTGSL}/include -L${EBROOTGSL}/lib -lgsl -lgslcblas -Wl,-rpath=${EBROOTGSL}/lib

Users can include the compilation option e.g. -Wl,-rpath=${EBROOTGSL}/lib to include the library directory in the runtime path. If this option is not included, then at runtime the user has to load the GSL module again, in order to define the environment variable LD_LIBRARY_PATH.