Skip to main content

Display and fit Optical (spectro-)Interferometric OIFITS data

Project description

banner

Python numpy scipy astropy matplotlib

Overview

PMOIRED is a Python3 module which allows to model astronomical spectro-interferometric data stored in the OIFITS format (Duvert et al. 2017). Parametric modeling is used to describe the observed scene as blocks such as disks, rings and Gaussians which can be combined and their parameters linked. It includes plotting, least-square fitting and bootstrapping estimation of uncertainties. For spectroscopic instruments (such as GRAVITY), tools are provided to model spectral lines and correct spectra for telluric lines.

The modelling of data is based on several principles:

  • The model is composed of a combination of basic building blocks (see the model definition notebook)
  • Simple building blocks include uniform disks, uniform rings, Gaussians.
  • Building blocks can be deformed (analytically), including stretched in one preferred direction, or slanted. This can efficiently simulate inclined components.
  • More complicated blocks are available, such as disks/rings with arbitrary radial profile, and possibility to include azimuthal intensity variations.
  • Each component has a spectrum, including modelling of emission or absorption lines (Gaussian or Lorentzian)
  • In order for the computation to be fast (a requirement to perform data fitting), basic blocks have analytical or semi-analytical complex visibilities. Moreover, for the same reason, their spectral component is independent of the geometry.

The principles are close to tools such as LITpro. However, PMOIRED offers additional features:

  • Modelling in the spectral dimension. For this reason, it contains a module to do basic telluric correction (only for VLTI/GRAVITY at the moment)
  • Models' parameters can be expressed a function of each others, which allows to build complex geometrical shapes: astronomical realistic models can be build this way, without compromising on execution speed.
  • Uncertainties can be estimated using bootstrapping (data resampling by date+telescope) to mitigate the effects of correlations between data.
  • The values of parameters can be explored using grid and or random search.
  • Synthetic data for VLTI array observations can be generated from data cubes.

diagramme

Install

Install with pip

PMOIRED is regularly pushed to PyPI at https://pypi.org/project/pmoired/ so you can install directly using pip, by typing:

pip3 install pmoired

Install with git

The Github version is the most up-to-date. To install from the github repository directly:

pip3 install git+https://github.com/amerand/PMOIRED

you can also clone the repository and install with pip:

git clone https://github.com/amerand/PMOIRED
cd PMOIRED
pip3 install .

Install in an environment and run the model definition notebook

python3 -m venv _pmoired
source _pmoired/bin/activate
pip3 install git+https://github.com/amerand/PMOIRED jupyterlab
jupyter-lab _pmoired/lib/python*/site-packages/pmoired/Model\ definitions\ and\ examples.ipynb
deactivate

Uninstall

To uninstall (works for both PyPI and github versions):

pip3 uninstall pmoired

Examples and tutorials

This repository comes with a Jupyter Notebook showing basic model syntax.

Full examples, how to load real data and analyse them, are available in a separate repository: PMOIRED_examples. These examples are Jupyter Notebooks reproducing published results with other tools, and serve both as tutorials and verification of PMOIRED. They cover most of the features of PMOIRED, from the basics to more advanced operations.

Using and quoting PMOIRED

References to PMOIRED should point to the 2022 SPIE Telescopes+Instrumentation conference proceeding paper.

This code is a research project in continuous development and not yet properly fully documented. If you want to get the best analysis for your data, do not hesitate to contact me: I try to be responsive, in particular with junior scientists. New features are driven by collaborations: if you think PMOIRED is missing something, definitely contact me!

I maintain a list of works published using PMOIRED in a curated bibliography.

I used to to request co-authorship on publications using PMOIRED (until Feb 2023): this is no longer the case, unless I contributed directly to the work in question

Limitations and known issues

Running a script in ipython hangs

PMOIRED uses the multiprocessing library to parallelise some computations (e.g. bootstrapping, grid search). This library has some issues if you run a script containing such computation is an interactive shell (using %run or run in ipython or Spyder). The provided examples as notebooks do not suffer from this problem. If you want to use PMOIRED in .py scripts you run in iPython, you should structure your .py script more or less as follow:

import pmoired
import matplotlib

matplotlib.interactive(True)
__spec__ = None
if __name__=='__main__':
    [code]

in iPython, you can now type %run myscript.py.

Dependencies

The latest version of PMOIRED has been tested on:

  • python 3.13.1
  • numpy 2.2.0 (need >2.0)
  • scipy 1.14.1
  • astropy 7.0.0
  • astroquery 0.4.7
  • matplotlib 4.3.3
  • jupyterlab 4.4.1

Acknowledgments

PMOIRED has received contributions from Akke Corporaal, Evgenia Koumpia and Robert Klement.

This project has received funding from the European Union’s Horizon 2020 research and innovation programme under grant agreement No 101004719.

EU ORP

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

pmoired-1.3.13.tar.gz (2.0 MB view details)

Uploaded Source

Built Distribution

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

pmoired-1.3.13-py3-none-any.whl (2.1 MB view details)

Uploaded Python 3

File details

Details for the file pmoired-1.3.13.tar.gz.

File metadata

  • Download URL: pmoired-1.3.13.tar.gz
  • Upload date:
  • Size: 2.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for pmoired-1.3.13.tar.gz
Algorithm Hash digest
SHA256 3da8310bceacf5e76560ffbca46432d7239c0768a6b95e5098fc5160fe7cb84c
MD5 86e925ee68d68eb0775c19d440889b65
BLAKE2b-256 0c7cdd104653e30023cb0641a5d1072ec78bf43950372d531cce22a23ef839fd

See more details on using hashes here.

File details

Details for the file pmoired-1.3.13-py3-none-any.whl.

File metadata

  • Download URL: pmoired-1.3.13-py3-none-any.whl
  • Upload date:
  • Size: 2.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for pmoired-1.3.13-py3-none-any.whl
Algorithm Hash digest
SHA256 d7ff87cef8d5a744dae07b5aa4c402541a140d5aaaad282cc7c195bde5af6e55
MD5 b621c65fc711205112ca0bac55eae2ee
BLAKE2b-256 3a02da2eb700edf81f7ba0d3b9684bf8b56c13586dad92ece9c573327dfcfd45

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