Source code for pyrfu.pyrf.t_eval
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Built-in imports
import bisect
# 3rd party imports
import numpy as np
import xarray as xr
__author__ = "Louis Richard"
__email__ = "louisr@irfu.se"
__copyright__ = "Copyright 2020-2023"
__license__ = "MIT"
__version__ = "2.4.2"
__status__ = "Prototype"
[docs]def t_eval(inp, times):
r"""Evaluates the input time series at the target time.
Parameters
----------
inp : xarray.DataArray
Time series if the input to evaluate.
times : ndarray
Times at which the input will be evaluated.
Returns
-------
out : xarray.DataArray
Time series of the input at times t.
"""
idx = np.zeros(len(times))
for i, time in enumerate(times):
idx[i] = bisect.bisect_left(inp.time.data, time)
idx = idx.astype(np.int64)
if inp.ndim == 2:
out = xr.DataArray(
inp.data[idx, :],
coords=[times, inp.comp],
dims=["time", "comp"],
)
else:
out = xr.DataArray(inp.data[idx], coords=[times], dims=["time"])
return out