\sin^{-1} \left(\frac{h}{\sqrt{eta \cdot eta - \frac{sinTheta_O \cdot sinTheta_O}{\sqrt{1 - sinTheta_O \cdot sinTheta_O}}}}\right)\sin^{-1} \left(\frac{h}{\sqrt{eta + \frac{sinTheta_O}{\sqrt{\sqrt{1 - sinTheta_O \cdot sinTheta_O}}}} \cdot \sqrt{eta - \frac{sinTheta_O}{\sqrt{\sqrt{1 - sinTheta_O \cdot sinTheta_O}}}}}\right)(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
(asin
(/
h
(*
(sqrt
(+ eta (/ sinTheta_O (sqrt (sqrt (- 1.0 (* sinTheta_O sinTheta_O)))))))
(sqrt
(-
eta
(/ sinTheta_O (sqrt (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)))));
}
float code(float sinTheta_O, float h, float eta) {
return asinf(h / (sqrtf(eta + (sinTheta_O / sqrtf(sqrtf(1.0f - (sinTheta_O * sinTheta_O))))) * sqrtf(eta - (sinTheta_O / sqrtf(sqrtf(1.0f - (sinTheta_O * sinTheta_O)))))));
}



Bits error versus sinTheta_O



Bits error versus h



Bits error versus eta
Results
Initial program 2.6
rmApplied add-sqr-sqrt_binary322.6
Applied times-frac_binary322.6
Applied difference-of-squares_binary322.6
Applied sqrt-prod_binary320.5
Final simplification0.5
herbie shell --seed 2021174
(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)))))))))