
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (/ (- (log (- 1.0 u0))) (+ (/ cos2phi (* alphax alphax)) (/ sin2phi (* alphay alphay)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return -logf((1.0f - u0)) / ((cos2phi / (alphax * alphax)) + (sin2phi / (alphay * alphay)));
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
code = -log((1.0e0 - u0)) / ((cos2phi / (alphax * alphax)) + (sin2phi / (alphay * alphay)))
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(-log(Float32(Float32(1.0) - u0))) / Float32(Float32(cos2phi / Float32(alphax * alphax)) + Float32(sin2phi / Float32(alphay * alphay)))) end
function tmp = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = -log((single(1.0) - u0)) / ((cos2phi / (alphax * alphax)) + (sin2phi / (alphay * alphay))); end
\begin{array}{l}
\\
\frac{-\log \left(1 - u0\right)}{\frac{cos2phi}{alphax \cdot alphax} + \frac{sin2phi}{alphay \cdot alphay}}
\end{array}
Sampling outcomes in binary32 precision:
Herbie found 11 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (/ (- (log (- 1.0 u0))) (+ (/ cos2phi (* alphax alphax)) (/ sin2phi (* alphay alphay)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return -logf((1.0f - u0)) / ((cos2phi / (alphax * alphax)) + (sin2phi / (alphay * alphay)));
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
code = -log((1.0e0 - u0)) / ((cos2phi / (alphax * alphax)) + (sin2phi / (alphay * alphay)))
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(-log(Float32(Float32(1.0) - u0))) / Float32(Float32(cos2phi / Float32(alphax * alphax)) + Float32(sin2phi / Float32(alphay * alphay)))) end
function tmp = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = -log((single(1.0) - u0)) / ((cos2phi / (alphax * alphax)) + (sin2phi / (alphay * alphay))); end
\begin{array}{l}
\\
\frac{-\log \left(1 - u0\right)}{\frac{cos2phi}{alphax \cdot alphax} + \frac{sin2phi}{alphay \cdot alphay}}
\end{array}
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (* (/ (- (log1p (- u0))) (+ (/ (* alphax sin2phi) alphay) (* (* alphay cos2phi) (/ 1.0 alphax)))) (* alphax alphay)))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return (-log1pf(-u0) / (((alphax * sin2phi) / alphay) + ((alphay * cos2phi) * (1.0f / alphax)))) * (alphax * alphay);
}
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(Float32(-log1p(Float32(-u0))) / Float32(Float32(Float32(alphax * sin2phi) / alphay) + Float32(Float32(alphay * cos2phi) * Float32(Float32(1.0) / alphax)))) * Float32(alphax * alphay)) end
\begin{array}{l}
\\
\frac{-\mathsf{log1p}\left(-u0\right)}{\frac{alphax \cdot sin2phi}{alphay} + \left(alphay \cdot cos2phi\right) \cdot \frac{1}{alphax}} \cdot \left(alphax \cdot alphay\right)
\end{array}
Initial program 62.4%
sub-neg62.4%
log1p-def97.8%
Simplified97.8%
associate-/r*97.8%
associate-/r*97.8%
frac-add97.4%
Applied egg-rr97.4%
+-commutative97.4%
*-commutative97.4%
fma-def97.5%
*-commutative97.5%
associate-*l/97.4%
associate-/l*97.5%
Simplified97.5%
associate-/r/98.1%
associate-/r/98.0%
Applied egg-rr98.0%
Taylor expanded in alphax around 0 98.3%
div-inv98.3%
Applied egg-rr98.3%
Final simplification98.3%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (* (* alphax alphay) (/ (- (log1p (- u0))) (+ (/ (* alphax sin2phi) alphay) (/ (* alphay cos2phi) alphax)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return (alphax * alphay) * (-log1pf(-u0) / (((alphax * sin2phi) / alphay) + ((alphay * cos2phi) / alphax)));
}
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(alphax * alphay) * Float32(Float32(-log1p(Float32(-u0))) / Float32(Float32(Float32(alphax * sin2phi) / alphay) + Float32(Float32(alphay * cos2phi) / alphax)))) end
\begin{array}{l}
\\
\left(alphax \cdot alphay\right) \cdot \frac{-\mathsf{log1p}\left(-u0\right)}{\frac{alphax \cdot sin2phi}{alphay} + \frac{alphay \cdot cos2phi}{alphax}}
\end{array}
Initial program 62.4%
sub-neg62.4%
log1p-def97.8%
Simplified97.8%
associate-/r*97.8%
associate-/r*97.8%
frac-add97.4%
Applied egg-rr97.4%
+-commutative97.4%
*-commutative97.4%
fma-def97.5%
*-commutative97.5%
associate-*l/97.4%
associate-/l*97.5%
Simplified97.5%
associate-/r/98.1%
associate-/r/98.0%
Applied egg-rr98.0%
Taylor expanded in alphax around 0 98.3%
Final simplification98.3%
(FPCore (alphax alphay u0 cos2phi sin2phi)
:precision binary32
(if (<= sin2phi 1.7999999499807018e-6)
(*
(* alphax alphay)
(/ u0 (+ (/ (* alphay cos2phi) alphax) (/ alphax (/ alphay sin2phi)))))
(* (/ (* (log1p (- u0)) (/ alphay alphax)) sin2phi) (* alphax (- alphay)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
float tmp;
if (sin2phi <= 1.7999999499807018e-6f) {
tmp = (alphax * alphay) * (u0 / (((alphay * cos2phi) / alphax) + (alphax / (alphay / sin2phi))));
} else {
tmp = ((log1pf(-u0) * (alphay / alphax)) / sin2phi) * (alphax * -alphay);
}
return tmp;
}
function code(alphax, alphay, u0, cos2phi, sin2phi) tmp = Float32(0.0) if (sin2phi <= Float32(1.7999999499807018e-6)) tmp = Float32(Float32(alphax * alphay) * Float32(u0 / Float32(Float32(Float32(alphay * cos2phi) / alphax) + Float32(alphax / Float32(alphay / sin2phi))))); else tmp = Float32(Float32(Float32(log1p(Float32(-u0)) * Float32(alphay / alphax)) / sin2phi) * Float32(alphax * Float32(-alphay))); end return tmp end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;sin2phi \leq 1.7999999499807018 \cdot 10^{-6}:\\
\;\;\;\;\left(alphax \cdot alphay\right) \cdot \frac{u0}{\frac{alphay \cdot cos2phi}{alphax} + \frac{alphax}{\frac{alphay}{sin2phi}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{log1p}\left(-u0\right) \cdot \frac{alphay}{alphax}}{sin2phi} \cdot \left(alphax \cdot \left(-alphay\right)\right)\\
\end{array}
\end{array}
if sin2phi < 1.79999995e-6Initial program 55.0%
sub-neg55.0%
log1p-def98.4%
Simplified98.4%
associate-/r*98.4%
associate-/r*98.3%
frac-add98.1%
Applied egg-rr98.1%
+-commutative98.1%
*-commutative98.1%
fma-def98.1%
*-commutative98.1%
associate-*l/97.8%
associate-/l*98.2%
Simplified98.2%
associate-/r/98.3%
associate-/r/98.1%
Applied egg-rr98.1%
Taylor expanded in u0 around 0 74.6%
*-un-lft-identity74.6%
associate-/l*74.7%
Applied egg-rr74.7%
if 1.79999995e-6 < sin2phi Initial program 68.2%
sub-neg68.2%
log1p-def97.3%
Simplified97.3%
associate-/r*97.3%
associate-/r*97.4%
frac-add96.9%
Applied egg-rr96.9%
+-commutative96.9%
*-commutative96.9%
fma-def97.0%
*-commutative97.0%
associate-*l/97.0%
associate-/l*97.0%
Simplified97.0%
associate-/r/97.9%
associate-/r/98.0%
Applied egg-rr98.0%
Taylor expanded in alphax around inf 68.6%
mul-1-neg68.6%
times-frac68.6%
Simplified68.6%
Taylor expanded in alphay around 0 68.6%
times-frac68.6%
associate-*r/68.5%
sub-neg68.5%
mul-1-neg68.5%
log1p-def96.2%
mul-1-neg96.2%
Simplified96.2%
Final simplification86.7%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (/ (- (log1p (- u0))) (+ (/ cos2phi (* alphax alphax)) (/ sin2phi (* alphay alphay)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return -log1pf(-u0) / ((cos2phi / (alphax * alphax)) + (sin2phi / (alphay * alphay)));
}
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(-log1p(Float32(-u0))) / Float32(Float32(cos2phi / Float32(alphax * alphax)) + Float32(sin2phi / Float32(alphay * alphay)))) end
\begin{array}{l}
\\
\frac{-\mathsf{log1p}\left(-u0\right)}{\frac{cos2phi}{alphax \cdot alphax} + \frac{sin2phi}{alphay \cdot alphay}}
\end{array}
Initial program 62.4%
sub-neg62.4%
log1p-def97.8%
Simplified97.8%
Final simplification97.8%
(FPCore (alphax alphay u0 cos2phi sin2phi)
:precision binary32
(if (<= sin2phi 4.999999873689376e-6)
(*
(* alphax alphay)
(/ u0 (+ (/ (* alphay cos2phi) alphax) (/ alphax (/ alphay sin2phi)))))
(/ (- (pow alphay 2.0)) (- (* sin2phi 0.5) (/ sin2phi u0)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
float tmp;
if (sin2phi <= 4.999999873689376e-6f) {
tmp = (alphax * alphay) * (u0 / (((alphay * cos2phi) / alphax) + (alphax / (alphay / sin2phi))));
} else {
tmp = -powf(alphay, 2.0f) / ((sin2phi * 0.5f) - (sin2phi / u0));
}
return tmp;
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
real(4) :: tmp
if (sin2phi <= 4.999999873689376e-6) then
tmp = (alphax * alphay) * (u0 / (((alphay * cos2phi) / alphax) + (alphax / (alphay / sin2phi))))
else
tmp = -(alphay ** 2.0e0) / ((sin2phi * 0.5e0) - (sin2phi / u0))
end if
code = tmp
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) tmp = Float32(0.0) if (sin2phi <= Float32(4.999999873689376e-6)) tmp = Float32(Float32(alphax * alphay) * Float32(u0 / Float32(Float32(Float32(alphay * cos2phi) / alphax) + Float32(alphax / Float32(alphay / sin2phi))))); else tmp = Float32(Float32(-(alphay ^ Float32(2.0))) / Float32(Float32(sin2phi * Float32(0.5)) - Float32(sin2phi / u0))); end return tmp end
function tmp_2 = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = single(0.0); if (sin2phi <= single(4.999999873689376e-6)) tmp = (alphax * alphay) * (u0 / (((alphay * cos2phi) / alphax) + (alphax / (alphay / sin2phi)))); else tmp = -(alphay ^ single(2.0)) / ((sin2phi * single(0.5)) - (sin2phi / u0)); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;sin2phi \leq 4.999999873689376 \cdot 10^{-6}:\\
\;\;\;\;\left(alphax \cdot alphay\right) \cdot \frac{u0}{\frac{alphay \cdot cos2phi}{alphax} + \frac{alphax}{\frac{alphay}{sin2phi}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{-{alphay}^{2}}{sin2phi \cdot 0.5 - \frac{sin2phi}{u0}}\\
\end{array}
\end{array}
if sin2phi < 4.99999987e-6Initial program 56.1%
sub-neg56.1%
log1p-def98.4%
Simplified98.4%
associate-/r*98.4%
associate-/r*98.3%
frac-add98.0%
Applied egg-rr98.0%
+-commutative98.0%
*-commutative98.0%
fma-def98.1%
*-commutative98.1%
associate-*l/97.8%
associate-/l*98.1%
Simplified98.1%
associate-/r/98.2%
associate-/r/98.1%
Applied egg-rr98.1%
Taylor expanded in u0 around 0 73.9%
*-un-lft-identity73.9%
associate-/l*74.0%
Applied egg-rr74.0%
if 4.99999987e-6 < sin2phi Initial program 67.8%
sub-neg67.8%
log1p-def97.3%
Simplified97.3%
Taylor expanded in cos2phi around 0 69.0%
mul-1-neg69.0%
associate-/l*67.9%
distribute-neg-frac67.9%
sub-neg67.9%
log1p-def96.2%
Simplified96.2%
Taylor expanded in u0 around 0 86.5%
neg-mul-186.5%
+-commutative86.5%
unsub-neg86.5%
*-commutative86.5%
Simplified86.5%
Final simplification80.7%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (* (* alphax alphay) (/ u0 (+ (/ (* alphay cos2phi) alphax) (* sin2phi (/ alphax alphay))))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return (alphax * alphay) * (u0 / (((alphay * cos2phi) / alphax) + (sin2phi * (alphax / alphay))));
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
code = (alphax * alphay) * (u0 / (((alphay * cos2phi) / alphax) + (sin2phi * (alphax / alphay))))
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(alphax * alphay) * Float32(u0 / Float32(Float32(Float32(alphay * cos2phi) / alphax) + Float32(sin2phi * Float32(alphax / alphay))))) end
function tmp = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = (alphax * alphay) * (u0 / (((alphay * cos2phi) / alphax) + (sin2phi * (alphax / alphay)))); end
\begin{array}{l}
\\
\left(alphax \cdot alphay\right) \cdot \frac{u0}{\frac{alphay \cdot cos2phi}{alphax} + sin2phi \cdot \frac{alphax}{alphay}}
\end{array}
Initial program 62.4%
sub-neg62.4%
log1p-def97.8%
Simplified97.8%
associate-/r*97.8%
associate-/r*97.8%
frac-add97.4%
Applied egg-rr97.4%
+-commutative97.4%
*-commutative97.4%
fma-def97.5%
*-commutative97.5%
associate-*l/97.4%
associate-/l*97.5%
Simplified97.5%
associate-/r/98.1%
associate-/r/98.0%
Applied egg-rr98.0%
Taylor expanded in alphax around 0 98.3%
Taylor expanded in u0 around 0 74.7%
associate-/l*74.7%
associate-/l*74.7%
associate-/r/74.7%
*-commutative74.7%
associate-/l*74.7%
Simplified74.7%
Final simplification74.7%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (/ (* u0 (* alphax alphay)) (+ (/ alphax (/ alphay sin2phi)) (/ alphay (/ alphax cos2phi)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return (u0 * (alphax * alphay)) / ((alphax / (alphay / sin2phi)) + (alphay / (alphax / cos2phi)));
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
code = (u0 * (alphax * alphay)) / ((alphax / (alphay / sin2phi)) + (alphay / (alphax / cos2phi)))
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(u0 * Float32(alphax * alphay)) / Float32(Float32(alphax / Float32(alphay / sin2phi)) + Float32(alphay / Float32(alphax / cos2phi)))) end
function tmp = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = (u0 * (alphax * alphay)) / ((alphax / (alphay / sin2phi)) + (alphay / (alphax / cos2phi))); end
\begin{array}{l}
\\
\frac{u0 \cdot \left(alphax \cdot alphay\right)}{\frac{alphax}{\frac{alphay}{sin2phi}} + \frac{alphay}{\frac{alphax}{cos2phi}}}
\end{array}
Initial program 62.4%
sub-neg62.4%
log1p-def97.8%
Simplified97.8%
associate-/r*97.8%
associate-/r*97.8%
frac-add97.4%
Applied egg-rr97.4%
+-commutative97.4%
*-commutative97.4%
fma-def97.5%
*-commutative97.5%
associate-*l/97.4%
associate-/l*97.5%
Simplified97.5%
associate-/r/98.1%
associate-/r/98.0%
Applied egg-rr98.0%
Taylor expanded in u0 around 0 74.7%
associate-*l/74.7%
associate-/l*74.8%
associate-/l*74.8%
Applied egg-rr74.8%
Final simplification74.8%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (if (<= sin2phi 7.599999731107421e-13) (* (* alphax alphay) (* (/ alphax alphay) (/ u0 cos2phi))) (* (/ alphay sin2phi) (/ alphay (/ 1.0 u0)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
float tmp;
if (sin2phi <= 7.599999731107421e-13f) {
tmp = (alphax * alphay) * ((alphax / alphay) * (u0 / cos2phi));
} else {
tmp = (alphay / sin2phi) * (alphay / (1.0f / u0));
}
return tmp;
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
real(4) :: tmp
if (sin2phi <= 7.599999731107421e-13) then
tmp = (alphax * alphay) * ((alphax / alphay) * (u0 / cos2phi))
else
tmp = (alphay / sin2phi) * (alphay / (1.0e0 / u0))
end if
code = tmp
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) tmp = Float32(0.0) if (sin2phi <= Float32(7.599999731107421e-13)) tmp = Float32(Float32(alphax * alphay) * Float32(Float32(alphax / alphay) * Float32(u0 / cos2phi))); else tmp = Float32(Float32(alphay / sin2phi) * Float32(alphay / Float32(Float32(1.0) / u0))); end return tmp end
function tmp_2 = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = single(0.0); if (sin2phi <= single(7.599999731107421e-13)) tmp = (alphax * alphay) * ((alphax / alphay) * (u0 / cos2phi)); else tmp = (alphay / sin2phi) * (alphay / (single(1.0) / u0)); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;sin2phi \leq 7.599999731107421 \cdot 10^{-13}:\\
\;\;\;\;\left(alphax \cdot alphay\right) \cdot \left(\frac{alphax}{alphay} \cdot \frac{u0}{cos2phi}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{alphay}{sin2phi} \cdot \frac{alphay}{\frac{1}{u0}}\\
\end{array}
\end{array}
if sin2phi < 7.59999973e-13Initial program 55.9%
sub-neg55.9%
log1p-def98.3%
Simplified98.3%
associate-/r*98.2%
associate-/r*98.2%
frac-add98.1%
Applied egg-rr98.1%
+-commutative98.1%
*-commutative98.1%
fma-def98.2%
*-commutative98.2%
associate-*l/97.8%
associate-/l*98.2%
Simplified98.2%
associate-/r/98.4%
associate-/r/98.2%
Applied egg-rr98.2%
Taylor expanded in u0 around 0 74.1%
Taylor expanded in alphax around 0 52.6%
times-frac52.5%
Simplified52.5%
if 7.59999973e-13 < sin2phi Initial program 65.7%
sub-neg65.7%
log1p-def97.6%
Simplified97.6%
associate-/r*97.6%
associate-/r*97.6%
frac-add97.1%
Applied egg-rr97.1%
+-commutative97.1%
*-commutative97.1%
fma-def97.2%
*-commutative97.2%
associate-*l/97.2%
associate-/l*97.1%
Simplified97.1%
Taylor expanded in u0 around 0 75.0%
Taylor expanded in alphax around inf 70.3%
associate-/l*69.7%
Simplified69.7%
unpow269.7%
div-inv69.6%
times-frac70.3%
Applied egg-rr70.3%
Final simplification64.3%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (if (<= sin2phi 7.599999731107421e-13) (* (* alphax alphay) (/ (* u0 alphax) (* alphay cos2phi))) (* (/ alphay sin2phi) (/ alphay (/ 1.0 u0)))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
float tmp;
if (sin2phi <= 7.599999731107421e-13f) {
tmp = (alphax * alphay) * ((u0 * alphax) / (alphay * cos2phi));
} else {
tmp = (alphay / sin2phi) * (alphay / (1.0f / u0));
}
return tmp;
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
real(4) :: tmp
if (sin2phi <= 7.599999731107421e-13) then
tmp = (alphax * alphay) * ((u0 * alphax) / (alphay * cos2phi))
else
tmp = (alphay / sin2phi) * (alphay / (1.0e0 / u0))
end if
code = tmp
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) tmp = Float32(0.0) if (sin2phi <= Float32(7.599999731107421e-13)) tmp = Float32(Float32(alphax * alphay) * Float32(Float32(u0 * alphax) / Float32(alphay * cos2phi))); else tmp = Float32(Float32(alphay / sin2phi) * Float32(alphay / Float32(Float32(1.0) / u0))); end return tmp end
function tmp_2 = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = single(0.0); if (sin2phi <= single(7.599999731107421e-13)) tmp = (alphax * alphay) * ((u0 * alphax) / (alphay * cos2phi)); else tmp = (alphay / sin2phi) * (alphay / (single(1.0) / u0)); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;sin2phi \leq 7.599999731107421 \cdot 10^{-13}:\\
\;\;\;\;\left(alphax \cdot alphay\right) \cdot \frac{u0 \cdot alphax}{alphay \cdot cos2phi}\\
\mathbf{else}:\\
\;\;\;\;\frac{alphay}{sin2phi} \cdot \frac{alphay}{\frac{1}{u0}}\\
\end{array}
\end{array}
if sin2phi < 7.59999973e-13Initial program 55.9%
sub-neg55.9%
log1p-def98.3%
Simplified98.3%
associate-/r*98.2%
associate-/r*98.2%
frac-add98.1%
Applied egg-rr98.1%
+-commutative98.1%
*-commutative98.1%
fma-def98.2%
*-commutative98.2%
associate-*l/97.8%
associate-/l*98.2%
Simplified98.2%
associate-/r/98.4%
associate-/r/98.2%
Applied egg-rr98.2%
Taylor expanded in u0 around 0 74.1%
Taylor expanded in alphax around 0 52.6%
if 7.59999973e-13 < sin2phi Initial program 65.7%
sub-neg65.7%
log1p-def97.6%
Simplified97.6%
associate-/r*97.6%
associate-/r*97.6%
frac-add97.1%
Applied egg-rr97.1%
+-commutative97.1%
*-commutative97.1%
fma-def97.2%
*-commutative97.2%
associate-*l/97.2%
associate-/l*97.1%
Simplified97.1%
Taylor expanded in u0 around 0 75.0%
Taylor expanded in alphax around inf 70.3%
associate-/l*69.7%
Simplified69.7%
unpow269.7%
div-inv69.6%
times-frac70.3%
Applied egg-rr70.3%
Final simplification64.3%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (* (/ alphay sin2phi) (/ alphay (/ 1.0 u0))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return (alphay / sin2phi) * (alphay / (1.0f / u0));
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
code = (alphay / sin2phi) * (alphay / (1.0e0 / u0))
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(Float32(alphay / sin2phi) * Float32(alphay / Float32(Float32(1.0) / u0))) end
function tmp = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = (alphay / sin2phi) * (alphay / (single(1.0) / u0)); end
\begin{array}{l}
\\
\frac{alphay}{sin2phi} \cdot \frac{alphay}{\frac{1}{u0}}
\end{array}
Initial program 62.4%
sub-neg62.4%
log1p-def97.8%
Simplified97.8%
associate-/r*97.8%
associate-/r*97.8%
frac-add97.4%
Applied egg-rr97.4%
+-commutative97.4%
*-commutative97.4%
fma-def97.5%
*-commutative97.5%
associate-*l/97.4%
associate-/l*97.5%
Simplified97.5%
Taylor expanded in u0 around 0 74.7%
Taylor expanded in alphax around inf 56.2%
associate-/l*55.7%
Simplified55.7%
unpow255.7%
div-inv55.7%
times-frac56.2%
Applied egg-rr56.2%
Final simplification56.2%
(FPCore (alphax alphay u0 cos2phi sin2phi) :precision binary32 (* alphay (/ alphay (/ sin2phi u0))))
float code(float alphax, float alphay, float u0, float cos2phi, float sin2phi) {
return alphay * (alphay / (sin2phi / u0));
}
real(4) function code(alphax, alphay, u0, cos2phi, sin2phi)
real(4), intent (in) :: alphax
real(4), intent (in) :: alphay
real(4), intent (in) :: u0
real(4), intent (in) :: cos2phi
real(4), intent (in) :: sin2phi
code = alphay * (alphay / (sin2phi / u0))
end function
function code(alphax, alphay, u0, cos2phi, sin2phi) return Float32(alphay * Float32(alphay / Float32(sin2phi / u0))) end
function tmp = code(alphax, alphay, u0, cos2phi, sin2phi) tmp = alphay * (alphay / (sin2phi / u0)); end
\begin{array}{l}
\\
alphay \cdot \frac{alphay}{\frac{sin2phi}{u0}}
\end{array}
Initial program 62.4%
sub-neg62.4%
log1p-def97.8%
Simplified97.8%
associate-/r*97.8%
associate-/r*97.8%
frac-add97.4%
Applied egg-rr97.4%
+-commutative97.4%
*-commutative97.4%
fma-def97.5%
*-commutative97.5%
associate-*l/97.4%
associate-/l*97.5%
Simplified97.5%
Taylor expanded in u0 around 0 74.7%
Taylor expanded in alphax around inf 56.2%
associate-/l*55.7%
Simplified55.7%
unpow255.7%
*-un-lft-identity55.7%
times-frac55.7%
Applied egg-rr55.7%
Final simplification55.7%
herbie shell --seed 2023319
(FPCore (alphax alphay u0 cos2phi sin2phi)
:name "Beckmann Distribution sample, tan2theta, alphax != alphay, u1 <= 0.5"
:precision binary32
:pre (and (and (and (and (and (<= 0.0001 alphax) (<= alphax 1.0)) (and (<= 0.0001 alphay) (<= alphay 1.0))) (and (<= 2.328306437e-10 u0) (<= u0 1.0))) (and (<= 0.0 cos2phi) (<= cos2phi 1.0))) (<= 0.0 sin2phi))
(/ (- (log (- 1.0 u0))) (+ (/ cos2phi (* alphax alphax)) (/ sin2phi (* alphay alphay)))))