Coverage for install/scipp/core/trigonometry.py: 37%
19 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
5from __future__ import annotations
7from .._scipp import core as _cpp
8from ..typing import VariableLikeType
9from ._cpp_wrapper_util import call_func as _call_cpp_func
10from .cpp_classes import Variable
13def sin(
14 x: VariableLikeType, *, out: VariableLikeType | None = None
15) -> VariableLikeType:
16 """Element-wise sine.
18 The input must have a plane-angle unit, i.e. ``rad``, ``deg``.
20 Parameters
21 ----------
22 x: scipp.typing.VariableLike
23 Input data.
24 out:
25 Optional output buffer.
27 Returns
28 -------
29 : Same type as input
30 The sine values of the input.
31 """
32 return _call_cpp_func(_cpp.sin, x, out=out) # type: ignore[return-value]
35def cos(
36 x: VariableLikeType, *, out: VariableLikeType | None = None
37) -> VariableLikeType:
38 """Element-wise cosine.
40 The input must have a plane-angle unit, i.e. ``rad``, ``deg``.
42 Parameters
43 ----------
44 x: scipp.typing.VariableLike
45 Input data.
46 out:
47 Optional output buffer.
49 Returns
50 -------
51 : Same type as input
52 The cosine values of the input.
53 """
54 return _call_cpp_func(_cpp.cos, x, out=out) # type: ignore[return-value]
57def tan(
58 x: VariableLikeType, *, out: VariableLikeType | None = None
59) -> VariableLikeType:
60 """Element-wise tangent.
62 The input must have a plane-angle unit, i.e. ``rad``, ``deg``.
64 Parameters
65 ----------
66 x: scipp.typing.VariableLike
67 Input data.
68 out:
69 Optional output buffer.
71 Returns
72 -------
73 : Same type as input
74 The tangent values of the input.
75 """
76 return _call_cpp_func(_cpp.tan, x, out=out) # type: ignore[return-value]
79def asin(
80 x: VariableLikeType, *, out: VariableLikeType | None = None
81) -> VariableLikeType:
82 """Element-wise inverse sine.
84 Parameters
85 ----------
86 x: scipp.typing.VariableLike
87 Input data.
88 out:
89 Optional output buffer.
91 Returns
92 -------
93 : Same type as input
94 The inverse sine values of the input in radians.
95 """
96 return _call_cpp_func(_cpp.asin, x, out=out) # type: ignore[return-value]
99def acos(
100 x: VariableLikeType, *, out: VariableLikeType | None = None
101) -> VariableLikeType:
102 """Element-wise inverse cosine.
104 Parameters
105 ----------
106 x: scipp.typing.VariableLike
107 Input data.
108 out:
109 Optional output buffer.
111 Returns
112 -------
113 : Same type as input
114 The inverse cosine values of the input in radians.
115 """
116 return _call_cpp_func(_cpp.acos, x, out=out) # type: ignore[return-value]
119def atan(
120 x: VariableLikeType, *, out: VariableLikeType | None = None
121) -> VariableLikeType:
122 """Element-wise inverse tangent.
124 Parameters
125 ----------
126 x: scipp.typing.VariableLike
127 Input data.
128 out:
129 Optional output buffer.
131 Returns
132 -------
133 : Same type as input
134 The inverse tangent values of the input in radians.
135 """
136 return _call_cpp_func(_cpp.atan, x, out=out) # type: ignore[return-value]
139def atan2(*, y: Variable, x: Variable, out: Variable | None = None) -> Variable:
140 """Element-wise inverse tangent of y/x determining the correct quadrant.
142 Parameters
143 ----------
144 y:
145 Input y values.
146 x:
147 Input x values.
148 out:
149 Optional output buffer.
151 Returns
152 -------
153 :
154 The signed inverse tangent values of y/x in the range [-π, π].
156 See Also
157 --------
158 `<https://en.cppreference.com/w/c/numeric/math/atan2>`_:
159 Documentation of all edge cases.
160 Note that domain errors are *not* propagated to Python.
161 numpy.arctan2:
162 The equivalent in NumPy with additional explanations.
163 """
164 return _call_cpp_func(_cpp.atan2, y=y, x=x, out=out) # type: ignore[return-value]