Utility scripts based on PyQUDA
Project description
PyQUDA
Python wrapper for QUDA written in Cython.
This project aims to benefit from the optimized linear algebra library CuPy in Python based on CUDA. CuPy and QUDA will allow us to perform most lattice QCD research operations with high performance. PyTorch is an alternative option. DPNP is the recommendation for Intel GPU.
This project is based on the latest QUDA develop branch. PyQUDA should be compatible with any commit of QUDA after https://github.com/lattice/quda/pull/1489, but leave some features disabled.
Feature
- Multi-GPU supported
- with MPI for Python package
- File I/O
- Read gauge and propagator in Chroma format (with checksum)
- Read gauge and propagator in MILC format (with checksum)
- Read/write gauge and propagator in KYU format
- Read/write gauge and propagator in XQCD format
- Read/write gauge in NERSC format
- Read/write gauge in OpenQCD format
- Read/write lattice field in NPY format (numpy)
- Read/write lattice field in HDF5 format (h5py)
- Quark propagator
- Isotropic/anisotropic Wilson fermion action with multigrid support
- Isotropic/anisotropic Clover fermion action with multigrid support
- Isotropic HISQ fermion action
- HMC
- Isotropic gauge action
- 1-flavor isotropic clover fermion action
- 2-flavor isotropic clover fermion action
- N-flavor isotropic HISQ fermion action
- Gauge fixing
- Rotation field with over-relaxation method (waiting for QUDA merge)
- Gauge smearing
- 3D/4D APE smearing
- 3D/4D stout smearing
- 3D/4D HYP smearing
- Fermion smearing
- Gaussian smearing
- Gradient flow
- Wilson/Symanzik flow
- Wilson/Symanzik flow with fermion
- Adjoint Wilson/Symanzik flow with fermion
Installation
Install from PyPI (Recommend)
Assuming the QUDA installation path is /path/to/quda/build/usqcd
export QUDA_PATH=/path/to/quda/build/usqcd
python3 -m pip install pyquda pyquda-utils
Install from source
export QUDA_PATH=/path/to/quda/build/usqcd
git clone --recursive https://github.com/CLQCD/PyQUDA.git
cd PyQUDA/pyquda_core
python3 -m pip install .
cd ..
python3 -m pip install .
Benchmark
Refer to https://github.com/CLQCD/PyQUDA/wiki/Benchmark for detailed instructions to run the PyQUDA benchmark.
Documentation (draft)
https://github.com/CLQCD/PyQUDA/wiki/Documentation
Plugin
Refer to https://github.com/CLQCD/PyQUDA/wiki/Plugin for detailed instructions to build PyQUDA plugins.
Here are plugins developed by PyQUDA developers:
Development
We recommend building PyQUDA using in-place mode instead of installing PyQUDA for development.
export QUDA_PATH=/path/to/quda/build/usqcd
git clone --recursive https://github.com/CLQCD/PyQUDA.git
cd PyQUDA/pyquda_core
python3 setup.py build_ext --inplace
cd ..
python3 setup.py egg_info
ln -s pyquda_core/pyquda_comm ./
ln -s pyquda_core/pyquda ./
Now you can modify Python files in the project and immediately get the new result by running scripts. Adding the root directory to sys.path is needed if you are running scripts from other directories.
Maintenance
Function definitions (mainly in quda.in.pxd and quda.in.pyx) and most docstrings (mainly in pyquda.pyi and enum_quda.in.py) should be manually updated as they cannot be autogenerated now. This also means PyQUDA should work well with future versions if the API remains unchanged.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file pyquda_utils-0.10.48.post0.tar.gz.
File metadata
- Download URL: pyquda_utils-0.10.48.post0.tar.gz
- Upload date:
- Size: 136.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4098885045a5aa2ad60d335479e3ae71e588e9c535c9679112c41007e44b1cca
|
|
| MD5 |
c89bf4bc4708fbf462d0124b98e41112
|
|
| BLAKE2b-256 |
829fa0a0f11743871dd48cf16f94283b36c7eedeb2213cfe31638a23fe628543
|
Provenance
The following attestation bundles were made for pyquda_utils-0.10.48.post0.tar.gz:
Publisher:
PyQUDA-Utils.yaml on CLQCD/PyQUDA
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pyquda_utils-0.10.48.post0.tar.gz -
Subject digest:
4098885045a5aa2ad60d335479e3ae71e588e9c535c9679112c41007e44b1cca - Sigstore transparency entry: 995127957
- Sigstore integration time:
-
Permalink:
CLQCD/PyQUDA@9c0f59486b787ee8f34317ec9e9e6af173b132f4 -
Branch / Tag:
refs/heads/master - Owner: https://github.com/CLQCD
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
PyQUDA-Utils.yaml@9c0f59486b787ee8f34317ec9e9e6af173b132f4 -
Trigger Event:
workflow_dispatch
-
Statement type: