Coverage for install/scipp/scipy/integrate/__init__.py: 95%
21 statements
« prev ^ index » next coverage.py v7.6.1, created at 2024-12-01 01:59 +0000
« prev ^ index » next coverage.py v7.6.1, created at 2024-12-01 01:59 +0000
1# SPDX-License-Identifier: BSD-3-Clause
2# Copyright (c) 2023 Scipp contributors (https://github.com/scipp)
3# @author Simon Heybrock
4"""Sub-package for integration.
6This subpackage provides wrappers for a subset of functions from
7:py:mod:`scipy.integrate`.
8"""
10from collections.abc import Callable
11from typing import Any
13import numpy.typing as npt
15from ...compat.wrapping import wrap1d
16from ...core import DataArray, array
19def _integrate(
20 func: Callable[..., npt.NDArray[Any]], da: DataArray, dim: str, **kwargs: Any
21) -> DataArray:
22 if 'dx' in kwargs:
23 raise ValueError(
24 "Invalid argument 'dx': Spacing of integration points is "
25 f"given by the '{dim}' coord."
26 )
27 integral = func(x=da.coords[dim].values, y=da.values, **kwargs)
28 dims = [d for d in da.dims if d != dim]
29 unit = da.unit * da.coords[dim].unit # type: ignore[operator] # from unit = None
30 return DataArray(data=array(dims=dims, values=integral, unit=unit))
33@wrap1d()
34def trapezoid(da: DataArray, dim: str, **kwargs: Any) -> DataArray:
35 """Integrate data array along the given dimension with
36 the composite trapezoidal rule.
38 This is a wrapper around :py:func:`scipy.integrate.trapezoid`.
40 Examples:
42 >>> x = sc.geomspace(dim='x', start=0.1, stop=0.4, num=4, unit='m')
43 >>> da = sc.DataArray(x*x, coords={'x': x})
44 >>> from scipp.scipy.integrate import trapezoid
45 >>> trapezoid(da, 'x')
46 <scipp.DataArray>
47 Dimensions: Sizes[]
48 Data:
49 float64 [m^3] () 0.0217094
50 """
51 import scipy.integrate as integ
53 return _integrate(integ.trapezoid, da, dim, **kwargs)
56@wrap1d()
57def simpson(da: DataArray, dim: str, **kwargs: Any) -> DataArray:
58 """Integrate data array along the given dimension with the composite Simpson's rule.
60 This is a wrapper around :py:func:`scipy.integrate.simpson`.
62 Examples:
64 >>> x = sc.geomspace(dim='x', start=0.1, stop=0.4, num=4, unit='m')
65 >>> da = sc.DataArray(x*x, coords={'x': x})
66 >>> from scipp.scipy.integrate import simpson
67 >>> simpson(da, 'x')
68 <scipp.DataArray>
69 Dimensions: Sizes[]
70 Data:
71 float64 [m^3] () 0.021
72 """
73 import scipy.integrate as integ
75 return _integrate(integ.simpson, da, dim, **kwargs)
78__all__ = ['simpson', 'trapezoid']