- Clone this repo using
git clone https://github.com/LLNL/lbann.git
- From anywhere in the lbann directory run the LC build script located in
<LBANN_dir>/lbann/scripts/build_lbann_lc.sh
- This will build LBANN in a newly created build directory. This build script uses the CMake superbuild. Information on the super build can be found in the superbuild directory.
- After the first use of this script, subsequent uses will recompile LBANN using the Makefile found in
build/<compiler>.<cluster>.llnl.gov/lbann/build/
. - To reconfigure the build add the --reconfigure plan. For example, to change this build from a release build to a debug build, add --debug and --reconfigure.
- To completely rebuild LBANN and its dependencies add the --clean-build flag. Other useful configuration options can be viewed by running the script with the --help flag.
- Clone this repo using
git clone https://github.com/LLNL/lbann.git
- From anywhere in the lbann directory run the LC build script located in
<LBANN_dir>/lbann/scripts/build_lbann_osx.sh
- This will build LBANN in a newly created build directory.
spack install lbann
LBANN uses C++ features provided by newer compilers. If you do not have the necessary compiler, you can use spack to install one. For full details, see the spack documentation.
spack install [email protected]
The above command builds and installs a compiler. It prints the install path as the final line. If successful, then register this compiler with spack using the spack compiler find command, passing the install path as an argument.
spack compiler add /path/to/compiler/install
Here is an example of setting up the local build environment on x86_64 HPC system
cd lbann
mkdir spack_builds; cd spack_builds
../scripts/spack_receipes/build_lbann.sh -c [email protected] -b openblas -m mvapich2
cd gcc-7.1.0_x86_64_mvapich2_openblas_rel/build
make -j all
The build_lbann.sh script roughly does the following steps for this example:
spack setup lbann@local build_type=Release dtype=4 %[email protected] ^elemental@master blas=openblas ^mvapich2
spack setup lbann@local %[email protected] ^mvapich2
mkdir -p gcc-7.1.0_x86_64_mvapich2_openblas_rel/build
cd gcc-7.1.0_x86_64_mvapich2_openblas_rel/build
../spconfig.py ../../..
By default, MVAPICH2 builds for PSM. For an ibverbs build of MVAPICH2, use the following:
../scripts/spack_receipes/build_lbann.sh -c [email protected] -b openblas -m 'mvapich2 fabrics=mrail'
We provide basic container defintion files, and instructions for their use, in the containers subdirectory. We currently support Docker and Singularity.
- Ensure the following dependencies are installed
CMake
MPI
Elemental
OpenCV
CUDA (optional)
cuDNN (optional)
Protocol Buffers (optional)
Doxygen (optional)
Note: LBANN also requires a C++ compiler with OpenMP support. The GCC 5.0 and Intel 16.0 C++ compilers are recommended
2. Clone this repo using
git clone https://github.com/LLNL/lbann.git
3. In the main LBANN directory create a build directory usingmkdir build
4.cd
into this directory and run the following commandscmake ../..
make
make install
Note: It may be necessary to manually set CMake variables to control the build configuration
- Allocate compute resources using SLURM:
salloc -N1 -t 60
- Run a test experiment for the MNIST data set; from the main lbann directory run the following command:
srun -n12 build/gnu.catalyst.llnl.gov/install/bin/lbann \
--model=model_zoo/models/lenet_mnist/model_lenet_mnist.prototext \
--reader=model_zoo/data_readers/data_reader_mnist.prototext \
--optimizer=model_zoo/optimizers/opt_adagrad.prototext \
--num_epochs=5
Note: srun -n12 build/gnu.catalyst.llnl.gov/install/bin/lbann
assumes you are running on the LLNL catalyst platform;
if running on some other platform, and/or have installed lbann in a different directory, you
will need to adjust this command.
This should produce roughly the following final results on Catalyst:
--------------------------------------------------------------------------------
[4] Epoch : stats formated [tr/v/te] iter/epoch = [844/94/157]
global MB = [ 64/ 64/ 64] global last MB = [ 48 / 48 / 16 ]
local MB = [ 64/ 64/ 64] local last MB = [ 48+0/ 48+0/ 16+0]
--------------------------------------------------------------------------------
Model 0 training epoch 4 objective function : 0.0471567
Model 0 training epoch 4 categorical accuracy : 99.6241%
Model 0 training epoch 4 run time : 7.64182s
Model 0 training epoch 4 mini-batch time statistics : 0.00901458s mean, 0.0212693s max, 0.0078979s min, 0.000458463s stdev
Model 0 validation objective function : 0.0670221
Model 0 validation categorical accuracy : 98.9%
Model 0 validation run time : 0.25341s
Model 0 validation mini-batch time statistics : 0.00269454s mean, 0.00285273s max, 0.0020936s min, 6.65695e-05s stdev
Model 0 test objective function : 0.0600125
Model 0 test categorical accuracy : 99.02%
Model 0 test run time : 0.421912s
Model 0 test mini-batch time statistics : 0.00268631s mean, 0.00278771s max, 0.00131827s min, 0.00011085s stdev
Note: LBANN performance will vary on a machine to machine basis. Results will also vary, but should not do so significantly.
There are various prototext models under the lbann/model_zoo/models/ directory: alexnet, autoencoder_mnist, lenet_mnist, etc. Each of these directories should have a script called runme.py. Run this script with no command line parameters for complete usage. Basically, these scripts generate command lines similar to the one above (in the Verifying LBANN on LC section). The scripts take two required arguments: --nodes=<int>
and --tasks=<int>
. The "tasks" option is used to specify the number of tasks per node, hence, the total number of tasks (cores) is: nodes*tasks. The generated command lines are designed to be executed using srun on LC systems, so you may need to modify, e.g, substitute mpirun, depending on your specific system.
Note: some directories contain multiple models, e.g, as of this writing, the autoencoder_cifar10 directory contains both model_autoencoder_cifar10.prototext and model_conv_autoencoder_cifar10.prototext. In these cases there may be multiple python scripts, e.g, runme_conv.py.