Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

157 lines
5.6 KiB

2 years ago
There are a few externally developed third-party libraries (TPL) that
are required to build SEACAS. You can build the libraries manually as
detailed below, or you can use the `install-tpl.sh` script as
described in the previous section.
* [Zoltan](#zoltan) -- required, supplied
* [HDF5](#hdf5) -- optional
* [NetCDF](#netcdf) -- required with possible modifications
* [Kokkos](#kokkos) -- optional
* [MatIO](#matio) -- optional, required for exo2mat and mat2exo
* [GNU Parallel](#gnu-parallel) -- optional
* [CGNS](#cgns) -- experimental optional
* [Faodel](#faodel) -- optional
## Zoltan
A snapshot of [zoltan_distrib\_v3.83.tar.gz](http://www.cs.sandia.gov/Zoltan/Zoltan_download.html) is provided in seacas/packages/zoltan. This will be built automatically as part of the SEACAS build process.
## HDF5
If you are using the netcdf-4 capability in the netcdf library or are using the MatIO library for conversion of exodus to/from matlab format, or using CGNS, then you will need the hdf5 library.
### WARNING
There are some issues with using HDF5-1.10.0 through HDF5-1.10.2 since
it will possibly create files which are unreadable by applications
using an earlier version of the library. As of HDF5-1.10.3 and later,
the HDF5 team added an option that makes it possible for the library
to create files readable by those applications. This flag is currently
being used by NetCDF and CGNS.
The hdf5 library is used for the netcdf4 capability in netcdf which in
turn is used by exodus. The netcdf4 capability is typically used for
large models (>150 million elements); if you are not planning to
create or read models of this size, you do not have to build hdf5.
* Download HDF5 from either:
* <https://www.hdfgroup.org/HDF5/release/obtain5.html> for HDF5-1.10.X or
* <https://support.hdfgroup.org/HDF5/release/obtain518.html> for HDF5-1.8.X
* Download to `seacas/TPL/hdf5` and untar it
* `cd` to that directory and enter the command:
```bash
sh ../runconfigure.sh
```
* `make && make install`
## NetCDF
The most recent released version is recommended. For use with Exodus, some local modifications to the netcdf.h include file are required if using versions prior to 4.5.1. See [NetCDF-Mapping.md](NetCDF-Mapping.md) for an explanation of why these modifications are required (or highly recommended)
* Download the latest netcdf-c release from <https://www.unidata.ucar.edu/downloads/netcdf/index.jsp> and put it inside `seacas/TPL/netcdf`
* `cd TPL/netcdf`
* `tar zxvf netcdf-4.6.1.tar.gz`
* If the version is *prior* to 4.5.1, then you need to modify the
following defines in
seacas/TPL/netcdf/netcdf-4.6.1/include/netcdf.h. Versions *4.5.1 or
later* do not check these limits and can be run unmodified.
```c
#define NC_MAX_DIMS 65536 /* max dimensions per file */
#define NC_MAX_VARS 524288 /* max variables per file */
```
* If you did *not* build HDF5, then you will need to edit the runcmake.sh script and remove all lines mentioning HDF5 and also set `ENABLE_NETCDF
_4` to `OFF`
* `cd netcdf-4.6.1` and enter the command:
```bash
mkdir build
cd build
sh ../../runcmake.sh
```
* `make && make install`
## Kokkos
The most recent released version is recommended.
* Download the latest Kokkos release from <https://github.com/kokkos/kokkos/releases> and put it inside `seacas/TPL/kokkos`
* `cd TPL/kokkos`
* `tar zxvf 2.8.0.tar.gz`
* `cd kokkos-2.8.0` and enter the command:
```bash
mkdir build
cd build
sh ../../runcmake.sh
```
* The default `runcmake.sh` will only build the `serial` device. Modify build options to tailor for your system as documented in the Kokkos documentation.
* `make && make install`
## MatIO
The MatIO library is used in the exo2mat and mat2exo programs which convert an exodus file to and from a MATLAB binary file. To use this do:
* Download matio via git:
* `cd TPL/matio`
* `git clone https://github.com/tbeu/matio.git`
* `cd matio` and enter the command:
```bash
./autogen.sh
sh ../runconfigure.sh
```
* `make && make install`
## GNU Parallel
GNU Parallel is a shell tool for executing jobs in parallel using one or more computers. A job is typically a single command or a small script that has to be run for each of the lines in the input. The typical input is a list of files, a list of hosts, a list of users, or a list of tables. In SEACAS, this is only used by epup which runs multiple epu jobs concurrently. To build:
* Download the most recent version of the library from <ftp://ftp.gnu.org/gnu/parallel/parallel-latest.tar.bz2>.
```bash
cd TPL/parallel
tar jxvf /path/to/parallel-latest.tar.bz2
cd parallel-20150522
sh ../runconfigure.sh
```
* `make && make install`
## CGNS
The IOSS library supports using CGNS for structured and unstructred meshes. To use this capability, you will need to download and install the CGNS library:
* Download CGNS via git:
```bash
cd TPL/cgns
git clone https://github.com/CGNS/CGNS.git
```
* Build using CMake.
* Modify `TPL/cgns/runcmake.sh` to meet your environment
* `cd CGNS`
* `mkdir build`
* `cd build`
* `../../runcmake.sh`
* `make && make install`
## Faodel
Faodel is a collection of data management tools that Sandia is developing to improve how datasets migrate between memory and storage resources in a distributed system. For SEACAS Faodel support means adding a new backend to IOSS. This enables additional data storage capabilities and the chance to communicate data between execution spaces.
Faodel is available at [Faodel](https://github.com/faodel/faodel). And is built here as a SEACAS TPL.