What’s New#
v2024.11.3#
Internal Changes#
Cleaned out lots of cruft from the repository, including obsolete Docker and Apptainer/Singularity files and folders.
Adjusted project files so that the complete repository, including documenatation and build scripts, gets packaged into the sdist. This is necessary for the conda build process to be able to rely on the sdist tarball rather than getting it GitHub.
Contributors#
v2024.11.2#
Internal Changes#
Updated the build scripts to be more friendly to being build in a conda package. This is part of an effort to generate a conda-forge package version of Swiftest. GH68.
Removed deprecated MacOS-12 support from the GitHub Actions and added MacOS-15 support.
Contributors#
v2024.11.1#
Bug Fixes#
Some versions of Cython would raise an exception of a long double array was passed to the
xv2el()orel2xv()methods. All input values are now cast tonp.float64before being passed to the Cython methods. (GH66 PR67) By David Minton
v2024.11.0#
Bug Fixes#
Fixed impact angle calculation in the Hyodo and Genda (2020) model. Previously it was measured from the zenith rather than from the horizon. GH61
Fixed issue that was causing EL or XV inputs to get erased. When calling the clean() method, the data Dataset needs to be reset to the first time frame rather than getting overridden by the init_cond Dataset, because init_cond gets scrubbed of unneeded values. GH63
Override the rotation and compute_conservation_values options to set them to True when using SyMBA, and issue a warning if the user tries to turn them off. GH63
Added a check for SyMBA rotation and energy parameters in the Fortran side and a corresponding unit test. GH63
Breaking Changes#
Support for
python 3.9has been dropped and the minimum versions of some dependencies were changed in order to allow fornumpy>=2.Package
Old
New
python
3.8
3.10
numpy
==1.26.4
>=1.26.4
xarray
2024.2.0
2024.10.0
Contributors#
v2024.09.2#
Internal Changes#
Added Python 3.13 for aarch64 Linux to the ignore list for cibuildwheel for due to incompatibility with the hdf5 python package.
v2024.09.1#
Bug Fixes#
Added a .compute() method call to to the the particle_type call in the indexer inside of the internal _scrub_init_cond() method to allow for proper operation when dask is turned on.
Breaking Changes#
Internal Changes#
Added support for macos-15 (Sequoia) to the build process.
Contributors#
v2024.09.0#
Bug Fixes#
Internal Changes#
Added a new test to
test_fraggle.pycalledtest_rotation_direction, which tests to ensure that the rotation state of a target in a disruptive collision is consistent with what is expected. rotation rate conversion during collisions #58
Contributors#
v2024.08.0#
This is a major update with a number of important improvements, bug fixes, and new features.
New Features#
The collision module has been updated to include a new model for small impacts based on Hyodo and Genda (2020). The new model is activated when the ratio of the projectile to the target body is less than 1/500. GH53
The core compiled library now stores angular quantities in degrees, just as the Python API does. This will help to prevent floating point errors from accumulating when passing values back and forth between the Python and Fortran code. GH53
Added a deep cleaning option that removes the simdir directory completely, which can be called with the
clean()method by passingdeep=Trueas an argument.Added a new argument to
Simulationcalledcleanthat, when set toTrue, will perform a deep cleaning of the simdir directory before starting a new run. This is useful for ensuring that the simdir is completely clean before starting a new run.
Bug Fixes#
Fixed several issues related to repeatability with restarted runs. A new suite of tests was added to ensure that restarted runs create output that is bit-identical with the original run. GH53
Changed the defaults and behaviors of read_data and read_init_cond to prevent an issue where bodies get added multiple times when running scripts from the same simdir without doing a deep clean inbetween.
Fixed problems where parameters like unit conversion factors were not being set properly when reading in a parameter file. Parameter input files are now processed the same way as arguments passed to the
set_parameter()method. GH53Fixed issue where the inner radius limit was not being set based on the central body radius.
Fixed issues getting initial conditions files build correctly when using an old data file as a source.
Fixed problem where the energy and momentum values were computed after the dump step, causing the values to be out of sync.
Breaking Changes#
Switched to using
np.longdoublefor the unit conversion attributes, which includesMU2KG,KG2MU,TU2S,S2TU,DU2M,M2DU, andGU. This was done to ensure that the precise value is passed back and forth to the compiled core library, otherwise floating point conversion errors can accumulate and cause the simulation to diverge on restarts. Be aware when making use of these values, and their equivalents inparam, that not all external libraries supportnp.longdouble, and so you may need to cast it asfloat. GH53Changed the default display style to
progressand renamed thestandarddisplay style toclassic.Changed the default collision model to
Fraggleinstead ofMerge.
Internal Changes#
Switched to an automated versioning system based on git tags. This will allow us to automatically increment the version number with each new release. GH53
Updated methods for extracting and saving initial conditions from old files, including a major overhaul of the modify_body method that is more robust.
Improved handling of initial conditions retrieval and saving from specific frames.
Contributors#
v2024.07.0#
Bug Fixes#
Contributors#
v2024.06.1#
Bug Fixes#
Fixed bug where a user-defined parameter file name was not read correctly and overwritten.
set_parameter() now handles changes to the parameter file name correctly.
Internal Changes#
Retooled build to use OpenMPI to support upcoming Coarray Test Particle feature. GH7
Pinned Numpy version to 1.26.4 because version 2.0.0 breaks Xarray (via Pandas). SO78634235
Build dependencies as static library for better portability.
v2024.06.0#
Bug Fixes#
Fixed bug that was causing some pl-tp discards to fail due to typos in the snapshot saver argument lists (pl and tp arrays were reversed in some places). GH42
Internal Changes#
Updated the gfortran version to 14 for Mac builds so that the homebrew libraries match the compiled libraries. Otherwise, library delocation fails due to identical fortran library names in two different locations.
v2024.04.3#
Bug Fixes#
Fixed bug that was causing discards to fail when there were more than one discard in a single step. This was due to not deallocating the ldiscard or
ldiscard_tp/ldiscard_plarrays after they were used. GH40
v2024.04.2#
Bug Fixes#
Fixed problems that were preventing non pl-pl collision types to be stored in the
collisions.ncfile (thecollisionsDataset). GH38Changed the way that mergers are handled when they would result in a merged body above the spin barrier. These are forced to always be pure hit-and-runs, rather than disruptive hit-and-run.
Internal Changes#
In preparation for a planned release that will use Coarray Fortran to parallelize RMVS runs, we have incorporated the OpenMPI library into the build process. All of the build scipts were overhauled in order to compile with the MPI wrappers.
A slew of new tests were added to test that collisions were being recorded correctly.
Breaking Changes#
We have dropped support for MacOS-11 from the official PyPI wheels, as the addition of OpenMPI to the build process prevented the wheels from being built on the GitHub runners.
The structure of the collisions Dataset has been altered to help improve performance in runs with large numbers of collisions and fragmentation. The
namevariable is no longer a dimension-coordinate, as this was causing the Dataset to become unreasonably large when reading in runs with a long history of fragmentation events. Instead, the names of bodies in the before and after stages of a collision are stored as regular variables that are unique to each individual collision. This will prevent thenamevariable from needing to be so large, as it only needs to be as long as the maximum number of bodies made in a single collision, rather than the total number of unique bodies every made in all collisions. This means that one cannot select bodies by name using the.selmethod, but instead must use the.wheremethod to select bodies by name. This change was made to address GH39.
v2024.04.1#
Bug Fixes#
Internal Changes#
Pinned the h5py package to v3.10.0 because v3.11.0 does not support aarch64 Linux wheels and the build fails on that platform.
v2024.04.0#
Bug Fixes#
Fixed the Simulation._combine_and_fix_dsnew method so that the name dimension is not added where not needed. GH33
Fixed the
read_encounter_file()for reading encounter variables due to change in how the encounter data is indexed. GH33Fixed bug in the Fortran collision module that was causing max_rot to always be set to 0 in Fraggle, causing Fraggle to fail more often due to not being able to satisfy the angular momentum constrain through fragment spin. GH34
Changed the fortran standard from 2018 to gnu in order to access quad precision by means of the
c_float128intrinsic iniso_c_binding.Fixed bug in Fraggle that was causing a segfault when computing the fragment SFD in Linux. The problem was due to passing a function pointer to a non-module procedure, which is a known issue in the GNU Fortran compiler. The solution was to move the function to a module procedure and pass the module procedure to the function. SO49965980 GH34
Internal Changes#
Updated headers of all build scripts and improved robustness of the MACOX_DEPLOYMENT_TARGET versioning determination with a dedicated script
Altered build scripts to build static libraries for all dependencies. These are now linked to the main library, which reduces the number of shared libraries to manage when installing. GH34
v2024.03.4#
New Features#
Added a new
modify_body()method that allows users to change the properties of a body that has already been added to the simulation. This is useful for changing the mass, radius, or other properties of a body after it has been added to the simulation. GH27Overhauled how the
init_condDataset is created. It now reduces the variables and dimensions relative to the originaldataDataset, such that only the variables that are needed for the initial conditions are included. For instance, ifinit_cond_format(orparam['IN_FORM']) is set toEL, it removes therhandvhvariables when creatinginit_cond, but if it is instead set toXV(the default), then it removes all the orbital element variables. It also reduces the dataset’s variables to either thej2rp2andj4rp4or thec_lmvariables if non-spherical central bodies are being used, and retains only the value that is associated with the current central body. These are all still in the original data (though this will get overridden once the simulation is run), allowing you to swap central bodies prior to starting a run. GH27
Bug Fixes#
Internal Changes#
Overhauled the build scripts used when calling cibuildwheel to make them more robust across the various platforms we build for. This includes a more robust and consistent way to obtain the paths to compilers that lets us select gfortran-13, gfortran-12, or gfortran as our compiler depending on the availability, which is useful for building in the GitHub runners. GH25
Added a more comprehensive suite of unit tests, including tests to ensure that the new
modify_body()method works as expected. GH27Upgraded SHTOOLS library version from 4.11.10 to 4.12.2.
Upgraded to cibuildwheel v2.17.0 to fix a bug that was causing the MacOS build to fail when building on the GitHub runners.
Documentation#
Added IPython blocks to the the Using the standalone executable page to demonstrate the usage of the standalone executable in a real-world scenario.
v2024.03.3#
New Features#
Introduced new classes
swiftest.data.SwiftestDataArrayandswiftest.data.SwiftestDataset. These are extensions of xarray.DataArray and xarray.Dataset, respectively. These are now used to define the internal data storage attributes, likeswiftest.Simulation.data,swiftest.Simulation.init_cond,swiftest.Simulation.collisions, andswiftest.Simulation.encounters, asxv2el()andel2xv(). GH24Added binding modules and started writing code to connect the Fortran el2xv and xv2el to Python and removed the Python implementation of these functions. This allows the Python code to call the same Fortran functions for converting state vectors to orbital elements and back again that the core Swiftest code uses, which are nearly identical to the original implementations of these functions written by Martin Duncan in 1992. The functions themselves are accessible via
swiftest.core.el2xv()andswiftest.core.xv2el().The
swiftest.Simulation.add_solar_system_body()andswiftest.Simulation.add_body()methods have been overhauled to make selecting the central body in a more consistent way. Central bodies are now chosen automatically to be the most massive body in the system, and the all other bodies’ position and velocity vectors are translated to the central body’s frame. We also include a new argument to these functions calledalign_to_central_body_rotationwhich can be used to rotate bodies into a frame that is aligned with the central body’s rotation vector. This is useful for usingadd_solar_system_body()to set bodies other than the Sun to be the central body, as otherwise it aligns all bodies to the ecliptic. See planetocentric initial conditions for details of how this works.
Bug Fixes#
Fixed problem with length check when passing ephemeris_id and name as scalars.
Add explicit status variable when adding bodies to ensure that they get counted properly.
Internal Changes#
Updated initial conditions generators to catch more bad or inconsistent inputs and added more tests to cover these cases.
Updated build script environment variables to help make the MacOS build more robust.
Improved the efficiency of the
solar_system_horizons()function when fetching physical parameters. It can now accept a jpl HorizonsClass object as an argument so that it can re-use a previous query to look for physical parameters, and only execute a new query on an altid if they are not found.Switched from using iso_fortran_env to iso_c_binding for basic type definitions in order to make it easier to expose the Fortran library API to Python.
Documentation#
Added a new documentation page to demonstrate the use of the standalone executable.
Added a new documentation page for setting planetocentric initial conditions
v2024.03.2#
Bug Fixes#
Fixed issue causing the get_solar_system_body method to break when using astroquery 0.4.7. Switched to using the ephemerides_async method instead of getting the raw_response attribute. GH19
v2024.03.1#
Bug Fixes#
Fixed problem that was causing the standalone swiftest console executable to not be found on the path when installing from wheel. This has been fixed by wrapping the executable in a Python wrapper called cli.py that is used to generate an executable script.
Fixed a bug that that was causing a file read error when reading a copied initial conditions file. This was caused by the file not being closed after being read.
Breaking Changes#
The binary executable has been refactored from swiftest_driver to swiftest
Internal Changes#
Addressed an issue where the latest OS X update broke dependency builds, ensuring environment compatibility.
Streamlined code structure by refactoring simulation_class to simulation.
Refactored _bindings module to core. In a future we plan to develop a more extensive core API exposing some of the lower level integration functions from the Fortran side into the Python module.
Removed outdated JOSS paper draft rendering workflow and specific CI/CD action on push to optimize development processes.
Skipped building the Python 3.12 wheel for linux aarch64 in cibuildwheel due to missing h5py, addressing compatibility issues.
Modified the dependency build scripts to skip tests when building dependent libraries (namely HDF5, NetCDF-C, and NetCDF-Fortran) in order to speed up the wheel generation on github actions.
Documentation#
Updated development status and primary repository location to keep the community informed.
v2024.03.0#
New Features#
Incorporation of SHTOOLS for incorporating gravitational harmonics coefficients into the central body gravity field calculations.
Introduction of rotation matrix calculations for non-z-axis central body rotation vectors, supporting more accurate precession effects.
Enhancement of the netCDF output capabilities, including the addition of dimension-coordinates for c_lm arrays and support for spherical harmonics parameters.
Bug Fixes#
Fixed a bug that was causing the spin poles of massive bodies to be calculated incorrectly when pulling ephemerides from JPL/Horizons using :py:meth:swiftest.Simulation.add_solar_system_body.
Correction of various typos and minor bugs across the documentation and codebase, improving clarity and accuracy.
Fixing of floating underflow errors and adjustments to normalization calculations to reduce computational errors.
Documentation#
Major updates to user guides and API documentation.
Breaking changes#
Support for
python 3.8has been dropped and the minimum versions of some dependencies were changed.Package
Old
New
python
3.8
3.9
numpy
1.24.3
1.26.4
scipy
1.10.1
1.12.0
matplotlib
3.7.1
3.8.0
astropy
5.2
6.0.0
dask
2023.5
2024.2.1
distributed
2023.5
2024.2.1
h5netcdf
1.1
1.3.0
h5py
3.9
3.10.0
bottleneck
1.3.5
1.3.8
cython
3.0.0
3.0.8
tqdm
4.65
4.66.2
v2023.12.1#
Improvements to the documentation and documentation build process.
Docstrings in the Python project files have been formatted for better rendering and numerous small inconsistencies and errors have been corrected.
Restructured the project so that the Fortran code does not have to be compiled when generating documentation for swiftest.readthedocs.io.
Refactored many swiftest.io functions to indicate that they are not part of the public API.
Added a more comprehensive list of sections to the API page.
v2023.12.0#
Minor changes aimed at building a better set of documentation pages.
Created a new swiftest.readthedocs.io page
Added sphinx-based documentation for the Python side and FORD-based documentation for the Fortran side
Improved docstrings in simulation_class.py in order to conform to sphinx guidelines.
v2023.11.0#
Fixed a bug that was causing some runs to fail when there were no massive bodies in the system.
v2023.10.2#
Official release for the Journal of Open Source Software.
v2023.10.1#
Bug fixes to Fraggle and improvements to the fragmentation test movie scripts.
Fixed issue that caused momentum convergence to be unstable due to floating point precision.
Tweaked the fraggle convergence loop limits to get a higher success rate in fitting angular momentum and energy constraints.
Fixed a typo in an OpenMP reduction declaration in the subroutine swiftest_kick_getacch_int_all_tri_rad_pl
v2023.10.0#
Minor changes and one bugfix.
Changed the dependency build scripts from using Automake to CMake for performance and robustness.
Fixed bug that was preventing initial conditions file from being saved when new bodys are added in multiple add_solar_system_body calls
v2023.09.3 Pre-release#
This release will become the first full release of Swiftest. Any previous releases contained a major bug that resulted in incorrect G*Mass values being used for bodies pulled from JPL Horizons. As the code is still undergoing review and testing, this will be set as a pre-release.