Albany-LCM (Laboratory for Computational Mechanics) is a fork of Albany, an implicit, unstructured grid, finite element code for the solution and analysis of multiphysics problems. Albany-LCM focuses on computational solid mechanics and thermo-mechanics, with nearly 200 regression tests demonstrating capabilities across a wide variety of problems.
Solid mechanics simulation of a notched cylinder using the alternating Schwarz-based multi-scale coupling capability in Albany-LCM.
- Large-scale parallel simulations (2.1+ billion DOFs) using MPI
- Automatic differentiation via Sacado
- Constitutive models: linear elasticity, J2 plasticity, crystal plasticity, hyperelasticity, damage models
- Schwarz alternating method for multi-scale coupling
- Arctic Coastal Erosion (ACE) model: coupled thermo-mechanical model with permafrost constitutive models, part of the InterFACE project
- Data transfer between coupled domains via DataTransferKit (DTK), bundled in-tree
Albany-LCM requires Trilinos and the following system packages.
sudo dnf install \
blas blas-devel boost boost-devel boost-openmpi boost-openmpi-devel \
cmake gcc-c++ gcc-gfortran gtest-devel git \
hdf5 hdf5-devel hdf5-openmpi hdf5-openmpi-devel \
lapack lapack-devel netcdf netcdf-devel netcdf-openmpi netcdf-openmpi-devel \
openblas openblas-devel openmpi openmpi-devel environment-modulesOptional (for clang builds):
sudo dnf install clang clang-develCMake 3.27+ is required. If your system cmake is older:
spack install cmake@3.27sudo apt install \
libblas-dev libboost-dev libboost-program-options-dev \
cmake g++ gfortran git \
libhdf5-openmpi-dev liblapack-dev libnetcdf-dev \
libopenmpi-dev mpi-default-bin environment-modulesNo system packages need to be installed. The lcm build script automatically
detects CEE LAN hosts by hostname and loads all required compilers and TPLs
from the SEMS/AUE module system (/projects/sems).
No .bashrc edits are needed. The lcm script sources the SEMS module
init, loads AUE/SEMS modules (GCC 12.3, OpenMPI 4.1.6, CMake 3.31, Boost,
HDF5, NetCDF, binutils), and exports all necessary environment variables
internally. You only need LCM_DIR and the lcm symlink.
Potential conflicts: If your .bashrc already sources the SEMS init
script or loads AUE/sierra-devel modules, those may conflict with the versions
the lcm script loads. Either remove those lines from .bashrc or start
from a clean shell (env -i bash --login). In particular, pre-loaded
sierra-devel modules set compiler and MPI paths that will clash with the
AUE modules that lcm expects.
Currently only GCC builds are supported on CEE (module serial-gcc-release).
mkdir ~/LCM && cd ~/LCM
git clone git@github.com:trilinos/Trilinos.git
git clone git@github.com:sandialabs/LCM.gitAdd to ~/.bashrc:
export LCM_DIR=~/LCM
module use $LCM_DIR/LCM/doc/LCM/modulefilesLog out and back in, or source ~/.bashrc.
On CEE LAN machines, module use requires Environment Modules to be
available. If module is not found, the lcm script will locate and source
the init script automatically, so .bashrc changes are optional on CEE.
cd ~/LCM
ln -s LCM/doc/LCM/build/lcm .cd ~/LCM
module load release # loads serial-gcc-release environment
./lcm clean trilinos # clean previous builds
./lcm config trilinos 16 # configure Trilinos (16 = parallel threads)
./lcm build trilinos 16 # build Trilinos
./lcm clean lcm # clean previous LCM build
./lcm config lcm 16 # configure LCM
./lcm build lcm 16 # build LCM
./lcm test lcm # run test suiteOr do everything at once:
./lcm all 16lcm clean <package> Clean build (and install for trilinos)
lcm config <package> [N] Configure package
lcm build <package> [N] Build package with N threads (default: nproc)
lcm test <package> Run tests
lcm all [N] Full pipeline: clean + config + build + test
lcm help Show help
Modules configure the compiler, architecture, and build type. Available configurations:
| Module | Compiler | Build Type |
|---|---|---|
serial-gcc-release |
GCC | Release (optimized) |
serial-gcc-debug |
GCC | Debug (symbols) |
serial-clang-release |
Clang | Release |
serial-clang-debug |
Clang | Debug |
The release module is an alias for serial-gcc-release.
Load a module before building:
module load serial-clang-release
./lcm all 16 --module=serial-clang-releaseBuild directories are named by configuration, e.g. lcm-build-serial-gcc-release.
A corresponding Trilinos installation must exist for each configuration.
After building, the Albany executable is in the build directory:
cd ~/LCM/lcm-build-serial-gcc-release/tests/LCM/Pressure
mpiexec -np 4 ~/LCM/lcm-build-serial-gcc-release/src/Albany input_tetra4.yamlThe module system adds build and Trilinos install directories to PATH, so after loading a module, Albany and Trilinos tools (decomp, epu, exodiff) are available directly.
The test suite is in tests/ and runs via CTest:
./lcm test lcmIndividual tests can be run from their subdirectory:
cd ~/LCM/lcm-build-serial-gcc-release/tests/LCM/Pressure
ctestMany tests run in parallel using up to 4 MPI ranks.
The clone-build-test-dash.sh script (in the workspace root) clones
Trilinos and LCM from scratch, builds with each supported compiler, and
submits results to CDash. It is typically run via cron:
# In crontab:
00 00 * * 1-5 cd /home/lcm/LCM; bash -l -c "./clone-build-test-dash.sh"Development discussion: https://github.com/sandialabs/LCM/issues
We follow the Google C++ Style Guide. Use clang-format with the .clang-format file in src/LCM/:
clang-format -i <source file>Please ensure all tests pass before pushing changes.
- Alejandro Mota (amota@sandia.gov)
- Irina Tezaur (ikalash@sandia.gov)

