| 
									
										
										
										
											2022-02-11 09:07:11 +11:00
										 |  |  | /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * \file | 
					
						
							|  |  |  |  * \ingroup pygen | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file defines the 'bl_math' module, a module for math utilities. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <Python.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BLI_math.h"
 | 
					
						
							|  |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "py_capi_utils.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "bl_math_py_api.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | /* -------------------------------------------------------------------- */ | 
					
						
							|  |  |  | /** \name Module Doc String
 | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |  * \{ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | PyDoc_STRVAR(M_bl_math_doc, "Miscellaneous math utilities module"); | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** \} */ | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* -------------------------------------------------------------------- */ | 
					
						
							|  |  |  | /** \name Python Functions
 | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |  * \{ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | PyDoc_STRVAR(py_bl_math_clamp_doc, | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |              ".. function:: clamp(value, min=0, max=1)\n" | 
					
						
							|  |  |  |              "\n" | 
					
						
							|  |  |  |              "   Clamps the float value between minimum and maximum. To avoid\n" | 
					
						
							|  |  |  |              "   confusion, any call must use either one or all three arguments.\n" | 
					
						
							|  |  |  |              "\n" | 
					
						
							|  |  |  |              "   :arg value: The value to clamp.\n" | 
					
						
							|  |  |  |              "   :type value: float\n" | 
					
						
							|  |  |  |              "   :arg min: The minimum value, defaults to 0.\n" | 
					
						
							|  |  |  |              "   :type min: float\n" | 
					
						
							|  |  |  |              "   :arg max: The maximum value, defaults to 1.\n" | 
					
						
							|  |  |  |              "   :type max: float\n" | 
					
						
							|  |  |  |              "   :return: The clamped value.\n" | 
					
						
							|  |  |  |              "   :rtype: float\n"); | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | static PyObject *py_bl_math_clamp(PyObject *UNUSED(self), PyObject *args) | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  | { | 
					
						
							|  |  |  |   double x, minv = 0.0, maxv = 1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (PyTuple_Size(args) <= 1) { | 
					
						
							|  |  |  |     if (!PyArg_ParseTuple(args, "d:clamp", &x)) { | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     if (!PyArg_ParseTuple(args, "ddd:clamp", &x, &minv, &maxv)) { | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   CLAMP(x, minv, maxv); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return PyFloat_FromDouble(x); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | PyDoc_STRVAR(py_bl_math_lerp_doc, | 
					
						
							| 
									
										
										
										
											2021-10-22 18:27:03 -04:00
										 |  |  |              ".. function:: lerp(from_value, to_value, factor)\n" | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |              "\n" | 
					
						
							|  |  |  |              "   Linearly interpolate between two float values based on factor.\n" | 
					
						
							|  |  |  |              "\n" | 
					
						
							| 
									
										
										
										
											2021-10-22 18:27:03 -04:00
										 |  |  |              "   :arg from_value: The value to return when factor is 0.\n" | 
					
						
							|  |  |  |              "   :type from_value: float\n" | 
					
						
							|  |  |  |              "   :arg to_value: The value to return when factor is 1.\n" | 
					
						
							|  |  |  |              "   :type to_value: float\n" | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |              "   :arg factor: The interpolation value, normally in [0.0, 1.0].\n" | 
					
						
							|  |  |  |              "   :type factor: float\n" | 
					
						
							|  |  |  |              "   :return: The interpolated value.\n" | 
					
						
							|  |  |  |              "   :rtype: float\n"); | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | static PyObject *py_bl_math_lerp(PyObject *UNUSED(self), PyObject *args) | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  | { | 
					
						
							|  |  |  |   double a, b, x; | 
					
						
							|  |  |  |   if (!PyArg_ParseTuple(args, "ddd:lerp", &a, &b, &x)) { | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return PyFloat_FromDouble(a * (1.0 - x) + b * x); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-25 22:18:45 -04:00
										 |  |  | PyDoc_STRVAR(py_bl_math_smoothstep_doc, | 
					
						
							|  |  |  |              ".. function:: smoothstep(from_value, to_value, value)\n" | 
					
						
							|  |  |  |              "\n" | 
					
						
							|  |  |  |              "   Performs smooth interpolation between 0 and 1 as value changes between from and " | 
					
						
							|  |  |  |              "to values.\n" | 
					
						
							|  |  |  |              "   Outside the range the function returns the same value as the nearest edge.\n" | 
					
						
							|  |  |  |              "\n" | 
					
						
							|  |  |  |              "   :arg from_value: The edge value where the result is 0.\n" | 
					
						
							|  |  |  |              "   :type from_value: float\n" | 
					
						
							|  |  |  |              "   :arg to_value: The edge value where the result is 1.\n" | 
					
						
							|  |  |  |              "   :type to_value: float\n" | 
					
						
							|  |  |  |              "   :arg factor: The interpolation value.\n" | 
					
						
							|  |  |  |              "   :type factor: float\n" | 
					
						
							|  |  |  |              "   :return: The interpolated value in [0.0, 1.0].\n" | 
					
						
							|  |  |  |              "   :rtype: float\n"); | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | static PyObject *py_bl_math_smoothstep(PyObject *UNUSED(self), PyObject *args) | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  | { | 
					
						
							|  |  |  |   double a, b, x; | 
					
						
							|  |  |  |   if (!PyArg_ParseTuple(args, "ddd:smoothstep", &a, &b, &x)) { | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   double t = (x - a) / (b - a); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   CLAMP(t, 0.0, 1.0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return PyFloat_FromDouble(t * t * (3.0 - 2.0 * t)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \} */ | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* -------------------------------------------------------------------- */ | 
					
						
							|  |  |  | /** \name Module Definition
 | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |  * \{ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | static PyMethodDef M_bl_math_methods[] = { | 
					
						
							|  |  |  |     {"clamp", (PyCFunction)py_bl_math_clamp, METH_VARARGS, py_bl_math_clamp_doc}, | 
					
						
							|  |  |  |     {"lerp", (PyCFunction)py_bl_math_lerp, METH_VARARGS, py_bl_math_lerp_doc}, | 
					
						
							|  |  |  |     {"smoothstep", (PyCFunction)py_bl_math_smoothstep, METH_VARARGS, py_bl_math_smoothstep_doc}, | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |     {NULL, NULL, 0, NULL}, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  | static struct PyModuleDef M_bl_math_module_def = { | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |     PyModuleDef_HEAD_INIT, | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  |     "bl_math",         /* m_name */ | 
					
						
							|  |  |  |     M_bl_math_doc,     /* m_doc */ | 
					
						
							|  |  |  |     0,                 /* m_size */ | 
					
						
							|  |  |  |     M_bl_math_methods, /* m_methods */ | 
					
						
							|  |  |  |     NULL,              /* m_reload */ | 
					
						
							|  |  |  |     NULL,              /* m_traverse */ | 
					
						
							|  |  |  |     NULL,              /* m_clear */ | 
					
						
							|  |  |  |     NULL,              /* m_free */ | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyMODINIT_FUNC BPyInit_bl_math(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-07-22 15:24:10 +10:00
										 |  |  |   PyObject *submodule = PyModule_Create(&M_bl_math_module_def); | 
					
						
							| 
									
										
										
										
											2020-07-04 13:20:59 +03:00
										 |  |  |   return submodule; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** \} */ |