JAX-powered Cosmological Particle-Mesh N-body Solver
Find a file
Francois Lanusse dd161f7364 Adding version (#29)
* adding version

* fixing version file

Former-commit-id: ba1206bce8a310f6ed06040c2e23b69d0ea502aa
2024-12-20 07:45:29 -05:00
.github/workflows jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
dev jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
jaxpm jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
notebooks jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
tests jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
.all-contributorsrc docs: update .all-contributorsrc [skip ci] 2024-12-07 19:54:33 +00:00
.gitignore jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
.pre-commit-config.yaml jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
LICENSE Initial commit 2021-07-16 23:10:42 +02:00
pyproject.toml Adding version (#29) 2024-12-20 07:45:29 -05:00
pytest.ini jaxdecomp proto (#21) 2024-12-20 05:44:02 -05:00
README.md Update README.md 2024-12-20 05:56:16 -05:00

JaxPM

Tests All Contributors

JAX-powered Cosmological Particle-Mesh N-body Solver

Goals

Provide a modern infrastructure to support differentiable PM N-body simulations using JAX:

  • Keep implementation simple and readable, in pure NumPy API
  • Any order forward and backward automatic differentiation
  • Support automated batching using vmap
  • Compatibility with external optimizer libraries like optax
  • Now fully distributable on multi-GPU and multi-node systems using jaxDecomp working withJAX v0.4.35

Open development and use

Current expectations are:

  • This project is and will remain open source, and usable without any restrictions for any purposes
  • Will be a simple publication on The Journal of Open Source Software
  • Everyone is welcome to contribute, and can join the JOSS publication (until it is submitted to the journal).
  • Anyone (including main contributors) can use this code as a framework to build and publish their own applications, with no expectation that they need to extend authorship to all jaxpm developers.

Getting Started

To dive into JaxPMs capabilities, please explore the notebook section for detailed tutorials and examples on various setups, from single-device simulations to multi-host configurations. You can find the notebooks' README here for a structured guide through each tutorial.

Contributors

Thanks goes to these wonderful people (emoji key):

Francois Lanusse
Francois Lanusse

🤔
Denise Lanzieri
Denise Lanzieri

💻
Wassim KABALAN
Wassim KABALAN

💻 🚇 👀
Hugo Simon-Onfroy
Hugo Simon-Onfroy

💻
Alexandre Boucaud
Alexandre Boucaud

👀

This project follows the all-contributors specification. Contributions of any kind welcome!