Skip to main content

Calibration routines for EDGES data

Project description

Build Status codecov Code style: black Documentation Status

Calculate calibration coefficients for EDGES Calibration Observations

Installation

Download/clone the repo and do

pip install .

in the top-level directory (optionally add an -e for develop-mode). Preferably, do this in an isolated python/conda environment.

Usage

CLI

There is a very basic CLI set up for running a full calibration pipeline over a set of data. To use it, do

$ edges-cal run --help

Multiple options exist, but the only ones required are CONFIG and PATH. The first should point to a YAML configuration for the run, and the second should point to a directory in which exists S11, Resistance and Spectra folders. Thus:

$ edges-cal run ~/config.yaml .

will work if you are in such a directory.

The config.yaml consists of a set of parameters passed to edges_cal.CalibrationObservation. See its docstring for more details.

In addition, you can run a “term sweep” over a given calibration, iterating over number of Cterms and Wterms until some threshold is met. This uses the same configuration as edges-cal run, but you can pass a maximum number of C and W-terms, along with a threshold at which to stop the sweep (this is a threshold in absolute RMS over degrees of freedom). This will write out a Calibration file for the “best” set of parameters.

You can also create full Jupyter notebook reports (and convert them to PDF!) using the CLI. To get this to work, you must install edges-cal with pip install edges-cal[report]. Then you must do the following:

  1. Activate the environment you wish to use to generate the reports (usually conda activate edges)

  2. Run python -m ipykernel install --user --name edges --display-name "edges"

Note that in the second command, calling it “edges” is necessary (regardless of the name of your environment!).

Now you can run

$ edges-cal report PATH --config ~/config.yaml

(obviously there are other parameters – use edges-cal report --help for help). The PATH should again be a calibration observation directory. The config can be the same file as in edges-cal run, and is optional. By default, both a notebook and a PDF will be produced, in the outputs/ directory of the observation. You can turn off the PDF production with a -R flag.

Similarly, you can compare two observations as a report notebook with

$ edges-cal compare PATH COMPARE --config ~/config.yaml --config-cmp ~/config.yaml

This is intended to more easily show up what might be wrong in an observation, when compared to a “golden” observation, for example.

Using the Library

To import:

import edges_cal as ec

Most of the functionality is highly object-oriented, and objects exist for each kind of data/measurement. However, there is a container object for all of these, which manages them. Thus you will typically use

>>> calobs = ec.CalibrationObservation(path="path/to/top/level")

Several other options exist, and they have documentation that you can access interactively by using

>>> help(ec.CalibrationObservation)

The most relevant attributes are the (lazily-evaluated) calibration coefficient models:

>>> plt.plot(calobs.freq.freq, calobs.C1())

the various plotting routines, eg.

>>> calobs.plot_coefficients()

and the calibrate/decalibrate methods:

>>> calibrated_temp = calobs.calibrate("ambient")

Note that this final method can be applied to any LoadSpectrum – i.e. you can pass in field observations, or an antenna simulator.

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

edges_cal-5.2.0.tar.gz (29.4 MB view details)

Uploaded Source

Built Distribution

edges_cal-5.2.0-py2.py3-none-any.whl (1.5 MB view details)

Uploaded Python 2 Python 3

File details

Details for the file edges_cal-5.2.0.tar.gz.

File metadata

  • Download URL: edges_cal-5.2.0.tar.gz
  • Upload date:
  • Size: 29.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for edges_cal-5.2.0.tar.gz
Algorithm Hash digest
SHA256 a37a1a4aa86b5c5f7f4c3f940f2a4b3516c6b3766ef0e1e9ad31b2e4b7d4b6a4
MD5 96ed666baeae7e03fd7d3e0795495894
BLAKE2b-256 7e19c3ca61f389a0b48e3c8d4840828d995ce3e7f9930fc706414c08898e94f6

See more details on using hashes here.

File details

Details for the file edges_cal-5.2.0-py2.py3-none-any.whl.

File metadata

  • Download URL: edges_cal-5.2.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 1.5 MB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.9.10

File hashes

Hashes for edges_cal-5.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8267e182a00383d5f2a06f04cf235505776460a1e736e48a3113fc54829ae92b
MD5 5de979c4aa47cffbb69401a658aad3bc
BLAKE2b-256 1500ec072c6eb47555a733f2a188d0bdb20fb94c0a165635c49b3b12815e13e5

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