Simulator of Asteroid Malformation Under Stress, package designed for Taylor et al 2023 (link forthcoming). Questions on its use should be directed to astertaylor@uchicago.edu.
This code simulates the deformation of minor bodies, assuming that they are homogenous incompressible fluid masses. They are initialized as ellipsoids and the Navier-Stokes equations are interatively solved to investigate the deformation of the body over time. This package is highly modular, and allows for user-defined output functions, size, and trajectories.
SAMUS is structured as a single large class, which allows for variables to be stored and for arbitrary function calls. A single high-fidelity simulation run can be quite lengthy, and so this allows for ease of debugging and investigation. It utilizes Python3.8 and above, and depends on the numpy
, FEniCS
, DOLFIN
, UFL
, SciPy
, pandas
, quaternion
, and mpipy
packages.
Further description of SAMUS can be found in Taylor et al 2023 (found on the ArXiv here (LINK)) and in the in-line documentation.
NOTE: SAMUSv1.0.0 assumes that the object follows a body-frame fixed non-principal axis rotation, which is not fully physical. This rotation is primarily used to compute the deforming forces, but otherwise is unenforced. If complex rotation is necessary for your usecase, testing and potential modification are recommended.
Examples of SAMUS's use are given in the examples folder.
There are two primary methods of installing SAMUS:
- Install through the Python Package Index (PyPI):
pip install SAMUS
- Install the developer's version on GitHub:
git clone https://github.com/astertaylor/SAMUS
cd SAMUS
python setup.py install
(Note that this command may require asudo
instruction.)
setup.py: Setup file for the package.
LICENSE.txt: Text file containing the license for use of this code.
README.md: Markdown file with basic documentation.
SAMUSfig.jpg: JPG file with the flowchart shown below, for ease of understanding.
Folder containing the build documents. Auto-generated with pip.
Folder containing documentation and examples of use.
Folder containing package itself.
modelFile.py: Primary file, containing the SAMUS model class.
__init__.py: Initializing file for the package.Folder containing meshes for use by SAMUS. Users should not have to interact with this.
__init__.py: Initializing file for the subpackage.
3ball.geo: GMSH file which contains the simple spherical mesh. Used to create the various improvements.
3ball?.msh: GMSH file containing the mesh, which has undergone ? refinements by splitting.
3ball?.xml: xml file containing the mesh, which has undergone ? refinements by splitting.Folder containing scripts for testing
SAMUS
and the discretizations it uses.__init__.py: Initializing file for the subpackage.
example_traj.csv: csv file with simple, short trajectory information, for use in validations.
example_traj.txt: txt file with simple, short trajectory information, for use in validations.
hyperbolic_traj.csv: csv file with hyperbolic trajectory information, for use in validations.
hyperbolic_traj.txt: txt file with hyperbolic trajectory information, for use in validations.
mesh_validation.py: Python script which runs simulations, validating the use of the lowest-refined mesh via doubling test.
modularity_example.py: Python script which runs simulations and demonstrates the modular use of SAMUS.
trajectory_jump_validation.py: Python script which validates the use of the trajectory jump method via doubling test.
euler_step_validation.py: Python script which validates the use of Euler finite-difference time steps via a doubling test.Folder containing the outputs from these testing simulations.
coarse_mesh_7.txt: Running log from a coarse-mesh run, run by mesh_validation.py.
Outputs_coarse_mesh_7.csv: Output log from from a coarse-mesh run, run by mesh_validation.py.
finer_mesh_7.txt: Running log from a finer-mesh run, run by mesh_validation.py.
Outputs_finer_mesh_7.csv: Output log from from a finer-mesh run, run by mesh_validation.py. Compare this file to Outputs_coarse_mesh_7.csv to demonstrate that the mesh usage is validated.
standard_tolerance_7.txt: Running log from a standard-tolerance run, run by trajectory_jump_validation.py.
Outputs_standard_tolerance_7.csv: Output log from from a standard-tolerance run, run by trajectory_jump_validation.py.
halved_tolerance_7.txt: Running log from a halved-tolerance run, run by trajectory_jump_validation.py.
Outputs_halved_tolerance_7.csv: Output log from from a halved-tolerance run, run by trajectory_jump_validation.py. Compare this file to Outputs_standard_tolerance_7.csv to demonstrate that the trajectory jump usage is validated.
standard_timestep_7.txt: Running log from a standard-timestep run, run by euler_step_validation.py.
Outputs_standard_timestep_7.csv: Output log from from a standard-tolerance run, run by euler_step_validation.py.
doubled_timestep_7.txt: Running log from a double-timestep run, run by euler_step_validation.py.
Outputs_doubled_timestep_7.csv: Output log from from a double-timestep run, run by euler_step_validation.py. Compare this file to Outputs_standard_timestep_7.csv to demonstrate that the usage of a Euler finite-difference timestep is validated.Folder containing examples of
SAMUS
's use. There are .ipynb and .py files for both examples. The .ipynb files have greater documentation, and the.py
files are more efficient to run.__init__.py: Initializing file for the subpackage.
example_traj.csv: .csv file with simple, short trajectory information, for use in validations.
example_traj.txt: .txt file with simple, short trajectory information, for use in validations.
Basic_Usage_Example.ipynb: A Jupyter Notebook file with a very basic example ofSAMUS
's use. This file has relatively extensive documentation, and should be used to gain greater understanding of howSAMUS
works.
basic_usage_example.py: A Python script with a very basic example ofSAMUS
's use. This file should be run by the learner, as it is capable of being run withmpirun
and runs significantly faster than the corresponding .ipynb file.
Modularity_Example.ipynb: A Jupyter Notebook file with an example ofSAMUS
's modular functionalities. This file has relatively extensive documentation, and should be used to gain greater understanding of howSAMUS
works.
modularity_example.py: A Python script with an example ofSAMUS
's modular functionalities. This file should be run by the learner, as it is capable of being run withmpirun
and runs significantly faster than the corresponding .ipynb file.Folder containing the outputs from these example simulations.
basic_example_6.txt: Running log from the basic example, run by basic_usage_example.py.
Outputs_basic_example_6.csv: Output log from from the basic example, run by basic_usage_example.py.
modularity_example_6.txt: Running log from the basic example, run by modularity_example.py.
Outputs_modularity_example_6.csv: Output log from from the basic example, run by modularity_example.py.
Below is a flowchart demonstrating the basic use case of SAMUS, as laid out in the various example files.
Aster Taylor
astertaylor@uchicago.edu | aster.taylor8587@gmail.com
University of Chicago, Department of Astrophysics