命名空间
变体
操作

std::sph_bessel,std::sph_besself,std::sph_bessell

来自 cppreference.com
 
 
 
 
定义在头文件 <cmath>
(1)
float       sph_bessel ( unsigned int n, float x );

double      sph_bessel ( unsigned int n, double x );

long double sph_bessel ( unsigned int n, long double x );
(自 C++17 起)
(直到 C++23)
/* 浮点类型 */ sph_bessel( unsigned int n,
                                      /* 浮点类型 */ x );
(自 C++23 起)
float       sph_besself( unsigned int n, float x );
(2) (自 C++17 起)
long double sph_bessell( unsigned int n, long double x );
(3) (自 C++17 起)
定义在头文件 <cmath>
template< class Integer >
double      sph_bessel ( unsigned int n, Integer x );
(A) (自 C++17 起)
1-3) 计算 第一类球面贝塞尔函数nx 库为参数 x 的所有 cv 无限定浮点类型提供了 std::sph_bessel 的重载。(自 C++23 起)
A) 为所有整数类型提供了额外的重载,这些类型被视为 double

内容

[编辑] 参数

n - 函数的阶数
x - 函数的自变量

[编辑] 返回值

如果未发生错误,则返回第一类球面贝塞尔函数的 nx 的值,即 j
n
(x) = (π/2x)1/2
J
n+1/2
(x)
其中 J
n
(x)
std::cyl_bessel_j(n, x)x≥0

[编辑] 错误处理

错误可能会如 math_errhandling 中指定的那样进行报告。

  • 如果自变量是 NaN,则返回 NaN 且不会报告域错误。
  • 如果 n≥128,则行为是实现定义的。

[编辑] 注释

不支持 C++17 但支持 ISO 29124:2010 的实现,如果实现将 __STDCPP_MATH_SPEC_FUNCS__ 定义为至少为 201003L 的值,并且如果用户在包含任何标准库头文件之前定义了 __STDCPP_WANT_MATH_SPEC_FUNCS__,则提供此函数。

不支持 ISO 29124:2010 但支持 TR 19768:2007 (TR1) 的实现,在头文件 tr1/cmath 和命名空间 std::tr1 中提供此函数。

此函数的实现也可在 boost.math 中获得。

额外的重载不需要完全按照 (A) 提供。它们只需要足够确保对于它们的整数类型自变量 numstd::sph_bessel(int_num, num)std::sph_bessel(int_num, static_cast<double>(num)) 具有相同的效果。

[编辑] 示例

#include <cmath>
#include <iostream>
 
int main()
{
    // spot check for n == 1
    double x = 1.2345;
    std::cout << "j_1(" << x << ") = " << std::sph_bessel(1, x) << '\n';
 
    // exact solution for j_1
    std::cout << "sin(x)/x² - cos(x)/x = "
              << std::sin(x) / (x * x) - std::cos(x) / x << '\n';
}

输出

j_1(1.2345) = 0.352106
sin(x)/x² - cos(x)/x = 0.352106

[编辑] 另请参阅

圆柱形贝塞尔函数(第一类)
(函数) [编辑]
球面诺伊曼函数
(函数) [编辑]

[编辑] 外部链接

Weisstein, Eric W. "第一类球贝塞尔函数." 来自 Wolfram Web 资源 — MathWorld。