hankel¶
Class summary¶
HankelTransform (func[, args, order, m, …]) |
Hankel transform of integer order |
Function summary¶
scratch () |
|
vhankel_transform (f, r[, args, order, m, …]) |
Hankel transform of f(r) |
Module listing¶
Hankel transforms.
-
class
geotecha.mathematics.hankel.
HankelTransform
(func, args=(), order=0, m=20, points=None, ng=10, ng0=20, shanks_ind=None)[source]¶ Bases:
object
Hankel transform of integer order
Applies Gauss-Kronrod quadrature between zeros of the integrand. Then uses shanks extrapolation.
Parameters: - func : function or method
Function to apply hankel trasnform to. func is called with func(r, *args). func should be vectorised in r.
- args : tuple, optional
Arguments to pass to f. Default args=().
- order : integer, optional
Order of Hankel transform. Default order=0.
- m : int, optional
Number of segments to break the integration interval into. Each segment will be between the zeros of the bessel function or order= `order’ divide by r Default ,=20.
- points : list/array of float, optional
Points in addition to those defined by m at which to split the integral. Use this if f itself oscillates or there are discontinuities. Points will only be included that are less than the m zeros mentined above. Default points=None i.e. no extra points. Basically the function is never evaluated at any ofthe points, rather they form the boundary four gauss quadrature.
- ng : [7,10,15,20,25,30], optional
Number of gauss points to use in integration after first zero. Default ng=10. Number of Kronrod points will automatically by 2 * ng + 1.
- ng0 : [7,10,15,20,25,30], optional
Number of gauss points to use in integrating between 0 and first zero. Default ng0=20.
- shanks_ind : int, optional
Start position of intervals (not including the first interval) from which to begin shanks transformation. Default shanks_ind=None i.e. no extrapolation. The first interval will never be included. Be careful when using shanks extrapolation; make sure you only begin to use it after the intgrand is well behaved. Use the plot_integrand method to check your integrand.
Returns: - f : float
Value of transform at r.
Notes
The Hankel Transform of order \(\nu\) is given by:
\[F_\nu(s)=\mathcal{H}_\nu\{f(r)\} = \int_0^{\infty}rf(r)J_\nu(sr)\,\mathrm{d}r\]Provided \(\nu\gt1/2\) the inverse hankel transform is the same as the normal transform:
\[f(r)=\mathcal{H}_{\nu}^{-1}\{F_{\nu}(s)\} = \int_0^{\infty}sF_\nu(s)J_\nu(sr)\,\mathrm{d}s\]References
[1] Piessens, Robert. 2000. ‘Chapter 9 The Hankel Transform’. In The Transforms and Applications Handbook, edited by Alexander D. Poularikas, 2nd edition. Boca Raton, USA: CRC Press. Methods
__call__
(s[, a, b])transform f(r, *args) at s plot_integrand
(s[, npts])Plot the integrand zeros_of_jn
()Roots of Jn for determining integration intervals (0 prepended) -
plot_integrand
(s, npts=1000)[source]¶ Plot the integrand
Parameters: - s : float
Transform variable, i.e. point to evaluate transform at
- npts : int, optional
Number of points to plot. Default npts=1000.
Returns: - fig : matplotlib.Figure
Use plt.show to plot
Notes
Use this to check if your parameters are appropriate.
-
geotecha.mathematics.hankel.
vhankel_transform
(f, r, args=(), order=0, m=20, ng=20, shanks_ind=None)[source]¶ Hankel transform of f(r)
This is a vectorised Hankel transform
Parameters: - f : function or method
Function to apply hankel trasnform to. f is called with f(s, *args).
- r : 1d array
Coordinate(s) to evaluate transform at.
- args : tuple, optional
Arguments to pass to f, default args=().
- order : integer, optional
Order of hankel transform. Default order=0.
- m : int, optional
Number of segments to break the integration interval into. Each segment will be between the zeros of the bessel function. Default m=20.
- ng : [2-20, 32, 64, 100], optional
Number of gauss points to use in integration. Default ng=20.
- shanks_ind : int, optional
Start position of intervals to start shanks extrapolation. Default shanks_ind=None i.e. no extrapolation. Be careful when using shanks extrapolation; make sure you only begin to use it after the intgrand is well behaved.
Returns: - f : 1d array of float
Value of transform at r.
See also
HankelTransform
- Non vectorised Hankel transform.
Notes
The Hankel Transform of order \(\nu\) is given by:
\[F_\nu(s)=\mathcal{H}_\nu\{f(r)\} = \int_0^{\infty}rf(r)J_\nu(sr)\,\mathrm{d}r\]Provided \(\nu\gt1/2\) the inverse hankel transform is the same as the normal transform:
\[f(r)=\mathcal{H}_{\nu}^{-1}\{F_{\nu}(s)\} = \int_0^{\infty}sF_\nu(s)J_\nu(sr)\,\mathrm{d}s\]Note that because this implementation does not allow for input of extra point to break up the integration inteval, there is no way to account for singularities and other oscillations. If you need this control then see the HankelTransform class which is not vectorized but provides a few more options.
References
[1] Piessens, Robert. 2000. ‘Chapter 9 The Hankel Transform’. In The Transforms and Applications Handbook, edited by Alexander D. Poularikas, 2nd edition. Boca Raton, USA: CRC Press.