The NeoRodinia Benchmark Suite is designed for educating and benchmarking parallel programming using OpenMP. It implements various parallelization levels, demonstrating their impact on performance, and serves as a tool for performance evaluation across different computing systems.
- Structured Optimization: Introduces parallelization levels for structured optimization in parallel programming.
- Automated Testing Framework: Simplifies the process of performance data collection and plotting for parallel programming benchmarking.
- Educational Tool: Acts as an instructional guide for structured application parallelization.
- Linux operating system
- GCC 11, LLVM 17, NVIDIA HPC SDK 22.1
- Clone the repository:
git clone https://github.com/passlab/NeoRodinia.git
- Navigate to the desired benchmark directory:
cd NeoRodinia/<benchmark_name>
- Compile the benchmark using the provided Makefiles:
make all CC=<compiler> OPT_LEVEL=<O1/O2/O3>
To run the benchmarks using the automated testing framework:
- Execute the benchmarks:
python ../csv_generator.py
- Collect and plot the performance data:
python ../figure_generator.py
Contributions are welcome! Please read the CONTRIBUTING.md file for details on our code of conduct, and the process for submitting pull requests.
This project is licensed under the BSD License.
If you use this suite in your research, please cite:
- [To be determined]
- Thanks to all contributors who have helped in developing and refining the NeoRodinia benchmark suite.