Difference between revisions of "How to build"

From Medusa: Coordinate Free Mehless Method implementation
Jump to: navigation, search
(HDF5)
(Installation)
Line 3: Line 3:
 
* Clone the repository: <syntaxhighlight lang="bash" inline> git clone https://gitlab.com/e62Lab/e62numcodes.git </syntaxhighlight>
 
* Clone the repository: <syntaxhighlight lang="bash" inline> git clone https://gitlab.com/e62Lab/e62numcodes.git </syntaxhighlight>
 
* Go to util and run tests:<syntaxhighlight lang="bash" line> ./run_tests.sh </syntaxhighlight>
 
* Go to util and run tests:<syntaxhighlight lang="bash" line> ./run_tests.sh </syntaxhighlight>
** This will check the configuration, resolve dependencies, build and run all tests, check code style and docs.
+
This will check the configuration, resolve dependencies, build and run all tests, check code style and docs.
 +
 
 +
To run from clean Ubuntu  install, you have to run
 +
<code line>
 +
sudo apt-get install cmake doxygen graphviz libboost-dev libsfml-dev libhdf5-serial-dev
 +
git clone https://gitlab.com/e62Lab/e62numcodes.git
 +
cd e62numcodes
 +
./run_tests.sh
 +
</code>
 +
and everything should run fine.
  
 
=Building=
 
=Building=

Revision as of 16:53, 1 November 2016

Installation

Instalation/requirements

  • Clone the repository: git clone https://gitlab.com/e62Lab/e62numcodes.git
  • Go to util and run tests:
    1  ./run_tests.sh
    

This will check the configuration, resolve dependencies, build and run all tests, check code style and docs.

To run from clean Ubuntu install, you have to run sudo apt-get install cmake doxygen graphviz libboost-dev libsfml-dev libhdf5-serial-dev git clone https://gitlab.com/e62Lab/e62numcodes.git cd e62numcodes ./run_tests.sh and everything should run fine.

Building

List of dependencies:

Out of source builds are preferred. Run

1 mkdir -p build
2 cd build
3 cmake ..
4 make

Note that you only have to run cmake once, after that only make is sufficient.

Binaries are placed into bin folder. Test can be run all at once via make run_all_tests or individually via eg. make basisfunc_run_tests.

Linear Algebra

We use Eigen as our matrix library. See here for use reference and documentation. For a quick transition from Matlab see here.

Drawing

Some tests include drawing. We are using SMFL library, which can be installed on most linux systems easly as sudo apt-get install libsfml-dev or sudo pacman -S sfml. After the installation uncomment a test case in domain_draw_test.cpp and run make test_domain_draw to see the visual effect.

Binaries using SFML require additional linker flags -lsfml-graphics -lsfml-window -lsfml-system, but the makefile should take care of that for you.

HDF5

In order to use IO you need hdf5 library. You can install it easily using the command sudo apt-get install libhdf5- dev or sudo pacman -S hdf5-cpp-fortran.

Ubuntu places hdf5 libs in a werid folder /usr/lib/x86_64-linux-gnu/hdf5/serial/. If you get error similar to -lhdf5 not found and you have hdf5 installed, you might have to link the libraries into a discoverable place, like /usr/lib/ or add the above directory to the linker path. If using cmake, you can add the following line to your CMakeLists.txt

 link_directories(/usr/lib/x86_64-linux-gnu/hdf5/serial/)