Source code for pyrfu.pyrf.calc_dt
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Built-in imports
from typing import Union
# 3rd party imports
import numpy as np
from xarray.core.dataarray import DataArray
from xarray.core.dataset import Dataset
__author__ = "Louis Richard"
__email__ = "louisr@irfu.se"
__copyright__ = "Copyright 2020-2024"
__license__ = "MIT"
__version__ = "2.4.13"
__status__ = "Prototype"
[docs]def calc_dt(inp: Union[Dataset, DataArray]) -> float:
r"""Compute time step of the input time series.
Parameters
----------
inp : DataArray or Dataset
Time series of the input variable.
Returns
-------
float
Time step in seconds.
"""
# Check input type
if not isinstance(inp, (Dataset, DataArray)):
raise TypeError("Input must be a time series")
# Convert time to nanoseconds
time_datetime64 = inp.time.data.astype(np.datetime64)
time_ns = time_datetime64.astype(np.int64)
# Calculate the sampling frequency
dt_s = 1e-9 * np.median(np.diff(time_ns))
return dt_s