Source code for smpl.data

"""Simplified internal data parsing and transforming."""
import numpy as np
import uncertainties.unumpy as unp

from smpl import doc, stat, util

default = {
    "frange": [
        None,
        "Limit the fit to given range. First integer is the lowest and second the highest index.",
    ],
    "fselector": [
        None,
        "Function that takes ``x`` and ``y`` as parameters and returns an array mask in order to limit the data points for fitting. Alternatively a mask for selecting elements from datax and datay.",
    ],
    "sortbyx": [
        True,
        "Enable sorting the x and y data so that x is sorted.",
    ],
    "bins": [
        0,
        "Number of bins for histogram",
    ],
    "binunc": [
        stat.poisson_dist,
        "Number of bins for histogram",
    ],
    "xerror": [True, "enable xerrors"],
    "yerror": [True, "enable yerrors"],
}


unv = unp.nominal_values
usd = unp.std_devs


[docs] @doc.append_str(doc.array_table(default, init=False)) @doc.append_str( doc.array_table({"data_kwargs": ["default", "description"]}, bottom=False) ) @doc.append_str("\n\n") def data_kwargs(kwargs): """Set default :func:`data_kwargs` if not set.""" for k, v in default.items(): if not k in kwargs: kwargs[k] = v[0] return kwargs
def __data_split(datax, datay, **kwargs): """ Splits datax and datay into (x,y,xerr,yerr). Does not apply filters `frange` and `fselector`. Parameters ---------- **kwargs : optional see :func:`data_kwargs`. """ if kwargs["bins"] > 0: N, bins = np.histogram(unv(datax), bins=kwargs["bins"]) y = kwargs["binunc"](N) yerr = usd(y) yerr = yerr if np.any(np.abs(yerr) > 0) else None return bins[0:-1] - (bins[0] - bins[1]) / 2, unv(y), None, yerr if util.has("sortbyx", kwargs) and kwargs["sortbyx"]: ind = np.argsort(unv(datax)) else: ind = np.array(range(len(datax))) x = unv(datax)[ind] y = unv(datay)[ind] xerr = usd(datax)[ind] yerr = usd(datay)[ind] xerr = xerr if np.any(np.abs(xerr) > 0) else None yerr = yerr if np.any(np.abs(yerr) > 0) else None if util.has("xerror", kwargs) and not kwargs["xerror"]: xerr = None if util.has("yerror", kwargs) and not kwargs["yerror"]: yerr = None return x, y, xerr, yerr def _data_split(datax, datay, **kwargs): """ Applies `fselector` and calls :func:`data_split` """ if util.has("fselector", kwargs): sel = kwargs["fselector"] if callable(sel): return __data_split( datax[sel(datax, datay)], datay[sel(datax, datay)], **kwargs ) else: return __data_split(datax[sel], datay[sel], **kwargs) return __data_split(datax, datay, **kwargs)
[docs] def filtered_data_split(datax, datay, **kwargs): """ Splits datax and datay into (x,y,xerr,yerr). Applies filters `fselector` and `frange`. Returns ------- (x,y,xerr,yerr) : tuple four arrays with specified values. Parameters ---------- **kwargs : optional see :func:`data_kwargs`. """ kwargs = data_kwargs(kwargs) x, y, xerr, yerr = _data_split(datax, datay, **kwargs) if util.has("frange", kwargs): x = x[kwargs["frange"][0] : kwargs["frange"][1]] y = y[kwargs["frange"][0] : kwargs["frange"][1]] if not yerr is None: yerr = yerr[kwargs["frange"][0] : kwargs["frange"][1]] if not xerr is None: xerr = xerr[kwargs["frange"][0] : kwargs["frange"][1]] return x, y, xerr, yerr
[docs] def flatmesh(*args): """ Similar to `numpy.meshgrid` but the result will be of one dimension instead of stacked arrays. """ r = np.meshgrid(*args) rr = [] for ri in r: rr += [ri.reshape(ri.size)] return rr