Source code for geoh5py.objects.surveys.electromagnetics.magnetotellurics
# ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
# Copyright (c) 2025 Mira Geoscience Ltd. '
# '
# This file is part of geoh5py. '
# '
# geoh5py is free software: you can redistribute it and/or modify '
# it under the terms of the GNU Lesser General Public License as published by '
# the Free Software Foundation, either version 3 of the License, or '
# (at your option) any later version. '
# '
# geoh5py is distributed in the hope that it will be useful, '
# but WITHOUT ANY WARRANTY; without even the implied warranty of '
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the '
# GNU Lesser General Public License for more details. '
# '
# You should have received a copy of the GNU Lesser General Public License '
# along with geoh5py. If not, see <https://www.gnu.org/licenses/>. '
# ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
from __future__ import annotations
import uuid
import numpy as np
from geoh5py.data import IntegerData, ReferencedData
from geoh5py.objects.points import Points
from .base import FEMSurvey
[docs]
class MTReceivers(FEMSurvey, Points):
"""
A magnetotellurics survey object.
"""
_TYPE_UID = uuid.UUID("{b99bd6e5-4fe1-45a5-bd2f-75fc31f91b38}")
__TYPE = "Receivers"
__INPUT_TYPE = ["Rx only"]
_default_name = "Magnetotellurics rx"
@property
def default_input_types(self) -> list[str]:
"""Choice of survey creation types."""
return self.__INPUT_TYPE
@property
def default_metadata(self) -> dict:
"""
:return: Default unique identifier
"""
return {
"EM Dataset": {
"Channels": [],
"Input type": "Rx only",
"Property groups": [],
"Receivers": None,
"Survey type": "Magnetotellurics",
"Unit": "Hertz (Hz)",
}
}
@property
def default_receiver_type(self):
"""
:return: Transmitter class
"""
return MTReceivers
@property
def default_transmitter_type(self):
"""
:return: Transmitter class
"""
return type(None)
@property
def base_receiver_type(self):
return Points
@property
def base_transmitter_type(self):
return type(None)
@property
def type(self):
"""Survey element type"""
return self.__TYPE
@property
def tx_id_property(self) -> ReferencedData | IntegerData | None:
"""
Data link between the receiver and transmitter object.
"""
return None
@tx_id_property.setter
def tx_id_property(self, value: uuid.UUID | ReferencedData | np.ndarray | None):
raise NotImplementedError(
"Transmitter property not available for magnetotellurics"
)