
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(asin
(/
h
(sqrt
(-
(* eta eta)
(/
(* sinTheta_O sinTheta_O)
(sqrt (- 1.0 (* sinTheta_O sinTheta_O)))))))))float code(float sinTheta_O, float h, float eta) {
return asinf((h / sqrtf(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrtf((1.0f - (sinTheta_O * sinTheta_O))))))));
}
real(4) function code(sintheta_o, h, eta)
use fmin_fmax_functions
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: h
real(4), intent (in) :: eta
code = asin((h / sqrt(((eta * eta) - ((sintheta_o * sintheta_o) / sqrt((1.0e0 - (sintheta_o * sintheta_o))))))))
end function
function code(sinTheta_O, h, eta) return asin(Float32(h / sqrt(Float32(Float32(eta * eta) - Float32(Float32(sinTheta_O * sinTheta_O) / sqrt(Float32(Float32(1.0) - Float32(sinTheta_O * sinTheta_O)))))))) end
function tmp = code(sinTheta_O, h, eta) tmp = asin((h / sqrt(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrt((single(1.0) - (sinTheta_O * sinTheta_O)))))))); end
\sin^{-1} \left(\frac{h}{\sqrt{eta \cdot eta - \frac{sinTheta\_O \cdot sinTheta\_O}{\sqrt{1 - sinTheta\_O \cdot sinTheta\_O}}}}\right)
Herbie found 6 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(asin
(/
h
(sqrt
(-
(* eta eta)
(/
(* sinTheta_O sinTheta_O)
(sqrt (- 1.0 (* sinTheta_O sinTheta_O)))))))))float code(float sinTheta_O, float h, float eta) {
return asinf((h / sqrtf(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrtf((1.0f - (sinTheta_O * sinTheta_O))))))));
}
real(4) function code(sintheta_o, h, eta)
use fmin_fmax_functions
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: h
real(4), intent (in) :: eta
code = asin((h / sqrt(((eta * eta) - ((sintheta_o * sintheta_o) / sqrt((1.0e0 - (sintheta_o * sintheta_o))))))))
end function
function code(sinTheta_O, h, eta) return asin(Float32(h / sqrt(Float32(Float32(eta * eta) - Float32(Float32(sinTheta_O * sinTheta_O) / sqrt(Float32(Float32(1.0) - Float32(sinTheta_O * sinTheta_O)))))))) end
function tmp = code(sinTheta_O, h, eta) tmp = asin((h / sqrt(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrt((single(1.0) - (sinTheta_O * sinTheta_O)))))))); end
\sin^{-1} \left(\frac{h}{\sqrt{eta \cdot eta - \frac{sinTheta\_O \cdot sinTheta\_O}{\sqrt{1 - sinTheta\_O \cdot sinTheta\_O}}}}\right)
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(let* ((t_0 (- (- (fabs eta)))))
(if (<= (* sinTheta_O sinTheta_O) 0.0)
(asin (/ h eta))
(asin
(/
h
(sqrt
(fma
t_0
t_0
(/
(* (- sinTheta_O) sinTheta_O)
(sqrt (- 1.0 (* sinTheta_O sinTheta_O)))))))))))float code(float sinTheta_O, float h, float eta) {
float t_0 = -(-fabsf(eta));
float tmp;
if ((sinTheta_O * sinTheta_O) <= 0.0f) {
tmp = asinf((h / eta));
} else {
tmp = asinf((h / sqrtf(fmaf(t_0, t_0, ((-sinTheta_O * sinTheta_O) / sqrtf((1.0f - (sinTheta_O * sinTheta_O))))))));
}
return tmp;
}
function code(sinTheta_O, h, eta) t_0 = Float32(-Float32(-abs(eta))) tmp = Float32(0.0) if (Float32(sinTheta_O * sinTheta_O) <= Float32(0.0)) tmp = asin(Float32(h / eta)); else tmp = asin(Float32(h / sqrt(fma(t_0, t_0, Float32(Float32(Float32(-sinTheta_O) * sinTheta_O) / sqrt(Float32(Float32(1.0) - Float32(sinTheta_O * sinTheta_O)))))))); end return tmp end
\begin{array}{l}
t_0 := -\left(-\left|eta\right|\right)\\
\mathbf{if}\;sinTheta\_O \cdot sinTheta\_O \leq 0:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{eta}\right)\\
\mathbf{else}:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{\sqrt{\mathsf{fma}\left(t\_0, t\_0, \frac{\left(-sinTheta\_O\right) \cdot sinTheta\_O}{\sqrt{1 - sinTheta\_O \cdot sinTheta\_O}}\right)}}\right)\\
\end{array}
if (*.f32 sinTheta_O sinTheta_O) < 0.0Initial program 91.9%
Taylor expanded in eta around inf
Applied rewrites95.4%
if 0.0 < (*.f32 sinTheta_O sinTheta_O) Initial program 91.9%
Applied rewrites91.9%
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(if (<= (* sinTheta_O sinTheta_O) 0.0)
(asin (/ h eta))
(asin
(/
h
(sqrt
(-
(* eta eta)
(/
(* sinTheta_O sinTheta_O)
(sqrt (- 1.0 (* sinTheta_O sinTheta_O))))))))))float code(float sinTheta_O, float h, float eta) {
float tmp;
if ((sinTheta_O * sinTheta_O) <= 0.0f) {
tmp = asinf((h / eta));
} else {
tmp = asinf((h / sqrtf(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrtf((1.0f - (sinTheta_O * sinTheta_O))))))));
}
return tmp;
}
real(4) function code(sintheta_o, h, eta)
use fmin_fmax_functions
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: h
real(4), intent (in) :: eta
real(4) :: tmp
if ((sintheta_o * sintheta_o) <= 0.0e0) then
tmp = asin((h / eta))
else
tmp = asin((h / sqrt(((eta * eta) - ((sintheta_o * sintheta_o) / sqrt((1.0e0 - (sintheta_o * sintheta_o))))))))
end if
code = tmp
end function
function code(sinTheta_O, h, eta) tmp = Float32(0.0) if (Float32(sinTheta_O * sinTheta_O) <= Float32(0.0)) tmp = asin(Float32(h / eta)); else tmp = asin(Float32(h / sqrt(Float32(Float32(eta * eta) - Float32(Float32(sinTheta_O * sinTheta_O) / sqrt(Float32(Float32(1.0) - Float32(sinTheta_O * sinTheta_O)))))))); end return tmp end
function tmp_2 = code(sinTheta_O, h, eta) tmp = single(0.0); if ((sinTheta_O * sinTheta_O) <= single(0.0)) tmp = asin((h / eta)); else tmp = asin((h / sqrt(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrt((single(1.0) - (sinTheta_O * sinTheta_O)))))))); end tmp_2 = tmp; end
\begin{array}{l}
\mathbf{if}\;sinTheta\_O \cdot sinTheta\_O \leq 0:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{eta}\right)\\
\mathbf{else}:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{\sqrt{eta \cdot eta - \frac{sinTheta\_O \cdot sinTheta\_O}{\sqrt{1 - sinTheta\_O \cdot sinTheta\_O}}}}\right)\\
\end{array}
if (*.f32 sinTheta_O sinTheta_O) < 0.0Initial program 91.9%
Taylor expanded in eta around inf
Applied rewrites95.4%
if 0.0 < (*.f32 sinTheta_O sinTheta_O) Initial program 91.9%
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(if (<= (* sinTheta_O sinTheta_O) 0.0)
(asin (/ h eta))
(asin
(/
h
(sqrt
(fma
(- eta)
(- eta)
(/ (* (- sinTheta_O) sinTheta_O) (sqrt 1.0))))))))float code(float sinTheta_O, float h, float eta) {
float tmp;
if ((sinTheta_O * sinTheta_O) <= 0.0f) {
tmp = asinf((h / eta));
} else {
tmp = asinf((h / sqrtf(fmaf(-eta, -eta, ((-sinTheta_O * sinTheta_O) / sqrtf(1.0f))))));
}
return tmp;
}
function code(sinTheta_O, h, eta) tmp = Float32(0.0) if (Float32(sinTheta_O * sinTheta_O) <= Float32(0.0)) tmp = asin(Float32(h / eta)); else tmp = asin(Float32(h / sqrt(fma(Float32(-eta), Float32(-eta), Float32(Float32(Float32(-sinTheta_O) * sinTheta_O) / sqrt(Float32(1.0))))))); end return tmp end
\begin{array}{l}
\mathbf{if}\;sinTheta\_O \cdot sinTheta\_O \leq 0:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{eta}\right)\\
\mathbf{else}:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{\sqrt{\mathsf{fma}\left(-eta, -eta, \frac{\left(-sinTheta\_O\right) \cdot sinTheta\_O}{\sqrt{1}}\right)}}\right)\\
\end{array}
if (*.f32 sinTheta_O sinTheta_O) < 0.0Initial program 91.9%
Taylor expanded in eta around inf
Applied rewrites95.4%
if 0.0 < (*.f32 sinTheta_O sinTheta_O) Initial program 91.9%
Taylor expanded in sinTheta_O around 0
Applied rewrites91.7%
Applied rewrites91.7%
Applied rewrites91.7%
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(if (<= (* sinTheta_O sinTheta_O) 0.0)
(asin (/ h eta))
(asin
(/
h
(sqrt
(fma (/ (- sinTheta_O) (sqrt 1.0)) sinTheta_O (* eta eta)))))))float code(float sinTheta_O, float h, float eta) {
float tmp;
if ((sinTheta_O * sinTheta_O) <= 0.0f) {
tmp = asinf((h / eta));
} else {
tmp = asinf((h / sqrtf(fmaf((-sinTheta_O / sqrtf(1.0f)), sinTheta_O, (eta * eta)))));
}
return tmp;
}
function code(sinTheta_O, h, eta) tmp = Float32(0.0) if (Float32(sinTheta_O * sinTheta_O) <= Float32(0.0)) tmp = asin(Float32(h / eta)); else tmp = asin(Float32(h / sqrt(fma(Float32(Float32(-sinTheta_O) / sqrt(Float32(1.0))), sinTheta_O, Float32(eta * eta))))); end return tmp end
\begin{array}{l}
\mathbf{if}\;sinTheta\_O \cdot sinTheta\_O \leq 0:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{eta}\right)\\
\mathbf{else}:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{\sqrt{\mathsf{fma}\left(\frac{-sinTheta\_O}{\sqrt{1}}, sinTheta\_O, eta \cdot eta\right)}}\right)\\
\end{array}
if (*.f32 sinTheta_O sinTheta_O) < 0.0Initial program 91.9%
Taylor expanded in eta around inf
Applied rewrites95.4%
if 0.0 < (*.f32 sinTheta_O sinTheta_O) Initial program 91.9%
Applied rewrites91.9%
Taylor expanded in sinTheta_O around 0
Applied rewrites91.7%
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(if (<= (* sinTheta_O sinTheta_O) 0.0)
(asin (/ h eta))
(asin
(/
h
(sqrt (- (* eta eta) (/ (* sinTheta_O sinTheta_O) (sqrt 1.0))))))))float code(float sinTheta_O, float h, float eta) {
float tmp;
if ((sinTheta_O * sinTheta_O) <= 0.0f) {
tmp = asinf((h / eta));
} else {
tmp = asinf((h / sqrtf(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrtf(1.0f))))));
}
return tmp;
}
real(4) function code(sintheta_o, h, eta)
use fmin_fmax_functions
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: h
real(4), intent (in) :: eta
real(4) :: tmp
if ((sintheta_o * sintheta_o) <= 0.0e0) then
tmp = asin((h / eta))
else
tmp = asin((h / sqrt(((eta * eta) - ((sintheta_o * sintheta_o) / sqrt(1.0e0))))))
end if
code = tmp
end function
function code(sinTheta_O, h, eta) tmp = Float32(0.0) if (Float32(sinTheta_O * sinTheta_O) <= Float32(0.0)) tmp = asin(Float32(h / eta)); else tmp = asin(Float32(h / sqrt(Float32(Float32(eta * eta) - Float32(Float32(sinTheta_O * sinTheta_O) / sqrt(Float32(1.0))))))); end return tmp end
function tmp_2 = code(sinTheta_O, h, eta) tmp = single(0.0); if ((sinTheta_O * sinTheta_O) <= single(0.0)) tmp = asin((h / eta)); else tmp = asin((h / sqrt(((eta * eta) - ((sinTheta_O * sinTheta_O) / sqrt(single(1.0))))))); end tmp_2 = tmp; end
\begin{array}{l}
\mathbf{if}\;sinTheta\_O \cdot sinTheta\_O \leq 0:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{eta}\right)\\
\mathbf{else}:\\
\;\;\;\;\sin^{-1} \left(\frac{h}{\sqrt{eta \cdot eta - \frac{sinTheta\_O \cdot sinTheta\_O}{\sqrt{1}}}}\right)\\
\end{array}
if (*.f32 sinTheta_O sinTheta_O) < 0.0Initial program 91.9%
Taylor expanded in eta around inf
Applied rewrites95.4%
if 0.0 < (*.f32 sinTheta_O sinTheta_O) Initial program 91.9%
Taylor expanded in sinTheta_O around 0
Applied rewrites91.7%
(FPCore (sinTheta_O h eta)
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))
(and (<= -1.0 h) (<= h 1.0)))
(and (<= 0.0 eta) (<= eta 10.0)))
(asin (/ h eta)))float code(float sinTheta_O, float h, float eta) {
return asinf((h / eta));
}
real(4) function code(sintheta_o, h, eta)
use fmin_fmax_functions
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: h
real(4), intent (in) :: eta
code = asin((h / eta))
end function
function code(sinTheta_O, h, eta) return asin(Float32(h / eta)) end
function tmp = code(sinTheta_O, h, eta) tmp = asin((h / eta)); end
\sin^{-1} \left(\frac{h}{eta}\right)
Initial program 91.9%
Taylor expanded in eta around inf
Applied rewrites95.4%
herbie shell --seed 2026070
(FPCore (sinTheta_O h eta)
:name "HairBSDF, gamma for a refracted ray"
:precision binary32
:pre (and (and (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0)) (and (<= -1.0 h) (<= h 1.0))) (and (<= 0.0 eta) (<= eta 10.0)))
(asin (/ h (sqrt (- (* eta eta) (/ (* sinTheta_O sinTheta_O) (sqrt (- 1.0 (* sinTheta_O sinTheta_O)))))))))