Skip to main content

normalising Flow exoPlanet Parameter Inference Toolkyt

Project description

FlopPITy

normalizing Flow exoplanet Parameter Inference Toolkyt

FlopPITy allows the user to easily perform atmospheric retrievals using SNPE-C (citation) and neural spline flows (citation).

Installation guide

Currently FlopPITy doesn't work with python 3.13

$ conda create -n floppity_env python==3.12.9
$ conda activate floppity_env
$ pip install floppity

Basic usage:

  • First, import FlopPITy:
from floppity import Retrieval
from floppity.simulators import read_ARCiS_input, ARCiS
  • Now you can initialize the retrieval class with a simulator. A python wrapper for ARCiS comes built-in (you need to install ARCiS on your own tho):
R = Retrieval(ARCiS)
  • Read in observations and define parameters to retrieve:
R.get_obs(['path/to/obs_0', 'path/to/obs_1',..., 'path/to/obs_n'])
    
R.add_parameter(par_0, min, max)
R.add_parameter(par_1, min, max)
...
R.add_parameter(par_m, min, max)
  • For ARCiS, the observations and parameters can be read from the ARCiS input file:
pars, obs_list = read_ARCiS_input('path/to/ARCiS/input')
R.get_obs(obs_list)
R.parameters=pars
  • For retrievals using ARCiS, the input file and output directory need to be passed in a dictionary:
ARCiS_kwargs= dict(
                    ARCiS_dir = "/path/to/ARCiS/executable", #only needs to be set if ARCiS is not on the default path
                    input_file = arcis_input,
                    output_dir = 'path/to/output',
                  )
  • You can now run the retrieval, indicating the number of rounds and samples per round:
R.run_retrieval(n_rounds=10, n_samples=1000, simulator_kwargs=ARCiS_kwargs)
  • Great! You can now inspect your posterior:
fig = R.plot_corner()

Writing a simulator

Writing a simulator to work for FlopPITy is relatively straightforward. All that's needed is a function that takes in observations and parameters and returns spectra. The spectra need to be returned in a dictionary where each key represents each of the observations simulated (e.g. simulated[0] contains PRISM spectra and simulated[1] contains MIRI/LRS spectra):

def simulator(obs, parameters, **kwargs):
    wvl_0 = obs[0][:,0]
    wvl_1 = obs[1][:,0]
    ...
    wvl_n = obs[n][:,0]

    spectra={}
    spectra[0] = # array of shape (ndims, len(wvl_0))
    spectra[1] = # array of shape (ndims, len(wvl_1))
    ...
    spectra[n] = # array of shape (ndims, len(wvl_n))

    return spectra

Advanced options:

  • Additional post processing parameters (currently RV, vrot, offset and scaling) can be added, for example:
R.add_parameter('RV', -100, 100, post_process=True) # km/s

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

floppity-0.0.10.2.tar.gz (2.5 MB view details)

Uploaded Source

Built Distribution

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

floppity-0.0.10.2-py3-none-any.whl (69.7 kB view details)

Uploaded Python 3

File details

Details for the file floppity-0.0.10.2.tar.gz.

File metadata

  • Download URL: floppity-0.0.10.2.tar.gz
  • Upload date:
  • Size: 2.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.7

File hashes

Hashes for floppity-0.0.10.2.tar.gz
Algorithm Hash digest
SHA256 bf34e1766082f0e839e4d4838ac3ec99e249d88d5390089ef85fdb498f3566e1
MD5 a874536f2e3c754c9213f2a41b18987e
BLAKE2b-256 8f7aa4264feadcead2d2c825a9d85fe4e75f2519051d68e3e7c07f05f6f391cb

See more details on using hashes here.

File details

Details for the file floppity-0.0.10.2-py3-none-any.whl.

File metadata

  • Download URL: floppity-0.0.10.2-py3-none-any.whl
  • Upload date:
  • Size: 69.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.7

File hashes

Hashes for floppity-0.0.10.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7095ae8f046adbd5f07eafc9d42ea33ac95d7741b8c90908dc3d7690b4cafd82
MD5 424eeb3cb9d02f0a9bc81ef43e6f5e0f
BLAKE2b-256 a8074d86fe9ecb96e8217426f1c7f58712402603e16d1da82177b64c7674f174

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