Skip to main content

Archivable and exchangeable format for magnetotelluric data

Project description

MTH5

PyPi Version Conda Version MIT License Documentation Status

MTH5 is an HDF5 data container for magnetotelluric time series data, but could be extended to other data types. This package provides tools for reading/writing/manipulating MTH5 files.

MTH5 uses h5py to interact with the HDF5 file, xarray to interact with the data in a nice way, and all metadata use mt_metadata. This project is in cooperation with the Incorporated Research Institutes of Seismology, the U.S. Geological Survey, and other collaborators. Facilities of the IRIS Consortium are supported by the National Science Foundation’s Seismological Facilities for the Advancement of Geoscience (SAGE) Award under Cooperative Support Agreement EAR-1851048. USGS is partially funded through the Community for Data Integration and IMAGe through the Minerals Resources Program.

  • Version: 0.2.5
  • Free software: MIT license
  • Documentation: https://mth5.readthedocs.io.
  • Examples: Click the Binder badge above and Jupyter Notebook examples are in docs/examples/notebooks
  • Suggested Citation: Peacock, J. R., Kappler, K., Ronan, T., Heagy, L., Kelbert, A., Frassetto, A. (2022) MTH5: An archive and exchangeable data format for magnetotelluric time series data, Computers & Geoscience, 162, doi:10.1016/j.cageo.2022.105102

Features

  • Read and write HDF5 files formated for magnetotelluric time series.
  • From MTH5 a user can create an MTH5 file, get/add/remove stations, runs, channels and filters and all associated metadata.
  • Data is contained as an xarray which can house the data and metadata together, and data is indexed by time.
  • Readers for some data types are included as plugins, namely
    • Z3D
    • NIMS BIN
    • USGS ASCII
    • LEMI
    • StationXML + miniseed

Introduction

The goal of MTH5 is to provide a self describing heirarchical data format for working, sharing, and archiving. MTH5 was cooperatively developed with community input and follows logically how magnetotelluric data are collected. This module provides open-source tools to interact with an MTH5 file.

The metadata follows the standards proposed by the IRIS-PASSCAL MT Software working group and documented in MT Metadata Standards Note: If you would like to comment or contribute checkout Issues or Slack.

MTH5 Format

  • The basic format of MTH5 is illustrated below, where metadata is attached at each level.

MTH5 File Version 0.1.0

MTH5 Format version 0.1.0

MTH5 file version 0.1.0 was the original file version where Survey was the highest level of the file. This has some limitations in that only one Survey could be saved in a single file, but if you have mulitple Surveys that you would like to store we need to add a higher level Experiment.

Important: Some MTH5 0.1.0 files have already been archived on ScienceBase and has been used as the working format for Aurora and is here for reference. Moving forward the new format will be 0.2.0 as described below.

MTH5 File Version 0.2.0

MTH5 Format version 0.2.0

MTH5 file version 0.2.0 has Experiment as the top level. This allows for multiple Surveys to be included in a single file and therefore allows for more flexibility. For example if you would like to remote reference stations in a local survey with stations from a different survey collected at the same time you can have all those surveys and stations in the same file and make it easier for processing.

Hint: MTH5 is comprehensively logged, therefore if any problems arise you can always check the mth5_debug.log (if you are in debug mode, change the mode in the mth5.init) and the mth5_error.log, which will be written to your current working directory.

Examples

Make a simple MTH5 with one station, 2 runs, and 2 channels (version 0.2.0)

from mth5.mth5 import MTH5

mth5_object = MTH5()
mth5_object.open_mth5(r"/home/mt/example_mth5.h5", "a")

# add a survey
survey_group = mth5_object.add_survey("example")

# add a station with metadata
station_group = m.add_station("mt001", survey="example")
station_group = survey_group.stations_group.add_station("mt002")
station_group.metadata.location.latitude = "40:05:01"
station_group.metadata.location.longitude = -122.3432
station_group.metadata.location.elevation = 403.1
station_group.metadata.acquired_by.author = "me"
station_group.metadata.orientation.reference_frame = "geomagnetic"

# IMPORTANT: Must always use the write_metadata method when metadata is updated.
station_group.write_metadata()

# add runs
run_01 = m.add_run("mt002", "001", survey="example")
run_02 = station_group.add_run("002")

# add channels
ex = m.add_channel("mt002", "001", "ex", "electric", None, survey="example")
hy = run_01.add_channel("hy", "magnetic", None)

print(mth5_object)

/:
====================
    |- Group: Experiment
    --------------------
        |- Group: Reports
        -----------------
        |- Group: Standards
        -------------------
            --> Dataset: summary
            ......................
        |- Group: Surveys
        -----------------
            |- Group: example
            -----------------
                |- Group: Filters
                -----------------
                    |- Group: coefficient
                    ---------------------
                    |- Group: fap
                    -------------
                    |- Group: fir
                    -------------
                    |- Group: time_delay
                    --------------------
                    |- Group: zpk
                    -------------
                |- Group: Reports
                -----------------
                |- Group: Standards
                -------------------
                    --> Dataset: summary
                    ......................
                |- Group: Stations
                ------------------
                    |- Group: mt001
                    ---------------
                    |- Group: mt002
                    ---------------
                        |- Group: 001
                        -------------
                            --> Dataset: ex
                            .................
                            --> Dataset: hy
                            .................
                        |- Group: 002
                        -------------

Credits

This project is in cooperation with the Incorporated Research Institutes of Seismology, the U.S. Geological Survey, and other collaborators. Facilities of the IRIS Consortium are supported by the National Science Foundation’s Seismological Facilities for the Advancement of Geoscience (SAGE) Award under Cooperative Support Agreement EAR-1851048. USGS is partially funded through the Community for Data Integration and IMAGe through the Minerals Resources Program.

History

0.1.0 (2021-06-30)

  • First release on PyPI.

0.2.0 (2021-10-31)

  • Updated the structure of MTH5 to have Experiment as the top level
  • Updated tests
  • Backwards compatibility works
  • Updated Docs

0.2.5 (2022-04-07)

  • fixed bugs
  • Added TransferFunctions and TransferFunction groups at the station level that can now hold transfer functions
  • Added channel_summary and tf_summary tables that are updated upon close if the file is in 'w' mode
  • Updated tests
  • Updated documentation
  • Note: tests for make_mth5 from IRIS are currently not working as there has been some reorganization with data at the DMC

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

mth5-0.2.5.tar.gz (3.0 MB view details)

Uploaded Source

Built Distribution

mth5-0.2.5-py2.py3-none-any.whl (136.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file mth5-0.2.5.tar.gz.

File metadata

  • Download URL: mth5-0.2.5.tar.gz
  • Upload date:
  • Size: 3.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.7.11

File hashes

Hashes for mth5-0.2.5.tar.gz
Algorithm Hash digest
SHA256 a8934b9121f12d3c3ac218c3576a438cd39ca94c3ef6b5a034329de00464f003
MD5 1c90c6a8db6bb44e6a5e1cdff528472d
BLAKE2b-256 bbb5d397d266e603c16a7b89cd858c531ad3b66abbcbe8617ddc04fa78a4c921

See more details on using hashes here.

File details

Details for the file mth5-0.2.5-py2.py3-none-any.whl.

File metadata

  • Download URL: mth5-0.2.5-py2.py3-none-any.whl
  • Upload date:
  • Size: 136.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.7.11

File hashes

Hashes for mth5-0.2.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 70671f9894cfad64d1b49fcd44ab2f09725d9bc5d98d3b586901161111c227c4
MD5 6da285b0d7973f9c412ed6094785fa8b
BLAKE2b-256 2790570fe570cdcea8947e5548294a118110a0f23897be80b5a0b493e9902c48

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