[libcxx-commits] [libcxx] [libc++][math] Mathematical Special Functions: Hermite Polynomial (PR #89982)
via libcxx-commits
libcxx-commits at lists.llvm.org
Tue Apr 30 11:19:38 PDT 2024
================
@@ -765,6 +766,53 @@ _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 _Tp __constexpr_scalbn(_Tp _
return __builtin_scalbn(__x, __exp);
}
+#if _LIBCPP_STD_VER >= 17
+
+/// \return the Hermite polynomial \f$ H_n(x) \f$
+/// \note The implementation is based on the recurrence formula
+/// \f[
+/// H_{n+1}(x) = 2x H_n(x) - 2n H_{n-1}
+/// \f]
+/// Press, William H., et al. Numerical recipes 3rd edition: The art of
+/// scientific computing. Cambridge university press, 2007, p. 183.
+template <class _Real>
+_LIBCPP_HIDE_FROM_ABI _Real __hermite(unsigned __n, _Real __x) {
+ if (std::isnan(__x))
+ return std::numeric_limits<_Real>::quiet_NaN();
+
+ _Real __H_0{1};
+ if (__n == 0)
+ return __H_0;
+
+ _Real __H_n_prev = __H_0;
+ _Real __H_n = 2 * __x;
+ for (unsigned __i = 1; __i < __n; ++__i) {
+ _Real __H_n_next = 2 * (__x * __H_n - __i * __H_n_prev);
+ __H_n_prev = __H_n;
+ __H_n = __H_n_next;
+ }
+ return __H_n;
----------------
PaulXiCao wrote:
While I was thinking about your comment for quite some time multiple issues crossed my mind.
* I assume your point is that in the nature of subtraction and recursive calls (e.g. `_Real __H_n_next = 2 * (__x * __H_n - __i * __H_n_prev);`) one could produce an Inf of the wrong sign?
* I will try to find a test set which would show this issue for the current implementation.
* I believe one needs to clearly separate between NaNs and Infs.
* NaNs are already handled at function entry. They should not be producible within this function.
* The check in your code snippet should probably test for Infs, i.e. `if (std::isinf(__H_n)) { ... }`?
* This does clutter the implementation quite a bit (mixing error checks with formula). I assume similar logic will need to apply for some of the other special math functions. We might probably want to extract that logic at some point.
https://github.com/llvm/llvm-project/pull/89982
More information about the libcxx-commits
mailing list