Development: Difference between revisions

From bwHPC Wiki
Jump to navigation Jump to search
 
(17 intermediate revisions by one other user not shown)
Line 1: Line 1:
== Compiling Software ==
== Compiling Software ==


Overview of [[General compiler usage]]
Overview of [[Development/General compiler usage|general compiler usage]]


== Parallel Programming ==
== Parallel Programming ==
Overview on [[BwHPC_BPG_for_Parallel_Programming | parallel programming with OpenMP and MPI]].
Overview on [[Development/Parallel_Programming | parallel programming with OpenMP and MPI]].


== Environment Modules ==
== Environment Modules ==
Line 30: Line 30:
Environment modules for software development and parallel programming with additional documentation here in the wiki:
Environment modules for software development and parallel programming with additional documentation here in the wiki:
=== Compiler and Debugger ===
=== Compiler and Debugger ===
* [[Development/GCC]]
* [[Development/GCC|GCC]]
* [[GDB]]
* [[Development/GDB|GDB]]
* [[Intel_Compiler]]
* [[Development/Intel_Compiler|Intel Compiler]]


=== Development Tools ===
=== Development Tools ===
* [[Score-P]]:<br />Tracing of OpenMP-, MPI- and GPU-parallel applications for Vampir and other performance analysis tools.
* [[Development/Score-P|Score-P]]:<br />Tracing of OpenMP-, MPI- and GPU-parallel applications for Vampir and other performance analysis tools.
* [[Vampir_and_VampirServer|Vampir and VampirServer]]:<br />Highly scalable Performance Analysis of OpenMP-, MPI- and GPU-parallel applications.
* [[Development/Vampir_and_VampirServer|Vampir and VampirServer]]:<br />Highly scalable Performance Analysis of OpenMP-, MPI- and GPU-parallel applications.
* [[Pahole]]:<br />Analyse data structures for cache-line alignment and (un)necessary holes that increase data structure size
* [[Development/Pahole|Pahole]]:<br />Analyse data structures for cache-line alignment and (un)necessary holes that increase data structure size
* [[Valgrind]]:<br />Very valuable framework with multiple tools, e.g. to detect memory access errors
* [[Development/Valgrind|Valgrind]]:<br />Very valuable framework with multiple tools, e.g. to detect memory access errors
* [[Forge]]:<br />Tools for debugging (arm DDT) and performance analysis (arm MAP)
* Forge:<br />Tools for debugging (arm DDT) and performance analysis (arm MAP)


=== Libraries and Numerical Libraries ===
=== Libraries and Numerical Libraries ===
* [[GSL]]
* [[Development/GSL|GSL]]
* [[FFTW]]
* [[Development/FFTW|FFTW]]
* [[MKL]]
* [[Development/MKL|MKL]]
=== Scripting Languages ===
* [[Development/Python|Python]]
=== Development Environments ===
=== Development Environments ===
* [[Conda]]
* [[Development/Conda|Conda]]
* [[Development/Containers|Containers]]

Latest revision as of 16:32, 8 November 2024

Compiling Software

Overview of general compiler usage

Parallel Programming

Overview on parallel programming with OpenMP and MPI.

Environment Modules

Compiler, libraries and development tools are provided as environment modules.

Required reading to use: Environment Modules

Available Development Software

Visit https://www.bwhpc.de/software.php select your cluster and

  • For compiler select Category → compiler
  • For MPI select Category → mpi
  • For libraries select Category → lib
  • For numerical libraries select Category → numlib
  • For further development tools select Category → devel

On a cluster use: module avail <Category>

Documentation

Availabe documentation for environment modules:

  • module help
  • examples in $SOFTNAME_EXA_DIR
  • additional docu in this wiki

Documentation in the Wiki

Environment modules for software development and parallel programming with additional documentation here in the wiki:

Compiler and Debugger

Development Tools

  • Score-P:
    Tracing of OpenMP-, MPI- and GPU-parallel applications for Vampir and other performance analysis tools.
  • Vampir and VampirServer:
    Highly scalable Performance Analysis of OpenMP-, MPI- and GPU-parallel applications.
  • Pahole:
    Analyse data structures for cache-line alignment and (un)necessary holes that increase data structure size
  • Valgrind:
    Very valuable framework with multiple tools, e.g. to detect memory access errors
  • Forge:
    Tools for debugging (arm DDT) and performance analysis (arm MAP)

Libraries and Numerical Libraries

Scripting Languages

Development Environments