Doping is a transparent and fully automatic framework that does source-to-source transformation and runtime compilation for enhancing the vectorisation of scientific applications. The framework masquerades the overall compilation and execution through a number of aspects. First it performs limited source-to-source, compile-time transformation to inject the code that facilitates dynamic evaluation of loops. During the dynamic evaluation, the framework delays the execution as much as possible to leverage potential runtime-only information, which are otherwise, unavailable to the compilers during static analysis. Once the framework believes that enough information has been collected to facilitate the vectorisation, it recompiles the ideal candidates (for the time being, these are loops) and links that to the currently running code.
Although it is possible to know more at runtime, a number of challenges do exist. First, delayed evaluation may not always pay off. After all, we may not find any candidates that massively benefits from vectorisation. Secondly, it is always a question, how much delaying is good. The aim of this framework is to facilitate the research into runtime vectorisation.
Doping uses the llvm libclang, which can be installed from your Package manager of choice. If libclang is installed manually make sure to add libclang.so path to LD_LIBRARY_PATH. All other dependencies are embedded or managed by the pip command, you can install them with:
pip install -e .
To build the Doping runtime use:
make
If it succeeds the bin folder should contains the files: dope, doping.h and libdoping.so.
The make targets below verify Doping is running correctly and demonstrate a simple example:
make test
make examples
make quickrun
To use Doping, first specify the DOPING_ROOT environment variable to point this repository.
export DOPING_ROOT=$PWD
Then prepend a compiler command with the dope command:
dope [doping_options] -- compiler_command
For example:
cd examples/quick_examples/multiplematrixmult/
dope -- gcc -O2 mm.cc -o mm.exe
Alternatively, you can try intercepting build system compiler invocations with:
CC="./doping [doping_options] -- icc" make
Finally, run the produced binary as normal, Doping runtime optimization will be triggered under-the-hood when a loop can be optimized. Optionally, the DOPING_VERBOSE environment variable can be set with a verbosity level in order to print more information about what Doping is doing during the execution of a program:
./mm.exe 50 10000
DOPING_VERBOSE=1 ./mm.exe 50 10000
In addition to the dependencies mentioned on the User's Guide, developers can install: pytest, pytest-cov, pycodestyle, Sphinx and sphinx_rtd_theme, this will allow to run the unit-tests and to build the documentation:
pip install -e .[dev]
As Doping is still under development, we don't enforce the development guidelines in the master branch, but ideally the following guideline must be followed:
- Document all new code using pyhton docstring.
- Make sure all unit tests and integration tests pass by executing:
make test
- Create a unit test for every new code addition, check the code coverage with:
pytest --cov-report=term --cov=src/codegen
- Add the appropriate documentation in the doc/source directory and check it generates with:
cd doc
make html
- Make sure all code passes the pycodestyle format test.
pycodestyle src/codegen/*
Note that there are additional dependencies to generate new UML diagram images (Plantuml, java and graphviz) and Latex documentation(Latex distribution). These should be installed manually.
Finally, to clean binaries and temporal files you can use:
make clean
- Sergi Siso <sergi.siso@stfc.ac.uk>
- Jeyan Thiyagalingam <T.Jeyarajan@liverpool.ac.uk>