digital-rf


Namedigital-rf JSON
Version 2.6.9 PyPI version JSON
download
home_pagehttps://github.com/MITHaystack/digital_rf
SummaryPython tools to read/write Digital RF data in HDF5 format
upload_time2024-05-23 22:25:10
maintainerNone
docs_urlNone
authorMIT Haystack Observatory
requires_pythonNone
licenseBSD-3-Clause
keywords hdf5 radio rf
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            The Digital RF project encompasses a standardized HDF5 format for reading and writing of radio frequency data and the software for doing so. The format is designed to be self-documenting for data archive and to allow rapid random access for data processing.

This package includes:

* ``digital_rf`` Python package
* Tools for managing and processing Digital RF data
* ``gr_digital_rf`` Python package for interfacing with GNU Radio
* GNU Radio Companion blocks
* ``thor.py`` UHD radio recorder script
* Example scripts and applications

Digital RF C and MATLAB libraries can be found at the `official source code repository <https://github.com/MITHaystack/digital_rf>`_. To build from source, you must have the HDF5 library and headers installed.

For help and/or questions, contact the `user mailing list <openradar-users@openradar.org>`_.


GNU Radio Configuration
=======================

If you plan on using Digital RF with GNU Radio, make sure to run the `pip` command in the same Python environment that your GNU Radio installation uses so that GNU Radio can find the packages. Depending on your GNU Radio installation, it may be necessary to add the Digital RF blocks to your GRC blocks path by creating or editing the GRC configuration file

:Unix (local): $HOME/.gnuradio/config.conf
:Windows (local): %APPDATA%/.gnuradio/config.conf
:Unix (global): /etc/gnuradio/conf.d/grc.conf
:Custom (global): {INSTALL_PREFIX}/etc/gnuradio/conf.d/grc.conf

to contain::

    [grc]
    local_blocks_path = {PIP_PREFIX}/share/gnuradio/grc/blocks

(replacing ``{PIP_PREFIX}`` with the pip installation prefix, "/usr/local" for example).


Example Usage
=============

The following code will load and read data located in a directory "/data/test".

Load the module and create a reader object::

    import digital_rf as drf
    do = drf.DigitalRFReader('/data/test')

List channels::

    do.get_channels()

Get data bounds for channel 'cha'::

    s, e = do.get_bounds('cha')

Read first 10 samples from channel 'cha'::

    data = do.read_vector(s, 10, 'cha')
            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/MITHaystack/digital_rf",
    "name": "digital-rf",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "hdf5 radio rf",
    "author": "MIT Haystack Observatory",
    "author_email": "openradar-developers@openradar.org",
    "download_url": "https://files.pythonhosted.org/packages/7b/91/4f1520fd0d8e5a60a19e51c6845a148e7dda5bb0f2a3eb97ddf6688f2617/digital_rf-2.6.9.tar.gz",
    "platform": null,
    "description": "The Digital RF project encompasses a standardized HDF5 format for reading and writing of radio frequency data and the software for doing so. The format is designed to be self-documenting for data archive and to allow rapid random access for data processing.\n\nThis package includes:\n\n* ``digital_rf`` Python package\n* Tools for managing and processing Digital RF data\n* ``gr_digital_rf`` Python package for interfacing with GNU Radio\n* GNU Radio Companion blocks\n* ``thor.py`` UHD radio recorder script\n* Example scripts and applications\n\nDigital RF C and MATLAB libraries can be found at the `official source code repository <https://github.com/MITHaystack/digital_rf>`_. To build from source, you must have the HDF5 library and headers installed.\n\nFor help and/or questions, contact the `user mailing list <openradar-users@openradar.org>`_.\n\n\nGNU Radio Configuration\n=======================\n\nIf you plan on using Digital RF with GNU Radio, make sure to run the `pip` command in the same Python environment that your GNU Radio installation uses so that GNU Radio can find the packages. Depending on your GNU Radio installation, it may be necessary to add the Digital RF blocks to your GRC blocks path by creating or editing the GRC configuration file\n\n:Unix (local): $HOME/.gnuradio/config.conf\n:Windows (local): %APPDATA%/.gnuradio/config.conf\n:Unix (global): /etc/gnuradio/conf.d/grc.conf\n:Custom (global): {INSTALL_PREFIX}/etc/gnuradio/conf.d/grc.conf\n\nto contain::\n\n    [grc]\n    local_blocks_path = {PIP_PREFIX}/share/gnuradio/grc/blocks\n\n(replacing ``{PIP_PREFIX}`` with the pip installation prefix, \"/usr/local\" for example).\n\n\nExample Usage\n=============\n\nThe following code will load and read data located in a directory \"/data/test\".\n\nLoad the module and create a reader object::\n\n    import digital_rf as drf\n    do = drf.DigitalRFReader('/data/test')\n\nList channels::\n\n    do.get_channels()\n\nGet data bounds for channel 'cha'::\n\n    s, e = do.get_bounds('cha')\n\nRead first 10 samples from channel 'cha'::\n\n    data = do.read_vector(s, 10, 'cha')",
    "bugtrack_url": null,
    "license": "BSD-3-Clause",
    "summary": "Python tools to read/write Digital RF data in HDF5 format",
    "version": "2.6.9",
    "project_urls": {
        "Homepage": "https://github.com/MITHaystack/digital_rf"
    },
    "split_keywords": [
        "hdf5",
        "radio",
        "rf"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "7b914f1520fd0d8e5a60a19e51c6845a148e7dda5bb0f2a3eb97ddf6688f2617",
                "md5": "7b6e792ebd7b7f510ec9aafa28686f08",
                "sha256": "61293e88bff5ad849ffe08b13665345a2eec2add3fa9891dcba80e9b9af48877"
            },
            "downloads": -1,
            "filename": "digital_rf-2.6.9.tar.gz",
            "has_sig": false,
            "md5_digest": "7b6e792ebd7b7f510ec9aafa28686f08",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 1221189,
            "upload_time": "2024-05-23T22:25:10",
            "upload_time_iso_8601": "2024-05-23T22:25:10.810865Z",
            "url": "https://files.pythonhosted.org/packages/7b/91/4f1520fd0d8e5a60a19e51c6845a148e7dda5bb0f2a3eb97ddf6688f2617/digital_rf-2.6.9.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-05-23 22:25:10",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "MITHaystack",
    "github_project": "digital_rf",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "circle": true,
    "lcname": "digital-rf"
}
        
Elapsed time: 0.26477s