Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/UCBerkeleySETI/blimpy
Breakthrough Listen I/O Methods for Python
https://github.com/UCBerkeleySETI/blimpy
Last synced: 2 months ago
JSON representation
Breakthrough Listen I/O Methods for Python
- Host: GitHub
- URL: https://github.com/UCBerkeleySETI/blimpy
- Owner: UCBerkeleySETI
- License: bsd-3-clause
- Created: 2016-06-15T19:42:52.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-11-18T14:55:22.000Z (about 2 years ago)
- Last Synced: 2024-10-01T09:25:49.645Z (3 months ago)
- Language: Python
- Homepage: https://blimpy.readthedocs.io
- Size: 6.13 MB
- Stars: 46
- Watchers: 15
- Forks: 40
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- frbsoft - GitHub - 7% open · ⏱️ 18.11.2022): (Data Read and Write Packages)
README
[![Build Status](https://github.com/UCBerkeleySETI/blimpy/workflows/Test%20Blimpy/badge.svg)](https://github.com/UCBerkeleySETI/blimpy/actions)
[![Documentation Status](https://readthedocs.org/projects/blimpy/badge/?version=latest)](https://blimpy.readthedocs.io/en/latest/?badge=latest)
[![codecov](https://codecov.io/gh/UCBerkeleySETI/blimpy/branch/master/graph/badge.svg)](https://codecov.io/gh/UCBerkeleySETI/blimpy)
[![JOSS status](http://joss.theoj.org/papers/e58ef21f0a924041bf9438fd75f8aed0/status.svg)](http://joss.theoj.org/papers/e58ef21f0a924041bf9438fd75f8aed0)## Breakthrough Listen I/O Methods for Python.
### Filterbank + Raw file readers
This repository contains Python 2/3 readers for interacting with [Sigproc filterbank](http://sigproc.sourceforge.net/sigproc.pdf) (.fil), HDF5 (.h5) and [guppi raw](https://baseband.readthedocs.io/en/stable/guppi/) (.raw) files,
as used in the [Breakthrough Listen](https://seti.berkeley.edu) search for intelligent life.### Installation
#### System Dependencies
Sometimes the `pip` installation can fail if a system dependency is not installed. To fix this, make sure you have `curl` and install the required system dependencies with the command bellow:##### Debian/Ubuntu
```
curl https://raw.githubusercontent.com/UCBerkeleySETI/blimpy/master/dependencies.txt | xargs -n 1 sudo apt install --no-install-recommends -y
```#### Manual Installation
The latest release can be installed via pip directly from this repository:
```
python3 -m pip install -U git+https://github.com/UCBerkeleySETI/blimpy
```Or, the latest version of the development code can be installed from the github [repo](https://github.com/UCBerkeleySETI/blimpy) and then run `python setup.py install` or `pip install .` (with sudo if required), or by using the following terminal command:
```
python3 -m pip install -U https://github.com/UCBerkeleySETI/blimpy/tarball/master
```To install everything required to run the unit tests, run:
```
python3 -m pip install -e .[full]
```You will need `numpy`, `h5py`, `astropy`, `scipy`, and `matplotlib` as dependencies. A `pip install` should pull in numpy, h5py, and astropy, but you may still need to install scipy and matplotlib separately.
To interact with compressed files, you'll need the `hdf5plugin` package too.Note that h5py generally needs to be installed in this way:
```
$ python3 -m pip install --no-binary=h5py h5py
```### Command line utilities
After installation, the following command will display the metadata (header) values and some information about the data matrix:
`watutil -i`
Other command line utilities available post-installation:
* `bl_scrunch`, Scrunch an HDF5 file (.h5) or a Sigproc Filterbank file (.fil) to an output HDF5 file. This has the effect of down-sampling adjacent fine frequency cells.
* `bldice`, Extract a smaller frequency region from a Filterbank file (.fil or .h5 file).
* `calcload`, Calculate the Waterfall max_load value needed to load the entire data array for a given Filterbank file.
* `dsamp`, Down-sample (time-dimension only) from one Filterbank file to another.
* `fil2h5`, Convert a .fil file into .h5 format.
* `h52fil`, Convert an .h5 file into .fil format.
* `peek`, Display a selected portion of values from the data matrix of a Filterbank file.
* `rawhdr`, Display the header fields of a raw guppi file.
* `rawutil`, Plot data in a guppi raw file.
* `srcname`, Patch the header source_name field in a .h5 file.
* `stax`, For a collection of .h5 or .fil files sharing the same frequency range, create a vertical stack of waterfall plots as a single PNG file.
* `stix`, For a single very large Filterbank file, create a horizontal or vertical stack of waterfall plots as a single PNG file.
* `watutil`, Information/read/write/plot utility for Filterbank files.Use the `-h` flag to any of the above command line utilities to display their available arguments.
### Reading blimpy filterbank files in .fil or .h5 format
The `blimpy.Waterfall` provides a Python API for interacting with filterbank data. It supports all BL filterbank data products; see this [example Jupyter notebook](https://github.com/UCBerkeleySETI/blimpy/blob/master/examples/voyager.ipynb) for an overview.
From the python, ipython or jupiter notebook environments.
```python
from blimpy import Waterfall
fb = Waterfall('/path/to/filterbank.fil')
#fb = Waterfall('/path/to/filterbank.h5') #works the same way
fb.info()
data = fb.data
```### Reading guppi raw files
The [Guppi Raw format](https://github.com/UCBerkeleySETI/breakthrough/blob/master/doc/RAW-File-Format.md) can be read using the `GuppiRaw` class from `guppi.py`:```python
from blimpy import GuppiRaw
gr = GuppiRaw('/path/to/guppirawfile.raw')header, data = gr.read_next_data_block()
```or
```python
from blimpy import GuppiRaw
gr = GuppiRaw('/path/to/guppirawfile.raw')for header, data_x, data_y in gr.get_data():
# process data
```Note: most users should start analysis with filterbank files, which are smaller in size and have been generated from the guppi raw files.
### Using blimpy inside Docker
The blimpy images are pushed to a public repository after each successful build on Travis.
If you have Docker installed, you can run the following commands to pull our images, which have the environment and dependencies set up for you.`docker pull fx196/blimpy:py3_kern_stable`
Here is a [more complete guide](./docker_guide.md) on using blimpy in Docker.
### Further reading
A detailed overview of the data formats used in Breakthrough Listen can be found in our [data format paper](https://ui.adsabs.harvard.edu/abs/2019arXiv190607391L/abstract). An archive of data files from the Breakthrough Listen program is provided at [seti.berkeley.edu/opendata](http://seti.berkeley.edu/opendata).
### If you have any requests or questions, please lets us know!