(FPCore (a b c)
:precision binary64
(/ (- (- b) (sqrt (- (* b b) (* 4.0 (* a c))))) (* 2.0 a)))
↓
(FPCore (a b c)
:precision binary64
(if (<= b -3e-118)
(/ 1.0 (- (/ a b) (/ b c)))
(if (<= b 2.5e+135)
(/ (- (- b) (sqrt (- (* b b) (* 4.0 (* a c))))) (* a 2.0))
(/ (- b) a))))
double code(double a, double b, double c) {
return (-b - sqrt(((b * b) - (4.0 * (a * c))))) / (2.0 * a);
}
↓
double code(double a, double b, double c) {
double tmp;
if (b <= -3e-118) {
tmp = 1.0 / ((a / b) - (b / c));
} else if (b <= 2.5e+135) {
tmp = (-b - sqrt(((b * b) - (4.0 * (a * c))))) / (a * 2.0);
} else {
tmp = -b / a;
}
return tmp;
}
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
code = (-b - sqrt(((b * b) - (4.0d0 * (a * c))))) / (2.0d0 * a)
end function
↓
real(8) function code(a, b, c)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8), intent (in) :: c
real(8) :: tmp
if (b <= (-3d-118)) then
tmp = 1.0d0 / ((a / b) - (b / c))
else if (b <= 2.5d+135) then
tmp = (-b - sqrt(((b * b) - (4.0d0 * (a * c))))) / (a * 2.0d0)
else
tmp = -b / a
end if
code = tmp
end function
public static double code(double a, double b, double c) {
return (-b - Math.sqrt(((b * b) - (4.0 * (a * c))))) / (2.0 * a);
}
↓
public static double code(double a, double b, double c) {
double tmp;
if (b <= -3e-118) {
tmp = 1.0 / ((a / b) - (b / c));
} else if (b <= 2.5e+135) {
tmp = (-b - Math.sqrt(((b * b) - (4.0 * (a * c))))) / (a * 2.0);
} else {
tmp = -b / a;
}
return tmp;
}
def code(a, b, c):
return (-b - math.sqrt(((b * b) - (4.0 * (a * c))))) / (2.0 * a)
↓
def code(a, b, c):
tmp = 0
if b <= -3e-118:
tmp = 1.0 / ((a / b) - (b / c))
elif b <= 2.5e+135:
tmp = (-b - math.sqrt(((b * b) - (4.0 * (a * c))))) / (a * 2.0)
else:
tmp = -b / a
return tmp
function code(a, b, c)
return Float64(Float64(Float64(-b) - sqrt(Float64(Float64(b * b) - Float64(4.0 * Float64(a * c))))) / Float64(2.0 * a))
end
↓
function code(a, b, c)
tmp = 0.0
if (b <= -3e-118)
tmp = Float64(1.0 / Float64(Float64(a / b) - Float64(b / c)));
elseif (b <= 2.5e+135)
tmp = Float64(Float64(Float64(-b) - sqrt(Float64(Float64(b * b) - Float64(4.0 * Float64(a * c))))) / Float64(a * 2.0));
else
tmp = Float64(Float64(-b) / a);
end
return tmp
end
function tmp = code(a, b, c)
tmp = (-b - sqrt(((b * b) - (4.0 * (a * c))))) / (2.0 * a);
end
↓
function tmp_2 = code(a, b, c)
tmp = 0.0;
if (b <= -3e-118)
tmp = 1.0 / ((a / b) - (b / c));
elseif (b <= 2.5e+135)
tmp = (-b - sqrt(((b * b) - (4.0 * (a * c))))) / (a * 2.0);
else
tmp = -b / a;
end
tmp_2 = tmp;
end
(*.f64 (+.f64 b (sqrt.f64 (fma.f64 b b (*.f64 a (*.f64 c -4))))) (/.f64 -1/2 a)): 0 points increase in error, 0 points decrease in error
(*.f64 (+.f64 b (sqrt.f64 (fma.f64 b b (*.f64 a (*.f64 c (Rewrite<= metadata-eval (neg.f64 4))))))) (/.f64 -1/2 a)): 0 points increase in error, 0 points decrease in error
(*.f64 (+.f64 b (sqrt.f64 (fma.f64 b b (Rewrite<= associate-*l*_binary64 (*.f64 (*.f64 a c) (neg.f64 4)))))) (/.f64 -1/2 a)): 1 points increase in error, 0 points decrease in error
(*.f64 (+.f64 b (sqrt.f64 (fma.f64 b b (Rewrite<= distribute-rgt-neg-in_binary64 (neg.f64 (*.f64 (*.f64 a c) 4)))))) (/.f64 -1/2 a)): 0 points increase in error, 0 points decrease in error
(*.f64 (+.f64 b (sqrt.f64 (fma.f64 b b (neg.f64 (Rewrite<= *-commutative_binary64 (*.f64 4 (*.f64 a c))))))) (/.f64 -1/2 a)): 0 points increase in error, 0 points decrease in error
(*.f64 (+.f64 b (sqrt.f64 (Rewrite<= fma-neg_binary64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c)))))) (/.f64 -1/2 a)): 1 points increase in error, 1 points decrease in error
(*.f64 (+.f64 b (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c))))) (/.f64 (Rewrite<= metadata-eval (/.f64 -1 2)) a)): 0 points increase in error, 0 points decrease in error
(*.f64 (+.f64 b (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c))))) (Rewrite<= associate-/r*_binary64 (/.f64 -1 (*.f64 2 a)))): 0 points increase in error, 0 points decrease in error
(Rewrite=> associate-*r/_binary64 (/.f64 (*.f64 (+.f64 b (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c))))) -1) (*.f64 2 a))): 8 points increase in error, 23 points decrease in error
(/.f64 (Rewrite<= *-commutative_binary64 (*.f64 -1 (+.f64 b (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c))))))) (*.f64 2 a)): 0 points increase in error, 0 points decrease in error
(/.f64 (Rewrite<= neg-mul-1_binary64 (neg.f64 (+.f64 b (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c))))))) (*.f64 2 a)): 0 points increase in error, 0 points decrease in error
(/.f64 (Rewrite<= distribute-neg-out_binary64 (+.f64 (neg.f64 b) (neg.f64 (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c))))))) (*.f64 2 a)): 0 points increase in error, 0 points decrease in error
(/.f64 (Rewrite<= sub-neg_binary64 (-.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 4 (*.f64 a c)))))) (*.f64 2 a)): 0 points increase in error, 0 points decrease in error
(-.f64 (/.f64 a b) (/.f64 b c)): 0 points increase in error, 0 points decrease in error
(Rewrite<= unsub-neg_binary64 (+.f64 (/.f64 a b) (neg.f64 (/.f64 b c)))): 0 points increase in error, 0 points decrease in error
(+.f64 (/.f64 a b) (Rewrite<= mul-1-neg_binary64 (*.f64 -1 (/.f64 b c)))): 0 points increase in error, 0 points decrease in error
(+.f64 (/.f64 a b) (*.f64 (Rewrite<= metadata-eval (/.f64 4 -4)) (/.f64 b c))): 0 points increase in error, 0 points decrease in error
(+.f64 (/.f64 a b) (*.f64 (/.f64 4 (Rewrite<= rem-square-sqrt_binary64 (*.f64 (sqrt.f64 -4) (sqrt.f64 -4)))) (/.f64 b c))): 200 points increase in error, 0 points decrease in error
(+.f64 (/.f64 a b) (*.f64 (/.f64 4 (Rewrite<= unpow2_binary64 (pow.f64 (sqrt.f64 -4) 2))) (/.f64 b c))): 0 points increase in error, 0 points decrease in error
(+.f64 (/.f64 a b) (Rewrite<= times-frac_binary64 (/.f64 (*.f64 4 b) (*.f64 (pow.f64 (sqrt.f64 -4) 2) c)))): 0 points increase in error, 0 points decrease in error
(+.f64 (/.f64 a b) (/.f64 (*.f64 4 b) (Rewrite<= *-commutative_binary64 (*.f64 c (pow.f64 (sqrt.f64 -4) 2))))): 0 points increase in error, 0 points decrease in error
(+.f64 (/.f64 a b) (Rewrite<= associate-*r/_binary64 (*.f64 4 (/.f64 b (*.f64 c (pow.f64 (sqrt.f64 -4) 2)))))): 0 points increase in error, 0 points decrease in error
if -3.00000000000000018e-118 < b < 2.50000000000000015e135
herbie shell --seed 2022300
(FPCore (a b c)
:name "quadm (p42, negative)"
:precision binary64
:herbie-target
(if (< b 0.0) (/ c (* a (/ (+ (- b) (sqrt (- (* b b) (* 4.0 (* a c))))) (* 2.0 a)))) (/ (- (- b) (sqrt (- (* b b) (* 4.0 (* a c))))) (* 2.0 a)))
(/ (- (- b) (sqrt (- (* b b) (* 4.0 (* a c))))) (* 2.0 a)))