Skip to main content

Package for generating initial conditions for AREPO

Project description

PyPI package version number

arepoICgen

Package for creating Initial Conditions for the AMR code AREPO[^1] for simulations of molecular clouds intended for scientific research. Many parts of this code are adapted from a FORTRAN code developed by Paul Clark called setpartarepo.

This code is available via a direct clone of this repository, or through pip: pip install arepoICgen

Usage Guide

arepoICgen takes in two python dictionaries as inputs, config and params. Config provides the code information about the geometry and metadata of the cloud, while params supplies the physical parameters of the cloud. Some config and param flags are required, and others are optional. Required flags will be marked with a "*".

Config
Flag Options Description Associated Params
verbose True, False Whether to print extended feedback as the code runs (does not affect the ICs)
grid* boxGrid, boxRan, sphereGrid, sphereRan, ellipseRan, cylinderRan The geometry and particle distribution (gridded or random). lengths, radii
turbulence turbFile Whether to apply to turbulent velocity field from a file virialParam
turbFile path_to_file The path to a turbulent velocity grid file, needed only for turbFile
turbSize integer The size of the velocity grid (assumed equal length cubic), needed only for turbFile
rotation rotation Whether to add rotation to the cloud beta
extras bossBodenheimer, densityGradient What density perturbation to add to the cloud, either Boss Bodenheimer[^2] or a linear density gradient[^3]
padding* True, False Whether to pad the cloud with low density particles tempFactor, boxDims, paddingDensity
bField True, False Whether we need to give the particles an inital magnetic field value (note this does not do anything besides gives particles an initial B field of 0)
outValue masses, density Option to output the mass field as density (note this needs AREPO to be compiled with the right config flag for this) density
output* hdf5 Filetype to write the ICs as (type 2 binary coming... one day)
filename* "..." Name of the IC file (note that the file extension is not needed)
Params

Note that lengths and radii are both marked as required, but only one may be needed in some cases.

Flag Format/Units Description Associated Config
ngas* Number of particles to populate the cloud with
lengths* [xLength, yLength, zLength] $\rm [pc]$ The length of the box or ellipse in each direction (for the cylinder, xLength is taken as the length of the cylinder) grid
radii* Radius $\rm [pc]$ The radius of a spherical cloud, or the radius of the face of a cylinder (not needed by box or elliptical setups) grid
mass* $\rm [M_\odot]$ The total mass of the cloud
temp* $\rm [K]$ The inital temperature of the gas inside the cloud
mu* $\mu$ The mean molecular weight of the gas in the cloud, typically 1.4 for atomic and 2.4 for molecular
virialParam $\alpha = \rm\frac{E_{Kin}}{E_{Grav}}$ The virial parameter of the cloud, used for scaling turbulent velocities turbulence
beta $\beta = \rm \frac{E_{Rot}}{E_{Grav}}$ The ratio between rotational and gravitational energy rotation
boxSize [x, y, z] The factor by which the box should be larger than the cloud in each dimension (i.e 2x, 3x, 4x the size) padding
tempFactor How much hotter to make the padding particles compared to the cloud particles padding
paddingDensity % What percent of the cloud's density should the padding region be padding
density $\rm cm^{-3}$ Density to give particles when outputting mass as density outValue

Calling generateICs

arepoICgen is called using code similar to the following, where it is wrapped in the generateICs function:

from arepoICgen import generateICs

config = {}
params = {}

generateICs(config, params)
Examples

See examples.txt for some example setups of the config and params dictionaries.

[^1]: AREPO is publicly available, see here [^2]: See Boss & Bodenheimer (1979) [^3]: See Bonnell et al. (2008)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

arepoicgen-0.1.2.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

arepoICgen-0.1.2-py3-none-any.whl (16.3 kB view details)

Uploaded Python 3

File details

Details for the file arepoicgen-0.1.2.tar.gz.

File metadata

  • Download URL: arepoicgen-0.1.2.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.9.19

File hashes

Hashes for arepoicgen-0.1.2.tar.gz
Algorithm Hash digest
SHA256 60c25739ec8955a8c9431216d80237f240d6d2e4ccedd377c9b01ff99a52299d
MD5 aeb8759e38a69a7db5ab1addd5d7eb60
BLAKE2b-256 a566880e4eceb48e31e7e6857480ac8c5c0e0e9ac00c02df9cfd22573893d212

See more details on using hashes here.

File details

Details for the file arepoICgen-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: arepoICgen-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 16.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.9.19

File hashes

Hashes for arepoICgen-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6d128d2d6c21853ea5c145004c3d972bce8e93088e46250b5618699f4242beea
MD5 3831492825a9d4c4065e34dc174efffc
BLAKE2b-256 f3bb246d22bee874b75d50bea4df3ce21d6c926174abdc2794c75fd213c229b0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page