-
Notifications
You must be signed in to change notification settings - Fork 27
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix multiple node half rotation MPI error (#324)
Fix the MPI error when running with multiple nodes and performing `half_rotate`, which involves the following code. `scomm` needs to be passed into this code. https://github.com/JoonhoLee-Group/ipie/blob/4b60ce0c923b90e8492b35ffb0e12600d1476ff4/ipie/utils/mpi.py#L117 Otherwise leads to ``` win = MPI.Win.Allocate_shared(nbytes, itemsize, comm=comm) File "mpi4py/MPI/Win.pyx", line 116, in mpi4py.MPI.Win.Allocate_shared mpi4py.MPI.Exception: MPI_ERR_RMA_SHARED: Memory cannot be shared ``` @Jinghong-Zhang also met this before. --------- Co-authored-by: Joonho Lee <[email protected]>
- Loading branch information
1 parent
b15f0b1
commit ed75292
Showing
3 changed files
with
68 additions
and
76 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,13 +1,12 @@ | ||
|
||
.. image:: https://github.com/linusjoonho/ipie/blob/main/logo.png | ||
:width: 200 | ||
|
||
ipie stands for **I**\ntelligent **P**\ython-based **I**\maginary-time **E**\volution with a focus on simplicity and speed. | ||
|
||
ipie inherits a lot of QMC features from pauxy. | ||
|
||
.. image:: https://github.com/linusjoonho/ipie/workflows/CI/badge.svg | ||
:target: https://github.com/linusjoonho/ipie/workflows/CI/badge.svg | ||
.. image:: https://github.com/JoonhoLee-Group/ipie/actions/workflows/ci.yml/badge.svg | ||
:target: https://github.com/JoonhoLee-Group/ipie/actions/workflows/ci.yml | ||
|
||
.. image:: http://readthedocs.org/projects/ipie/badge/?version=latest | ||
:target: http://ipie.readthedocs.io/en/latest/?badge=latest | ||
|
@@ -21,33 +20,44 @@ ipie inherits a lot of QMC features from pauxy. | |
.. image:: https://img.shields.io/badge/paper%20%28v0%29-arXiv%3A2209.04015-B31B1B | ||
:target: https://arxiv.org/abs/2209.04015 | ||
|
||
.. image:: https://img.shields.io/badge/paper%20%28v1%29-arXiv%3A2406.16238-B31B1B | ||
:target: https://arxiv.org/abs/2406.16238 | ||
|
||
Copyright by Joonho Lee ([email protected]) | ||
Our first release paper can be found at https://pubs.acs.org/doi/10.1021/acs.jctc.2c00934 | ||
|
||
Features | ||
ipie is a Python-based auxiliary-field quantum Monte Carlo (AFQMC) package, designed for simplicity and computational efficiency. The package has seen substantial improvements in modularity, functionality, and compatibility since its first release. | ||
|
||
Key features include: | ||
-------- | ||
ipie currently supports: | ||
|
||
- estimation of the ground state energy of ab-initio systems using phaseless AFQMC with support for CPUs and GPUs. | ||
- simple data analysis. | ||
- other legacy functionalities available in pauxy such as the ground state and finite-temperature energies and properties (via backpropagation) of the ab initio, UEG, Hubbard, and Hubbard-Holstein models. | ||
- **Ground State Energy Estimation**: Calculate ground state energies of ab-initio systems with phaseless AFQMC. | ||
- **Distributed Hamiltonian Simulations**: Run large-scale simulations distributed across multiple CPUs or GPUs, enabling calculations on systems too large for a single node or GPU card. | ||
- **GPU Acceleration**: Support both CPU and GPU calculations, with GPU acceleration provided by CuPy/CUDA and CUDA-aware MPI. | ||
- **Extended AFQMC Algorithms**: Includes free projection AFQMC, finite temperature AFQMC, AFQMC for electron-phonon systems, and automatic differentiation for property calculation. | ||
- **Simple Data Analysis** | ||
- **Other legacy features from pauxy** | ||
|
||
For technical details, see our latest release papers: | ||
|
||
- [J. Chem. Theory Comput., 2023, 19(1): 109-121](https://pubs.acs.org/doi/10.1021/acs.jctc.2c00934) | ||
- [J. Chem. Phys. 161, 162502 (2024)](https://doi.org/10.1063/5.0225596) | ||
|
||
Installation | ||
------------ | ||
|
||
Linux and Mac OS wheels are available for installation via pip | ||
Linux and Mac OS wheels are available for installation via pip: | ||
|
||
:: | ||
|
||
$ pip install ipie | ||
|
||
For develpment you can instead clone the repository | ||
For development, clone the repository: | ||
|
||
:: | ||
|
||
$ git clone https://github.com/linusjoonho/ipie.git | ||
|
||
and run the following in the top-level ipie directory | ||
Navigate to the top-level `ipie` directory and run: | ||
|
||
:: | ||
|
||
|
@@ -57,57 +67,47 @@ and run the following in the top-level ipie directory | |
Requirements | ||
------------ | ||
|
||
To build ipie with MPI support (via mpi4py) do: | ||
To build ipie with MPI support (via `mpi4py`), install with: | ||
|
||
:: | ||
|
||
$ pip install -e .[mpi] | ||
|
||
Note that mpi4py requires a working MPI installation to be built on your | ||
machine. This it is often the trickiest dependency to setup correctly. | ||
|
||
One of the easiest ways (if you are using pip to install ipie wheels) is via | ||
conda: | ||
This requires a working MPI installation on your machine, which can be installed via `conda`: | ||
|
||
:: | ||
|
||
conda install openmpi | ||
|
||
which will just install the OpenMPI library. | ||
We refer users to the mpi4py | ||
`documentation <https://mpi4py.readthedocs.io/en/stable/install.html>`_ for | ||
alternative ways of building mpi4py and the required MPI library. | ||
|
||
Further requirements are listed in requirements.txt. | ||
|
||
GPU Support | ||
----------- | ||
Cupy is is required when running calculations on GPUs which | ||
can be install following the instructions `here <https://cupy.dev/>`_ . | ||
Refer to the `mpi4py` `documentation <https://mpi4py.readthedocs.io/en/stable/install.html>`_ for alternative installation options. | ||
|
||
Cuda aware MPI may be installed via conda-forge. | ||
For GPU support, `cupy` is required and can be installed as outlined on the `Cupy website <https://cupy.dev/>`_. For CUDA-aware MPI, consider `conda-forge`. | ||
|
||
Running the Test Suite | ||
---------------------- | ||
|
||
ipie contains unit tests and some longer driver tests that can be run using pytest by | ||
running: | ||
Unit tests and driver tests are included. To run all tests: | ||
|
||
:: | ||
|
||
$ pytest -v | ||
|
||
in the base of the repo. Some longer parallel tests are also run through the CI. See | ||
`.github/workflows/ci.yml` for more details. | ||
More extensive parallel tests are executed in the CI; see `.github/workflows/ci.yml` for details. | ||
|
||
.. image:: https://github.com/linusjoonho/ipie/workflows/CI/badge.svg | ||
:target: https://github.com/linusjoonho/ipie/workflows/CI/badge.svg | ||
.. image:: https://github.com/JoonhoLee-Group/ipie/actions/workflows/ci.yml/badge.svg | ||
:target: https://github.com/JoonhoLee-Group/ipie/actions/workflows/ci.yml | ||
|
||
Building Optimized C/C++ Code | ||
----------------------------- | ||
|
||
ipie also provides optimized implementations for certain functions involving multiple Slater determinant trials using C/C++ code, which can be built for enhanced performance. To compile these functions into a shared library, navigate to the `ipie/lib/wicks` folder and use `CMake` and `Make`: | ||
|
||
:: | ||
|
||
$ cmake . | ||
$ make | ||
|
||
Documentation | ||
------------- | ||
|
||
Documentation and tutorials are available at | ||
`readthedocs <https://ipie.readthedocs.org>`_. | ||
|
||
.. image:: http://readthedocs.org/projects/ipie/badge/?version=latest | ||
:target: http://ipie.readthedocs.io/en/latest/?badge=latest | ||
Documentation and tutorials are available at `ReadTheDocs <https://ipie.readthedocs.org>`_. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters