Skip to main content

An interface layer for scripting the AMI-Reduce pipeline.

Project description

A python package for scripting the AMI-reduce pipeline.

For a full description, see Staley and Anderson (in prep). If you use drive-ami in work leading to a publication, we ask that you cite the paper above, and the relevant ASCL entry.

Rationale

From a radio astronomy point of view:

This package makes it trivial to script reduction of raw AMI data from python. What’s more, it provides tools to group the raw files into datasets, outputting the UVFITS for each dataset under a single folder. It does this by extracting the pointing information from the raw data, resulting in fairly reliable groupings (although you can edit these manually, see later).

When processing the data, all output from reduce is saved to an accompanying log-file, retaining all information that would normally be available to the user from the interactive interface. Meanwhile, all emulated commands passed to reduce are recorded in a separate log for each file processed, so it’s easy to re-run the script manually and tinker with the reduction process.

Additionally, when running commands listed in a script the interface quietly parses key information such as flagging percentages, rain modulation, and estimated noise, from the reduce output. These are then stored to disk alongside the UVFITs in easily machine readable JSON format. (These may also be added to the UVFITS header in future.)

From a software engineering point of view:

Written in Fortran, with an interactive terminal interface, the reduce pipeline takes a little coaxing to co-operate with calling scripts, making automated processing of large numbers of files tricky. Fortunately, the python library pexpect provides an easy mechanism to emulate human interaction, upon which I’ve built an interface class. Limitations such as a maximum path length of ~32 chars are circumvented with a few careful hacks. The python logging libraries then allow us provide the user with minimal progress information, whilst retaining all possible information for debugging and scientific evaluation.

Installation

Requirements:
  • You will need a working installation of AMI-reduce (naturally)

  • pexpect For interfacing with AMI-reduce. (Installed automatically as part of the python setup.)

  • astropy Used for calculating co-ordinate distances, etc. (Installed automatically as part of the python setup.)

From the command line (preferably within a virtualenv):

git clone git://github.com/timstaley/drive-ami.git
cd drive-ami
pip install numpy #Workaround for buggy scipy/numpy combined install.
pip install .

Usage

Command-line scripts are installed along with the package. Their sourcefiles can be found at https://github.com/timstaley/drive-ami/tree/master/bin. For full details, run e.g.:

driveami_list_rawfiles.py -h

Where -h is short for ‘help’.

Typical usage is to run driveami_list_rawfiles.py to build a full listing of available data, followed by driveami_filter_rawfile_listing.py to extract the entries on a desired target. Finally, driveami_calibrate_rawfiles.py actually does the processing using AMI-REDUCE.

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

drive-ami-1.0.4.tar.gz (30.3 kB view details)

Uploaded Source

File details

Details for the file drive-ami-1.0.4.tar.gz.

File metadata

  • Download URL: drive-ami-1.0.4.tar.gz
  • Upload date:
  • Size: 30.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for drive-ami-1.0.4.tar.gz
Algorithm Hash digest
SHA256 8648377fbafd24eb8aecf38c14ee51c85db1a5a0a255113f0b9847edd12e058e
MD5 8570770f982ff6cbb4aed9d0a4b4ea0a
BLAKE2b-256 2f2482724ec8fc655746926218d9ba9df7f2a93770dc22bb4cc042cdf8435040

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