Size: 1893
Comment:
|
Size: 1641
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 5: | Line 5: |
== ParallelHowTo == |
|
Line 6: | Line 8: |
= ParallelHowTo = | |
Line 8: | Line 9: |
=== Portland Compiler === | It is possible to run CLaMS on multi-processor machines using MPI. |
Line 10: | Line 11: |
It is possible to run CLaMS on multi-processor machines using MPI or OpenMP. | === Intel Compiler 17.0.1 === |
Line 12: | Line 13: |
On the Ubuntu machines the PGF compiler suite is installed that has MPICH implemented. In the following a short How to: First it is necessary to make the path of the MPI libraries public by executing: for 64bit machines: {{{ . /opt/pgi/linux86-64/10.4/mpi.sh |
The MPICH Library 3.2 is installed in directory ''/usr/nfs/local/local/mpich-3.2-ifort-17.0.1''. <<BR>> Add the bin subdirectory of the installation directory of MPICH library to your path: {{{ PATH=/usr/nfs/local/local/mpich-3.2-ifort-17.0.1/bin:$PATH export PATH |
Line 24: | Line 21: |
for 32bit machines: {{{ . /opt/pgi/linux86/10.4/mpi.sh |
Remove serial compiled object files: {{{ make distclean |
Line 30: | Line 26: |
Then compile the needed programs by executing: {{{ make useMPI=true |
Compile with MPI: {{{ make useMPI=true progname |
Line 36: | Line 31: |
Before running the CLaMS script or a single program you have to execute: {{{ > ssh-agent > SSH_AUTH_SOCK=/tmp/ssh-arHtY17224/agent.17224; export SSH_AUTH_SOCK; > SSH_AGENT_PID=17225; export SSH_AGENT_PID; > echo Agent pid 17225; > ssh-add .ssh/id_rsa }}} This is necessary, because the processes communicate per ssh. The programs must be called as following: {{{ mpirun -np # [ --all-local ] program # - number of processors use the option --all-local for running it on the CPUs of the local machine only. |
Execute on <n> CPUs: {{{ mpiexec|mpirun -np <n> <progname> |
Line 58: | Line 37: |
=== Intel Compiler === | === Intel Compiler 14.0.3 === |
Line 60: | Line 39: |
The MPICH2 Library (1.3.2p1) is installed in directory ''/usr/nfs/local/local/mpich2-intel'' (for Intel C and Fortran compilers). Add the bin subdirectory of the installation directory to your path: {{{ PATH=/usr/nfs/local/local/mpich2-intel/bin:$PATH |
The MPICH Library is installed in directory ''/usr/nfs/local/local/mpich-intel''. Add the bin subdirectory of the installation directory of MPICH library to your path: {{{ PATH=/usr/nfs/local/local/mpich-intel/bin:$PATH |
Line 68: | Line 46: |
To read the man pages set MANPATH to the following: {{{ MANPATH=/usr/nfs/local/local/mpich2-intel/share/man:$MANPATH export MANPATH |
Remove serial compiled object files: {{{ make distclean |
Line 74: | Line 51: |
The programs can be compiled with: {{{ make useComp=ifc useMPI=true <progname> |
Compile with MPI: {{{ make useMPI=true [useComp=ifc] progname |
Line 79: | Line 56: |
Execute on <n> CPUs: {{{ mpiexec -np <n> <progname> |
Execute on <n> CPUs: {{{ mpiexec|mpirun -np <n> <progname> |
Line 84: | Line 61: |
It may be necessary to unset the memory limit: {{{ ulimit -s unlimited |
=== Portland Compiler 14.6 === It is necessary to make the path of the MPI libraries (included in the portland compiler suite) public by executing: {{{ . /opt/pgi/linux86-64/14.6/mpi.sh |
Line 88: | Line 67: |
Remove serial compiled object files: {{{ make distclean }}} Compile with MPI: {{{ make useMPI=true [useComp=pgi] progname }}} Execute on <n> CPUs: {{{ mpiexec|mpirun -np <n> <progname> }}} |
ParallelHowTo
It is possible to run CLaMS on multi-processor machines using MPI.
Intel Compiler 17.0.1
The MPICH Library 3.2 is installed in directory /usr/nfs/local/local/mpich-3.2-ifort-17.0.1.
- Add the bin subdirectory of the installation directory of MPICH library to your path:
PATH=/usr/nfs/local/local/mpich-3.2-ifort-17.0.1/bin:$PATH export PATH
Remove serial compiled object files:make distclean
Compile with MPI:make useMPI=true progname
Execute on <n> CPUs:
mpiexec|mpirun -np <n> <progname>
Intel Compiler 14.0.3
The MPICH Library is installed in directory /usr/nfs/local/local/mpich-intel. Add the bin subdirectory of the installation directory of MPICH library to your path:
PATH=/usr/nfs/local/local/mpich-intel/bin:$PATH export PATH
Remove serial compiled object files:make distclean
Compile with MPI:make useMPI=true [useComp=ifc] progname
Execute on <n> CPUs:
mpiexec|mpirun -np <n> <progname>
Portland Compiler 14.6
- It is necessary to make the path of the MPI libraries (included in the portland compiler suite) public by executing:
. /opt/pgi/linux86-64/14.6/mpi.sh
Remove serial compiled object files:make distclean
Compile with MPI:make useMPI=true [useComp=pgi] progname
Execute on <n> CPUs:
mpiexec|mpirun -np <n> <progname>