Autoperf is a tool for creating and managing performance experiments, including data post processing and analysis. It provides a simple format for defining the experiment environment and data to be collected, and interfaces to a variety of performance tools (e.g., TAU and HPCToolkit) to perform the measurements and subsequent analyses. The current capabilities include the collection of detailed hardware performance counters, derived performance metrics computations, statistical analysis, and preliminary support for comparisons of different code versions.
autoperf/ -- the autoperf python package bin/ -- directory which holds the driver script example/ -- a few examples ext/ -- c/c++ extension for python cmake/ -- CMake build files README.rst -- this file
- Python 3, including the development headers (e.g., python-dev package in various Linux distros)
- One or more performance measurement tools, e.g., PAPI, TAU, HPCToolkit. The minimum installation does not require anything beyond a recent GCC compiler (version 7 or newer).
You can install this package by using CMake version 3.10 or newer. First create a build directory and go to it to configure and build. For example:
git clone https://github.com/HPCL/autoperf cd autoperf mkdir build cd build cmake .. make make install
This will use /usr/local as the prefix, to customize the installation location, specify a path using the -DCMAKE_INSTALL_PREFIX flag, e.g.:
cmake -DCMAKE_INSTALL_PREFIX=<some_directory> ..
For a list of available configuration options, run:
cmake .. --help
The C extension (partitioner) in this package requires headers and libraries of PAPI/SQLITE3 to compile. You may need to point out where to find those using environment variables PAPI or the -DWITH_PAPI=<papi path> option to cmake.
Autoperf also supports CUDA/CUpti. To enable this feature, set th CUDA environment variable to the CUDA SDK installation directory on your system.
Several examples are provided under example/. A config file, autoperf.cfg, is provided for each example.
The config file can be specified though command line option. If not specified, autoperf will search for the first valid file in the order below:
.autoperf.cfg : autoperf.cfg : ~/.autoperf.cfg
A driver script named "autoperf" is included in the bin/ subdirectory of your installation path. Run the driver script to execute the experiments and collect the data:
$ autoperf -h usage: autoperf [-h] [-f CFGFILE] [-D CONFIG.OPTION=VALUE] [-r | -c | -y | -q] [-e EXP[@NUM]] [-i INSTANCE] [-b] optional arguments: -h, --help show this help message and exit -f CFGFILE, --config CFGFILE Specify a config file. If not specified or file does not exist, search for .autoperf.cfg, autoperf.cfg, ~/.autoperf.cfg in order -D CONFIG.OPTION=VALUE Override a config option in config file. This option can be specified multiple times -r, --run When used with '-e', run specified experiment(s). Otherwise run each defined experiment once. (default) -c, --check When used with '-e' or '-i', show the status (Unknown, Queueing, Running or Finished) of those experiments. Otherwise, show status of all experiments. -y, --analyze When used with '-e' or '-i', analyze those experiments data. Otherwise, analyze all exepriments. The experiment must be in 'Finished' state. -q, --cancel When used with '-e' or '-i', cancel those experiments if they are still running. -e EXP[@NUM], --exp EXP[@NUM] Select experiment EXP NUM times. This option can be used multiple times and experiments will be selected in the order they appear. [default: NUM=1] -i INSTANCE, --insname INSTANCE Use with '-c' or '-y' to specify the instance name of the experiment. This option can be specified multiple times -b, --block Instead of exiting immediately after submitting theexperiment to the batch system, now block until the job is finished [default: False]
Thus, you could try:
$ autoperf
or:
$ autoperf -e pi_tau_inst -e pi_tau_samp@5
Note that this will just submit the job to batch system (maybe PBS). You can check whether the job has been finished with:
$ autoperf -c
If the job is finished, you can analyze collected data with:
$ autoperf -y
Or, you can do the job submission and data analyze in one step:
$ autoperf -b
In this case, the script will not return until the job is finished and the analysis is done. After the driver script returns, you can find collected data under output/. The data is also loaded into taudb if "Datastore=taudb" is specified in config file. In such case,You can run paraprof (part of TAU) to check the data.