Building the DIPlib project on Linux
Contents
Compiling DIPlib requires a few programs that often are not present on a bare Linux installation. It depends on your distribution how you can obtain these. Below we give instructions for Ubuntu.
See CMake configuration for additional information on the build targets and CMake configuration options.
Everything here requires a shell (such as Bash), which typically runs inside a terminal window. If you’re using Linux we’ll assume you know where to find this.
Installing build tools and dependencies on Ubuntu
Type the following command in your shell:
sudo apt install build-essential cmake git
This will install all the required tools. Depending on your version of Ubuntu, you might have a compiler that is too old to correctly build DIPlib. To see which version of GCC you have, type:
g++ --version
You want to see at least version 5.4, but later versions would be better. If your version of GCC is older, you will need to manually install a newer version.
If you want to compile DIPviewer, you need to install freeglut
as well:
sudo apt install freeglut3-dev
To compile the documentation yourself (note that the compiled documentation can be found online), you need dox++. See Building the DIPlib documentation for details.
Finally, even if the python3
program is already installed, you might need to
install the Python 3 header files and static library:
sudo apt install python3-dev
Cloning the repository
Next, get the source repository from GitHub:
mkdir ~/src cd ~/src git clone https://github.com/DIPlib/diplib.git
This creates a directory src/diplib
in your home directory. Feel free to use any other
directory if you prefer.
Building
To build, run cmake
and make
from a build directory:
mkdir ~/src/diplib/target cd ~/src/diplib/target cmake .. make -j check make -j install
This will install to /usr/local
. If you prefer to install elsewhere, change the
CMAKE_INSTALL_PREFIX
. For example:
cmake .. -DCMAKE_INSTALL_PREFIX=$HOME
This will install DIPlib, DIPviewer, DIPjavaio, DIPimage and the documentation
under the lib
, include
and share
directories in your home directory.
Before running make
, examine the output of cmake
to verify all the features you need are enabled,
and that your chosen dependencies were found. This is also a good moment to disable the features that
you don’t need. By default, everything will be build and installed, if the required external dependencies
are found: you need FreeGLUT or GLFW for DIPviewer, a Java JDK for DIPjavaio, Python for PyDIP, and
MATLAB for DIPimage. Add -DDIP_BUILD_DIPVIEWER=Off
, -DDIP_BUILD_JAVAIO=Off
, -DDIP_BUILD_DIPIMAGE=Off
or -DDIP_BUILD_PYDIP=Off
to your CMake command to turn the corresponding component off, if you don’t
need that component.
See CMake variables for a summary of all the CMake options to manually specify paths and configure your build.
PyDIP is installed separately through pip
. Once the install
target has finished building
and installing, run
make pip_install
Note that it is necessary to install the DIPlib libraries before running the pip_install
target.
We recommend you additionally specify the -DCMAKE_CXX_FLAGS="-march=native"
option to cmake
. This will enable additional optimizations that are specific
to your computer. Note that the resulting binaries will likely be slower on a different
computer, and possibly not work at all.
If you build a static version of the DIPlib library, DIPimage and PyDIP will not work correctly.
Enabling Bio-Formats
If building only DIPimage (the MATLAB toolbox), skip this section and instead follow the directions
you can read when you do help readim
in MATLAB after installation.
First, make sure you have the Java 8 SDK (JDK 8) or later installed, you can obtain it from the Oracle website for commercial purposes, or from jdk.java.net for an open-source build.
When running CMake with the proper JDK installed, the DIPjavaio module becomes available.
Check the CMake output to see which JNI was found. It should match the version of Java found.
These two should be listed together, but the JNI output is only produced on first run.
Delete the CMakeCache.txt
file to run cmake
fresh and see all its output.
If the version of JNI found is not the one in the JDK, or if it is not found at all, add -DJAVA_HOME=<path>
to the cmake
command line:
cmake .. -DJAVA_HOME=/opt/jvm/java-8-oracle
Note that these arguments to cmake
must be combined with the arguments mentioned earlier, into a single,
long command line argument.
Using DIPimage
Once the install
target has finished building and installing the toolbox, start
MATLAB. Type the following command:
addpath('/Users/<name>/dip/share/DIPimage')
This will make the toolbox available (replace /Users/<name>/dip
with the
actual path you installed to).
To get started using DIPimage, read the DIPimage User Manual, and look through the help, starting at
help DIPimage
Or start the GUI:
dipimage
If you see error messages such as
Invalid MEX-file '/Users/\<name>/dip/share/DIPimage/measure.mexa64': /<path>/bin/glnxa64/../../sys/os/glnxa64/libstdc++.so.6: version `GLIBCXX_3.4.26' not found (required by /Users/\<name>/dip/share/DIPimage/../../lib/libDIP.so)
then please read this next section.
MATLAB and the GCC libraries
Skip this section if you do not have any problems running DIPimage functions.
MATLAB is built on Linux with a version of GCC that is typically various years behind the latest, and it ships with copies of the GCC libraries so that it can run on older systems that have older versions of those libraries. When building a MEX-file with a newer version of GCC, the MEX-file will depend on a newer version of the GCC libraries than what MATLAB links against, and will therefore fail to load within MATLAB.
In the documentation they specify which compiler versions are compatible with each version of MATLAB. This list includes the version of GCC used to build that version of MATLAB, and a few older releases. That is, their solution to this issue is to tell customers to use only those specific versions of GCC to build MEX-files. If you do want to follow MATLAB’s recommendation, then install one of the supported compilers, and add tell CMake about them using the following command:
cmake . -DCMAKE_C_COMPILER=gcc-9 -DCMAKE_CXX_COMPILER=g++-9
(replacing gcc-9
and g++-9
with the actual names of the compiler installed). Then rebuild the whole project.
However, there’s a simpler solution. Given that you have a newer version of GCC installed than that used by MATLAB,
and given that the GCC libraries are perfectly backwards-compatible, one can simply delete the libraries distributed
with MATLAB, and have it use the ones in your system. In the directory <matlabroot>/sys/os/glnxa64
, delete
the file libstdc++.*
, and possibly also the files libg2c.*
and libgcc_s*
(or rather, rename them, so you can put
them back if things go sour). Note that you need to restart MATLAB after making this change. You can discover
what <matlabroot>
is by typing matlabroot
at the MATLAB command prompt.
Using PyDIP
Once the pip_install
target has finished installing, start Python.
The following command will import the PyDIP package as dip
, which is shorter to
type and mimics the namespace used in the C++ library:
import diplib as dip
To get started using PyDIP, look through the help, starting at
help(dip)
The PyDIP User Manual is still quite short, but does contain some important information to get you started.