This plugin adds HIP platform that allows to run OpenMM on CDNA and RDNA AMD GPUs on AMD ROCm™ open software platform.
conda create -n openmm-env -c streamhpc -c conda-forge --strict-channel-priority openmm-hip
conda activate openmm-env
This command creates a new environment, installs OpenMM and the plugin and activates the new environment.
Note: cudatoolkit
is a large (about 1 GB) dependency of openmm
package, however it is not
required for the HIP plugin. It is possible to install a tiny "shim" package instead (for more
information see
this comment):
conda create -n openmm-env -c jaimergp/label/unsupported-cudatoolkit-shim -c streamhpc -c conda-forge --strict-channel-priority openmm-hip
conda activate openmm-env
Verify your installation (HIP must be one of available platforms):
python -m openmm.testInstallation
If there is no HIP among available platforms check why the HIP platform fails to load:
python -c "import openmm as mm; print('---Loaded---', *mm.pluginLoadedLibNames, '---Failed---', *mm.Platform.getPluginLoadFailures(), sep='\n')"
Run tests:
cd $CONDA_PREFIX/share/openmm/tests/
./test_openmm_hip.sh
Run benchmarks (see more options python benchmark.py --help
):
cd $CONDA_PREFIX/share/openmm/examples/
python benchmark.py --platform=HIP
To remove OpenMM and the HIP plugin, run:
conda uninstall openmm-hip openmm
This project uses CMake for its build system.
The plugin requires source code of OpenMM, it can be downloaded as an archive here or as a Git repository:
git clone https://github.com/openmm/openmm.git -b 8.1.1
To build the plugin, follow these steps:
-
Create a directory in which to build the plugin.
-
Run the CMake GUI or ccmake, specifying your new directory as the build directory and the top level directory of this project as the source directory.
-
Press "Configure".
-
Set OPENMM_DIR to point to the directory where OpenMM is installed. This is needed to locate the OpenMM header files and libraries.
-
Set OPENMM_SOURCE_DIR to point to the directory where OpenMM source code is located.
-
Set CMAKE_INSTALL_PREFIX to the directory where the plugin should be installed. Usually, this will be the same as OPENMM_DIR, so the plugin will be added to your OpenMM installation.
-
Press "Configure" again if necessary, then press "Generate".
-
Use the build system you selected to build and install the plugin. For example, if you selected Unix Makefiles, type
make install
.
Here are all commands required for building and installing OpenMM with HIP support from the latest source code:
mkdir build build-hip install
git clone https://github.com/openmm/openmm.git -b 8.1.1
cd build
cmake ../openmm/ -D CMAKE_INSTALL_PREFIX=../install -D OPENMM_BUILD_COMMON=ON -D OPENMM_PYTHON_USER_INSTALL=ON
make
make install
make PythonInstall
cd ..
git clone https://github.com/amd/openmm-hip.git
cd build-hip
cmake ../openmm-hip/ -D OPENMM_DIR=../install -D OPENMM_SOURCE_DIR=../openmm -D CMAKE_INSTALL_PREFIX=../install
make
make install
If you do not want to install OpenMM Python libraries into the user site-packages directory
remove -D OPENMM_PYTHON_USER_INSTALL=ON
.
Use ROCM_PATH
environment variable if ROCm is not installed in the default directory (/opt/rocm).
To run all the test cases build the "test" target, for example by typing make test
, or call
ctest --output-on-failure --repeat until-pass:3
(retry three times so stochastic tests have
a chance).
There are 3 implementations (backends) of FFT, the default is VkFFT. If some tests fail or you suspect that your simulation with PME produces incorrect results, please try different backends:
- the built-in FFT implementation (
export OPENMM_FFT_BACKEND=0
). - the hipFFT/rocFFT-based implementation (
export OPENMM_FFT_BACKEND=1
); - the VkFFT-based implementation (
export OPENMM_FFT_BACKEND=2
);
The hipFFT/rocFFT-based implementation requires hipFFT and rocFFT libraries, otherwise it will be disabled, install them from ROCm repositories before running cmake:
apt install hipfft rocfft
If you see "libhipfft.so.0: cannot open shared object file: No such file or directory", run
ldconfig
.
By default, the HIP Platform builds kernels with the amdclang++ compiler. To run the compiler, paths in the following order are used:
properties['HipCompiler']
, if it is passed to Context constructor;OPENMM_HIP_COMPILER
environment variable, if it is set;${ROCM_PATH}/bin/amdclang++
, ifROCM_PATH
environment variable is set;/opt/rocm/bin/amdclang++
otherwise.
There is an alternative way to compile kernels: hipRTC, it is implemented by
plugins/hipcompiler
. To enable this way:
- set
properties['HipAllowRuntimeCompiler'] = 'true'
; - set
OPENMM_USE_HIPRTC
environment variable to 1 (export OPENMM_USE_HIPRTC=1
).
Warning: hipRTC from ROCm 6.0.0 has issues with ambiguous operators for vector and complex
types. It seems that they have been fixed in ROCm/clr's develop
branch and likely OpenMM+hipRTC
will be usable with the next ROCm release.
The HIP Platform uses OpenMM API under the terms of the MIT License. A copy of this license may be found in the accompanying file MIT.txt.
The HIP Platform is based on the CUDA Platform of OpenMM under the terms of the GNU Lesser General Public License. A copy of this license may be found in the accompanying file LGPL.txt. It in turn incorporates the terms of the GNU General Public License, which may be found in the accompanying file GPL.txt.
The HIP Platform uses VkFFT by Dmitrii Tolmachev under the terms of the MIT License. A copy of this license may be found in the accompanying file MIT-VkFFT.txt.