Skip to main content

ORIO -- An Annotation-Based Performance Tuning Tool

Project description

Orio

Orio is an open-source extensible framework for the definition of domain-specific languages and generation of optimized code for multiple architecture targets, including support for empirical autotuning of the generated code.

For more detailed documentation, refer to the Orio website, http://brnorris03.github.io/Orio/.

Installation

The Orio installation follows the standard Python setuptools process. The simplest way to install Orio is to run

</code></pre>
<p>For users who want to quickly install Orio to the standard locations
of third-party Python modules (requiring superuser privileges in a
Unix system), the installation is straightforward as shown below. Note that
some modules may require certain packages (e.g., Mlsearch requires <code>pandas</code>),
so it's recommended that you use <a href="http://docs.conda.io">Conda</a> or a similar Python
environment manager.</p>
<pre><code>  $ tar -xzf orio.tar.gz
  $ cd orio
  $ python setup.py install --prefix=$VALID_PYTHON_PATH

On a Unix platform, the install command without the --prefix option will install Orio in the default python installation (system version or currently activated virtual environment). An alternetive approach is to install using the --user option, which does not modify the python installation. Without any options, python setup.py install will typically require superuser permissions and would install the Orio executables (orcc, orcu, orcl, etc.) in /usr/local/bin and and python packages in /usr/local/lib/python2.X. At this point, there is no uninstall script, so removing the above two components manually is sufficient to uninstall Orio.

To test whether Orio has been properly installed in your system, try to execute orcc command as given below as an example.

  $ orcc --help

  description: compile shell for Orio

  usage: orcc [options] <ifile>
    <ifile>   input file containing the annotated code

  options:
    -h, --help                     display this message
    -o <file>, --output=<file>     place the output to <file>
    -v, --verbose                  verbosely show details of the results of the running program

You can optionally include the installed orcc script location in the PATH shell variable. To do this for the above example, the following two lines can be added in the .bashrc configuration file (assuming the user uses Bash shell, of course).

export PYTHONPATH=$PYTHONPATH:/home/username/lib/python/site-packages
export PATH=$PATH:/home/username/bin

After making sure that the orcc executable is in your path, you can try some of the examples included in the testsuite subdirectory, e.g.:

 $ cd examples
 $ orcc -v axpy5.c

The same directory contains two more examples of Orio input -- one with a separate tuning specification file (orcc -v -s axpy5.spec axpy5-nospec.c) and another with two transformations specified using a Composite annotation (orcc -v axpy5a.c). To see a list of options, orcc -h. To keep all intermediate code versions, use the -k option. You can also enable various levels of debugging output by setting the ORIO_DEBUG_LEVEL to an integer value betwen 1 and 6, e.g., for the most verbose output export ORIO_DEBUG_LEVEL=6 and run Orio with the -v command-line option. This is the recommended setting when submitting sample output for bug reports.

To use machine learning-based search (Mlsearch), install numpy, pandas, and scikit-learn modules. Alternatively, if using conda, simply run conda install pandas to obtain all prerequisites if needed.

If Orio reports problems building the code, adjust the compiler settings in the tuning spec included in the axpy5.c example.

Authors and Contact Information

Please send all questions, bugs reports, and comments to: Boyana Norris, brnorris03@gmail.com

Principal Authors:

  • Boyana Norris, University of Oregon
  • Albert Hartono, Intel
  • Azamat Mametjanov, Argonne National Laboratory
  • Prasanna Balaprakash, Argonne National Laboratory
  • Nick Chaimov, University of Oregon

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

orio-0.5.0.tar.gz (410.6 kB view hashes)

Uploaded Source

Built Distribution

orio-0.5.0-py2-none-any.whl (519.0 kB view hashes)

Uploaded Python 2

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page