Source code for pyrfu.pyrf.avg_4sc

#!/usr/bin/env python
# -*- coding: utf-8 -*-

# Built-in imports
from typing import Sequence

# 3rd party imports
import numpy as np
import xarray as xr
from xarray.core.dataarray import DataArray

# Local imports
from pyrfu.pyrf.calc_fs import calc_fs
from pyrfu.pyrf.resample import resample

__author__ = "Louis Richard"
__email__ = "louisr@irfu.se"
__copyright__ = "Copyright 2020-2024"
__license__ = "MIT"
__version__ = "2.4.13"
__status__ = "Prototype"


[docs]def avg_4sc(b_list: Sequence[DataArray]) -> DataArray: r"""Computes the input quantity at the center of mass of the MMS tetrahedron. Parameters ---------- b_list : Sequence of DataArray or Dataset List of the time series of the quantity for each spacecraft. Returns ------- b_avg : DataArray or Dataset Time series of the input quantity a the enter of mass of the MMS tetrahedron. Raises ------ TypeError If b_list is not a list of DataArray or Dataset Examples -------- >>> from pyrfu.mms import get_data >>> from pyrfu.pyrf import avg_4sc Time interval >>> tint = ["2019-09-14T07:54:00.000", "2019-09-14T08:11:00.000"] Spacecraft indices >>> b_mms = [get_data("B_gse_fgm_srvy_l2", tint, i) for i in range(1, 5)] >>> b_xyz = avg_4sc(b_mms) """ # Check input type if not isinstance(b_list, list): raise TypeError("b_list must be a list") b_list_r = [] for b in b_list: if isinstance(b, (xr.DataArray, xr.Dataset)): b_list_r.append(resample(b, b_list[0], f_s=calc_fs(b_list[0]))) else: raise TypeError("elements of b_list must be DataArray or Dataset") b_avg_data = np.zeros(b_list_r[0].data.shape) # for b in b_list_r: # b_avg_data += b.data # Average the resamples time series if isinstance(b_list_r[0], xr.DataArray): for b in b_list_r: b_avg_data += b.data b_avg = xr.DataArray( b_avg_data / len(b_list_r), coords=b_list_r[0].coords, dims=b_list_r[0].dims, attrs=b_list_r[0].attrs, ) else: data_vars_names = list(b_list_r[0].data_vars) data_vars_coords = [ list(list(b_list_r[0].data_vars[data_vars_name].coords)) for data_vars_name in data_vars_names ] for b in b_list_r: b_avg_data += b.data.data data_vars_dict = { data_vars_name: b_list_r[0].data_vars[data_vars_name].data for data_vars_name in data_vars_names if data_vars_name != "data" } data_vars_dict["data"] = b_avg_data / len(b_list_r) # return data_vars_dict b_avg = xr.Dataset( data_vars={ data_vars_name: (data_vars_coord, data_vars_dict[data_vars_name]) for data_vars_name, data_vars_coord in zip( data_vars_names, data_vars_coords ) }, coords=b_list_r[0].coords, attrs=b_list_r[0].attrs, ) # return data_vars_dict return b_avg