ExponentialHermite#
- class splinebox.basis_functions.ExponentialHermite(M)#
Basis function for an exponential Hermite spline.
For a detailed theoretical description – including the equation and a plot of the function – refer to the Exponential Hermite basis section in the documentation.
The constructor requires M, the number of knots in the spline, as an argument.
Note: This basis function is a
multigeneratorand__call__returns two values.Methods
__call__(t[, derivative])Evaluate the function at position(s) t.
Returns a filtered version of the input s, used to convert knots into control points for a closed spline.
Returns a filtered version of the input s, used to convert knots into control points for an open spline.
This function is needed for local refinement (see [Badoual2016]).
Examples
>>> import splinebox >>> import numpy as np >>> import matplotlib.pyplot as plt
Create a basis function object:
>>> basis_function = splinebox.basis_functions.ExponentialHermite(M=5)
Evaluate the basis function at a single position:
>>> basis_function(0.5) array([0.5 , 0.129])
Evaluate the basis function at multiple positions simultaneously:
>>> t = np.array([-0.2, 0, 0.5]) >>> basis_function(t) array([[ 0.897, -0.13 ], [ 1. , 0. ], [ 0.5 , 0.129]])
Compute the first derivative of the basis function at multiple positions:
>>> basis_function(t, derivative=1) array([[ 0.955, 0.336], [-0. , 1. ], [-1.51 , -0.255]])
>>> t = np.linspace(-2.1, 2.1, 500) >>> plt.plot(t, basis_function(t)[0]) >>> plt.plot(t, basis_function(t)[1], linestyle="-.") >>> plt.show()