Octeract Engine
Octeract Engine is a massively parallel MINLP solver. It is written in ORL (Octeract Reformulation Language).
The engine contains 14 Octeract solvers for different types of mathematical structure, each with their own algorithms, to a grand total of 1031 high-performance algorithms.
Octeract Engine supports the Python, C++ and Julia programming languages alongside several modelling languages such as AMPL, PYOMO, JuMP, GAMS and Mosel.
Usage
Octeract Engine 3.1.0 can be loaded by module loading with the following command:
module load octeract-engine/3.1.0/binary
Interactive jobs
After connecting to Bessemer (see Establishing a SSH connection), Octeract Engine can be used interactively by starting an interactive session with srun --pty bash -i
and then issuing the commands:
module load octeract-engine/3.1.0/binary
octeract-engine /usr/local/packages/live/noeb/octeract-engine/3.1.0/binary/examples/nl/ex2_1_1.nl -d ${PWD}
Batch jobs
Octeract is capable of running in parallel on a single node or across multiple nodes and this is facilitated by MPI. However, on Bessemer cross node jobs are not permitted (up to 40 cores on a single node only).
Important
It is important that you use the -d $SLURM_SUBMIT_DIR
argument to instruct Octeract Engine
where to save the output file.
Octeract Engine will spawn a SLURM sub-task and SLURM will empty the $TMPDIR
directory
between tasks preventing any subsequent file move operation.
Example job:
!/bin/bash
#SBATCH -J octeract-8core-test
#SBATCH -o "%j".out
#SBATCH --mail-user a.person@sheffield.ac.uk
#SBATCH --mail-type=ALL
#SBATCH -t 0:05:0 # Request 5 mins run time
#SBATCH --ntasks-per-node=8
#SBATCH --mem=8000
module load octeract-engine/3.1.0/binary
octeract-engine /usr/local/packages/live/noeb/octeract-engine/3.1.0/binary/examples/nl/ex2_1_1.nl -n$SLURM_NTASKS -d $SLURM_SUBMIT_DIR
Using Octeract Engine with Pyomo:
Integrating the Octeract Engine with Pyomo is straightforward using our Python module.
By creating a specific Python environment for Octeract Engine and Pyomo you can help keep libraries and executables managed and available without polluting your base environment. This process, followed by running an example, is shown below:
Hint
You only need to create the conda environment and install Pyomo once. To use it for subsequent jobs you need only
run the command: source activate octeract-engine-pyomo
module load octeract-engine/3.1.0/binary
module load Anaconda3/2019.07
conda create -n octeract-engine-pyomo python=3.7
source activate octeract-engine-pyomo #Make sure to use source activate, NOT conda activate.
pip install pyomo
pyomo --version #Check this version is supported.
python3 /usr/local/packages/live/noeb/octeract-engine/3.1.0/binary/examples/pyomo/pyomo_example.py
The above instructions have been adjusted from the following documentation provided by Octeract at: https://docs.octeract.com/htg1005-how_to_use_pyomo_with_octeract_engine
Installation notes
Octeract Engine 3.1.0 was a binary installation provided from the
following link (https://download.octeract.com/octeract-engine-3.1.0-Linux-Centos7.tar.gz) and
was installed using the script
install_octeract-engine.sh
The software was tested by running the example batch job supplied above.