
(FPCore (a b) :precision binary64 (* (* (/ PI 2.0) (/ 1.0 (- (* b b) (* a a)))) (- (/ 1.0 a) (/ 1.0 b))))
double code(double a, double b) {
return ((((double) M_PI) / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b));
}
public static double code(double a, double b) {
return ((Math.PI / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b));
}
def code(a, b): return ((math.pi / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b))
function code(a, b) return Float64(Float64(Float64(pi / 2.0) * Float64(1.0 / Float64(Float64(b * b) - Float64(a * a)))) * Float64(Float64(1.0 / a) - Float64(1.0 / b))) end
function tmp = code(a, b) tmp = ((pi / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b)); end
code[a_, b_] := N[(N[(N[(Pi / 2.0), $MachinePrecision] * N[(1.0 / N[(N[(b * b), $MachinePrecision] - N[(a * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(N[(1.0 / a), $MachinePrecision] - N[(1.0 / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\left(\frac{\pi}{2} \cdot \frac{1}{b \cdot b - a \cdot a}\right) \cdot \left(\frac{1}{a} - \frac{1}{b}\right)
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 13 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (a b) :precision binary64 (* (* (/ PI 2.0) (/ 1.0 (- (* b b) (* a a)))) (- (/ 1.0 a) (/ 1.0 b))))
double code(double a, double b) {
return ((((double) M_PI) / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b));
}
public static double code(double a, double b) {
return ((Math.PI / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b));
}
def code(a, b): return ((math.pi / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b))
function code(a, b) return Float64(Float64(Float64(pi / 2.0) * Float64(1.0 / Float64(Float64(b * b) - Float64(a * a)))) * Float64(Float64(1.0 / a) - Float64(1.0 / b))) end
function tmp = code(a, b) tmp = ((pi / 2.0) * (1.0 / ((b * b) - (a * a)))) * ((1.0 / a) - (1.0 / b)); end
code[a_, b_] := N[(N[(N[(Pi / 2.0), $MachinePrecision] * N[(1.0 / N[(N[(b * b), $MachinePrecision] - N[(a * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(N[(1.0 / a), $MachinePrecision] - N[(1.0 / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\left(\frac{\pi}{2} \cdot \frac{1}{b \cdot b - a \cdot a}\right) \cdot \left(\frac{1}{a} - \frac{1}{b}\right)
\end{array}
(FPCore (a b) :precision binary64 (/ (* (/ PI (+ a b)) (* 0.5 (/ (- b a) (* a b)))) (- b a)))
double code(double a, double b) {
return ((((double) M_PI) / (a + b)) * (0.5 * ((b - a) / (a * b)))) / (b - a);
}
public static double code(double a, double b) {
return ((Math.PI / (a + b)) * (0.5 * ((b - a) / (a * b)))) / (b - a);
}
def code(a, b): return ((math.pi / (a + b)) * (0.5 * ((b - a) / (a * b)))) / (b - a)
function code(a, b) return Float64(Float64(Float64(pi / Float64(a + b)) * Float64(0.5 * Float64(Float64(b - a) / Float64(a * b)))) / Float64(b - a)) end
function tmp = code(a, b) tmp = ((pi / (a + b)) * (0.5 * ((b - a) / (a * b)))) / (b - a); end
code[a_, b_] := N[(N[(N[(Pi / N[(a + b), $MachinePrecision]), $MachinePrecision] * N[(0.5 * N[(N[(b - a), $MachinePrecision] / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\frac{\pi}{a + b} \cdot \left(0.5 \cdot \frac{b - a}{a \cdot b}\right)}{b - a}
\end{array}
Initial program 80.1%
times-frac80.2%
*-commutative80.2%
times-frac80.2%
difference-of-squares87.6%
associate-/r*88.3%
metadata-eval88.3%
sub-neg88.3%
distribute-neg-frac88.3%
metadata-eval88.3%
Simplified88.3%
frac-add88.3%
*-un-lft-identity88.3%
Applied egg-rr88.3%
*-commutative88.3%
neg-mul-188.3%
sub-neg88.3%
Simplified88.3%
expm1-log1p-u68.8%
expm1-udef55.5%
Applied egg-rr55.5%
expm1-def68.8%
expm1-log1p88.3%
*-commutative88.3%
associate-*l*88.3%
Simplified88.3%
associate-*l/99.6%
Applied egg-rr99.6%
Final simplification99.6%
(FPCore (a b)
:precision binary64
(let* ((t_0 (+ (/ 1.0 a) (/ -1.0 b))))
(if (<= a -1.1e+88)
(/ (/ (* -0.5 (/ PI (- b a))) b) a)
(if (<= a -1e-166)
(* (* 0.5 (/ (/ PI (+ a b)) (- b a))) t_0)
(if (<= a 2.6e-107)
(/ (* 0.5 (/ PI (* a b))) (- b a))
(if (<= a 1.5e+138)
(/ (* t_0 (* PI 0.5)) (- (* b b) (* a a)))
(/ (/ (* PI -0.5) (* b (- b a))) a)))))))
double code(double a, double b) {
double t_0 = (1.0 / a) + (-1.0 / b);
double tmp;
if (a <= -1.1e+88) {
tmp = ((-0.5 * (((double) M_PI) / (b - a))) / b) / a;
} else if (a <= -1e-166) {
tmp = (0.5 * ((((double) M_PI) / (a + b)) / (b - a))) * t_0;
} else if (a <= 2.6e-107) {
tmp = (0.5 * (((double) M_PI) / (a * b))) / (b - a);
} else if (a <= 1.5e+138) {
tmp = (t_0 * (((double) M_PI) * 0.5)) / ((b * b) - (a * a));
} else {
tmp = ((((double) M_PI) * -0.5) / (b * (b - a))) / a;
}
return tmp;
}
public static double code(double a, double b) {
double t_0 = (1.0 / a) + (-1.0 / b);
double tmp;
if (a <= -1.1e+88) {
tmp = ((-0.5 * (Math.PI / (b - a))) / b) / a;
} else if (a <= -1e-166) {
tmp = (0.5 * ((Math.PI / (a + b)) / (b - a))) * t_0;
} else if (a <= 2.6e-107) {
tmp = (0.5 * (Math.PI / (a * b))) / (b - a);
} else if (a <= 1.5e+138) {
tmp = (t_0 * (Math.PI * 0.5)) / ((b * b) - (a * a));
} else {
tmp = ((Math.PI * -0.5) / (b * (b - a))) / a;
}
return tmp;
}
def code(a, b): t_0 = (1.0 / a) + (-1.0 / b) tmp = 0 if a <= -1.1e+88: tmp = ((-0.5 * (math.pi / (b - a))) / b) / a elif a <= -1e-166: tmp = (0.5 * ((math.pi / (a + b)) / (b - a))) * t_0 elif a <= 2.6e-107: tmp = (0.5 * (math.pi / (a * b))) / (b - a) elif a <= 1.5e+138: tmp = (t_0 * (math.pi * 0.5)) / ((b * b) - (a * a)) else: tmp = ((math.pi * -0.5) / (b * (b - a))) / a return tmp
function code(a, b) t_0 = Float64(Float64(1.0 / a) + Float64(-1.0 / b)) tmp = 0.0 if (a <= -1.1e+88) tmp = Float64(Float64(Float64(-0.5 * Float64(pi / Float64(b - a))) / b) / a); elseif (a <= -1e-166) tmp = Float64(Float64(0.5 * Float64(Float64(pi / Float64(a + b)) / Float64(b - a))) * t_0); elseif (a <= 2.6e-107) tmp = Float64(Float64(0.5 * Float64(pi / Float64(a * b))) / Float64(b - a)); elseif (a <= 1.5e+138) tmp = Float64(Float64(t_0 * Float64(pi * 0.5)) / Float64(Float64(b * b) - Float64(a * a))); else tmp = Float64(Float64(Float64(pi * -0.5) / Float64(b * Float64(b - a))) / a); end return tmp end
function tmp_2 = code(a, b) t_0 = (1.0 / a) + (-1.0 / b); tmp = 0.0; if (a <= -1.1e+88) tmp = ((-0.5 * (pi / (b - a))) / b) / a; elseif (a <= -1e-166) tmp = (0.5 * ((pi / (a + b)) / (b - a))) * t_0; elseif (a <= 2.6e-107) tmp = (0.5 * (pi / (a * b))) / (b - a); elseif (a <= 1.5e+138) tmp = (t_0 * (pi * 0.5)) / ((b * b) - (a * a)); else tmp = ((pi * -0.5) / (b * (b - a))) / a; end tmp_2 = tmp; end
code[a_, b_] := Block[{t$95$0 = N[(N[(1.0 / a), $MachinePrecision] + N[(-1.0 / b), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[a, -1.1e+88], N[(N[(N[(-0.5 * N[(Pi / N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / b), $MachinePrecision] / a), $MachinePrecision], If[LessEqual[a, -1e-166], N[(N[(0.5 * N[(N[(Pi / N[(a + b), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision], If[LessEqual[a, 2.6e-107], N[(N[(0.5 * N[(Pi / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision], If[LessEqual[a, 1.5e+138], N[(N[(t$95$0 * N[(Pi * 0.5), $MachinePrecision]), $MachinePrecision] / N[(N[(b * b), $MachinePrecision] - N[(a * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(Pi * -0.5), $MachinePrecision] / N[(b * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / a), $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{1}{a} + \frac{-1}{b}\\
\mathbf{if}\;a \leq -1.1 \cdot 10^{+88}:\\
\;\;\;\;\frac{\frac{-0.5 \cdot \frac{\pi}{b - a}}{b}}{a}\\
\mathbf{elif}\;a \leq -1 \cdot 10^{-166}:\\
\;\;\;\;\left(0.5 \cdot \frac{\frac{\pi}{a + b}}{b - a}\right) \cdot t_0\\
\mathbf{elif}\;a \leq 2.6 \cdot 10^{-107}:\\
\;\;\;\;\frac{0.5 \cdot \frac{\pi}{a \cdot b}}{b - a}\\
\mathbf{elif}\;a \leq 1.5 \cdot 10^{+138}:\\
\;\;\;\;\frac{t_0 \cdot \left(\pi \cdot 0.5\right)}{b \cdot b - a \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{\pi \cdot -0.5}{b \cdot \left(b - a\right)}}{a}\\
\end{array}
\end{array}
if a < -1.10000000000000004e88Initial program 61.2%
times-frac61.4%
*-commutative61.4%
times-frac61.4%
difference-of-squares75.1%
associate-/r*76.8%
metadata-eval76.8%
sub-neg76.8%
distribute-neg-frac76.8%
metadata-eval76.8%
Simplified76.8%
Taylor expanded in a around inf 76.8%
Taylor expanded in b around 0 76.8%
expm1-log1p-u74.8%
expm1-udef59.2%
associate-*l*59.2%
associate-/l/59.2%
Applied egg-rr59.2%
expm1-def73.1%
expm1-log1p75.1%
*-commutative75.1%
associate-/r*76.8%
associate-*r/99.7%
associate-*r/99.7%
metadata-eval99.7%
Simplified99.7%
associate-*l/99.8%
Applied egg-rr99.8%
if -1.10000000000000004e88 < a < -1.00000000000000004e-166Initial program 97.7%
times-frac97.7%
*-commutative97.7%
times-frac97.7%
difference-of-squares99.7%
associate-/r*99.7%
metadata-eval99.7%
sub-neg99.7%
distribute-neg-frac99.7%
metadata-eval99.7%
Simplified99.7%
if -1.00000000000000004e-166 < a < 2.6000000000000001e-107Initial program 75.4%
times-frac75.6%
*-commutative75.6%
times-frac75.6%
difference-of-squares83.3%
associate-/r*83.3%
metadata-eval83.3%
sub-neg83.3%
distribute-neg-frac83.3%
metadata-eval83.3%
Simplified83.3%
frac-add83.2%
*-un-lft-identity83.2%
Applied egg-rr83.2%
*-commutative83.2%
neg-mul-183.2%
sub-neg83.2%
Simplified83.2%
expm1-log1p-u55.9%
expm1-udef49.8%
Applied egg-rr49.8%
expm1-def55.9%
expm1-log1p83.2%
*-commutative83.2%
associate-*l*83.5%
Simplified83.5%
associate-*l/99.5%
Applied egg-rr99.5%
Taylor expanded in a around 0 91.9%
if 2.6000000000000001e-107 < a < 1.50000000000000005e138Initial program 99.5%
associate-*r/99.5%
*-rgt-identity99.5%
sub-neg99.5%
distribute-neg-frac99.5%
metadata-eval99.5%
Simplified99.5%
associate-*l/99.6%
div-inv99.6%
metadata-eval99.6%
Applied egg-rr99.6%
if 1.50000000000000005e138 < a Initial program 67.2%
times-frac67.2%
*-commutative67.2%
times-frac67.2%
difference-of-squares81.5%
associate-/r*83.6%
metadata-eval83.6%
sub-neg83.6%
distribute-neg-frac83.6%
metadata-eval83.6%
Simplified83.6%
Taylor expanded in a around inf 83.6%
Taylor expanded in b around 0 83.6%
expm1-log1p-u83.6%
expm1-udef76.4%
associate-*l*76.4%
associate-/l/76.4%
Applied egg-rr76.4%
expm1-def81.5%
expm1-log1p81.5%
*-commutative81.5%
associate-/r*83.7%
associate-*r/99.7%
associate-*r/99.7%
metadata-eval99.7%
Simplified99.7%
frac-times99.9%
Applied egg-rr99.9%
Final simplification97.7%
(FPCore (a b)
:precision binary64
(let* ((t_0 (* (/ PI (- (* b b) (* a a))) (+ (/ 0.5 a) (/ -0.5 b)))))
(if (<= a -2e+89)
(/ (/ (* -0.5 (/ PI (- b a))) b) a)
(if (<= a -1.7e-151)
t_0
(if (<= a 2.6e-107)
(/ (* 0.5 (/ PI (* a b))) (- b a))
(if (<= a 8e+146) t_0 (/ (/ (* PI -0.5) (* b (- b a))) a)))))))
double code(double a, double b) {
double t_0 = (((double) M_PI) / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b));
double tmp;
if (a <= -2e+89) {
tmp = ((-0.5 * (((double) M_PI) / (b - a))) / b) / a;
} else if (a <= -1.7e-151) {
tmp = t_0;
} else if (a <= 2.6e-107) {
tmp = (0.5 * (((double) M_PI) / (a * b))) / (b - a);
} else if (a <= 8e+146) {
tmp = t_0;
} else {
tmp = ((((double) M_PI) * -0.5) / (b * (b - a))) / a;
}
return tmp;
}
public static double code(double a, double b) {
double t_0 = (Math.PI / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b));
double tmp;
if (a <= -2e+89) {
tmp = ((-0.5 * (Math.PI / (b - a))) / b) / a;
} else if (a <= -1.7e-151) {
tmp = t_0;
} else if (a <= 2.6e-107) {
tmp = (0.5 * (Math.PI / (a * b))) / (b - a);
} else if (a <= 8e+146) {
tmp = t_0;
} else {
tmp = ((Math.PI * -0.5) / (b * (b - a))) / a;
}
return tmp;
}
def code(a, b): t_0 = (math.pi / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b)) tmp = 0 if a <= -2e+89: tmp = ((-0.5 * (math.pi / (b - a))) / b) / a elif a <= -1.7e-151: tmp = t_0 elif a <= 2.6e-107: tmp = (0.5 * (math.pi / (a * b))) / (b - a) elif a <= 8e+146: tmp = t_0 else: tmp = ((math.pi * -0.5) / (b * (b - a))) / a return tmp
function code(a, b) t_0 = Float64(Float64(pi / Float64(Float64(b * b) - Float64(a * a))) * Float64(Float64(0.5 / a) + Float64(-0.5 / b))) tmp = 0.0 if (a <= -2e+89) tmp = Float64(Float64(Float64(-0.5 * Float64(pi / Float64(b - a))) / b) / a); elseif (a <= -1.7e-151) tmp = t_0; elseif (a <= 2.6e-107) tmp = Float64(Float64(0.5 * Float64(pi / Float64(a * b))) / Float64(b - a)); elseif (a <= 8e+146) tmp = t_0; else tmp = Float64(Float64(Float64(pi * -0.5) / Float64(b * Float64(b - a))) / a); end return tmp end
function tmp_2 = code(a, b) t_0 = (pi / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b)); tmp = 0.0; if (a <= -2e+89) tmp = ((-0.5 * (pi / (b - a))) / b) / a; elseif (a <= -1.7e-151) tmp = t_0; elseif (a <= 2.6e-107) tmp = (0.5 * (pi / (a * b))) / (b - a); elseif (a <= 8e+146) tmp = t_0; else tmp = ((pi * -0.5) / (b * (b - a))) / a; end tmp_2 = tmp; end
code[a_, b_] := Block[{t$95$0 = N[(N[(Pi / N[(N[(b * b), $MachinePrecision] - N[(a * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(N[(0.5 / a), $MachinePrecision] + N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[a, -2e+89], N[(N[(N[(-0.5 * N[(Pi / N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / b), $MachinePrecision] / a), $MachinePrecision], If[LessEqual[a, -1.7e-151], t$95$0, If[LessEqual[a, 2.6e-107], N[(N[(0.5 * N[(Pi / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision], If[LessEqual[a, 8e+146], t$95$0, N[(N[(N[(Pi * -0.5), $MachinePrecision] / N[(b * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / a), $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{\pi}{b \cdot b - a \cdot a} \cdot \left(\frac{0.5}{a} + \frac{-0.5}{b}\right)\\
\mathbf{if}\;a \leq -2 \cdot 10^{+89}:\\
\;\;\;\;\frac{\frac{-0.5 \cdot \frac{\pi}{b - a}}{b}}{a}\\
\mathbf{elif}\;a \leq -1.7 \cdot 10^{-151}:\\
\;\;\;\;t_0\\
\mathbf{elif}\;a \leq 2.6 \cdot 10^{-107}:\\
\;\;\;\;\frac{0.5 \cdot \frac{\pi}{a \cdot b}}{b - a}\\
\mathbf{elif}\;a \leq 8 \cdot 10^{+146}:\\
\;\;\;\;t_0\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{\pi \cdot -0.5}{b \cdot \left(b - a\right)}}{a}\\
\end{array}
\end{array}
if a < -1.99999999999999999e89Initial program 61.2%
times-frac61.4%
*-commutative61.4%
times-frac61.4%
difference-of-squares75.1%
associate-/r*76.8%
metadata-eval76.8%
sub-neg76.8%
distribute-neg-frac76.8%
metadata-eval76.8%
Simplified76.8%
Taylor expanded in a around inf 76.8%
Taylor expanded in b around 0 76.8%
expm1-log1p-u74.8%
expm1-udef59.2%
associate-*l*59.2%
associate-/l/59.2%
Applied egg-rr59.2%
expm1-def73.1%
expm1-log1p75.1%
*-commutative75.1%
associate-/r*76.8%
associate-*r/99.7%
associate-*r/99.7%
metadata-eval99.7%
Simplified99.7%
associate-*l/99.8%
Applied egg-rr99.8%
if -1.99999999999999999e89 < a < -1.7000000000000001e-151 or 2.6000000000000001e-107 < a < 7.99999999999999947e146Initial program 99.6%
times-frac99.6%
*-commutative99.6%
times-frac99.6%
difference-of-squares99.6%
associate-/r*99.6%
metadata-eval99.6%
sub-neg99.6%
distribute-neg-frac99.6%
metadata-eval99.6%
Simplified99.6%
distribute-lft-in99.6%
associate-/l/99.5%
associate-/l/99.6%
Applied egg-rr99.6%
distribute-lft-out99.6%
associate-*r*99.6%
associate-*l/99.6%
*-commutative99.6%
difference-of-squares99.6%
associate-*l/99.6%
distribute-lft-in99.6%
associate-*r/99.6%
metadata-eval99.6%
associate-*r/99.6%
metadata-eval99.6%
Simplified99.6%
if -1.7000000000000001e-151 < a < 2.6000000000000001e-107Initial program 76.4%
times-frac76.5%
*-commutative76.5%
times-frac76.5%
difference-of-squares84.9%
associate-/r*84.9%
metadata-eval84.9%
sub-neg84.9%
distribute-neg-frac84.9%
metadata-eval84.9%
Simplified84.9%
frac-add84.8%
*-un-lft-identity84.8%
Applied egg-rr84.8%
*-commutative84.8%
neg-mul-184.8%
sub-neg84.8%
Simplified84.8%
expm1-log1p-u53.3%
expm1-udef47.7%
Applied egg-rr47.7%
expm1-def53.3%
expm1-log1p84.8%
*-commutative84.8%
associate-*l*85.1%
Simplified85.1%
associate-*l/99.5%
Applied egg-rr99.5%
Taylor expanded in a around 0 91.3%
if 7.99999999999999947e146 < a Initial program 61.7%
times-frac61.7%
*-commutative61.7%
times-frac61.7%
difference-of-squares78.4%
associate-/r*81.0%
metadata-eval81.0%
sub-neg81.0%
distribute-neg-frac81.0%
metadata-eval81.0%
Simplified81.0%
Taylor expanded in a around inf 81.0%
Taylor expanded in b around 0 81.0%
expm1-log1p-u81.0%
expm1-udef78.4%
associate-*l*78.4%
associate-/l/78.4%
Applied egg-rr78.4%
expm1-def78.4%
expm1-log1p78.4%
*-commutative78.4%
associate-/r*81.0%
associate-*r/99.8%
associate-*r/99.8%
metadata-eval99.8%
Simplified99.8%
frac-times99.9%
Applied egg-rr99.9%
Final simplification97.3%
(FPCore (a b)
:precision binary64
(if (<= a -1.2e+87)
(/ (/ (* -0.5 (/ PI (- b a))) b) a)
(if (<= a -1.08e-166)
(* (* 0.5 (/ (/ PI (+ a b)) (- b a))) (+ (/ 1.0 a) (/ -1.0 b)))
(if (<= a 2.6e-107)
(/ (* 0.5 (/ PI (* a b))) (- b a))
(if (<= a 1.8e+147)
(* (/ PI (- (* b b) (* a a))) (+ (/ 0.5 a) (/ -0.5 b)))
(/ (/ (* PI -0.5) (* b (- b a))) a))))))
double code(double a, double b) {
double tmp;
if (a <= -1.2e+87) {
tmp = ((-0.5 * (((double) M_PI) / (b - a))) / b) / a;
} else if (a <= -1.08e-166) {
tmp = (0.5 * ((((double) M_PI) / (a + b)) / (b - a))) * ((1.0 / a) + (-1.0 / b));
} else if (a <= 2.6e-107) {
tmp = (0.5 * (((double) M_PI) / (a * b))) / (b - a);
} else if (a <= 1.8e+147) {
tmp = (((double) M_PI) / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b));
} else {
tmp = ((((double) M_PI) * -0.5) / (b * (b - a))) / a;
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if (a <= -1.2e+87) {
tmp = ((-0.5 * (Math.PI / (b - a))) / b) / a;
} else if (a <= -1.08e-166) {
tmp = (0.5 * ((Math.PI / (a + b)) / (b - a))) * ((1.0 / a) + (-1.0 / b));
} else if (a <= 2.6e-107) {
tmp = (0.5 * (Math.PI / (a * b))) / (b - a);
} else if (a <= 1.8e+147) {
tmp = (Math.PI / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b));
} else {
tmp = ((Math.PI * -0.5) / (b * (b - a))) / a;
}
return tmp;
}
def code(a, b): tmp = 0 if a <= -1.2e+87: tmp = ((-0.5 * (math.pi / (b - a))) / b) / a elif a <= -1.08e-166: tmp = (0.5 * ((math.pi / (a + b)) / (b - a))) * ((1.0 / a) + (-1.0 / b)) elif a <= 2.6e-107: tmp = (0.5 * (math.pi / (a * b))) / (b - a) elif a <= 1.8e+147: tmp = (math.pi / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b)) else: tmp = ((math.pi * -0.5) / (b * (b - a))) / a return tmp
function code(a, b) tmp = 0.0 if (a <= -1.2e+87) tmp = Float64(Float64(Float64(-0.5 * Float64(pi / Float64(b - a))) / b) / a); elseif (a <= -1.08e-166) tmp = Float64(Float64(0.5 * Float64(Float64(pi / Float64(a + b)) / Float64(b - a))) * Float64(Float64(1.0 / a) + Float64(-1.0 / b))); elseif (a <= 2.6e-107) tmp = Float64(Float64(0.5 * Float64(pi / Float64(a * b))) / Float64(b - a)); elseif (a <= 1.8e+147) tmp = Float64(Float64(pi / Float64(Float64(b * b) - Float64(a * a))) * Float64(Float64(0.5 / a) + Float64(-0.5 / b))); else tmp = Float64(Float64(Float64(pi * -0.5) / Float64(b * Float64(b - a))) / a); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if (a <= -1.2e+87) tmp = ((-0.5 * (pi / (b - a))) / b) / a; elseif (a <= -1.08e-166) tmp = (0.5 * ((pi / (a + b)) / (b - a))) * ((1.0 / a) + (-1.0 / b)); elseif (a <= 2.6e-107) tmp = (0.5 * (pi / (a * b))) / (b - a); elseif (a <= 1.8e+147) tmp = (pi / ((b * b) - (a * a))) * ((0.5 / a) + (-0.5 / b)); else tmp = ((pi * -0.5) / (b * (b - a))) / a; end tmp_2 = tmp; end
code[a_, b_] := If[LessEqual[a, -1.2e+87], N[(N[(N[(-0.5 * N[(Pi / N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / b), $MachinePrecision] / a), $MachinePrecision], If[LessEqual[a, -1.08e-166], N[(N[(0.5 * N[(N[(Pi / N[(a + b), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(N[(1.0 / a), $MachinePrecision] + N[(-1.0 / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[a, 2.6e-107], N[(N[(0.5 * N[(Pi / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision], If[LessEqual[a, 1.8e+147], N[(N[(Pi / N[(N[(b * b), $MachinePrecision] - N[(a * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(N[(0.5 / a), $MachinePrecision] + N[(-0.5 / b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(Pi * -0.5), $MachinePrecision] / N[(b * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / a), $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -1.2 \cdot 10^{+87}:\\
\;\;\;\;\frac{\frac{-0.5 \cdot \frac{\pi}{b - a}}{b}}{a}\\
\mathbf{elif}\;a \leq -1.08 \cdot 10^{-166}:\\
\;\;\;\;\left(0.5 \cdot \frac{\frac{\pi}{a + b}}{b - a}\right) \cdot \left(\frac{1}{a} + \frac{-1}{b}\right)\\
\mathbf{elif}\;a \leq 2.6 \cdot 10^{-107}:\\
\;\;\;\;\frac{0.5 \cdot \frac{\pi}{a \cdot b}}{b - a}\\
\mathbf{elif}\;a \leq 1.8 \cdot 10^{+147}:\\
\;\;\;\;\frac{\pi}{b \cdot b - a \cdot a} \cdot \left(\frac{0.5}{a} + \frac{-0.5}{b}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{\pi \cdot -0.5}{b \cdot \left(b - a\right)}}{a}\\
\end{array}
\end{array}
if a < -1.19999999999999991e87Initial program 61.2%
times-frac61.4%
*-commutative61.4%
times-frac61.4%
difference-of-squares75.1%
associate-/r*76.8%
metadata-eval76.8%
sub-neg76.8%
distribute-neg-frac76.8%
metadata-eval76.8%
Simplified76.8%
Taylor expanded in a around inf 76.8%
Taylor expanded in b around 0 76.8%
expm1-log1p-u74.8%
expm1-udef59.2%
associate-*l*59.2%
associate-/l/59.2%
Applied egg-rr59.2%
expm1-def73.1%
expm1-log1p75.1%
*-commutative75.1%
associate-/r*76.8%
associate-*r/99.7%
associate-*r/99.7%
metadata-eval99.7%
Simplified99.7%
associate-*l/99.8%
Applied egg-rr99.8%
if -1.19999999999999991e87 < a < -1.08e-166Initial program 97.7%
times-frac97.7%
*-commutative97.7%
times-frac97.7%
difference-of-squares99.7%
associate-/r*99.7%
metadata-eval99.7%
sub-neg99.7%
distribute-neg-frac99.7%
metadata-eval99.7%
Simplified99.7%
if -1.08e-166 < a < 2.6000000000000001e-107Initial program 75.4%
times-frac75.6%
*-commutative75.6%
times-frac75.6%
difference-of-squares83.3%
associate-/r*83.3%
metadata-eval83.3%
sub-neg83.3%
distribute-neg-frac83.3%
metadata-eval83.3%
Simplified83.3%
frac-add83.2%
*-un-lft-identity83.2%
Applied egg-rr83.2%
*-commutative83.2%
neg-mul-183.2%
sub-neg83.2%
Simplified83.2%
expm1-log1p-u55.9%
expm1-udef49.8%
Applied egg-rr49.8%
expm1-def55.9%
expm1-log1p83.2%
*-commutative83.2%
associate-*l*83.5%
Simplified83.5%
associate-*l/99.5%
Applied egg-rr99.5%
Taylor expanded in a around 0 91.9%
if 2.6000000000000001e-107 < a < 1.8000000000000001e147Initial program 99.5%
times-frac99.6%
*-commutative99.6%
times-frac99.6%
difference-of-squares99.6%
associate-/r*99.5%
metadata-eval99.5%
sub-neg99.5%
distribute-neg-frac99.5%
metadata-eval99.5%
Simplified99.5%
distribute-lft-in99.5%
associate-/l/99.5%
associate-/l/99.6%
Applied egg-rr99.6%
distribute-lft-out99.6%
associate-*r*99.6%
associate-*l/99.6%
*-commutative99.6%
difference-of-squares99.6%
associate-*l/99.6%
distribute-lft-in99.6%
associate-*r/99.6%
metadata-eval99.6%
associate-*r/99.6%
metadata-eval99.6%
Simplified99.6%
if 1.8000000000000001e147 < a Initial program 61.7%
times-frac61.7%
*-commutative61.7%
times-frac61.7%
difference-of-squares78.4%
associate-/r*81.0%
metadata-eval81.0%
sub-neg81.0%
distribute-neg-frac81.0%
metadata-eval81.0%
Simplified81.0%
Taylor expanded in a around inf 81.0%
Taylor expanded in b around 0 81.0%
expm1-log1p-u81.0%
expm1-udef78.4%
associate-*l*78.4%
associate-/l/78.4%
Applied egg-rr78.4%
expm1-def78.4%
expm1-log1p78.4%
*-commutative78.4%
associate-/r*81.0%
associate-*r/99.8%
associate-*r/99.8%
metadata-eval99.8%
Simplified99.8%
frac-times99.9%
Applied egg-rr99.9%
Final simplification97.7%
(FPCore (a b) :precision binary64 (if (or (<= a -1.05e-102) (not (<= a 3.3e-96))) (* (/ PI (- b a)) (/ (/ -0.5 b) a)) (* (/ 0.5 a) (/ PI (* b b)))))
double code(double a, double b) {
double tmp;
if ((a <= -1.05e-102) || !(a <= 3.3e-96)) {
tmp = (((double) M_PI) / (b - a)) * ((-0.5 / b) / a);
} else {
tmp = (0.5 / a) * (((double) M_PI) / (b * b));
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if ((a <= -1.05e-102) || !(a <= 3.3e-96)) {
tmp = (Math.PI / (b - a)) * ((-0.5 / b) / a);
} else {
tmp = (0.5 / a) * (Math.PI / (b * b));
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -1.05e-102) or not (a <= 3.3e-96): tmp = (math.pi / (b - a)) * ((-0.5 / b) / a) else: tmp = (0.5 / a) * (math.pi / (b * b)) return tmp
function code(a, b) tmp = 0.0 if ((a <= -1.05e-102) || !(a <= 3.3e-96)) tmp = Float64(Float64(pi / Float64(b - a)) * Float64(Float64(-0.5 / b) / a)); else tmp = Float64(Float64(0.5 / a) * Float64(pi / Float64(b * b))); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -1.05e-102) || ~((a <= 3.3e-96))) tmp = (pi / (b - a)) * ((-0.5 / b) / a); else tmp = (0.5 / a) * (pi / (b * b)); end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -1.05e-102], N[Not[LessEqual[a, 3.3e-96]], $MachinePrecision]], N[(N[(Pi / N[(b - a), $MachinePrecision]), $MachinePrecision] * N[(N[(-0.5 / b), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision], N[(N[(0.5 / a), $MachinePrecision] * N[(Pi / N[(b * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -1.05 \cdot 10^{-102} \lor \neg \left(a \leq 3.3 \cdot 10^{-96}\right):\\
\;\;\;\;\frac{\pi}{b - a} \cdot \frac{\frac{-0.5}{b}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{0.5}{a} \cdot \frac{\pi}{b \cdot b}\\
\end{array}
\end{array}
if a < -1.05e-102 or 3.2999999999999999e-96 < a Initial program 80.6%
times-frac80.7%
*-commutative80.7%
times-frac80.7%
difference-of-squares88.1%
associate-/r*89.1%
metadata-eval89.1%
sub-neg89.1%
distribute-neg-frac89.1%
metadata-eval89.1%
Simplified89.1%
Taylor expanded in a around inf 81.0%
Taylor expanded in b around 0 80.9%
expm1-log1p-u68.3%
expm1-udef58.2%
associate-*l*58.2%
associate-/l/58.2%
Applied egg-rr58.2%
expm1-def67.3%
expm1-log1p79.9%
*-commutative79.9%
associate-/r*80.9%
associate-*r/91.4%
associate-*r/91.4%
metadata-eval91.4%
Simplified91.4%
expm1-log1p-u78.8%
expm1-udef58.2%
associate-/l*58.2%
Applied egg-rr58.2%
expm1-def67.8%
expm1-log1p80.4%
associate-/r/91.4%
Simplified91.4%
if -1.05e-102 < a < 3.2999999999999999e-96Initial program 79.0%
times-frac79.1%
*-commutative79.1%
times-frac79.1%
difference-of-squares86.5%
associate-/r*86.6%
metadata-eval86.6%
sub-neg86.6%
distribute-neg-frac86.6%
metadata-eval86.6%
Simplified86.6%
frac-add86.5%
*-un-lft-identity86.5%
Applied egg-rr86.5%
*-commutative86.5%
neg-mul-186.5%
sub-neg86.5%
Simplified86.5%
expm1-log1p-u53.5%
expm1-udef48.6%
Applied egg-rr48.6%
expm1-def53.5%
expm1-log1p86.5%
*-commutative86.5%
associate-*l*86.7%
Simplified86.7%
Taylor expanded in a around 0 81.5%
associate-*r/81.5%
*-commutative81.5%
*-commutative81.5%
times-frac81.5%
unpow281.5%
Simplified81.5%
Final simplification88.3%
(FPCore (a b) :precision binary64 (if (or (<= a -2.6e-103) (not (<= a 9.2e-99))) (* (/ PI (- b a)) (/ (/ -0.5 b) a)) (/ (* 0.5 (/ PI (* a b))) (- b a))))
double code(double a, double b) {
double tmp;
if ((a <= -2.6e-103) || !(a <= 9.2e-99)) {
tmp = (((double) M_PI) / (b - a)) * ((-0.5 / b) / a);
} else {
tmp = (0.5 * (((double) M_PI) / (a * b))) / (b - a);
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if ((a <= -2.6e-103) || !(a <= 9.2e-99)) {
tmp = (Math.PI / (b - a)) * ((-0.5 / b) / a);
} else {
tmp = (0.5 * (Math.PI / (a * b))) / (b - a);
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -2.6e-103) or not (a <= 9.2e-99): tmp = (math.pi / (b - a)) * ((-0.5 / b) / a) else: tmp = (0.5 * (math.pi / (a * b))) / (b - a) return tmp
function code(a, b) tmp = 0.0 if ((a <= -2.6e-103) || !(a <= 9.2e-99)) tmp = Float64(Float64(pi / Float64(b - a)) * Float64(Float64(-0.5 / b) / a)); else tmp = Float64(Float64(0.5 * Float64(pi / Float64(a * b))) / Float64(b - a)); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -2.6e-103) || ~((a <= 9.2e-99))) tmp = (pi / (b - a)) * ((-0.5 / b) / a); else tmp = (0.5 * (pi / (a * b))) / (b - a); end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -2.6e-103], N[Not[LessEqual[a, 9.2e-99]], $MachinePrecision]], N[(N[(Pi / N[(b - a), $MachinePrecision]), $MachinePrecision] * N[(N[(-0.5 / b), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision], N[(N[(0.5 * N[(Pi / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -2.6 \cdot 10^{-103} \lor \neg \left(a \leq 9.2 \cdot 10^{-99}\right):\\
\;\;\;\;\frac{\pi}{b - a} \cdot \frac{\frac{-0.5}{b}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{0.5 \cdot \frac{\pi}{a \cdot b}}{b - a}\\
\end{array}
\end{array}
if a < -2.59999999999999996e-103 or 9.1999999999999994e-99 < a Initial program 80.6%
times-frac80.7%
*-commutative80.7%
times-frac80.7%
difference-of-squares88.1%
associate-/r*89.1%
metadata-eval89.1%
sub-neg89.1%
distribute-neg-frac89.1%
metadata-eval89.1%
Simplified89.1%
Taylor expanded in a around inf 81.0%
Taylor expanded in b around 0 80.9%
expm1-log1p-u68.3%
expm1-udef58.2%
associate-*l*58.2%
associate-/l/58.2%
Applied egg-rr58.2%
expm1-def67.3%
expm1-log1p79.9%
*-commutative79.9%
associate-/r*80.9%
associate-*r/91.4%
associate-*r/91.4%
metadata-eval91.4%
Simplified91.4%
expm1-log1p-u78.8%
expm1-udef58.2%
associate-/l*58.2%
Applied egg-rr58.2%
expm1-def67.8%
expm1-log1p80.4%
associate-/r/91.4%
Simplified91.4%
if -2.59999999999999996e-103 < a < 9.1999999999999994e-99Initial program 79.0%
times-frac79.1%
*-commutative79.1%
times-frac79.1%
difference-of-squares86.5%
associate-/r*86.6%
metadata-eval86.6%
sub-neg86.6%
distribute-neg-frac86.6%
metadata-eval86.6%
Simplified86.6%
frac-add86.5%
*-un-lft-identity86.5%
Applied egg-rr86.5%
*-commutative86.5%
neg-mul-186.5%
sub-neg86.5%
Simplified86.5%
expm1-log1p-u53.5%
expm1-udef48.6%
Applied egg-rr48.6%
expm1-def53.5%
expm1-log1p86.5%
*-commutative86.5%
associate-*l*86.7%
Simplified86.7%
associate-*l/99.5%
Applied egg-rr99.5%
Taylor expanded in a around 0 88.4%
Final simplification90.5%
(FPCore (a b) :precision binary64 (if (or (<= a -1.9e-104) (not (<= a 2.35e-101))) (/ (/ (* PI -0.5) (* b (- b a))) a) (/ (* 0.5 (/ PI (* a b))) (- b a))))
double code(double a, double b) {
double tmp;
if ((a <= -1.9e-104) || !(a <= 2.35e-101)) {
tmp = ((((double) M_PI) * -0.5) / (b * (b - a))) / a;
} else {
tmp = (0.5 * (((double) M_PI) / (a * b))) / (b - a);
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if ((a <= -1.9e-104) || !(a <= 2.35e-101)) {
tmp = ((Math.PI * -0.5) / (b * (b - a))) / a;
} else {
tmp = (0.5 * (Math.PI / (a * b))) / (b - a);
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -1.9e-104) or not (a <= 2.35e-101): tmp = ((math.pi * -0.5) / (b * (b - a))) / a else: tmp = (0.5 * (math.pi / (a * b))) / (b - a) return tmp
function code(a, b) tmp = 0.0 if ((a <= -1.9e-104) || !(a <= 2.35e-101)) tmp = Float64(Float64(Float64(pi * -0.5) / Float64(b * Float64(b - a))) / a); else tmp = Float64(Float64(0.5 * Float64(pi / Float64(a * b))) / Float64(b - a)); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -1.9e-104) || ~((a <= 2.35e-101))) tmp = ((pi * -0.5) / (b * (b - a))) / a; else tmp = (0.5 * (pi / (a * b))) / (b - a); end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -1.9e-104], N[Not[LessEqual[a, 2.35e-101]], $MachinePrecision]], N[(N[(N[(Pi * -0.5), $MachinePrecision] / N[(b * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / a), $MachinePrecision], N[(N[(0.5 * N[(Pi / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -1.9 \cdot 10^{-104} \lor \neg \left(a \leq 2.35 \cdot 10^{-101}\right):\\
\;\;\;\;\frac{\frac{\pi \cdot -0.5}{b \cdot \left(b - a\right)}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{0.5 \cdot \frac{\pi}{a \cdot b}}{b - a}\\
\end{array}
\end{array}
if a < -1.9e-104 or 2.35e-101 < a Initial program 80.6%
times-frac80.7%
*-commutative80.7%
times-frac80.7%
difference-of-squares88.1%
associate-/r*89.1%
metadata-eval89.1%
sub-neg89.1%
distribute-neg-frac89.1%
metadata-eval89.1%
Simplified89.1%
Taylor expanded in a around inf 81.0%
Taylor expanded in b around 0 80.9%
expm1-log1p-u68.3%
expm1-udef58.2%
associate-*l*58.2%
associate-/l/58.2%
Applied egg-rr58.2%
expm1-def67.3%
expm1-log1p79.9%
*-commutative79.9%
associate-/r*80.9%
associate-*r/91.4%
associate-*r/91.4%
metadata-eval91.4%
Simplified91.4%
frac-times91.5%
Applied egg-rr91.5%
if -1.9e-104 < a < 2.35e-101Initial program 79.0%
times-frac79.1%
*-commutative79.1%
times-frac79.1%
difference-of-squares86.5%
associate-/r*86.6%
metadata-eval86.6%
sub-neg86.6%
distribute-neg-frac86.6%
metadata-eval86.6%
Simplified86.6%
frac-add86.5%
*-un-lft-identity86.5%
Applied egg-rr86.5%
*-commutative86.5%
neg-mul-186.5%
sub-neg86.5%
Simplified86.5%
expm1-log1p-u53.5%
expm1-udef48.6%
Applied egg-rr48.6%
expm1-def53.5%
expm1-log1p86.5%
*-commutative86.5%
associate-*l*86.7%
Simplified86.7%
associate-*l/99.5%
Applied egg-rr99.5%
Taylor expanded in a around 0 88.4%
Final simplification90.5%
(FPCore (a b) :precision binary64 (if (or (<= a -2.1e-102) (not (<= a 1.7e-101))) (/ (/ (* -0.5 (/ PI (- b a))) b) a) (/ (* 0.5 (/ PI (* a b))) (- b a))))
double code(double a, double b) {
double tmp;
if ((a <= -2.1e-102) || !(a <= 1.7e-101)) {
tmp = ((-0.5 * (((double) M_PI) / (b - a))) / b) / a;
} else {
tmp = (0.5 * (((double) M_PI) / (a * b))) / (b - a);
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if ((a <= -2.1e-102) || !(a <= 1.7e-101)) {
tmp = ((-0.5 * (Math.PI / (b - a))) / b) / a;
} else {
tmp = (0.5 * (Math.PI / (a * b))) / (b - a);
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -2.1e-102) or not (a <= 1.7e-101): tmp = ((-0.5 * (math.pi / (b - a))) / b) / a else: tmp = (0.5 * (math.pi / (a * b))) / (b - a) return tmp
function code(a, b) tmp = 0.0 if ((a <= -2.1e-102) || !(a <= 1.7e-101)) tmp = Float64(Float64(Float64(-0.5 * Float64(pi / Float64(b - a))) / b) / a); else tmp = Float64(Float64(0.5 * Float64(pi / Float64(a * b))) / Float64(b - a)); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -2.1e-102) || ~((a <= 1.7e-101))) tmp = ((-0.5 * (pi / (b - a))) / b) / a; else tmp = (0.5 * (pi / (a * b))) / (b - a); end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -2.1e-102], N[Not[LessEqual[a, 1.7e-101]], $MachinePrecision]], N[(N[(N[(-0.5 * N[(Pi / N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / b), $MachinePrecision] / a), $MachinePrecision], N[(N[(0.5 * N[(Pi / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -2.1 \cdot 10^{-102} \lor \neg \left(a \leq 1.7 \cdot 10^{-101}\right):\\
\;\;\;\;\frac{\frac{-0.5 \cdot \frac{\pi}{b - a}}{b}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{0.5 \cdot \frac{\pi}{a \cdot b}}{b - a}\\
\end{array}
\end{array}
if a < -2.1e-102 or 1.69999999999999995e-101 < a Initial program 80.6%
times-frac80.7%
*-commutative80.7%
times-frac80.7%
difference-of-squares88.1%
associate-/r*89.1%
metadata-eval89.1%
sub-neg89.1%
distribute-neg-frac89.1%
metadata-eval89.1%
Simplified89.1%
Taylor expanded in a around inf 81.0%
Taylor expanded in b around 0 80.9%
expm1-log1p-u68.3%
expm1-udef58.2%
associate-*l*58.2%
associate-/l/58.2%
Applied egg-rr58.2%
expm1-def67.3%
expm1-log1p79.9%
*-commutative79.9%
associate-/r*80.9%
associate-*r/91.4%
associate-*r/91.4%
metadata-eval91.4%
Simplified91.4%
associate-*l/91.5%
Applied egg-rr91.5%
if -2.1e-102 < a < 1.69999999999999995e-101Initial program 79.0%
times-frac79.1%
*-commutative79.1%
times-frac79.1%
difference-of-squares86.5%
associate-/r*86.6%
metadata-eval86.6%
sub-neg86.6%
distribute-neg-frac86.6%
metadata-eval86.6%
Simplified86.6%
frac-add86.5%
*-un-lft-identity86.5%
Applied egg-rr86.5%
*-commutative86.5%
neg-mul-186.5%
sub-neg86.5%
Simplified86.5%
expm1-log1p-u53.5%
expm1-udef48.6%
Applied egg-rr48.6%
expm1-def53.5%
expm1-log1p86.5%
*-commutative86.5%
associate-*l*86.7%
Simplified86.7%
associate-*l/99.5%
Applied egg-rr99.5%
Taylor expanded in a around 0 88.4%
Final simplification90.6%
(FPCore (a b)
:precision binary64
(let* ((t_0 (/ PI (- b a))))
(if (<= a -1.86e-104)
(/ (* t_0 (/ -0.5 b)) a)
(if (<= a 6.6e-105)
(/ (* 0.5 (/ PI (* a b))) (- b a))
(* t_0 (/ (/ -0.5 b) a))))))
double code(double a, double b) {
double t_0 = ((double) M_PI) / (b - a);
double tmp;
if (a <= -1.86e-104) {
tmp = (t_0 * (-0.5 / b)) / a;
} else if (a <= 6.6e-105) {
tmp = (0.5 * (((double) M_PI) / (a * b))) / (b - a);
} else {
tmp = t_0 * ((-0.5 / b) / a);
}
return tmp;
}
public static double code(double a, double b) {
double t_0 = Math.PI / (b - a);
double tmp;
if (a <= -1.86e-104) {
tmp = (t_0 * (-0.5 / b)) / a;
} else if (a <= 6.6e-105) {
tmp = (0.5 * (Math.PI / (a * b))) / (b - a);
} else {
tmp = t_0 * ((-0.5 / b) / a);
}
return tmp;
}
def code(a, b): t_0 = math.pi / (b - a) tmp = 0 if a <= -1.86e-104: tmp = (t_0 * (-0.5 / b)) / a elif a <= 6.6e-105: tmp = (0.5 * (math.pi / (a * b))) / (b - a) else: tmp = t_0 * ((-0.5 / b) / a) return tmp
function code(a, b) t_0 = Float64(pi / Float64(b - a)) tmp = 0.0 if (a <= -1.86e-104) tmp = Float64(Float64(t_0 * Float64(-0.5 / b)) / a); elseif (a <= 6.6e-105) tmp = Float64(Float64(0.5 * Float64(pi / Float64(a * b))) / Float64(b - a)); else tmp = Float64(t_0 * Float64(Float64(-0.5 / b) / a)); end return tmp end
function tmp_2 = code(a, b) t_0 = pi / (b - a); tmp = 0.0; if (a <= -1.86e-104) tmp = (t_0 * (-0.5 / b)) / a; elseif (a <= 6.6e-105) tmp = (0.5 * (pi / (a * b))) / (b - a); else tmp = t_0 * ((-0.5 / b) / a); end tmp_2 = tmp; end
code[a_, b_] := Block[{t$95$0 = N[(Pi / N[(b - a), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[a, -1.86e-104], N[(N[(t$95$0 * N[(-0.5 / b), $MachinePrecision]), $MachinePrecision] / a), $MachinePrecision], If[LessEqual[a, 6.6e-105], N[(N[(0.5 * N[(Pi / N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(b - a), $MachinePrecision]), $MachinePrecision], N[(t$95$0 * N[(N[(-0.5 / b), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \frac{\pi}{b - a}\\
\mathbf{if}\;a \leq -1.86 \cdot 10^{-104}:\\
\;\;\;\;\frac{t_0 \cdot \frac{-0.5}{b}}{a}\\
\mathbf{elif}\;a \leq 6.6 \cdot 10^{-105}:\\
\;\;\;\;\frac{0.5 \cdot \frac{\pi}{a \cdot b}}{b - a}\\
\mathbf{else}:\\
\;\;\;\;t_0 \cdot \frac{\frac{-0.5}{b}}{a}\\
\end{array}
\end{array}
if a < -1.8599999999999999e-104Initial program 76.8%
times-frac76.9%
*-commutative76.9%
times-frac76.9%
difference-of-squares85.0%
associate-/r*86.1%
metadata-eval86.1%
sub-neg86.1%
distribute-neg-frac86.1%
metadata-eval86.1%
Simplified86.1%
Taylor expanded in a around inf 78.5%
Taylor expanded in b around 0 78.3%
expm1-log1p-u64.9%
expm1-udef52.4%
associate-*l*52.4%
associate-/l/52.4%
Applied egg-rr52.4%
expm1-def63.8%
expm1-log1p77.3%
*-commutative77.3%
associate-/r*78.3%
associate-*r/91.9%
associate-*r/91.9%
metadata-eval91.9%
Simplified91.9%
if -1.8599999999999999e-104 < a < 6.5999999999999997e-105Initial program 79.0%
times-frac79.1%
*-commutative79.1%
times-frac79.1%
difference-of-squares86.5%
associate-/r*86.6%
metadata-eval86.6%
sub-neg86.6%
distribute-neg-frac86.6%
metadata-eval86.6%
Simplified86.6%
frac-add86.5%
*-un-lft-identity86.5%
Applied egg-rr86.5%
*-commutative86.5%
neg-mul-186.5%
sub-neg86.5%
Simplified86.5%
expm1-log1p-u53.5%
expm1-udef48.6%
Applied egg-rr48.6%
expm1-def53.5%
expm1-log1p86.5%
*-commutative86.5%
associate-*l*86.7%
Simplified86.7%
associate-*l/99.5%
Applied egg-rr99.5%
Taylor expanded in a around 0 88.4%
if 6.5999999999999997e-105 < a Initial program 84.2%
times-frac84.3%
*-commutative84.3%
times-frac84.3%
difference-of-squares91.0%
associate-/r*92.0%
metadata-eval92.0%
sub-neg92.0%
distribute-neg-frac92.0%
metadata-eval92.0%
Simplified92.0%
Taylor expanded in a around inf 83.5%
Taylor expanded in b around 0 83.4%
expm1-log1p-u71.6%
expm1-udef63.8%
associate-*l*63.8%
associate-/l/63.8%
Applied egg-rr63.8%
expm1-def70.6%
expm1-log1p82.4%
*-commutative82.4%
associate-/r*83.4%
associate-*r/91.0%
associate-*r/91.0%
metadata-eval91.0%
Simplified91.0%
expm1-log1p-u79.2%
expm1-udef63.8%
associate-/l*63.8%
Applied egg-rr63.8%
expm1-def71.6%
expm1-log1p83.5%
associate-/r/91.1%
Simplified91.1%
Final simplification90.5%
(FPCore (a b) :precision binary64 (if (or (<= a -2.2e-65) (not (<= a 1.12e-38))) (* 0.5 (/ PI (* a (* a b)))) (* 0.5 (/ PI (* a (* b b))))))
double code(double a, double b) {
double tmp;
if ((a <= -2.2e-65) || !(a <= 1.12e-38)) {
tmp = 0.5 * (((double) M_PI) / (a * (a * b)));
} else {
tmp = 0.5 * (((double) M_PI) / (a * (b * b)));
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if ((a <= -2.2e-65) || !(a <= 1.12e-38)) {
tmp = 0.5 * (Math.PI / (a * (a * b)));
} else {
tmp = 0.5 * (Math.PI / (a * (b * b)));
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -2.2e-65) or not (a <= 1.12e-38): tmp = 0.5 * (math.pi / (a * (a * b))) else: tmp = 0.5 * (math.pi / (a * (b * b))) return tmp
function code(a, b) tmp = 0.0 if ((a <= -2.2e-65) || !(a <= 1.12e-38)) tmp = Float64(0.5 * Float64(pi / Float64(a * Float64(a * b)))); else tmp = Float64(0.5 * Float64(pi / Float64(a * Float64(b * b)))); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -2.2e-65) || ~((a <= 1.12e-38))) tmp = 0.5 * (pi / (a * (a * b))); else tmp = 0.5 * (pi / (a * (b * b))); end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -2.2e-65], N[Not[LessEqual[a, 1.12e-38]], $MachinePrecision]], N[(0.5 * N[(Pi / N[(a * N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(0.5 * N[(Pi / N[(a * N[(b * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -2.2 \cdot 10^{-65} \lor \neg \left(a \leq 1.12 \cdot 10^{-38}\right):\\
\;\;\;\;0.5 \cdot \frac{\pi}{a \cdot \left(a \cdot b\right)}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \frac{\pi}{a \cdot \left(b \cdot b\right)}\\
\end{array}
\end{array}
if a < -2.20000000000000021e-65 or 1.1200000000000001e-38 < a Initial program 78.1%
times-frac78.2%
*-commutative78.2%
times-frac78.2%
difference-of-squares86.6%
associate-/r*87.7%
metadata-eval87.7%
sub-neg87.7%
distribute-neg-frac87.7%
metadata-eval87.7%
Simplified87.7%
frac-add87.7%
*-un-lft-identity87.7%
Applied egg-rr87.7%
*-commutative87.7%
neg-mul-187.7%
sub-neg87.7%
Simplified87.7%
expm1-log1p-u76.1%
expm1-udef58.6%
Applied egg-rr58.6%
expm1-def76.1%
expm1-log1p87.7%
*-commutative87.7%
associate-*l*87.7%
Simplified87.7%
Taylor expanded in a around inf 77.6%
unpow277.6%
associate-*l*89.6%
Simplified89.6%
if -2.20000000000000021e-65 < a < 1.1200000000000001e-38Initial program 83.1%
*-commutative83.1%
associate-/r/83.2%
associate-*l/83.1%
*-commutative83.1%
associate-/r/83.1%
times-frac83.1%
Simplified83.1%
Taylor expanded in b around inf 80.2%
unpow280.2%
Simplified80.2%
Final simplification85.9%
(FPCore (a b) :precision binary64 (if (or (<= a -4.2e-65) (not (<= a 1.55e-38))) (* 0.5 (/ PI (* a (* a b)))) (* (/ 0.5 a) (/ PI (* b b)))))
double code(double a, double b) {
double tmp;
if ((a <= -4.2e-65) || !(a <= 1.55e-38)) {
tmp = 0.5 * (((double) M_PI) / (a * (a * b)));
} else {
tmp = (0.5 / a) * (((double) M_PI) / (b * b));
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if ((a <= -4.2e-65) || !(a <= 1.55e-38)) {
tmp = 0.5 * (Math.PI / (a * (a * b)));
} else {
tmp = (0.5 / a) * (Math.PI / (b * b));
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -4.2e-65) or not (a <= 1.55e-38): tmp = 0.5 * (math.pi / (a * (a * b))) else: tmp = (0.5 / a) * (math.pi / (b * b)) return tmp
function code(a, b) tmp = 0.0 if ((a <= -4.2e-65) || !(a <= 1.55e-38)) tmp = Float64(0.5 * Float64(pi / Float64(a * Float64(a * b)))); else tmp = Float64(Float64(0.5 / a) * Float64(pi / Float64(b * b))); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -4.2e-65) || ~((a <= 1.55e-38))) tmp = 0.5 * (pi / (a * (a * b))); else tmp = (0.5 / a) * (pi / (b * b)); end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -4.2e-65], N[Not[LessEqual[a, 1.55e-38]], $MachinePrecision]], N[(0.5 * N[(Pi / N[(a * N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(0.5 / a), $MachinePrecision] * N[(Pi / N[(b * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -4.2 \cdot 10^{-65} \lor \neg \left(a \leq 1.55 \cdot 10^{-38}\right):\\
\;\;\;\;0.5 \cdot \frac{\pi}{a \cdot \left(a \cdot b\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{0.5}{a} \cdot \frac{\pi}{b \cdot b}\\
\end{array}
\end{array}
if a < -4.20000000000000006e-65 or 1.54999999999999991e-38 < a Initial program 78.1%
times-frac78.2%
*-commutative78.2%
times-frac78.2%
difference-of-squares86.6%
associate-/r*87.7%
metadata-eval87.7%
sub-neg87.7%
distribute-neg-frac87.7%
metadata-eval87.7%
Simplified87.7%
frac-add87.7%
*-un-lft-identity87.7%
Applied egg-rr87.7%
*-commutative87.7%
neg-mul-187.7%
sub-neg87.7%
Simplified87.7%
expm1-log1p-u76.1%
expm1-udef58.6%
Applied egg-rr58.6%
expm1-def76.1%
expm1-log1p87.7%
*-commutative87.7%
associate-*l*87.7%
Simplified87.7%
Taylor expanded in a around inf 77.6%
unpow277.6%
associate-*l*89.6%
Simplified89.6%
if -4.20000000000000006e-65 < a < 1.54999999999999991e-38Initial program 83.1%
times-frac83.2%
*-commutative83.2%
times-frac83.2%
difference-of-squares89.1%
associate-/r*89.2%
metadata-eval89.2%
sub-neg89.2%
distribute-neg-frac89.2%
metadata-eval89.2%
Simplified89.2%
frac-add89.1%
*-un-lft-identity89.1%
Applied egg-rr89.1%
*-commutative89.1%
neg-mul-189.1%
sub-neg89.1%
Simplified89.1%
expm1-log1p-u57.5%
expm1-udef50.8%
Applied egg-rr50.8%
expm1-def57.5%
expm1-log1p89.1%
*-commutative89.1%
associate-*l*89.3%
Simplified89.3%
Taylor expanded in a around 0 80.2%
associate-*r/80.2%
*-commutative80.2%
*-commutative80.2%
times-frac80.2%
unpow280.2%
Simplified80.2%
Final simplification85.9%
(FPCore (a b) :precision binary64 (if (or (<= a -4.2e-65) (not (<= a 9.4e-39))) (* (/ 0.5 a) (/ (/ PI b) a)) (* (/ 0.5 a) (/ PI (* b b)))))
double code(double a, double b) {
double tmp;
if ((a <= -4.2e-65) || !(a <= 9.4e-39)) {
tmp = (0.5 / a) * ((((double) M_PI) / b) / a);
} else {
tmp = (0.5 / a) * (((double) M_PI) / (b * b));
}
return tmp;
}
public static double code(double a, double b) {
double tmp;
if ((a <= -4.2e-65) || !(a <= 9.4e-39)) {
tmp = (0.5 / a) * ((Math.PI / b) / a);
} else {
tmp = (0.5 / a) * (Math.PI / (b * b));
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -4.2e-65) or not (a <= 9.4e-39): tmp = (0.5 / a) * ((math.pi / b) / a) else: tmp = (0.5 / a) * (math.pi / (b * b)) return tmp
function code(a, b) tmp = 0.0 if ((a <= -4.2e-65) || !(a <= 9.4e-39)) tmp = Float64(Float64(0.5 / a) * Float64(Float64(pi / b) / a)); else tmp = Float64(Float64(0.5 / a) * Float64(pi / Float64(b * b))); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -4.2e-65) || ~((a <= 9.4e-39))) tmp = (0.5 / a) * ((pi / b) / a); else tmp = (0.5 / a) * (pi / (b * b)); end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -4.2e-65], N[Not[LessEqual[a, 9.4e-39]], $MachinePrecision]], N[(N[(0.5 / a), $MachinePrecision] * N[(N[(Pi / b), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision], N[(N[(0.5 / a), $MachinePrecision] * N[(Pi / N[(b * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -4.2 \cdot 10^{-65} \lor \neg \left(a \leq 9.4 \cdot 10^{-39}\right):\\
\;\;\;\;\frac{0.5}{a} \cdot \frac{\frac{\pi}{b}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{0.5}{a} \cdot \frac{\pi}{b \cdot b}\\
\end{array}
\end{array}
if a < -4.20000000000000006e-65 or 9.4000000000000005e-39 < a Initial program 78.1%
times-frac78.2%
*-commutative78.2%
times-frac78.2%
difference-of-squares86.6%
associate-/r*87.7%
metadata-eval87.7%
sub-neg87.7%
distribute-neg-frac87.7%
metadata-eval87.7%
Simplified87.7%
clear-num87.7%
inv-pow87.7%
Applied egg-rr87.7%
unpow-187.7%
+-commutative87.7%
Simplified87.7%
Taylor expanded in a around inf 77.6%
associate-*r/77.6%
*-commutative77.6%
*-commutative77.6%
times-frac77.7%
unpow277.7%
Simplified77.7%
associate-*r/77.7%
Applied egg-rr77.7%
times-frac90.1%
Applied egg-rr90.1%
if -4.20000000000000006e-65 < a < 9.4000000000000005e-39Initial program 83.1%
times-frac83.2%
*-commutative83.2%
times-frac83.2%
difference-of-squares89.1%
associate-/r*89.2%
metadata-eval89.2%
sub-neg89.2%
distribute-neg-frac89.2%
metadata-eval89.2%
Simplified89.2%
frac-add89.1%
*-un-lft-identity89.1%
Applied egg-rr89.1%
*-commutative89.1%
neg-mul-189.1%
sub-neg89.1%
Simplified89.1%
expm1-log1p-u57.5%
expm1-udef50.8%
Applied egg-rr50.8%
expm1-def57.5%
expm1-log1p89.1%
*-commutative89.1%
associate-*l*89.3%
Simplified89.3%
Taylor expanded in a around 0 80.2%
associate-*r/80.2%
*-commutative80.2%
*-commutative80.2%
times-frac80.2%
unpow280.2%
Simplified80.2%
Final simplification86.2%
(FPCore (a b) :precision binary64 (* 0.5 (/ PI (* a (* a b)))))
double code(double a, double b) {
return 0.5 * (((double) M_PI) / (a * (a * b)));
}
public static double code(double a, double b) {
return 0.5 * (Math.PI / (a * (a * b)));
}
def code(a, b): return 0.5 * (math.pi / (a * (a * b)))
function code(a, b) return Float64(0.5 * Float64(pi / Float64(a * Float64(a * b)))) end
function tmp = code(a, b) tmp = 0.5 * (pi / (a * (a * b))); end
code[a_, b_] := N[(0.5 * N[(Pi / N[(a * N[(a * b), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
0.5 \cdot \frac{\pi}{a \cdot \left(a \cdot b\right)}
\end{array}
Initial program 80.1%
times-frac80.2%
*-commutative80.2%
times-frac80.2%
difference-of-squares87.6%
associate-/r*88.3%
metadata-eval88.3%
sub-neg88.3%
distribute-neg-frac88.3%
metadata-eval88.3%
Simplified88.3%
frac-add88.3%
*-un-lft-identity88.3%
Applied egg-rr88.3%
*-commutative88.3%
neg-mul-188.3%
sub-neg88.3%
Simplified88.3%
expm1-log1p-u68.8%
expm1-udef55.5%
Applied egg-rr55.5%
expm1-def68.8%
expm1-log1p88.3%
*-commutative88.3%
associate-*l*88.3%
Simplified88.3%
Taylor expanded in a around inf 57.8%
unpow257.8%
associate-*l*65.1%
Simplified65.1%
Final simplification65.1%
herbie shell --seed 2023171
(FPCore (a b)
:name "NMSE Section 6.1 mentioned, B"
:precision binary64
(* (* (/ PI 2.0) (/ 1.0 (- (* b b) (* a a)))) (- (/ 1.0 a) (/ 1.0 b))))