An atmospheric chemistry box model. Powered by MUSICA.
Project description
acom_music_box (Python)
Python implementation of the MusicBox atmospheric chemistry box model, built on the MUSICA framework.
Installation
pip install acom_music_box
GPU Support
GPU-accelerated solving requires the NVIDIA PyPI index:
pip install --upgrade setuptools pip wheel
pip install nvidia-pyindex
pip install acom_music_box[gpu]
Quick Start
In-code mechanism
Define species, reactions, and initial conditions entirely in Python:
from acom_music_box import MusicBox, Conditions
import musica.mechanism_configuration as mc
# Define species
A = mc.Species(name="A")
B = mc.Species(name="B")
C = mc.Species(name="C")
gas = mc.Phase(name="gas", species=[A, B, C])
# Define reactions
arr1 = mc.Arrhenius(name="A->B", A=4.0e-3, C=50, reactants=[A], products=[B], gas_phase=gas)
arr2 = mc.Arrhenius(name="B->C", A=1.2e-4, B=2.5, C=75, D=50, E=0.5, reactants=[B], products=[C], gas_phase=gas)
mechanism = mc.Mechanism(name="example", species=[A, B, C], phases=[gas], reactions=[arr1, arr2])
# Create and configure the box model
box = MusicBox()
box.load_mechanism(mechanism)
box.initial_conditions = Conditions(
temperature=300.0,
pressure=101000.0,
species_concentrations={"A": 1.0, "B": 3.0, "C": 5.0},
)
# Optionally add evolving conditions at a specific time (seconds)
box.add_evolving_condition(300.0, Conditions(
temperature=290.0,
pressure=100200.0,
species_concentrations={"A": 1.0, "B": 3.0, "C": 10.0},
))
box.box_model_options.simulation_length = 20 # seconds
box.box_model_options.chem_step_time = 1 # seconds
box.box_model_options.output_step_time = 4 # seconds
df = box.solve()
print(df)
From a JSON configuration file
Load a music-box v1 JSON config from disk:
from acom_music_box import MusicBox
box = MusicBox()
box.readConditionsFromJson("my_config.json")
df = box.solve()
print(df)
Plotting results
import matplotlib.pyplot as plt
df.plot(
x='time.s',
y=['CONC.A.mol m-3', 'CONC.B.mol m-3', 'CONC.C.mol m-3'],
title='Concentration over time',
ylabel='Concentration (mol m-3)',
xlabel='Time (s)',
)
plt.show()
Command Line Tool
MusicBox includes a music_box CLI for running configurations and built-in examples.
music_box -h
Run a built-in example (output printed to terminal as CSV):
music_box -e Chapman
Save output to a file:
music_box -e Chapman -o output.csv
music_box -e Chapman -o output.nc # NetCDF format
music_box -e Analytical -o results.csv -o results.nc # multiple outputs
Run your own configuration:
music_box -c my_config.json
Plotting from the CLI
Plot species concentrations using matplotlib:
music_box -e Chapman -o output.csv --plot O1D
Plot multiple species groups:
music_box -e TS1 --plot O3 --plot PAN,HF
Change output units (default is mol m-3):
music_box -e TS1 --plot O3 --plot-output-unit ppb
Tool: waccmToMusicBox
This tool allows you to extract chemical species concentrations from WACCM or WRF-Chem model output and write them as MusicBox initial conditions. Use the built-in help to display all options including template configurations and multiple output formats:
waccmToMusicBox --help
You may specify a single point in space and date-time by passing single values to date, time, latitude, and longitude. Altitude defaults to the surface. You may also specify a rectangle or cube by specifying multiple values for latitude, longitude, and altitude. Use a lat-lon variable (PBLH) to bound the vertical dimension at a specific height. If you request two date-time pairs, the tool will create evolving conditions over time rather than initial conditions.
waccmToMusicBox --waccmDir "./sample_waccm_data" --date "20260208" --time "07:00" --latitude 3.1 --longitude 101.7 --verbose
waccmToMusicBox --wrfchemDir "./sample_waccm_data" --date "20250820" --time "08:00" --latitude 47.0,49.0 --longitude "'-123.0,-121.0'"
waccmToMusicBox uses MUSICA configuration file to create a list of common chemical species between MusicBox and WACCM or WRF-Chem. The default configuration file is in the ts1 example because that example has many species. Use the --template parameter to specify your own configuration file (usually my_config.json).
waccmToMusicBox --wrfchemDir ~/MusicBox/WRF-Chem/model-output --date 20250820,20250822 --time 18:00,05:00 --stride 3 --latitude 47.0,49.0 --longitude "'-123.0,-121.0'" --altitude surface,PBLH --template ./examples/ts1 --output evolving_conditions.csv --verbose
waccmToMusicBox --waccmDir ~/MusicBox/WACCM/model-output --date 20240301,20240304 --time 17:00,04:00 --latitude "'-4.0,-2.0'" --longitude 101.0,103.0 --altitude 567.8,4567.8 --template ./examples/ts1 --output conditions/evolving_conditions.csv --verbose -v
Development
Install as an editable package with dev dependencies:
pip install -e '.[dev]'
Run the test suite:
pytest
Run only unit or integration tests:
pytest python/tests/unit/
pytest python/tests/integration/
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file acom_music_box-3.0.2.tar.gz.
File metadata
- Download URL: acom_music_box-3.0.2.tar.gz
- Upload date:
- Size: 817.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4bc0e959e24bccab694558a1ba64e4ba106916299a6cacbb73b1379326384824
|
|
| MD5 |
9bf278389db93e6594d6c628f30c8ded
|
|
| BLAKE2b-256 |
29b74e6a82f444dbd05bffdf9bf951de81c71915b25b2ae713590965d0c2326f
|
Provenance
The following attestation bundles were made for acom_music_box-3.0.2.tar.gz:
Publisher:
publish-package.yml on NCAR/music-box
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
acom_music_box-3.0.2.tar.gz -
Subject digest:
4bc0e959e24bccab694558a1ba64e4ba106916299a6cacbb73b1379326384824 - Sigstore transparency entry: 1418592340
- Sigstore integration time:
-
Permalink:
NCAR/music-box@e80949007606253e4c0bf81f6401f243b44e063a -
Branch / Tag:
refs/tags/v3.0.2 - Owner: https://github.com/NCAR
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-package.yml@e80949007606253e4c0bf81f6401f243b44e063a -
Trigger Event:
release
-
Statement type:
File details
Details for the file acom_music_box-3.0.2-py3-none-any.whl.
File metadata
- Download URL: acom_music_box-3.0.2-py3-none-any.whl
- Upload date:
- Size: 91.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6595e8712044394faf07958509d387aff6596170767fd763d69de8d7f70dcc9c
|
|
| MD5 |
8996fe7cc784f9660a09c12a3f1a8842
|
|
| BLAKE2b-256 |
c4e9d469c465fcc28190fa85f6319fccbfd170165e2def0d630867c55e8717e9
|
Provenance
The following attestation bundles were made for acom_music_box-3.0.2-py3-none-any.whl:
Publisher:
publish-package.yml on NCAR/music-box
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
acom_music_box-3.0.2-py3-none-any.whl -
Subject digest:
6595e8712044394faf07958509d387aff6596170767fd763d69de8d7f70dcc9c - Sigstore transparency entry: 1418592449
- Sigstore integration time:
-
Permalink:
NCAR/music-box@e80949007606253e4c0bf81f6401f243b44e063a -
Branch / Tag:
refs/tags/v3.0.2 - Owner: https://github.com/NCAR
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-package.yml@e80949007606253e4c0bf81f6401f243b44e063a -
Trigger Event:
release
-
Statement type: