(FPCore (x y z) :precision binary64 (/ (* x y) (* (* z z) (+ z 1.0))))
↓
(FPCore (x y z)
:precision binary64
(let* ((t_0 (* (* z z) (+ z 1.0))))
(if (<= t_0 -1000000.0)
(/ (/ x (/ z (/ y z))) z)
(if (<= t_0 2e-278)
(/ (/ x (/ z y)) z)
(if (<= t_0 1e-161)
(/ x (* z (* z (/ (+ z 1.0) y))))
(if (<= t_0 1e+238) (/ (* x y) t_0) (* (/ (/ x z) z) (/ y z))))))))
double code(double x, double y, double z) {
double t_0 = (z * z) * (z + 1.0);
double tmp;
if (t_0 <= -1000000.0) {
tmp = (x / (z / (y / z))) / z;
} else if (t_0 <= 2e-278) {
tmp = (x / (z / y)) / z;
} else if (t_0 <= 1e-161) {
tmp = x / (z * (z * ((z + 1.0) / y)));
} else if (t_0 <= 1e+238) {
tmp = (x * y) / t_0;
} else {
tmp = ((x / z) / z) * (y / z);
}
return tmp;
}
real(8) function code(x, y, z)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
code = (x * y) / ((z * z) * (z + 1.0d0))
end function
↓
real(8) function code(x, y, z)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8) :: t_0
real(8) :: tmp
t_0 = (z * z) * (z + 1.0d0)
if (t_0 <= (-1000000.0d0)) then
tmp = (x / (z / (y / z))) / z
else if (t_0 <= 2d-278) then
tmp = (x / (z / y)) / z
else if (t_0 <= 1d-161) then
tmp = x / (z * (z * ((z + 1.0d0) / y)))
else if (t_0 <= 1d+238) then
tmp = (x * y) / t_0
else
tmp = ((x / z) / z) * (y / z)
end if
code = tmp
end function
public static double code(double x, double y, double z) {
return (x * y) / ((z * z) * (z + 1.0));
}
↓
public static double code(double x, double y, double z) {
double t_0 = (z * z) * (z + 1.0);
double tmp;
if (t_0 <= -1000000.0) {
tmp = (x / (z / (y / z))) / z;
} else if (t_0 <= 2e-278) {
tmp = (x / (z / y)) / z;
} else if (t_0 <= 1e-161) {
tmp = x / (z * (z * ((z + 1.0) / y)));
} else if (t_0 <= 1e+238) {
tmp = (x * y) / t_0;
} else {
tmp = ((x / z) / z) * (y / z);
}
return tmp;
}
def code(x, y, z):
return (x * y) / ((z * z) * (z + 1.0))
↓
def code(x, y, z):
t_0 = (z * z) * (z + 1.0)
tmp = 0
if t_0 <= -1000000.0:
tmp = (x / (z / (y / z))) / z
elif t_0 <= 2e-278:
tmp = (x / (z / y)) / z
elif t_0 <= 1e-161:
tmp = x / (z * (z * ((z + 1.0) / y)))
elif t_0 <= 1e+238:
tmp = (x * y) / t_0
else:
tmp = ((x / z) / z) * (y / z)
return tmp
function code(x, y, z)
return Float64(Float64(x * y) / Float64(Float64(z * z) * Float64(z + 1.0)))
end
herbie shell --seed 2023088
(FPCore (x y z)
:name "Statistics.Distribution.Beta:$cvariance from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(if (< z 249.6182814532307) (/ (* y (/ x z)) (+ z (* z z))) (/ (* (/ (/ y z) (+ 1.0 z)) x) z))
(/ (* x y) (* (* z z) (+ z 1.0))))