39 return $e->getMessage();
46 $fResult = self::calculate(
$x, $ord);
56 return self::besselJ0($x);
58 return self::besselJ1($x);
61 return self::besselJ2($x, $ord);
70 $ans1 = 57568490574.0 +
$y * (-13362590354.0 +
$y * (651619640.7 +
$y * (-11214424.18 +
$y *
71 (77392.33017 +
$y * (-184.9052456)))));
72 $ans2 = 57568490411.0 +
$y * (1029532985.0 +
$y * (9494680.718 +
$y * (59272.64853 +
$y *
73 (267.8532712 +
$y * 1.0))));
80 $xx = $ax - 0.785398164;
81 $ans1 = 1.0 +
$y * (-0.1098628627e-2 +
$y * (0.2734510407e-4 +
$y * (-0.2073370639e-5 +
$y * 0.2093887211e-6)));
82 $ans2 = -0.1562499995e-1 +
$y * (0.1430488765e-3 +
$y * (-0.6911147651e-5 +
$y *
83 (0.7621095161e-6 -
$y * 0.934935152e-7)));
85 return sqrt(0.636619772 / $ax) * (cos($xx) * $ans1 - $z * sin($xx) * $ans2);
94 $ans1 = $x * (72362614232.0 +
$y * (-7895059235.0 +
$y * (242396853.1 +
$y *
95 (-2972611.439 +
$y * (15704.48260 +
$y * (-30.16036606))))));
96 $ans2 = 144725228442.0 +
$y * (2300535178.0 +
$y * (18583304.74 +
$y * (99447.43394 +
$y *
97 (376.9991397 +
$y * 1.0))));
104 $xx = $ax - 2.356194491;
106 $ans1 = 1.0 +
$y * (0.183105e-2 +
$y * (-0.3516396496e-4 +
$y * (0.2457520174e-5 +
$y * (-0.240337019e-6))));
107 $ans2 = 0.04687499995 +
$y * (-0.2002690873e-3 +
$y * (0.8449199096e-5 +
$y *
108 (-0.88228987e-6 +
$y * 0.105787412e-6)));
109 $ans = sqrt(0.636619772 / $ax) * (cos($xx) * $ans1 - $z * sin($xx) * $ans2);
111 return ($x < 0.0) ? -$ans : $ans;
122 return self::besselj2a($ax, $ord, $x);
125 return self::besselj2b($ax, $ord, $x);
131 $bjm = self::besselJ0($ax);
132 $bj = self::besselJ1($ax);
133 for ($j = 1; $j < $ord; ++$j) {
134 $bjp = $j * $tox * $bj - $bjm;
140 return ($x < 0.0 && ($ord % 2) == 1) ? -$ans : $ans;
147 $bjp = $ans = $sum = 0.0;
149 for ($j = 2 * ($ord + (
int) sqrt(40.0 * $ord)); $j > 0; --$j) {
150 $bjm = $j * $tox * $bj - $bjp;
153 if (abs($bj) > 1.0e+10) {
159 if ($jsum ===
true) {
167 $sum = 2.0 * $sum - $bj;
170 return ($x < 0.0 && ($ord % 2) === 1) ? -$ans : $ans;
static besselj2a(float $ax, int $ord, float $x)
static besselj2b(float $ax, int $ord, float $x)
static besselJ1(float $x)
static BESSELJ($x, $ord)
BESSELJ.
static besselJ0(float $x)
static besselJ2(float $x, int $ord)
static calculate(float $x, int $ord)
static validateFloat($value)
static flattenSingleValue($value='')
Convert an array to a single scalar value by extracting the first element.
static validateInt($value)