Note
The published documentation is available at ROCm Performance Primitives (RPP) in an organized, easy-to-read format, with search and a table of contents. The documentation source files reside in the docs folder of this repository. As with all ROCm projects, the documentation is open source. For more information on contributing to the documentation, see Contribute to ROCm documentation.
AMD ROCm Performance Primitives (RPP) library is a comprehensive, high-performance computer
vision library for AMD processors that have HIP, OpenCL, or CPU backends.
| Input (nifti1 .nii medical image) | fused_multiply_add_scalar (brightened 3D image) | 
|---|---|
- Below are the list of audio functions supported
- Non Silent Region Detection (HOST and HIP)
- To Decibels (HOST and HIP)
- Downmixing (HOST and HIP)
- Preemphasis Filter (HOST and HIP)
- Resample (HOST and HIP)
- Mel Filter Bank (HOST and HIP)
- Spectrogram (HOST and HIP)
 
Spectrogram kernel output represented as a image 
- Linux
- Ubuntu - 22.04/24.04
- RedHat - 8/9
- SLES - 15-SP5
 
- Ubuntu - 
- CPU: AMD64
- GPU: AMD Radeon™ Graphics / AMD Instinct™ Accelerators
Important
- ROCm-supported hardware required for HIP backend
- gfx908or higher GPU required
- Install ROCm 7.0.0or later with amdgpu-install: Required usecase:rocm
Important
sudo amdgpu-install --usecase=rocm
- AMD Clang++ Version 18.0.0 or later - installed with ROCm
Note
- For CPU only backend use Clang Version 5.0.1or latersudo apt install clang 
- To use GNU compiler or custom compilers use -D CMAKE_CXX_COMPILERduring build
- 
CMake Version 3.10or latersudo apt install cmake 
- 
HIP sudo apt install rocm-hip-runtime-dev 
- 
OpenMP sudo apt install openmp-extras-dev 
- 
Half-precision floating-point library - Version 1.12.0or latersudo apt install half 
Important
- Required compiler support
- C++17
- OpenMP
- Threads
 
- On Ubuntu 22.04 - Additional package required: libstdc++-12-dev
sudo apt install libstdc++-12-devNote
- All package installs are shown with the aptpackage manager. Use the appropriate package manager for your operating system.
The installation process uses the following steps:
- 
ROCm-supported hardware install verification 
- 
Install ROCm 7.0.0or later with amdgpu-install with--usecase=rocm
Important
Use either package install or source install as described below.
Install RPP runtime, development, and test packages.
- Runtime package - rpponly provides the rpp librarylibrpp.so
- Development package - rpp-dev/rpp-develprovides the library, header files, and samples
- Test package - rpp-testprovides CTest to verify installation
Note
Package install will auto install all dependencies.
sudo apt install rpp rpp-dev rpp-testsudo yum install rpp rpp-devel rpp-testsudo zypper install rpp rpp-devel rpp-test- 
Clone RPP git repository git clone https://github.com/ROCm/rpp.git 
Note
RPP has support for two GPU backends: OPENCL and HIP:
mkdir build-hip
cd build-hip
cmake ../rpp
make -j8
sudo make install- Run tests - test option instructions
make testImportant
make test requires test suite prerequisites installed
mkdir build-ocl
cd build-ocl
cmake -DBACKEND=OCL ../rpp
make -j8
sudo make installThe installer will copy
- Libraries into /opt/rocm/lib
- Header files into /opt/rocm/include/rpp
- Samples, and test folder into /opt/rocm/share/rpp
- Documents folder into /opt/rocm/share/doc/rpp
Test package will install CTest module to test rpp. Follow below steps to test package install
mkdir rpp-test && cd rpp-test
cmake /opt/rocm/share/rpp/test/
ctest -VVNote
- Ubuntu: Install Nifti-Imaging to run all tests
git clone https://github.com/NIFTI-Imaging/nifti_clib.git
cd nifti_clib
git reset --hard 84e323cc3cbb749b6a3eeef861894e444cf7d788
mkdir build && cd build && cmake ..
sudo make -j$nproc install
- SLES/RHEL: Install prerequisites to run all tests
To test latest Image/Voxel/Audio/Miscellaneous functionalities of RPP using a python script please view AMD ROCm Performance Primitives (RPP) Test Suite
MIVisionX RPP extension vx_rpp supports RPP functionality through the OpenVX Framework.
For RPP questions and feedback, you can contact us at [email protected].
To submit feature requests and bug reports, use our GitHub issues page.
You can build our documentation locally using the following code:
- 
Sphinx cd docs pip3 install -r .sphinx/requirements.txt python3 -m sphinx -T -E -b html -d _build/doctrees -D language=en . _build/html 
- 
Doxygen doxygen .Doxyfile 
All notable changes for each release are added to our changelog.
- Linux distribution
- Ubuntu - 22.04/24.04
- RedHat - 8/9
- SLES - 15-SP5
 
- Ubuntu - 
- ROCm: rocm-core - 7.0.0+
- CMake - Version 3.10+
- AMD Clang++ - Version 18.0.0+
- Half - IEEE 754-based half-precision floating-point library - Version 1.12.0/ package V1.12.0
- OpenCV - 4.6.0