Skip to content

Latest commit

 

History

History
executable file
·
500 lines (340 loc) · 18.1 KB

INSTALL.md

File metadata and controls

executable file
·
500 lines (340 loc) · 18.1 KB

Installation

Table of Contents

  1. Availability
  2. Python
  3. MATLAB
  4. C++ only
  5. Dependencies

Availability

The sources for AMICI are available as

A Python package is available on pypi, see below.

If AMICI was downloaded as a zip, it needs to be unpacked in a convenient directory. If AMICI was obtained via cloning of the git repository, no further unpacking is necessary.

Obtaining AMICI via the GIT version control system

In order to always stay up-to-date with the latest AMICI versions, simply pull it from our GIT repository and recompile it when a new release is available. For more information about GIT checkout their website

The GIT repository can currently be found at https://github.com/AMICI-dev/AMICI and a direct clone is possible via

git clone https://github.com/AMICI-dev/AMICI.git AMICI

Python

To use AMICI from python, install the module and all other requirements using pip:

pip3 install amici

You can now import it as python module:

import amici

For cases where this installation fails, check below for special setups and custom installations. For Python-AMICI usage see https://github.com/AMICI-dev/AMICI/blob/master/documentation/PYTHON.md.

Installation of development versions

To install development versions which have not been released to pypi yet, you can install AMICI with pip directly from GitHub using:

pip3 install -e git+https://github.com/AMICI-dev/amici.git@develop#egg=amici\&subdirectory=python/sdist

Replace develop by the branch or commit you want to install.

Note that this will probably not work on Windows which does not support symlinks by default (https://stackoverflow.com/questions/5917249/git-symlinks-in-windows/49913019#49913019).

Light installation

In case you only want to use the AMICI Python package for generating model code for use with Matlab or C++ and don't want to bothered with any unnecessary dependencies, you can run

pip3 install --install-option --no-clibs amici

Note, however, that you will not be able to compile any model into a Python extension with this installation.

NOTE: If you run into an error with above installation command, install all AMICI dependencies listed in setup.py manually, and try again. (This is because pip --install-options are applied to all installed packages, including dependencies.)

Anaconda

To use an Anaconda installation of python (https://www.anaconda.com/distribution/, Python>=3.6), proceed as follows:

Since Anaconda provides own versions of some packages which might not work with amici (in particular the gcc compiler), create a minimal virtual environment via:

conda create --name ENV_NAME pip python

Here, replace ENV_NAME by some name for the environment. To activate the environment, do:

source activate ENV_NAME

(and conda deactivate later to deactivate it again).

SWIG must be installed and available in your PATH, and a CBLAS-compatible BLAS must be available. You can also use conda to install the latter locally, using:

conda install -c conda-forge openblas

To install AMICI, now do:

pip install amici

The option --no-cache may be helpful here to make sure the installation is done completely anew.

Now, you are ready to use AMICI in the virtual environment.

Anaconda on Mac

If the above installation does not work for you, try installing AMICI via:

CFLAGS="-stdlib=libc++" CC=clang CXX=clang pip3 install --verbose amici

This will use the clang compiler.

You will have to pass the same options when compiling any model later on. This can be done by inserting the following code before calling sbml2amici:

import os
os.environ['CC'] = 'clang'
os.environ['CXX'] = 'clang'
os.environ['CFLAGS'] = '-stdlib=libc++'

(For further discussion see AMICI-dev#357)

Windows using GCC (mingw)

To install AMICI on Windows using python, you can proceed as follows:

Some general remarks:

  • Install all libraries in a path not containing white spaces, e.g. directly under C:.
  • Replace the following paths according to your installation.
  • Slashes can be preferable to backslashes for some environment variables.
  • See also #425 for further discussion.

Then, follow these steps:

  • A python environment for Windows is required. We recommend Anaconda with python >=3.7.

  • Install MinGW-W64 (32bit will succeed to compile, but fail during linking). MinGW-W64 GCC-8.1.0 for x86_64-posix-sjlj (direct link has been shown to work on Windows 7 and 10 test systems.

  • Add the following directory to PATH:

    • C:\mingw-w64\x86_64-8.1.0-posix-sjlj-rt_v6-rev0\mingw64\bin
  • Make sure that this is the compiler that is found by the system (e.g. where gcc in a cmd should point to this installation).

  • Download CBLAS headers and libraries, e.g. OpenBLAS, binary distribution 0.2.19. Set the following environment variables:

    • BLAS_CFLAGS=-IC:/OpenBLAS-v0.2.19-Win64-int32/include
    • BLAS_LIBS=-Wl,-Bstatic -LC:/OpenBLAS-v0.2.19-Win64-int32/lib -lopenblas -Wl,-Bdynamic
  • Install SWIG (version swigwin-3.0.12 worked) and add the following directory to PATH:

    • C:\swigwin-3.0.12
  • Install AMICI using:

    pip install --global-option="build_clib" --global-option="--compiler=mingw32" --global-option="build_ext" --global-option="--compiler=mingw32" amici --no-cache-dir --verbose

Possible sources of errors:

  • On recent Windows versions, anaconda3\Lib\distutils\cygwinccompiler.py fails linking msvcr140.dll with [...] x86_64-w64-mingw32/bin/ld.exe: cannot find -lmsvcr140. This is not required for amici, so in cygwinccompiler.py return ['msvcr140'] can be changed to return [].

  • If you use a python version where python/cpython#880 has not been fixed yet, you need to disable define hypot _hypot in anaconda3\include/pyconfig.h yourself.

  • import amici in python resulting in the very informative

    ImportError: DLL load failed: The specified module could not be found.

    means that some amici module dependencies were not found (not the AMICI module itself). DependencyWalker will show you which ones.

    Support for msvc is experimental. installOpenBLAS.ps1 and compileBLAS.cmd may serve as guidance on how to install openBLAS using msvc.

Windows using MSVC (Visual Studio)

Visual Studio

We assume that Visual Studio (not to be confused with Visual Studio Code) is already installed. Using Visual Studio Installer, the following components need to be included:

  • Microsoft Visual C++ (MSVC). This is part of multiple packages, including Desktop Development with C++.
  • Windows Universal C Runtime. This is an individual component and installs some DLLs that we need.

openBLAS

To install open BLAS, download the following scripts from AMICI:

https://github.com/AMICI-dev/AMICI/blob/master/scripts/installOpenBLAS.ps1 https://github.com/AMICI-dev/AMICI/blob/master/scripts/compileBLAS.cmd

The first script needs to be called in Powershell, and it needs to call compileBLAS.cmd, so you will need to modify line 11:

C:\Users\travis\build\AMICI\scripts\compileBLAS.cmd

so that it matches your directory structure. This will download openBLAS and compile it, creating

C:\BLAS\lib\openblas.lib
C:\BLAS\bin\openblas.dll

You will also need to define two environment variables:

BLAS_LIBS="/LIBPATH:C:\BLAS\lib openblas.lib"
BLAS_CFLAGS="/IC:\BLAS\OpenBLAS-v0.3.10\OpenBLAS-0.3.10"

One way to do that is to run a PowerShell script with the following commands:

[System.Environment]::SetEnvironmentVariable("BLAS_LIBS", "/LIBPATH:C:\BLAS\lib openblas.lib", [System.EnvironmentVariableTarget]::User)
[System.Environment]::SetEnvironmentVariable("BLAS_LIBS", "/LIBPATH:C:\BLAS\lib openblas.lib", [System.EnvironmentVariableTarget]::Process)
[System.Environment]::SetEnvironmentVariable("BLAS_CFLAGS", "-IC:\BLAS\OpenBLAS-v0.3.10\OpenBLAS-0.3.10", [System.EnvironmentVariableTarget]::User)
[System.Environment]::SetEnvironmentVariable("BLAS_CFLAGS", "-IC:\BLAS\OpenBLAS-v0.3.10\OpenBLAS-0.3.10", [System.EnvironmentVariableTarget]::Process)

The call ending in Process sets the environment variable in the current process, and it is no longer in effect in the next process. The call ending in User is permanent, and takes effect the next time the user logs on.

PATH

Now we need to make sure that all required DLLs are within the scope of the PATH variable. In particular, the following directories need to be included in PATH:

C:\BLAS\bin
C:\Program Files (x86)\Windows Kits\10\Redist\ucrt\DLLs\x64

The first one is needed for openblas.dll and the second is needed for the Windows Universal C Runtime. If any DLLs are missing in the PATH variable, Python will return the following error:

ImportError: DLL load failed: The specified module could not be found.

This can be tested using the "where" command. For example

where openblas.dll

should return

C:\BLAS\bin\openblas.dll

Almost all of the DLLs are standard Windows DLLs and should be included in either Windows or Visual Studio. But, in case it is necessary to test this, here is a list of some DLLs required by AMICI (when compiled with MSVC):

  • openblas.dll
  • python37.dll
  • MSVCP140.dll
  • KERNEL32.dll
  • VCRUNTIME140_1.dll
  • VCRUNTIME140.dll
  • api-ms-win-crt-convert-l1-1-0.dll
  • api-ms-win-crt-heap-l1-1-0.dll
  • api-ms-win-crt-stdio-l1-1-0.dll
  • api-ms-win-crt-string-l1-1-0.dll
  • api-ms-win-crt-runtime-l1-1-0.dll
  • api-ms-win-crt-time-l1-1-0.dll
  • api-ms-win-crt-math-l1-1-0.dll

MSVCP140.dll, VCRUNTIME140.dll, and VCRUNTIME140_1.dll are needed by MSVC (see Visual Studio above). KERNEL32.dll is part of Windows and in C:\Windows\System32. The api-ms-win-crt-XXX-l1-1-0.dll are needed by openblas.dll and are part of the Windows Universal C Runtime (see Visual Studio above).

Custom installation

AMICI Python package installation can be customized using a number of environment variables:

Variable Purpose Example
CC Setting the C(++) compiler CC=/usr/bin/g++
CFLAGS Extra compiler flags used in every compiler call
BLAS_CFLAGS Compiler flags for, e.g. BLAS include directories
BLAS_LIBS Flags for linking BLAS
ENABLE_GCOV_COVERAGE Set to build AMICI to provide code coverage information ENABLE_GCOV_COVERAGE=TRUE
ENABLE_AMICI_DEBUGGING Set to build AMICI with debugging symbols ENABLE_AMICI_DEBUGGING=TRUE
AMICI_PARALLEL_COMPILE Set to the number of parallel processes to be used for C(++) file compilation (defaults to 1) AMICI_PARALLEL_COMPILE=4

MATLAB

To use AMICI from MATLAB, start MATLAB and add the AMICI/matlab directory to the MATLAB path. To add all toolbox directories to the MATLAB path, execute the matlab script

installAMICI.m

To store the installation for further MATLAB session, the path can be saved via

savepath

For the compilation of .mex files, MATLAB needs to be configured with a working C++ compiler. The C++ compiler needs to be installed and configured via:

mex -setup c++

For a list of supported compilers we refer to the mathworks documentation: mathworks.com Note that Microsoft Visual Studio compilers are currently not supported.

C++ only

To use AMICI from C++, run the

./scripts/buildSundials.sh
./scripts/buildSuitesparse.sh
./scripts/buildAmici.sh

script to compile AMICI library.

NOTE: On some systems, the CMake executable may be named something other than cmake. In this case, set the CMAKE environment variable to the correct name (e.g. export CMAKE=cmake3, in case you have CMake available as cmake3).

The static library file can then be linked from

./build/libamici.a

In CMake-based packages, amici can be linked via

find_package(Amici)

Optional SuperLU_MT support

To build AMICI with SuperLU_MT support, run

./scripts/buildSuperLUMT.sh
./scripts/buildSundials.sh
cd build/
cmake -DSUNDIALS_SUPERLUMT_ENABLE=ON ..
make

Dependencies

General

The tools SUNDIALS and SuiteSparse shipped with AMICI do not require explicit installation.

AMICI uses the following packages from SUNDIALS:

CVODES: the sensitivity-enabled ODE solver in SUNDIALS. Radu Serban and Alan C. Hindmarsh. ASME 2005 International Design Engineering Technical Conferences and Computers and Information in Engineering Conference. American Society of Mechanical Engineers, 2005. PDF

IDAS

AMICI uses the following packages from SuiteSparse:

Algorithm 907: KLU, A Direct Sparse Solver for Circuit Simulation Problems. Timothy A. Davis, Ekanathan Palamadai Natarajan, ACM Transactions on Mathematical Software, Vol 37, Issue 6, 2010, pp 36:1 - 36:17. PDF

Algorithm 837: AMD, an approximate minimum degree ordering algorithm, Patrick R. Amestoy, Timothy A. Davis, Iain S. Duff, ACM Transactions on Mathematical Software, Vol 30, Issue 3, 2004, pp 381 - 388. PDF

Algorithm 836: COLAMD, a column approximate minimum degree ordering algorithm, Timothy A. Davis, John R. Gilbert, Stefan I. Larimore, Esmond G. Ng ACM Transactions on Mathematical Software, Vol 30, Issue 3, 2004, pp 377 - 380. PDF

libsbml

To import Systems Biology Markup Language (SBML) models, AMICI relies on the Python or MATLAB SBML library.

Math Kernel Library (MKL)

The python and C++ interfaces require a system installation of a BLAS. AMICI has been tested with various native and general purpose MKL implementations such as Accelerate, Intel MKL, cblas, openblas, atlas. The matlab interface uses the MATLAB MKL, which requires no separate installation.

On Ubuntu, this requirement can be satisfied with

apt install libatlas-base-dev

On Fedora (32):

sudo dnf install blas-devel

C++ compiler

All AMICI installations require a C++11-compatible C++ compiler. AMICI has been tested with g++, mingw, clang and the Intel compiler. Visual C++ is not officially supported, but may work.

HDF5

The python and C++ interfaces provide routines to read and write options and results in hdf5 format. For the python interface, the installation of hdf5 is optional, but for the C++ interace it is currently required.

HDF5 can be installed using package managers such as brew or apt:

brew install hdf5

or

apt-get install libhdf5-serial-dev

SWIG

The python interface requires SWIG, which has to be installed by the user. As root user, SWIG can be installed using package managers such as brew or apt:

brew install swig

or

apt-get install swig3.0

Or by non-root users, using scripts/downloadAndBuildSwig.sh from the AMICI repository (not included in the PyPI package). The binary directory has to be added to the PATH environment variable, or SWIG has to be set as described in the following section.

Using a non-default SWIG executable

We note here that some linux package managers may provide swig executables as swig3.0, but installation as swig is required. This can be fixed as root user using, e.g., symbolic links:

mkdir -p ~/bin/ && ln -s $(which swig3.0) ~/bin/swig && export PATH=~/bin/:$PATH

Non-root users can set the SWIG environment variable to the full path of the desired SWIG executable. This variable has be set during AMICI package installation as well as during model compilation.

Matlab

The MATLAB interface requires the Mathworks Symbolic Toolbox for model generation via amiwrap(...), but not for execution of precompiled models. Currently MATLAB R2018a or newer is not supported (see AMICI-dev#307).

The Symbolic Toolbox requirement can be circumvented by performing model import using the Python interface. The result code can then be used from Matlab.

Python

The python interface requires python 3.6 or newer and a cblas-compatible BLAS library to be installed. Windows installations via pip are currently not supported, but users may try to install amici using the build scripts provided for the C++ interface (these will by default automatically install the python module).

The python interface depends on some additional packages, e.g. numpy. They are automatically installed when installing the python package.

C++

The C++ interface requires cmake and a cblas-compatible BLAS to be installed.

Optional

SuperLU_MT, "a general purpose library for the direct solution of large, sparse, nonsymmetric systems of linear equations" (https://crd-legacy.lbl.gov/~xiaoye/SuperLU/#superlu_mt). SuperLU_MT is optional and is so far only available from the C++ interface.