\sin^{-1} \left(\frac{h}{\sqrt{eta \cdot eta - \frac{sinTheta_O \cdot sinTheta_O}{\sqrt{1 - sinTheta_O \cdot sinTheta_O}}}}\right)
\begin{array}{l}
t_0 := \frac{sinTheta_O}{\sqrt{\sqrt{1 - sinTheta_O \cdot sinTheta_O}}}\\
\sin^{-1} \left(\frac{h}{\sqrt{eta + t_0} \cdot \sqrt{eta - t_0}}\right)
\end{array}
(FPCore (sinTheta_O h eta)
:precision binary32
(asin
(/
h
(sqrt
(-
(* eta eta)
(/
(* sinTheta_O sinTheta_O)
(sqrt (- 1.0 (* sinTheta_O sinTheta_O)))))))))(FPCore (sinTheta_O h eta) :precision binary32 (let* ((t_0 (/ sinTheta_O (sqrt (sqrt (- 1.0 (* sinTheta_O sinTheta_O))))))) (asin (/ h (* (sqrt (+ eta t_0)) (sqrt (- eta t_0)))))))
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)))));
}
float code(float sinTheta_O, float h, float eta) {
float t_0 = sinTheta_O / sqrtf(sqrtf(1.0f - (sinTheta_O * sinTheta_O)));
return asinf(h / (sqrtf(eta + t_0) * sqrtf(eta - t_0)));
}



Bits error versus sinTheta_O



Bits error versus h



Bits error versus eta
Results
Initial program 2.5
rmApplied add-sqr-sqrt_binary322.5
Applied times-frac_binary322.5
Applied difference-of-squares_binary322.5
Applied sqrt-prod_binary320.5
Final simplification0.5
herbie shell --seed 2021190
(FPCore (sinTheta_O h eta)
:name "HairBSDF, gamma for a refracted ray"
:precision binary32
:pre (and (<= -1.0 sinTheta_O 1.0) (<= -1.0 h 1.0) (<= 0.0 eta 10.0))
(asin (/ h (sqrt (- (* eta eta) (/ (* sinTheta_O sinTheta_O) (sqrt (- 1.0 (* sinTheta_O sinTheta_O)))))))))