/PyLibAPR

Python wrappers for LibAPR

Primary LanguageC++Apache License 2.0Apache-2.0

Note: This repository is a mirror of AdaptiveParticles/PyLibAPR. Please refer to the original repository for issues and pull requests.

PyLibAPR

Python wrappers for LibAPR - Library for producing and processing on the Adaptive Particle Representation (APR).

For article see: https://www.nature.com/articles/s41467-018-07390-9

Exclusive features

In addition to providing wrappers for most of the functionality of LibAPR, we provide a number of new features that simplify the generation and handling of the APR. For example:

Dependencies

LibAPR is included as a submodule, and built alongside the wrappers. This requires the following packages:

  • HDF5 1.8.20 or higher
  • OpenMP > 3.0 (optional, but recommended)
  • CMake 3.6 or higher
  • LibTIFF 4.0 or higher

The Python library additionally requires Python 3, and the packages listed in requirements.txt.

Installing dependencies on Linux

On Ubuntu, install the cmake, build-essential, libhdf5-dev and libtiff5-dev packages (on other distributions, refer to the documentation there, the package names will be similar). OpenMP support is provided by the GCC compiler installed as part of the build-essential package.

Installing dependencies on OSX

On OSX, install the cmake, hdf5 and libtiff homebrew packages and have the Xcode command line tools installed. If you want to compile with OpenMP support, also install the llvm package (this can also be done using homebrew), as the clang version shipped by Apple currently does not support OpenMP.

Note for windows users

The simplest way to utilise the library from Windows is through Windows Subsystem for Linux; see: https://docs.microsoft.com/en-us/windows/wsl/install-win10 then follow linux instructions.

The viewers and demos use a Graphical User Interface. In order to use these features from WSL, you may additionally need to install an X server.

Building

The repository requires submodules, so the repository needs to be cloned recursively:

git clone --recursive https://github.com/AdaptiveParticles/PyLibAPR.git

It is recommended to use a virtual environment, such as virtualenv. To set this up, use e.g.

pip3 install virtualenv
python3 -m virtualenv myenv
source myenv/bin/activate

The required Python packages can be installed via the command

pip install -r requirements.txt 

Once the dependencies are installed, PyLibAPR can be built via the setup.py script:

python setup.py install

CMake build options

There are two CMake options that can be given to enable or disable OpenMP and CUDA:

Option Description Default value
PYAPR_USE_OPENMP Enable multithreading via OpenMP ON
PYAPR_USE_CUDA Build available CUDA functionality OFF

When building via the setup.py script, these options can be set via the environment variable CMAKE_COMMON_VARIABLES. For example,

CMAKE_COMMON_VARIABLES="-DPYAPR_USE_OPENMP=OFF -DPYAPR_USE_CUDA=OFF" python setup.py install

should install the package with both OpenMP and CUDA disabled.

OpenMP support on OSX

To use the homebrew-installed clang for OpenMP support on OSX, modify the call above to

CPPFLAGS="-I/usr/local/opt/llvm/include" LDFLAGS="-L/usr/local/opt/llvm/lib -Wl,-rpath,/usr/local/opt/llvm/lib" CXX="/usr/local/opt/llvm/bin/clang++" CC="/usr/local/opt/llvm/bin/clang" python setup.py install 

Contact us

If anything is not working as you think it should, or would like it to, please get in touch with us!! Further, dont hesitate to contact us if you have a project or algorithm you would like to try using the APR for. We would be happy to assist you!