Skip to main content

1D relaxation Parker wind model with metal and X-ray physics based on Murray-Clay et al. (2009)

Project description

Wind-AE (BETA)

Wind-AE (/windy/) stands for "wind atmospheric escape" and is a relatively fast 1D, steady-state, hydrodynamic, non-isothermal, Parker wind relaxation code for modeling atmospheric escape based on Murray-Clay et al. (2009). Wind-AE is a forward model that solves the energy conservation, momentum conservation, and ionization equilibrium equations at the substellar point using the "Numerical Recipes in C" relaxation method. This allows Wind-AE to quickly compute the atmosphere mass loss rate as well as upper atmosphere (<~100 microbar) velocity, temperature, density, and ionization structure as a function of altitude.

Wind-AE updates Murray-Clay et al. (2009) to allow for the modeling of atomic metals and multifrequency XUV stellar spectra (Broome et al. submitted). If you use Wind-AE, please consider citing Broome et al. (in prep).

We appreciate your patience while the docs are developed. In the meantime, take advantage of Notebooks/Quickstart.ipynb to get a quick orientation to Wind-AE and please report any bugs via Github or via email to mabroome@ucsc.edu.

A rectangular badge, half black half purple containing the text made at Code Astro

Is Wind-AE the right tool for me?

Wind-AE is well-suited for users interested in quickly estimating mass loss rates or outflow structure. Outflow structure includes bulk temperature and per-species ionization fractions as a function of radius, so can be easily translated into approximating and predicting observables and transits, including metastable helium (He 10830$\AA$) transits, though a He transit module is not yet included. Precise modeling of lower atmosphere ($\lssim 100 \mu$bar) is considered necessary for highly accurate transit models, but Wind-AE can be easily coupled to lower atmosphere photochemistry models whose outputs can (e.g., radius, temperature, abundances, ionization fractions, etc. at 1 $\mu$bar) can be fed into Wind-AE as inputs.

If you are interested in outflow structure: Past the Coriolis turning radius (a few planetary radii) 3D physics dominates, so Wind-AE does not integrate past that point. Wind-AE also makes simplifying assumptions about the region below the region below the wind-launch radius (~10 nanobars).

Because Wind-AE runs on the order of seconds to minutes, it can be (and has been) used to model planet evolution.

Wind-AE can model:

  • Multiple atomic species
  • X-ray physics (secondary ionizations and K-shell ionization cross-sections for relevant metals)
  • Both low and high stellar XUV flux
  • Heating & Cooling: Ionization heating, bolometric heating & cooling (negligible in wind), PdV cooling (work done due to expansion of gas), radiative / atomic line cooling (Lyman-$\alpha$, OI, OII, OIII, CI, CII), recombination cooling

Wind-AE does not (currently) include:

  • Magnetic fields

  • Time dependence

  • Diffusion/drag - the atomic species set by the user are assumed to be entrained in the outflow and in thermal equilibrium. This is an appropriate assumption for species below the crossover mass and a warning will be raised.

  • Heating & Cooling: Conduction (warning raised if relevant, planned), H3+ line cooling (not planned), Fe & Ca line cooling (relevant at high Z only, planned), free-free cooling (warning raised if relevant, not planned)

  • Multiple ionization states of the same species (planned) See Broome et al. (submitted) for more details.

  • Want a rapid H/He model with power-law approximated XUV spectra? Check out ATES (Caldiroli et al. 2021)

  • Do you want to set the mass loss rate ($\dot{M}$) yourself or want an EUV isothermal Parker wind outflow model that runs in nanoseconds? Check out p-winds (Dos Santos et al. 2022).

  • Do you want to use p-winds and get transit models for metals via Cloudy? Check out Sunbather (Linssen et al. 2024)

  • Want to leverage Cloudy and the hydrodynamic code PLUTO for more thorough XUV-irradiated, but slightly more expensive calculations? Check out TPCI (Salz et al. 2015)

  • That sound great, but you prefer to code in Python over C/C++? Check out pyTPCI Riley, Zhang, & Bean 2025

  • Do you care about diffusion throughout the wind? Check out AIOLIS (Schulik & Booth, 2022).

  • Want to model the lower atmosphere in more detail? Check out CETIMB (Koskinen et al. 2022)

  • Just want a grid of mass loss rates for pure-Hydrogen, low-flux-EUV-irradiated planets? See Kubyshkina & Fossati

  • Want a grid of mass loss rates for pure-Hydrogen, high-flux-XUV-irradiated planets? See Owen & Jackson (2012)

Want your model added to this list or to update the short bio? Email mabroome@ucsc.edu

Requirements

Wind-AE requires the following packages and will pip install them automatically by following the Installation guide below.

  • python
  • numpy
  • scipy
  • astropy
  • pandas>=2.2.3
  • matplotlib
  • datetime
  • pyarrow
  • fastparquet
  • requests
  • ChiantiPy

Installation

Compile from source (only available in beta)

Clone the repository using

git clone https://github.com/mibroome/wind-ae/

or navigate to github.com/mibroome/wind-ae/ and download and unzip the zip file.

Until Wind-AE is dockerized, it is recommended to use a Python environment to avoid dependency issues. However, if your system meets the above requirements, there is no need to create an environment and you can skip to the compilation step. To create an environment use either

python3 -m venv venv_name.venv
source venv_name.venv/bin/activate

or using conda

conda create -n venv_name
conda activate venv_name
conda install pip

To compile from the source,

pip install -r requirements.txt
pip install -e .

You can test the install by running

python -c "import wind_ae"

Now you can run Wind-AE from anywhere! As seen in the tutorial (Notebooks/Quickstart.ipynb), the following imports are helpful for most purposes.

from wind_ae.wrapper.relax_wrapper import wind_simulation as wind_sim
from wind_ae.wrapper.wrapper_utils.plots import energy_plot six_panel_plot quick_plot 
from wind_ae.wrapper.wrapper_utils import constants as const
from wind_ae.wrapper.wrapper_utils.system import system
from wind_ae.wrapper.wrapper_utils.spectrum import spectrum

Note: If you ever need to interface directly with the C code, it lives in wind_ae/src/ and can be excecuted from within the wind_ae/ folder via ./bin/relaxed_ae. The solution generated will be for a planet with the parameters detailed in the input files in the Inputs/ folder. There is generally no need to interface with the C code and most standard tasks can be accomplished by using the Python wrapper.

Future features and known problems

Check out the open issues.

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

wind_ae-0.3.1.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

wind_ae-0.3.1-py3-none-any.whl (1.2 MB view details)

Uploaded Python 3

File details

Details for the file wind_ae-0.3.1.tar.gz.

File metadata

  • Download URL: wind_ae-0.3.1.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.12

File hashes

Hashes for wind_ae-0.3.1.tar.gz
Algorithm Hash digest
SHA256 0289fbedf9b89b0c3475006c89a4e7322ec654c46768e49237d6fad6837f6191
MD5 9daaa216d49a13564750d86bb7f5ae60
BLAKE2b-256 e5e812c241795dfe053750aae37885d9182f6434b5cf8cbff6d13a700a0594ab

See more details on using hashes here.

File details

Details for the file wind_ae-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: wind_ae-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 1.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.12

File hashes

Hashes for wind_ae-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 297986c4c221efddec319a733367a6ecf31bec794c14b4d7204518bfbe02fc04
MD5 2d1762ef296cccc54756a2709f8aae26
BLAKE2b-256 a029cf83f3570fac1ad6b4d8eed11e931f00a8dfe3cb2b28468ab7a457ed62f9

See more details on using hashes here.

Supported by

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