
(FPCore (u v t1) :precision binary64 (/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))
double code(double u, double v, double t1) {
return (-t1 * v) / ((t1 + u) * (t1 + u));
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
code = (-t1 * v) / ((t1 + u) * (t1 + u))
end function
public static double code(double u, double v, double t1) {
return (-t1 * v) / ((t1 + u) * (t1 + u));
}
def code(u, v, t1): return (-t1 * v) / ((t1 + u) * (t1 + u))
function code(u, v, t1) return Float64(Float64(Float64(-t1) * v) / Float64(Float64(t1 + u) * Float64(t1 + u))) end
function tmp = code(u, v, t1) tmp = (-t1 * v) / ((t1 + u) * (t1 + u)); end
code[u_, v_, t1_] := N[(N[((-t1) * v), $MachinePrecision] / N[(N[(t1 + u), $MachinePrecision] * N[(t1 + u), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 12 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (u v t1) :precision binary64 (/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))
double code(double u, double v, double t1) {
return (-t1 * v) / ((t1 + u) * (t1 + u));
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
code = (-t1 * v) / ((t1 + u) * (t1 + u))
end function
public static double code(double u, double v, double t1) {
return (-t1 * v) / ((t1 + u) * (t1 + u));
}
def code(u, v, t1): return (-t1 * v) / ((t1 + u) * (t1 + u))
function code(u, v, t1) return Float64(Float64(Float64(-t1) * v) / Float64(Float64(t1 + u) * Float64(t1 + u))) end
function tmp = code(u, v, t1) tmp = (-t1 * v) / ((t1 + u) * (t1 + u)); end
code[u_, v_, t1_] := N[(N[((-t1) * v), $MachinePrecision] / N[(N[(t1 + u), $MachinePrecision] * N[(t1 + u), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}
\end{array}
(FPCore (u v t1) :precision binary64 (* (/ v (- (- u) t1)) (/ t1 (+ t1 u))))
double code(double u, double v, double t1) {
return (v / (-u - t1)) * (t1 / (t1 + u));
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
code = (v / (-u - t1)) * (t1 / (t1 + u))
end function
public static double code(double u, double v, double t1) {
return (v / (-u - t1)) * (t1 / (t1 + u));
}
def code(u, v, t1): return (v / (-u - t1)) * (t1 / (t1 + u))
function code(u, v, t1) return Float64(Float64(v / Float64(Float64(-u) - t1)) * Float64(t1 / Float64(t1 + u))) end
function tmp = code(u, v, t1) tmp = (v / (-u - t1)) * (t1 / (t1 + u)); end
code[u_, v_, t1_] := N[(N[(v / N[((-u) - t1), $MachinePrecision]), $MachinePrecision] * N[(t1 / N[(t1 + u), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{v}{\left(-u\right) - t1} \cdot \frac{t1}{t1 + u}
\end{array}
Initial program 73.1%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6497.5
Applied rewrites97.5%
Final simplification97.5%
(FPCore (u v t1)
:precision binary64
(let* ((t_1 (- (- u) t1)) (t_2 (* v (/ t1 (* (+ t1 u) t_1)))))
(if (<= u -1.75e+130)
(/ (* t1 (/ (- v) u)) u)
(if (<= u -5.6e-156)
t_2
(if (<= u 7.6e-156)
(/ (fma (/ v t1) (* u -2.0) v) (- t1))
(if (<= u 1.6e+80) t_2 (* (/ v t_1) (/ t1 u))))))))
double code(double u, double v, double t1) {
double t_1 = -u - t1;
double t_2 = v * (t1 / ((t1 + u) * t_1));
double tmp;
if (u <= -1.75e+130) {
tmp = (t1 * (-v / u)) / u;
} else if (u <= -5.6e-156) {
tmp = t_2;
} else if (u <= 7.6e-156) {
tmp = fma((v / t1), (u * -2.0), v) / -t1;
} else if (u <= 1.6e+80) {
tmp = t_2;
} else {
tmp = (v / t_1) * (t1 / u);
}
return tmp;
}
function code(u, v, t1) t_1 = Float64(Float64(-u) - t1) t_2 = Float64(v * Float64(t1 / Float64(Float64(t1 + u) * t_1))) tmp = 0.0 if (u <= -1.75e+130) tmp = Float64(Float64(t1 * Float64(Float64(-v) / u)) / u); elseif (u <= -5.6e-156) tmp = t_2; elseif (u <= 7.6e-156) tmp = Float64(fma(Float64(v / t1), Float64(u * -2.0), v) / Float64(-t1)); elseif (u <= 1.6e+80) tmp = t_2; else tmp = Float64(Float64(v / t_1) * Float64(t1 / u)); end return tmp end
code[u_, v_, t1_] := Block[{t$95$1 = N[((-u) - t1), $MachinePrecision]}, Block[{t$95$2 = N[(v * N[(t1 / N[(N[(t1 + u), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[u, -1.75e+130], N[(N[(t1 * N[((-v) / u), $MachinePrecision]), $MachinePrecision] / u), $MachinePrecision], If[LessEqual[u, -5.6e-156], t$95$2, If[LessEqual[u, 7.6e-156], N[(N[(N[(v / t1), $MachinePrecision] * N[(u * -2.0), $MachinePrecision] + v), $MachinePrecision] / (-t1)), $MachinePrecision], If[LessEqual[u, 1.6e+80], t$95$2, N[(N[(v / t$95$1), $MachinePrecision] * N[(t1 / u), $MachinePrecision]), $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \left(-u\right) - t1\\
t_2 := v \cdot \frac{t1}{\left(t1 + u\right) \cdot t\_1}\\
\mathbf{if}\;u \leq -1.75 \cdot 10^{+130}:\\
\;\;\;\;\frac{t1 \cdot \frac{-v}{u}}{u}\\
\mathbf{elif}\;u \leq -5.6 \cdot 10^{-156}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;u \leq 7.6 \cdot 10^{-156}:\\
\;\;\;\;\frac{\mathsf{fma}\left(\frac{v}{t1}, u \cdot -2, v\right)}{-t1}\\
\mathbf{elif}\;u \leq 1.6 \cdot 10^{+80}:\\
\;\;\;\;t\_2\\
\mathbf{else}:\\
\;\;\;\;\frac{v}{t\_1} \cdot \frac{t1}{u}\\
\end{array}
\end{array}
if u < -1.75e130Initial program 70.7%
Taylor expanded in t1 around 0
unpow2N/A
lower-*.f6470.7
Applied rewrites70.7%
lift-neg.f64N/A
*-commutativeN/A
times-fracN/A
lift-neg.f64N/A
distribute-frac-negN/A
distribute-frac-neg2N/A
associate-*r/N/A
lower-/.f64N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f6495.6
Applied rewrites95.6%
if -1.75e130 < u < -5.6000000000000003e-156 or 7.60000000000000015e-156 < u < 1.59999999999999995e80Initial program 78.7%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6485.9
Applied rewrites85.9%
if -5.6000000000000003e-156 < u < 7.60000000000000015e-156Initial program 61.1%
Taylor expanded in t1 around inf
mul-1-negN/A
metadata-evalN/A
distribute-lft-neg-inN/A
associate-*r/N/A
distribute-neg-inN/A
associate-*r/N/A
distribute-neg-fracN/A
lower-neg.f64N/A
lower-/.f64N/A
associate-*r/N/A
+-commutativeN/A
associate-*r*N/A
associate-/l*N/A
*-commutativeN/A
lower-fma.f64N/A
lower-/.f64N/A
*-commutativeN/A
lower-*.f6489.8
Applied rewrites89.8%
if 1.59999999999999995e80 < u Initial program 79.0%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6499.5
Applied rewrites99.5%
Taylor expanded in t1 around 0
lower-/.f6491.4
Applied rewrites91.4%
Final simplification89.5%
(FPCore (u v t1)
:precision binary64
(let* ((t_1 (- (- u) t1)) (t_2 (* v (/ t1 (* (+ t1 u) t_1)))))
(if (<= u -1.75e+130)
(/ (* t1 (/ (- v) u)) u)
(if (<= u -5.6e-156)
t_2
(if (<= u 7.6e-156)
(* v (/ (fma u (/ 2.0 t1) -1.0) t1))
(if (<= u 1.6e+80) t_2 (* (/ v t_1) (/ t1 u))))))))
double code(double u, double v, double t1) {
double t_1 = -u - t1;
double t_2 = v * (t1 / ((t1 + u) * t_1));
double tmp;
if (u <= -1.75e+130) {
tmp = (t1 * (-v / u)) / u;
} else if (u <= -5.6e-156) {
tmp = t_2;
} else if (u <= 7.6e-156) {
tmp = v * (fma(u, (2.0 / t1), -1.0) / t1);
} else if (u <= 1.6e+80) {
tmp = t_2;
} else {
tmp = (v / t_1) * (t1 / u);
}
return tmp;
}
function code(u, v, t1) t_1 = Float64(Float64(-u) - t1) t_2 = Float64(v * Float64(t1 / Float64(Float64(t1 + u) * t_1))) tmp = 0.0 if (u <= -1.75e+130) tmp = Float64(Float64(t1 * Float64(Float64(-v) / u)) / u); elseif (u <= -5.6e-156) tmp = t_2; elseif (u <= 7.6e-156) tmp = Float64(v * Float64(fma(u, Float64(2.0 / t1), -1.0) / t1)); elseif (u <= 1.6e+80) tmp = t_2; else tmp = Float64(Float64(v / t_1) * Float64(t1 / u)); end return tmp end
code[u_, v_, t1_] := Block[{t$95$1 = N[((-u) - t1), $MachinePrecision]}, Block[{t$95$2 = N[(v * N[(t1 / N[(N[(t1 + u), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[u, -1.75e+130], N[(N[(t1 * N[((-v) / u), $MachinePrecision]), $MachinePrecision] / u), $MachinePrecision], If[LessEqual[u, -5.6e-156], t$95$2, If[LessEqual[u, 7.6e-156], N[(v * N[(N[(u * N[(2.0 / t1), $MachinePrecision] + -1.0), $MachinePrecision] / t1), $MachinePrecision]), $MachinePrecision], If[LessEqual[u, 1.6e+80], t$95$2, N[(N[(v / t$95$1), $MachinePrecision] * N[(t1 / u), $MachinePrecision]), $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \left(-u\right) - t1\\
t_2 := v \cdot \frac{t1}{\left(t1 + u\right) \cdot t\_1}\\
\mathbf{if}\;u \leq -1.75 \cdot 10^{+130}:\\
\;\;\;\;\frac{t1 \cdot \frac{-v}{u}}{u}\\
\mathbf{elif}\;u \leq -5.6 \cdot 10^{-156}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;u \leq 7.6 \cdot 10^{-156}:\\
\;\;\;\;v \cdot \frac{\mathsf{fma}\left(u, \frac{2}{t1}, -1\right)}{t1}\\
\mathbf{elif}\;u \leq 1.6 \cdot 10^{+80}:\\
\;\;\;\;t\_2\\
\mathbf{else}:\\
\;\;\;\;\frac{v}{t\_1} \cdot \frac{t1}{u}\\
\end{array}
\end{array}
if u < -1.75e130Initial program 70.7%
Taylor expanded in t1 around 0
unpow2N/A
lower-*.f6470.7
Applied rewrites70.7%
lift-neg.f64N/A
*-commutativeN/A
times-fracN/A
lift-neg.f64N/A
distribute-frac-negN/A
distribute-frac-neg2N/A
associate-*r/N/A
lower-/.f64N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f6495.6
Applied rewrites95.6%
if -1.75e130 < u < -5.6000000000000003e-156 or 7.60000000000000015e-156 < u < 1.59999999999999995e80Initial program 78.7%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6485.9
Applied rewrites85.9%
if -5.6000000000000003e-156 < u < 7.60000000000000015e-156Initial program 61.1%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6465.3
Applied rewrites65.3%
Taylor expanded in t1 around inf
lower-/.f64N/A
sub-negN/A
associate-*r/N/A
*-commutativeN/A
associate-/l*N/A
metadata-evalN/A
lower-fma.f64N/A
lower-/.f6489.7
Applied rewrites89.7%
if 1.59999999999999995e80 < u Initial program 79.0%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6499.5
Applied rewrites99.5%
Taylor expanded in t1 around 0
lower-/.f6491.4
Applied rewrites91.4%
Final simplification89.5%
(FPCore (u v t1)
:precision binary64
(let* ((t_1 (- (- u) t1)) (t_2 (* v (/ t1 (* (+ t1 u) t_1)))))
(if (<= u -1.75e+130)
(/ (* t1 (/ (- v) u)) u)
(if (<= u -5.6e-156)
t_2
(if (<= u 7.6e-156)
(/ (- v) t1)
(if (<= u 1.6e+80) t_2 (* (/ v t_1) (/ t1 u))))))))
double code(double u, double v, double t1) {
double t_1 = -u - t1;
double t_2 = v * (t1 / ((t1 + u) * t_1));
double tmp;
if (u <= -1.75e+130) {
tmp = (t1 * (-v / u)) / u;
} else if (u <= -5.6e-156) {
tmp = t_2;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 1.6e+80) {
tmp = t_2;
} else {
tmp = (v / t_1) * (t1 / u);
}
return tmp;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
t_1 = -u - t1
t_2 = v * (t1 / ((t1 + u) * t_1))
if (u <= (-1.75d+130)) then
tmp = (t1 * (-v / u)) / u
else if (u <= (-5.6d-156)) then
tmp = t_2
else if (u <= 7.6d-156) then
tmp = -v / t1
else if (u <= 1.6d+80) then
tmp = t_2
else
tmp = (v / t_1) * (t1 / u)
end if
code = tmp
end function
public static double code(double u, double v, double t1) {
double t_1 = -u - t1;
double t_2 = v * (t1 / ((t1 + u) * t_1));
double tmp;
if (u <= -1.75e+130) {
tmp = (t1 * (-v / u)) / u;
} else if (u <= -5.6e-156) {
tmp = t_2;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 1.6e+80) {
tmp = t_2;
} else {
tmp = (v / t_1) * (t1 / u);
}
return tmp;
}
def code(u, v, t1): t_1 = -u - t1 t_2 = v * (t1 / ((t1 + u) * t_1)) tmp = 0 if u <= -1.75e+130: tmp = (t1 * (-v / u)) / u elif u <= -5.6e-156: tmp = t_2 elif u <= 7.6e-156: tmp = -v / t1 elif u <= 1.6e+80: tmp = t_2 else: tmp = (v / t_1) * (t1 / u) return tmp
function code(u, v, t1) t_1 = Float64(Float64(-u) - t1) t_2 = Float64(v * Float64(t1 / Float64(Float64(t1 + u) * t_1))) tmp = 0.0 if (u <= -1.75e+130) tmp = Float64(Float64(t1 * Float64(Float64(-v) / u)) / u); elseif (u <= -5.6e-156) tmp = t_2; elseif (u <= 7.6e-156) tmp = Float64(Float64(-v) / t1); elseif (u <= 1.6e+80) tmp = t_2; else tmp = Float64(Float64(v / t_1) * Float64(t1 / u)); end return tmp end
function tmp_2 = code(u, v, t1) t_1 = -u - t1; t_2 = v * (t1 / ((t1 + u) * t_1)); tmp = 0.0; if (u <= -1.75e+130) tmp = (t1 * (-v / u)) / u; elseif (u <= -5.6e-156) tmp = t_2; elseif (u <= 7.6e-156) tmp = -v / t1; elseif (u <= 1.6e+80) tmp = t_2; else tmp = (v / t_1) * (t1 / u); end tmp_2 = tmp; end
code[u_, v_, t1_] := Block[{t$95$1 = N[((-u) - t1), $MachinePrecision]}, Block[{t$95$2 = N[(v * N[(t1 / N[(N[(t1 + u), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[u, -1.75e+130], N[(N[(t1 * N[((-v) / u), $MachinePrecision]), $MachinePrecision] / u), $MachinePrecision], If[LessEqual[u, -5.6e-156], t$95$2, If[LessEqual[u, 7.6e-156], N[((-v) / t1), $MachinePrecision], If[LessEqual[u, 1.6e+80], t$95$2, N[(N[(v / t$95$1), $MachinePrecision] * N[(t1 / u), $MachinePrecision]), $MachinePrecision]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \left(-u\right) - t1\\
t_2 := v \cdot \frac{t1}{\left(t1 + u\right) \cdot t\_1}\\
\mathbf{if}\;u \leq -1.75 \cdot 10^{+130}:\\
\;\;\;\;\frac{t1 \cdot \frac{-v}{u}}{u}\\
\mathbf{elif}\;u \leq -5.6 \cdot 10^{-156}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;u \leq 7.6 \cdot 10^{-156}:\\
\;\;\;\;\frac{-v}{t1}\\
\mathbf{elif}\;u \leq 1.6 \cdot 10^{+80}:\\
\;\;\;\;t\_2\\
\mathbf{else}:\\
\;\;\;\;\frac{v}{t\_1} \cdot \frac{t1}{u}\\
\end{array}
\end{array}
if u < -1.75e130Initial program 70.7%
Taylor expanded in t1 around 0
unpow2N/A
lower-*.f6470.7
Applied rewrites70.7%
lift-neg.f64N/A
*-commutativeN/A
times-fracN/A
lift-neg.f64N/A
distribute-frac-negN/A
distribute-frac-neg2N/A
associate-*r/N/A
lower-/.f64N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f6495.6
Applied rewrites95.6%
if -1.75e130 < u < -5.6000000000000003e-156 or 7.60000000000000015e-156 < u < 1.59999999999999995e80Initial program 78.7%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6485.9
Applied rewrites85.9%
if -5.6000000000000003e-156 < u < 7.60000000000000015e-156Initial program 61.1%
Taylor expanded in t1 around inf
associate-*r/N/A
lower-/.f64N/A
mul-1-negN/A
lower-neg.f6489.1
Applied rewrites89.1%
if 1.59999999999999995e80 < u Initial program 79.0%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6499.5
Applied rewrites99.5%
Taylor expanded in t1 around 0
lower-/.f6491.4
Applied rewrites91.4%
Final simplification89.4%
(FPCore (u v t1)
:precision binary64
(let* ((t_1 (* v (/ t1 (* (+ t1 u) (- (- u) t1)))))
(t_2 (/ (* t1 (/ (- v) u)) u)))
(if (<= u -1.75e+130)
t_2
(if (<= u -5.6e-156)
t_1
(if (<= u 7.6e-156) (/ (- v) t1) (if (<= u 6e+72) t_1 t_2))))))
double code(double u, double v, double t1) {
double t_1 = v * (t1 / ((t1 + u) * (-u - t1)));
double t_2 = (t1 * (-v / u)) / u;
double tmp;
if (u <= -1.75e+130) {
tmp = t_2;
} else if (u <= -5.6e-156) {
tmp = t_1;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 6e+72) {
tmp = t_1;
} else {
tmp = t_2;
}
return tmp;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
t_1 = v * (t1 / ((t1 + u) * (-u - t1)))
t_2 = (t1 * (-v / u)) / u
if (u <= (-1.75d+130)) then
tmp = t_2
else if (u <= (-5.6d-156)) then
tmp = t_1
else if (u <= 7.6d-156) then
tmp = -v / t1
else if (u <= 6d+72) then
tmp = t_1
else
tmp = t_2
end if
code = tmp
end function
public static double code(double u, double v, double t1) {
double t_1 = v * (t1 / ((t1 + u) * (-u - t1)));
double t_2 = (t1 * (-v / u)) / u;
double tmp;
if (u <= -1.75e+130) {
tmp = t_2;
} else if (u <= -5.6e-156) {
tmp = t_1;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 6e+72) {
tmp = t_1;
} else {
tmp = t_2;
}
return tmp;
}
def code(u, v, t1): t_1 = v * (t1 / ((t1 + u) * (-u - t1))) t_2 = (t1 * (-v / u)) / u tmp = 0 if u <= -1.75e+130: tmp = t_2 elif u <= -5.6e-156: tmp = t_1 elif u <= 7.6e-156: tmp = -v / t1 elif u <= 6e+72: tmp = t_1 else: tmp = t_2 return tmp
function code(u, v, t1) t_1 = Float64(v * Float64(t1 / Float64(Float64(t1 + u) * Float64(Float64(-u) - t1)))) t_2 = Float64(Float64(t1 * Float64(Float64(-v) / u)) / u) tmp = 0.0 if (u <= -1.75e+130) tmp = t_2; elseif (u <= -5.6e-156) tmp = t_1; elseif (u <= 7.6e-156) tmp = Float64(Float64(-v) / t1); elseif (u <= 6e+72) tmp = t_1; else tmp = t_2; end return tmp end
function tmp_2 = code(u, v, t1) t_1 = v * (t1 / ((t1 + u) * (-u - t1))); t_2 = (t1 * (-v / u)) / u; tmp = 0.0; if (u <= -1.75e+130) tmp = t_2; elseif (u <= -5.6e-156) tmp = t_1; elseif (u <= 7.6e-156) tmp = -v / t1; elseif (u <= 6e+72) tmp = t_1; else tmp = t_2; end tmp_2 = tmp; end
code[u_, v_, t1_] := Block[{t$95$1 = N[(v * N[(t1 / N[(N[(t1 + u), $MachinePrecision] * N[((-u) - t1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(t1 * N[((-v) / u), $MachinePrecision]), $MachinePrecision] / u), $MachinePrecision]}, If[LessEqual[u, -1.75e+130], t$95$2, If[LessEqual[u, -5.6e-156], t$95$1, If[LessEqual[u, 7.6e-156], N[((-v) / t1), $MachinePrecision], If[LessEqual[u, 6e+72], t$95$1, t$95$2]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := v \cdot \frac{t1}{\left(t1 + u\right) \cdot \left(\left(-u\right) - t1\right)}\\
t_2 := \frac{t1 \cdot \frac{-v}{u}}{u}\\
\mathbf{if}\;u \leq -1.75 \cdot 10^{+130}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;u \leq -5.6 \cdot 10^{-156}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;u \leq 7.6 \cdot 10^{-156}:\\
\;\;\;\;\frac{-v}{t1}\\
\mathbf{elif}\;u \leq 6 \cdot 10^{+72}:\\
\;\;\;\;t\_1\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if u < -1.75e130 or 6.00000000000000006e72 < u Initial program 74.7%
Taylor expanded in t1 around 0
unpow2N/A
lower-*.f6472.8
Applied rewrites72.8%
lift-neg.f64N/A
*-commutativeN/A
times-fracN/A
lift-neg.f64N/A
distribute-frac-negN/A
distribute-frac-neg2N/A
associate-*r/N/A
lower-/.f64N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f6492.0
Applied rewrites92.0%
if -1.75e130 < u < -5.6000000000000003e-156 or 7.60000000000000015e-156 < u < 6.00000000000000006e72Initial program 78.8%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6486.3
Applied rewrites86.3%
if -5.6000000000000003e-156 < u < 7.60000000000000015e-156Initial program 61.1%
Taylor expanded in t1 around inf
associate-*r/N/A
lower-/.f64N/A
mul-1-negN/A
lower-neg.f6489.1
Applied rewrites89.1%
Final simplification89.1%
(FPCore (u v t1)
:precision binary64
(let* ((t_1 (* v (/ t1 (* (+ t1 u) (- (- u) t1)))))
(t_2 (/ (* v (/ t1 u)) (- u))))
(if (<= u -9.5e+130)
t_2
(if (<= u -5.6e-156)
t_1
(if (<= u 7.6e-156) (/ (- v) t1) (if (<= u 5.6e+74) t_1 t_2))))))
double code(double u, double v, double t1) {
double t_1 = v * (t1 / ((t1 + u) * (-u - t1)));
double t_2 = (v * (t1 / u)) / -u;
double tmp;
if (u <= -9.5e+130) {
tmp = t_2;
} else if (u <= -5.6e-156) {
tmp = t_1;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 5.6e+74) {
tmp = t_1;
} else {
tmp = t_2;
}
return tmp;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
t_1 = v * (t1 / ((t1 + u) * (-u - t1)))
t_2 = (v * (t1 / u)) / -u
if (u <= (-9.5d+130)) then
tmp = t_2
else if (u <= (-5.6d-156)) then
tmp = t_1
else if (u <= 7.6d-156) then
tmp = -v / t1
else if (u <= 5.6d+74) then
tmp = t_1
else
tmp = t_2
end if
code = tmp
end function
public static double code(double u, double v, double t1) {
double t_1 = v * (t1 / ((t1 + u) * (-u - t1)));
double t_2 = (v * (t1 / u)) / -u;
double tmp;
if (u <= -9.5e+130) {
tmp = t_2;
} else if (u <= -5.6e-156) {
tmp = t_1;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 5.6e+74) {
tmp = t_1;
} else {
tmp = t_2;
}
return tmp;
}
def code(u, v, t1): t_1 = v * (t1 / ((t1 + u) * (-u - t1))) t_2 = (v * (t1 / u)) / -u tmp = 0 if u <= -9.5e+130: tmp = t_2 elif u <= -5.6e-156: tmp = t_1 elif u <= 7.6e-156: tmp = -v / t1 elif u <= 5.6e+74: tmp = t_1 else: tmp = t_2 return tmp
function code(u, v, t1) t_1 = Float64(v * Float64(t1 / Float64(Float64(t1 + u) * Float64(Float64(-u) - t1)))) t_2 = Float64(Float64(v * Float64(t1 / u)) / Float64(-u)) tmp = 0.0 if (u <= -9.5e+130) tmp = t_2; elseif (u <= -5.6e-156) tmp = t_1; elseif (u <= 7.6e-156) tmp = Float64(Float64(-v) / t1); elseif (u <= 5.6e+74) tmp = t_1; else tmp = t_2; end return tmp end
function tmp_2 = code(u, v, t1) t_1 = v * (t1 / ((t1 + u) * (-u - t1))); t_2 = (v * (t1 / u)) / -u; tmp = 0.0; if (u <= -9.5e+130) tmp = t_2; elseif (u <= -5.6e-156) tmp = t_1; elseif (u <= 7.6e-156) tmp = -v / t1; elseif (u <= 5.6e+74) tmp = t_1; else tmp = t_2; end tmp_2 = tmp; end
code[u_, v_, t1_] := Block[{t$95$1 = N[(v * N[(t1 / N[(N[(t1 + u), $MachinePrecision] * N[((-u) - t1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(v * N[(t1 / u), $MachinePrecision]), $MachinePrecision] / (-u)), $MachinePrecision]}, If[LessEqual[u, -9.5e+130], t$95$2, If[LessEqual[u, -5.6e-156], t$95$1, If[LessEqual[u, 7.6e-156], N[((-v) / t1), $MachinePrecision], If[LessEqual[u, 5.6e+74], t$95$1, t$95$2]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := v \cdot \frac{t1}{\left(t1 + u\right) \cdot \left(\left(-u\right) - t1\right)}\\
t_2 := \frac{v \cdot \frac{t1}{u}}{-u}\\
\mathbf{if}\;u \leq -9.5 \cdot 10^{+130}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;u \leq -5.6 \cdot 10^{-156}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;u \leq 7.6 \cdot 10^{-156}:\\
\;\;\;\;\frac{-v}{t1}\\
\mathbf{elif}\;u \leq 5.6 \cdot 10^{+74}:\\
\;\;\;\;t\_1\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if u < -9.5000000000000009e130 or 5.60000000000000003e74 < u Initial program 74.2%
Taylor expanded in t1 around 0
unpow2N/A
lower-*.f6474.3
Applied rewrites74.3%
lift-neg.f64N/A
*-commutativeN/A
times-fracN/A
lift-neg.f64N/A
distribute-frac-negN/A
distribute-frac-neg2N/A
associate-*r/N/A
lower-/.f64N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f6491.8
Applied rewrites91.8%
associate-*l/N/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6491.3
Applied rewrites91.3%
if -9.5000000000000009e130 < u < -5.6000000000000003e-156 or 7.60000000000000015e-156 < u < 5.60000000000000003e74Initial program 79.2%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6486.6
Applied rewrites86.6%
if -5.6000000000000003e-156 < u < 7.60000000000000015e-156Initial program 61.1%
Taylor expanded in t1 around inf
associate-*r/N/A
lower-/.f64N/A
mul-1-negN/A
lower-neg.f6489.1
Applied rewrites89.1%
Final simplification88.9%
(FPCore (u v t1)
:precision binary64
(let* ((t_1 (* v (/ t1 (* (+ t1 u) (- (- u) t1)))))
(t_2 (* (/ v u) (- (/ t1 u)))))
(if (<= u -2.45e+147)
t_2
(if (<= u -5.6e-156)
t_1
(if (<= u 7.6e-156) (/ (- v) t1) (if (<= u 6e+72) t_1 t_2))))))
double code(double u, double v, double t1) {
double t_1 = v * (t1 / ((t1 + u) * (-u - t1)));
double t_2 = (v / u) * -(t1 / u);
double tmp;
if (u <= -2.45e+147) {
tmp = t_2;
} else if (u <= -5.6e-156) {
tmp = t_1;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 6e+72) {
tmp = t_1;
} else {
tmp = t_2;
}
return tmp;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
real(8) :: t_1
real(8) :: t_2
real(8) :: tmp
t_1 = v * (t1 / ((t1 + u) * (-u - t1)))
t_2 = (v / u) * -(t1 / u)
if (u <= (-2.45d+147)) then
tmp = t_2
else if (u <= (-5.6d-156)) then
tmp = t_1
else if (u <= 7.6d-156) then
tmp = -v / t1
else if (u <= 6d+72) then
tmp = t_1
else
tmp = t_2
end if
code = tmp
end function
public static double code(double u, double v, double t1) {
double t_1 = v * (t1 / ((t1 + u) * (-u - t1)));
double t_2 = (v / u) * -(t1 / u);
double tmp;
if (u <= -2.45e+147) {
tmp = t_2;
} else if (u <= -5.6e-156) {
tmp = t_1;
} else if (u <= 7.6e-156) {
tmp = -v / t1;
} else if (u <= 6e+72) {
tmp = t_1;
} else {
tmp = t_2;
}
return tmp;
}
def code(u, v, t1): t_1 = v * (t1 / ((t1 + u) * (-u - t1))) t_2 = (v / u) * -(t1 / u) tmp = 0 if u <= -2.45e+147: tmp = t_2 elif u <= -5.6e-156: tmp = t_1 elif u <= 7.6e-156: tmp = -v / t1 elif u <= 6e+72: tmp = t_1 else: tmp = t_2 return tmp
function code(u, v, t1) t_1 = Float64(v * Float64(t1 / Float64(Float64(t1 + u) * Float64(Float64(-u) - t1)))) t_2 = Float64(Float64(v / u) * Float64(-Float64(t1 / u))) tmp = 0.0 if (u <= -2.45e+147) tmp = t_2; elseif (u <= -5.6e-156) tmp = t_1; elseif (u <= 7.6e-156) tmp = Float64(Float64(-v) / t1); elseif (u <= 6e+72) tmp = t_1; else tmp = t_2; end return tmp end
function tmp_2 = code(u, v, t1) t_1 = v * (t1 / ((t1 + u) * (-u - t1))); t_2 = (v / u) * -(t1 / u); tmp = 0.0; if (u <= -2.45e+147) tmp = t_2; elseif (u <= -5.6e-156) tmp = t_1; elseif (u <= 7.6e-156) tmp = -v / t1; elseif (u <= 6e+72) tmp = t_1; else tmp = t_2; end tmp_2 = tmp; end
code[u_, v_, t1_] := Block[{t$95$1 = N[(v * N[(t1 / N[(N[(t1 + u), $MachinePrecision] * N[((-u) - t1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(v / u), $MachinePrecision] * (-N[(t1 / u), $MachinePrecision])), $MachinePrecision]}, If[LessEqual[u, -2.45e+147], t$95$2, If[LessEqual[u, -5.6e-156], t$95$1, If[LessEqual[u, 7.6e-156], N[((-v) / t1), $MachinePrecision], If[LessEqual[u, 6e+72], t$95$1, t$95$2]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := v \cdot \frac{t1}{\left(t1 + u\right) \cdot \left(\left(-u\right) - t1\right)}\\
t_2 := \frac{v}{u} \cdot \left(-\frac{t1}{u}\right)\\
\mathbf{if}\;u \leq -2.45 \cdot 10^{+147}:\\
\;\;\;\;t\_2\\
\mathbf{elif}\;u \leq -5.6 \cdot 10^{-156}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;u \leq 7.6 \cdot 10^{-156}:\\
\;\;\;\;\frac{-v}{t1}\\
\mathbf{elif}\;u \leq 6 \cdot 10^{+72}:\\
\;\;\;\;t\_1\\
\mathbf{else}:\\
\;\;\;\;t\_2\\
\end{array}
\end{array}
if u < -2.4499999999999999e147 or 6.00000000000000006e72 < u Initial program 75.3%
Taylor expanded in t1 around 0
unpow2N/A
lower-*.f6473.3
Applied rewrites73.3%
distribute-lft-neg-outN/A
*-commutativeN/A
distribute-lft-neg-inN/A
lift-neg.f64N/A
times-fracN/A
lower-*.f64N/A
lower-/.f64N/A
lower-/.f6492.3
Applied rewrites92.3%
if -2.4499999999999999e147 < u < -5.6000000000000003e-156 or 7.60000000000000015e-156 < u < 6.00000000000000006e72Initial program 78.2%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6485.6
Applied rewrites85.6%
if -5.6000000000000003e-156 < u < 7.60000000000000015e-156Initial program 61.1%
Taylor expanded in t1 around inf
associate-*r/N/A
lower-/.f64N/A
mul-1-negN/A
lower-neg.f6489.1
Applied rewrites89.1%
Final simplification88.9%
(FPCore (u v t1)
:precision binary64
(let* ((t_1 (- (- u) t1)))
(if (<= t1 -1e+155)
(/ v t_1)
(if (<= t1 1.1e+128)
(* v (/ t1 (* (+ t1 u) t_1)))
(* v (/ -1.0 (+ t1 u)))))))
double code(double u, double v, double t1) {
double t_1 = -u - t1;
double tmp;
if (t1 <= -1e+155) {
tmp = v / t_1;
} else if (t1 <= 1.1e+128) {
tmp = v * (t1 / ((t1 + u) * t_1));
} else {
tmp = v * (-1.0 / (t1 + u));
}
return tmp;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
real(8) :: t_1
real(8) :: tmp
t_1 = -u - t1
if (t1 <= (-1d+155)) then
tmp = v / t_1
else if (t1 <= 1.1d+128) then
tmp = v * (t1 / ((t1 + u) * t_1))
else
tmp = v * ((-1.0d0) / (t1 + u))
end if
code = tmp
end function
public static double code(double u, double v, double t1) {
double t_1 = -u - t1;
double tmp;
if (t1 <= -1e+155) {
tmp = v / t_1;
} else if (t1 <= 1.1e+128) {
tmp = v * (t1 / ((t1 + u) * t_1));
} else {
tmp = v * (-1.0 / (t1 + u));
}
return tmp;
}
def code(u, v, t1): t_1 = -u - t1 tmp = 0 if t1 <= -1e+155: tmp = v / t_1 elif t1 <= 1.1e+128: tmp = v * (t1 / ((t1 + u) * t_1)) else: tmp = v * (-1.0 / (t1 + u)) return tmp
function code(u, v, t1) t_1 = Float64(Float64(-u) - t1) tmp = 0.0 if (t1 <= -1e+155) tmp = Float64(v / t_1); elseif (t1 <= 1.1e+128) tmp = Float64(v * Float64(t1 / Float64(Float64(t1 + u) * t_1))); else tmp = Float64(v * Float64(-1.0 / Float64(t1 + u))); end return tmp end
function tmp_2 = code(u, v, t1) t_1 = -u - t1; tmp = 0.0; if (t1 <= -1e+155) tmp = v / t_1; elseif (t1 <= 1.1e+128) tmp = v * (t1 / ((t1 + u) * t_1)); else tmp = v * (-1.0 / (t1 + u)); end tmp_2 = tmp; end
code[u_, v_, t1_] := Block[{t$95$1 = N[((-u) - t1), $MachinePrecision]}, If[LessEqual[t1, -1e+155], N[(v / t$95$1), $MachinePrecision], If[LessEqual[t1, 1.1e+128], N[(v * N[(t1 / N[(N[(t1 + u), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(v * N[(-1.0 / N[(t1 + u), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \left(-u\right) - t1\\
\mathbf{if}\;t1 \leq -1 \cdot 10^{+155}:\\
\;\;\;\;\frac{v}{t\_1}\\
\mathbf{elif}\;t1 \leq 1.1 \cdot 10^{+128}:\\
\;\;\;\;v \cdot \frac{t1}{\left(t1 + u\right) \cdot t\_1}\\
\mathbf{else}:\\
\;\;\;\;v \cdot \frac{-1}{t1 + u}\\
\end{array}
\end{array}
if t1 < -1.00000000000000001e155Initial program 53.7%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6499.9
Applied rewrites99.9%
Taylor expanded in t1 around inf
Applied rewrites88.5%
lift-neg.f64N/A
lift-+.f64N/A
lift-/.f64N/A
*-rgt-identity88.5
Applied rewrites88.5%
if -1.00000000000000001e155 < t1 < 1.10000000000000008e128Initial program 80.9%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
lift-*.f64N/A
*-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f6485.1
Applied rewrites85.1%
if 1.10000000000000008e128 < t1 Initial program 50.1%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6499.9
Applied rewrites99.9%
Taylor expanded in t1 around inf
Applied rewrites84.7%
lift-neg.f64N/A
lift-+.f64N/A
associate-*l/N/A
*-rgt-identityN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*l/N/A
lift-/.f64N/A
lower-*.f6484.7
Applied rewrites84.7%
Final simplification85.5%
(FPCore (u v t1) :precision binary64 (let* ((t_1 (* (- t1) (/ v (* u u))))) (if (<= u -6e+36) t_1 (if (<= u 1.65e+18) (/ (- v) t1) t_1))))
double code(double u, double v, double t1) {
double t_1 = -t1 * (v / (u * u));
double tmp;
if (u <= -6e+36) {
tmp = t_1;
} else if (u <= 1.65e+18) {
tmp = -v / t1;
} else {
tmp = t_1;
}
return tmp;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
real(8) :: t_1
real(8) :: tmp
t_1 = -t1 * (v / (u * u))
if (u <= (-6d+36)) then
tmp = t_1
else if (u <= 1.65d+18) then
tmp = -v / t1
else
tmp = t_1
end if
code = tmp
end function
public static double code(double u, double v, double t1) {
double t_1 = -t1 * (v / (u * u));
double tmp;
if (u <= -6e+36) {
tmp = t_1;
} else if (u <= 1.65e+18) {
tmp = -v / t1;
} else {
tmp = t_1;
}
return tmp;
}
def code(u, v, t1): t_1 = -t1 * (v / (u * u)) tmp = 0 if u <= -6e+36: tmp = t_1 elif u <= 1.65e+18: tmp = -v / t1 else: tmp = t_1 return tmp
function code(u, v, t1) t_1 = Float64(Float64(-t1) * Float64(v / Float64(u * u))) tmp = 0.0 if (u <= -6e+36) tmp = t_1; elseif (u <= 1.65e+18) tmp = Float64(Float64(-v) / t1); else tmp = t_1; end return tmp end
function tmp_2 = code(u, v, t1) t_1 = -t1 * (v / (u * u)); tmp = 0.0; if (u <= -6e+36) tmp = t_1; elseif (u <= 1.65e+18) tmp = -v / t1; else tmp = t_1; end tmp_2 = tmp; end
code[u_, v_, t1_] := Block[{t$95$1 = N[((-t1) * N[(v / N[(u * u), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[u, -6e+36], t$95$1, If[LessEqual[u, 1.65e+18], N[((-v) / t1), $MachinePrecision], t$95$1]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \left(-t1\right) \cdot \frac{v}{u \cdot u}\\
\mathbf{if}\;u \leq -6 \cdot 10^{+36}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;u \leq 1.65 \cdot 10^{+18}:\\
\;\;\;\;\frac{-v}{t1}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if u < -6e36 or 1.65e18 < u Initial program 79.5%
Taylor expanded in t1 around 0
mul-1-negN/A
associate-/l*N/A
distribute-rgt-neg-inN/A
mul-1-negN/A
lower-*.f64N/A
mul-1-negN/A
distribute-neg-frac2N/A
mul-1-negN/A
lower-/.f64N/A
mul-1-negN/A
unpow2N/A
distribute-rgt-neg-inN/A
lower-*.f64N/A
lower-neg.f6477.0
Applied rewrites77.0%
if -6e36 < u < 1.65e18Initial program 66.3%
Taylor expanded in t1 around inf
associate-*r/N/A
lower-/.f64N/A
mul-1-negN/A
lower-neg.f6477.9
Applied rewrites77.9%
Final simplification77.4%
(FPCore (u v t1) :precision binary64 (let* ((t_1 (/ (- v) u))) (if (<= u -4.2e+152) t_1 (if (<= u 3.8e+94) (/ (- v) t1) t_1))))
double code(double u, double v, double t1) {
double t_1 = -v / u;
double tmp;
if (u <= -4.2e+152) {
tmp = t_1;
} else if (u <= 3.8e+94) {
tmp = -v / t1;
} else {
tmp = t_1;
}
return tmp;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
real(8) :: t_1
real(8) :: tmp
t_1 = -v / u
if (u <= (-4.2d+152)) then
tmp = t_1
else if (u <= 3.8d+94) then
tmp = -v / t1
else
tmp = t_1
end if
code = tmp
end function
public static double code(double u, double v, double t1) {
double t_1 = -v / u;
double tmp;
if (u <= -4.2e+152) {
tmp = t_1;
} else if (u <= 3.8e+94) {
tmp = -v / t1;
} else {
tmp = t_1;
}
return tmp;
}
def code(u, v, t1): t_1 = -v / u tmp = 0 if u <= -4.2e+152: tmp = t_1 elif u <= 3.8e+94: tmp = -v / t1 else: tmp = t_1 return tmp
function code(u, v, t1) t_1 = Float64(Float64(-v) / u) tmp = 0.0 if (u <= -4.2e+152) tmp = t_1; elseif (u <= 3.8e+94) tmp = Float64(Float64(-v) / t1); else tmp = t_1; end return tmp end
function tmp_2 = code(u, v, t1) t_1 = -v / u; tmp = 0.0; if (u <= -4.2e+152) tmp = t_1; elseif (u <= 3.8e+94) tmp = -v / t1; else tmp = t_1; end tmp_2 = tmp; end
code[u_, v_, t1_] := Block[{t$95$1 = N[((-v) / u), $MachinePrecision]}, If[LessEqual[u, -4.2e+152], t$95$1, If[LessEqual[u, 3.8e+94], N[((-v) / t1), $MachinePrecision], t$95$1]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{-v}{u}\\
\mathbf{if}\;u \leq -4.2 \cdot 10^{+152}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;u \leq 3.8 \cdot 10^{+94}:\\
\;\;\;\;\frac{-v}{t1}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if u < -4.2000000000000003e152 or 3.7999999999999996e94 < u Initial program 75.3%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6499.2
Applied rewrites99.2%
Taylor expanded in t1 around inf
Applied rewrites36.5%
Taylor expanded in t1 around 0
mul-1-negN/A
lower-neg.f64N/A
lower-/.f6433.1
Applied rewrites33.1%
if -4.2000000000000003e152 < u < 3.7999999999999996e94Initial program 72.0%
Taylor expanded in t1 around inf
associate-*r/N/A
lower-/.f64N/A
mul-1-negN/A
lower-neg.f6464.5
Applied rewrites64.5%
Final simplification54.0%
(FPCore (u v t1) :precision binary64 (/ v (- (- u) t1)))
double code(double u, double v, double t1) {
return v / (-u - t1);
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
code = v / (-u - t1)
end function
public static double code(double u, double v, double t1) {
return v / (-u - t1);
}
def code(u, v, t1): return v / (-u - t1)
function code(u, v, t1) return Float64(v / Float64(Float64(-u) - t1)) end
function tmp = code(u, v, t1) tmp = v / (-u - t1); end
code[u_, v_, t1_] := N[(v / N[((-u) - t1), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{v}{\left(-u\right) - t1}
\end{array}
Initial program 73.1%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6497.5
Applied rewrites97.5%
Taylor expanded in t1 around inf
Applied rewrites54.4%
lift-neg.f64N/A
lift-+.f64N/A
lift-/.f64N/A
*-rgt-identity54.4
Applied rewrites54.4%
Final simplification54.4%
(FPCore (u v t1) :precision binary64 (/ (- v) u))
double code(double u, double v, double t1) {
return -v / u;
}
real(8) function code(u, v, t1)
real(8), intent (in) :: u
real(8), intent (in) :: v
real(8), intent (in) :: t1
code = -v / u
end function
public static double code(double u, double v, double t1) {
return -v / u;
}
def code(u, v, t1): return -v / u
function code(u, v, t1) return Float64(Float64(-v) / u) end
function tmp = code(u, v, t1) tmp = -v / u; end
code[u_, v_, t1_] := N[((-v) / u), $MachinePrecision]
\begin{array}{l}
\\
\frac{-v}{u}
\end{array}
Initial program 73.1%
lift-neg.f64N/A
lift-+.f64N/A
lift-+.f64N/A
*-commutativeN/A
lift-neg.f64N/A
neg-mul-1N/A
associate-*r*N/A
times-fracN/A
*-commutativeN/A
neg-mul-1N/A
lower-*.f64N/A
lower-/.f64N/A
lower-neg.f64N/A
lower-/.f6497.5
Applied rewrites97.5%
Taylor expanded in t1 around inf
Applied rewrites54.4%
Taylor expanded in t1 around 0
mul-1-negN/A
lower-neg.f64N/A
lower-/.f6414.9
Applied rewrites14.9%
Final simplification14.9%
herbie shell --seed 2024216
(FPCore (u v t1)
:name "Rosa's DopplerBench"
:precision binary64
(/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))