ak.linear_fit#
Defined in awkward.operations.ak_linear_fit on line 17.
- ak.linear_fit(x, y, weight=None, axis=None, *, keepdims=False, mask_identity=False, highlevel=True, behavior=None, attrs=None)#
- Parameters:
x – One coordinate to use in the linear fit (anything
ak.to_layoutrecognizes).y – The other coordinate to use in the linear fit (anything
ak.to_layoutrecognizes).weight – Data that can be broadcasted to
xandyto give each point a weight. Weighting points equally is the same as no weights; weighting some points higher increases the significance of those points. Weights can be zero or negative.axis (None or int or str) – If None, combine all values from the array into a single scalar result; if an int, group by that axis:
0is the outermost,1is the first level of nested lists, etc., and negativeaxiscounts from the innermost:-1is the innermost,-2is the next level up, etc; if a str, it is interpreted as the name of the axis which maps to an int if named axes are present. Named axes are attached to an array usingak.with_named_axisand removed withak.without_named_axis; also see the Named axes user guide.keepdims (bool) – If False, this function decreases the number of dimensions by 1; if True, the output values are wrapped in a new length-1 dimension so that the result of this operation may be broadcasted with the original array.
mask_identity (bool) – If True, the application of this function on empty lists results in None (an option type); otherwise, the calculation is followed through with the reducers’ identities, usually resulting in floating-point
nan.highlevel (bool) – If True, return an
ak.Array; otherwise, return a low-levelak.contents.Contentsubclass.behavior (None or dict) – Custom
ak.behaviorfor the output array, if high-level.attrs (None or dict) – Custom attributes for the output array, if high-level.
Computes the linear fit of
ywith respect tox(many types supported, including all Awkward Arrays and Records, must be broadcastable to each other). The grouping is performed the same way as for reducers, though this operation is not a reducer and has no identity.This function has no NumPy equivalent.
Passing all arguments to the reducers, the linear fit is calculated as:
sumw = ak.sum(weight) sumwx = ak.sum(weight * x) sumwy = ak.sum(weight * y) sumwxx = ak.sum(weight * x**2) sumwxy = ak.sum(weight * x * y) delta = (sumw*sumwxx) - (sumwx*sumwx) intercept = ((sumwxx*sumwy) - (sumwx*sumwxy)) / delta slope = ((sumw*sumwxy) - (sumwx*sumwy)) / delta intercept_error = np.sqrt(sumwxx / delta) slope_error = np.sqrt(sumw / delta)
The results,
intercept,slope,intercept_error, andslope_error, are given as anak.Recordwith four fields. The values of these fields might be arrays or even nested arrays; they match the structure ofxandy.See
ak.sumfor a complete description of handling nested lists and missing values (None) in reducers, andak.meanfor an example with another non-reducer.