Skip to content

Commit

Permalink
Reviewed and updated some of the online and user manual documentation.
Browse files Browse the repository at this point in the history
  • Loading branch information
Bruce J Palmer committed Dec 14, 2023
1 parent ca200c4 commit 4a0df26
Show file tree
Hide file tree
Showing 7 changed files with 62 additions and 32 deletions.
3 changes: 2 additions & 1 deletion docs/markdown/required/GLOBAL_ARRAYS.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,8 @@ A comparison of the performance of the progress ranks and two-sided runtimes is
shown below for the Polish network test calculation included as part of the
contingency analysis application. The progress ranks runtime shows significantly
better performance for all process counts, especially after four processors or
so.
so. After 16 processors, the performance of the two-sided runtime has degraded
to the point that the overall runtime for the calculation starts increasing.

<img src="../images/GA_perf.png" alt="drawing" width="600"/>

Expand Down
12 changes: 5 additions & 7 deletions docs/user_manual/tex/build.tex
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,9 @@ \chapter{Configuring and Building GridPACK}

This particular form assumes that the build directory is below the directory that contains the top-level \texttt{\textbf{CMakeLists.txt}} file for the build. For GridPACK, this is located in the \texttt{\textbf{src}} directory. If your build directory for GridPACK is below \texttt{\textbf{src}} and you invoke CMake from this directory, the ``\texttt{\textbf{..}}'' at the end of the \texttt{\textbf{cmake}} command is pointing to \texttt{\textbf{src}}. You could also use the absolute path to the \texttt{\textbf{src}} directory instead of ``\texttt{\textbf{..}}'' and this would work no matter where you locate the build directory.

Building GridPACK requires several external libraries that must be built prior trying to configure and build GridPACK itself. On some systems, these libraries may already be available but in many cases, users will need to build them by hand. An exception is MPI, which is usually available on parallel platforms, although users interested in running parallel jobs on a multi-core workstation may still need to build it themselves. In any case, the best way to guarantee that all libraries are compatible with each other is to build them all using a consistent environment and set of compilers. There is extensive documentation on how to build GridPACK and the libraries on which it depends on the website located at https://gridpack.org. We refer to the information on the website for most of the details on how to build GridPACK and will only discuss some general properties of the configure procedure in this document.
Building GridPACK requires several external libraries that must be built prior trying to configure and build GridPACK itself. On some systems, these libraries may already be available but in many cases, users will need to build them by hand. An exception is MPI, which is usually available on parallel platforms, although users interested in running parallel jobs on a multi-core workstation may still need to build it themselves. In any case, the best way to guarantee that all libraries are compatible with each other is to build them all using a consistent environment and set of compilers. There is extensive documentation on how to build GridPACK and the libraries on which it depends on the website located at \href{https://github.com/GridOPTICS/GridPACK}{https://github.com/GridOPTICS/GridPACK}. We refer to the information on the website for most of the details on how to build GridPACK and will only discuss some general properties of the configure procedure in this document.

Example scripts for building the libraries used by GridPACK on different systems can be found under \texttt{\textbf{\$GRIDPACK/src/scripts}}. In most cases these need to be modified slightly before they will work on your system, but the changes are usually small and self-evident. The scripts contain some additional documentation at the top to help you with these modifications. Find a script for a platform that is similar to your system and use this as the starting point for your build.
Example scripts for building the libraries used by GridPACK on different systems can be found under \texttt{\textbf{\$GRIDPACK/src/scripts}}. In most cases these need to be modified slightly before they will work on your system, but the changes are usually small and self-evident. The scripts contain some additional documentation at the top to help you with these modifications. Find a script for a platform that is similar to your system and use this as the starting point for your build. Addititional information for building on advanced platforms, such as DOE's Leadership Class Facilities, can be found in the \texttt{\textbf{\$GRIDPACK/docs/notes}} directory. This directory contains notes on building GridPACK on different platforms that may be useful to users trying to build on similar systems. Note that these systems can be quite complicated to build on for any application and usually require assistance from facility staff.

GridPACK uses the CMake build system to create a set of make files that can then be used to compile the entire GridPACK framework. Most of the effort in building GridPACK is focused on getting the configure process to work, once configure has been successfully completed, compilation is usually straightforward. Builds of GridPACK should be done in their own directory and this also makes it possible to have multiple builds that use different configuration parameters associated with the same source tree. Typically, the build directories are under \texttt{\textbf{\$GRIDPACK/src}} directory but they can be put anywhere the user chooses. The user then needs to run CMake from the build directory to configure GridPACK and then \texttt{\textbf{make}} and \texttt{\textbf{make install}} to compile and install the GridPACK libraries. After running \texttt{\textbf{make}}, all applications in the GridPACK source tree are also available for use. The application executables will be located in the build directory and not in the source tree.

Expand All @@ -34,7 +34,6 @@ \chapter{Configuring and Building GridPACK}
'\$HOME/software_new/petsc-3.6.0/linux-openmpi-gnu-cxx/lib' \
-D GA_DIR:STRING='\$HOME/software_new/ga-5-4-ib' \
-D USE_PROGRESS_RANKS:BOOL=FALSE \
-D GA_EXTRA_LIBS='-lrt -libverbs' \
-D MPI_CXX_COMPILER:STRING='mpicxx' \
-D MPI_C_COMPILER:STRING='mpicc' \
-D MPIEXEC:STRING='mpiexec' \
Expand All @@ -50,9 +49,8 @@ \chapter{Configuring and Building GridPACK}

The Boost, PETSc, Parmetis and Global Array library locations are specified by the \texttt{\textbf{BOOST\_ROOT}}, \texttt{\textbf{PETSC\_DIR}}, \texttt{\textbf{PARMETIS\_DIR}} and \texttt{\textbf{GA\_DIR}} variables. The \texttt{\textbf{PETSC\_ARCH}} variable specifies the particular build within PETSc that you want GridPACK to use. It is usually possible when configuring and building PETSc to have it download and build Parmetis as well. This was done in the example above and thus the Parmetis libraries are located within the PETSc source tree in the directory corresponding to the architecture specified in \texttt{\textbf{PETSC\_ARCH}}.

The Global Arrays library can be built using a number of different runtimes. The default runtime uses MPI two-sided communication. While it is very easy to use, this runtime does not scale well beyond a dozen or so processors. Users interested on running on large numbers of cores should look at configuring Global Arrays with other runtimes. A high performing GA runtime that is available on most platforms is called progress ranks. This runtime has a peculiarity in that it reserves one MPI process per SMP node to manage communication. Thus, if you request a total of 20 MPI processes on 4 nodes with 5 processes running on each node only 4 MPI process per node will actually be available to the application for a total of 16. In order to notify GridPACK that you are using this runtime, you need to set the parameter \texttt{\textbf{USE\_PROGRESS\_RANKS}} to true. In the example above, we are not using progress ranks so we set \texttt{\textbf{USE\_PROGRESS\_RANKS}} to false.
The Global Arrays library can be built using a number of different runtimes. The default runtime uses MPI two-sided communication. While it is very easy to use, this runtime does not scale well beyond a dozen or so processors. Users interested on running on large numbers of cores should look at configuring Global Arrays with other runtimes. A high performing GA runtime that is available on all platforms is called progress ranks. While it is very robust, this runtime has a peculiarity in that it reserves one MPI process per SMP node to manage communication. Thus, if you request a total of 20 MPI processes on 4 nodes with 5 processes running on each node only 4 MPI process per node will actually be available to the application for a total of 16. In order to notify GridPACK that you are using this runtime, you need to set the parameter \texttt{\textbf{USE\_PROGRESS\_RANKS}} to true. In the example above, we are not using progress ranks so we set \texttt{\textbf{USE\_PROGRESS\_RANKS}} to false. The \texttt{\textbf{GA\_EXTRA\_LIBS}} parameter can be used to include extra libraries in the link step that are not picked up as part of the configuration process. For this example, this parameter is not needed.

The \texttt{\textbf{GA\_EXTRA\_LIBS}} parameter can be used to include extra libraries in the link step that are not picked up as part of the configuration process. In this example, GA is configured to run on an Infiniband network so it is necessary to explicitly include \texttt{\textbf{libibverbs}} and \texttt{\textbf{librt}}. For most of the MPI-based runtimes, this variable is not needed.
The MPI wrappers for the C and C++ compilers can be specified by setting \texttt{\textbf{MPI\_C\_COMPILER}} and \texttt{\textbf{MPI\_CXX\_COMPILER}} and the MPI launch command can be specified using \texttt{\textbf{MPIEXEC}}. The \texttt{\textbf{CMAKE\_INSTALL\_PREFIX}} specifies the location of the installed build of GridPACK. This location should be used when linking external applications to GridPACK. The \texttt{\textbf{CMAKE\_BUILD\_TYPE}} can be used to control the level of debugging symbols in the library. \texttt{\textbf{MPIEXEC\_NUM\_PROCS}} should be set to a small number and controls the number of processors that will be used if running the parallel tests in the GridPACK test suite. Many of the application tests are small (9 or 14 buses) and will fail if you try and run on a large number of cores. Finally, \texttt{\textbf{CMAKE\_VERBOSE\_MAKEFILE}} controls the level of information generated during the compilation. It is mainly of interest for people doing development in GridPACK and most other users can safely set it to false.

A new feature in the build is to use shared libraries instead of static builds. This may be of interest to users that are interested in wrapping GridPACK applications with python. A shared library version of GridPACK can be created by configuring GridPACK against versions of Boost, GA, and PETSc that are built as shared libraries. It appears that just configuring against shared libraries is enough to trigger a share library build in CMake, but users can add the line
Expand All @@ -73,8 +71,8 @@ \chapter{Configuring and Building GridPACK}
{
\color{red}
\begin{Verbatim}[fontseries=b]
mpirun -n 2 code.x
mpirun -n 2 code.x input.xml
\end{Verbatim}
}

In this case the code will run on 2 processors. Different platforms may use different scripts to run the parallel job. Consult your local system documentation for details. Applications may also have additional arguments that are processed inside the application itself. Most GridPACK applications will take an argument representing the input file for the application.
In this case the code will run on 2 processors. Different platforms may use different scripts to run the parallel job. Consult your local system documentation for details. Applications may also have additional arguments that are processed inside the application itself. Most GridPACK applications will take an argument representing the input file for the application. In this example, the input file is \texttt{\textbf{input.xml}}.
2 changes: 1 addition & 1 deletion docs/user_manual/tex/buildapps.tex
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ \chapter{Building GridPACK Applications}
{
\color{red}
\begin{Verbatim}[fontseries=b]
1 cmake_minimum_required(VERSION 2.6.4)
1 cmake_minimum_required(VERSION 3.5.0)
2
3 if (NOT GRIDPACK_DIR)
4 set(GRIDPACK_DIR /HOME/gridpack-install
Expand Down
23 changes: 21 additions & 2 deletions docs/user_manual/tex/framework.tex
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,18 @@ \chapter{GridPACK Framework Components}

%\textcolor{red}{\texttt{\textbf{Figure 1.}} Relationship between major GridPACK components.}

A full description of a power grid network requires specification of both the network topology and the physical properties of the bus and branch components. The combination of the models and the network generate algebraic equations that can be solved to get desired system properties. GridPACK supplies numerous modules to simplify the process of specifying the model and solving it. These include power grid components that describe the physics of the different network models or analyses, grid component factories that initialize the grid components, mappers that convert the current state of the grid components into matrices and vectors, solvers that supply the preconditioner and solver functionality necessary to implement solution algorithms, input and output modules that allow developers to import and export data, and other utility modules that support standard code develop operations like timing, event logging, and error handling.
A full description of a power grid network requires specification of both the
network topology and the physical properties of the bus and branch components.
The combination of the models and the network generate algebraic equations that
can be solved to get desired system properties. GridPACK supplies numerous
modules to simplify the process of specifying the model and solving it. These
include power grid components that describe the physics of the different network
models or analyses, grid component factories that initialize the grid
components, mappers that convert the current state of the grid components into
matrices and vectors, solvers that supply the preconditioner and solver
functionality necessary to implement solution algorithms, input and output
modules that allow developers to import and export data, and other utility
modules that support standard code development operations like timing, event logging, and error handling.

Many of these modules are constructed using libraries developed elsewhere so as
to minimize framework development time. However, by wrapping them in interfaces
Expand Down Expand Up @@ -64,4 +75,12 @@ \section{Preliminaries} The GridPACK software uses a few coding conventions to h

at the top of the application .hpp and/or .cpp files. This file contains definitions of all the GridPACK modules and their associated functions.

Matrices and vectors in GridPACK were originally complex but now either complex or real matrices can be created using the library. Inside the GridPACK implementation, the underlying distributed matrices are either complex or real, but the framework adds a layer that supports both types of objects, even if the underlying math library does not. However, computations on complex matrices will perform better if the underlying math library is configured to use complex matrices directly. This should be kept in mind when choosing the math library to build GridPACK on. The underlying PETSc library can be configured to support either real or complex matrices. Complex numbers are represented in GridPACK as having type \texttt{\textbf{ComplexType}}. The real and imaginary parts of a complex number \texttt{\textbf{x}} can be obtained using the functions \texttt{\textbf{real(x)}} and \texttt{\textbf{imag(x)}}.
Matrices and vectors in GridPACK were originally complex but now either complex
or real matrices can be created using the library. Inside the GridPACK
implementation, the underlying distributed matrices are either complex or real,
but the framework adds a layer that supports both types of objects, even if the
underlying math library does not. However, computations on complex matrices will
perform better if the underlying math library is configured to use complex
matrices directly. This should be kept in mind when choosing the math library to
build GridPACK on. The underlying PETSc library can be configured to support
either real or complex matrices, but not both at the same time. Complex numbers are represented in GridPACK as having type \texttt{\textbf{ComplexType}}. The real and imaginary parts of a complex number \texttt{\textbf{x}} can be obtained using the functions \texttt{\textbf{real(x)}} and \texttt{\textbf{imag(x)}}.
Loading

0 comments on commit 4a0df26

Please sign in to comment.