Skip to content

Latest commit

 

History

History
91 lines (68 loc) · 4.54 KB

README.rst

File metadata and controls

91 lines (68 loc) · 4.54 KB

REBOUND - An open-source multi-purpose N-body code

http://img.shields.io/badge/rebound-v3.6.2-green.svg?style=flat http://img.shields.io/badge/license-GPL-green.svg?style=flat http://img.shields.io/travis/hannorein/rebound/master.svg?style=flat https://coveralls.io/repos/hannorein/rebound/badge.svg?branch=master&service=github http://img.shields.io/badge/arXiv-1110.4876-green.svg?style=flat http://img.shields.io/badge/arXiv-1409.4779-green.svg?style=flat http://img.shields.io/badge/arXiv-1506.01084-green.svg?style=flat http://img.shields.io/badge/arXiv-1603.03424-green.svg?style=flat https://readthedocs.org/projects/pip/badge/?version=latest https://img.shields.io/badge/launch-binder-ff69b4.svg?style=flat

FEATURES

REBOUND is an N-body integrator, i.e. a software package that can integrate the motion of particles under the influence of gravity. The particles can represent stars, planets, moons, ring or dust particles. REBOUND is very flexible and can be customized to accurately and efficiently solve many problems in astrophysics. An incomplete feature list of REBOUND:

  • Symplectic integrators (WHFast, WHFastHelio, SEI, LEAPFROG)
  • High accuracy non-symplectic integrator with adaptive timestepping (IAS15)
  • Support for collisional/granular dynamics, various collision detection routines
  • The code is written entirely in C, conforms to the ISO standard C99 and can be used as a thread-safe shared library
  • Easy-to-use Python module, installation in 3 words: pip install rebound
  • Extensive set of example problems in both C and Python
  • Real-time, 3D OpenGL visualization (C version)
  • Parallelized with OpenMP (for shared memory systems)
  • Parallelized with MPI using an essential tree for gravity and collisions (for distributed memory systems)
  • No libraries are needed, use of OpenGL/glfw3 for visualization is optional
  • The code is fully open-source and can be downloaded freely from http://github.com/hannorein/rebound
  • No configuration is needed to run any of the example problems. Just type make && ./rebound in the problem directory to run them
  • Comes with standard ASCII or binary output routines
  • Different modules are easily interchangeable at runtime

One minute installation

You can install REBOUND with pip if you want to only use the python version of REBOUND:

pip install rebound

Then, you can run a simple REBOUND simulation such as

import rebound
sim = rebound.Simulation()
sim.add(m=1.0)
sim.add(m=1.0e-3, a=1.0)
sim.integrate(1000.)
sim.status()

If you want to use the C version of REBOUND simply copy and paste this line into your terminal (it won't do anything bad, we promise):

git clone http://github.com/hannorein/rebound && cd rebound/examples/shearing_sheet && make && ./rebound

Documentation

The full documentation with many examples, changelogs and tutorials can be found at

http://rebound.readthedocs.org

We're alway trying to improve REBOUND and extending the documention is high on our to-do list. If you have trouble installing or using REBOUND, please open an issue on github and we'll try to help as much as we can.

Changelog

For a changelog of the most important changes in recent updates, see https://github.com/hannorein/rebound/blob/master/changelog.rst

License

REBOUND is using GNU General Public License (GPL) v3 which is provided in the LICENSE file that comes with this package. If you have a usecase that requires a different license, please contact the developers.

Parts of this package make use of Jeff Verkoeyen's fmemopen replacement (https://github.com/NimbusKit/memorymapping) and Ian Piumarta's open_memstream replacement (http://piumarta.com/software/memstream/) for old Mac OSX versions. Please see these websites for the respective licenses.