std:: cyl_bessel_j, std:: cyl_bessel_jf, std:: cyl_bessel_jl
|
헤더 파일에 정의됨
<cmath>
|
||
| (1) | ||
|
float
cyl_bessel_j
(
float
nu,
float
x
)
;
double
cyl_bessel_j
(
double
nu,
double
x
)
;
|
(C++17 이후)
(C++23 이전) |
|
|
/* floating-point-type */
cy_bessel_j
(
/* floating-point-type */
nu,
/* floating-point-type */ x ) ; |
(C++23 이후) | |
|
float
cyl_bessel_jf
(
float
nu,
float
x
)
;
|
(2) | (C++17 이후) |
|
long
double
cyl_bessel_jl
(
long
double
nu,
long
double
x
)
;
|
(3) | (C++17 이후) |
|
헤더 파일에 정의됨
<cmath>
|
||
|
template
<
class
Arithmetic1,
class
Arithmetic2
>
/* common-floating-point-type */
|
(A) | (C++17 이후) |
std::cyl_bessel_j
의 오버로드를 제공합니다.
(C++23부터)
목차 |
매개변수
| nu | - | 함수의 차수 |
| x | - | 함수의 인수 |
반환값
If no errors occur, value of the cylindrical Bessel function of the first kind of nu and x , that is J ν (x) = Σ ∞k=0
|
(-1)
k
(x/2) ν+2k |
| k!Γ(ν+k+1) |
오류 처리
오류는 다음과 같이 지정된 대로 보고될 수 있습니다: math_errhandling :
- 인수가 NaN이면, NaN이 반환되고 도메인 오류가 보고되지 않습니다.
- 만약 nu≥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) 와 정확히 동일하게 제공될 필요는 없습니다. 첫 번째 인수 num1 과 두 번째 인수 num2 에 대해 다음을 보장할 수 있을 만큼 충분하기만 하면 됩니다:
|
(C++23 이전) |
|
num1
과
num2
이 산술 타입을 가지는 경우,
std
::
cyl_bessel_j
(
num1, num2
)
은
std
::
cyl_bessel_j
(
static_cast
<
/* common-floating-point-type */
>
(
num1
)
,
가장 높은 순위와 하위 순위를 가지는 부동소수점 타입이 존재하지 않는 경우, 오버로드 해결 은 제공된 오버로드들 중에서 사용 가능한 후보를 결과로 내지 않습니다. |
(C++23 이후) |
예제
#include <cmath> #include <iostream> int main() { // nu == 0에 대한 점검 const double x = 1.2345; std::cout << "J_0(" << x << ") = " << std::cyl_bessel_j(0, x) << '\n'; // J_0에 대한 급수 전개 double fct = 1; double sum = 0; for (int k = 0; k < 6; fct *= ++k) { sum += std::pow(-1, k) * std::pow(x / 2, 2 * k) / std::pow(fct, 2); std::cout << "sum = " << sum << '\n'; } }
출력:
J_0(1.2345) = 0.653792 sum = 1 sum = 0.619002 sum = 0.655292 sum = 0.653756 sum = 0.653793 sum = 0.653792
참고 항목
|
(C++17)
(C++17)
(C++17)
|
정규 수정 원통 베셀 함수
(함수) |
외부 링크
| Weisstein, Eric W. "Bessel Function of the First Kind." MathWorld — Wolfram 웹 리소스에서 발췌. |