
(FPCore (cosTheta_i cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (/ (* (exp (- (/ (* sinTheta_i sinTheta_O) v))) (/ (* cosTheta_i cosTheta_O) v)) (* (* (sinh (/ 1.0 v)) 2.0) v)))
float code(float cosTheta_i, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return (expf(-((sinTheta_i * sinTheta_O) / v)) * ((cosTheta_i * cosTheta_O) / v)) / ((sinhf((1.0f / v)) * 2.0f) * v);
}
real(4) function code(costheta_i, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = (exp(-((sintheta_i * sintheta_o) / v)) * ((costheta_i * costheta_o) / v)) / ((sinh((1.0e0 / v)) * 2.0e0) * v)
end function
function code(cosTheta_i, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(Float32(exp(Float32(-Float32(Float32(sinTheta_i * sinTheta_O) / v))) * Float32(Float32(cosTheta_i * cosTheta_O) / v)) / Float32(Float32(sinh(Float32(Float32(1.0) / v)) * Float32(2.0)) * v)) end
function tmp = code(cosTheta_i, cosTheta_O, sinTheta_i, sinTheta_O, v) tmp = (exp(-((sinTheta_i * sinTheta_O) / v)) * ((cosTheta_i * cosTheta_O) / v)) / ((sinh((single(1.0) / v)) * single(2.0)) * v); end
\begin{array}{l}
\\
\frac{e^{-\frac{sinTheta_i \cdot sinTheta_O}{v}} \cdot \frac{cosTheta_i \cdot cosTheta_O}{v}}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v}
\end{array}
Sampling outcomes in binary32 precision:
Herbie found 13 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (cosTheta_i cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (/ (* (exp (- (/ (* sinTheta_i sinTheta_O) v))) (/ (* cosTheta_i cosTheta_O) v)) (* (* (sinh (/ 1.0 v)) 2.0) v)))
float code(float cosTheta_i, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return (expf(-((sinTheta_i * sinTheta_O) / v)) * ((cosTheta_i * cosTheta_O) / v)) / ((sinhf((1.0f / v)) * 2.0f) * v);
}
real(4) function code(costheta_i, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = (exp(-((sintheta_i * sintheta_o) / v)) * ((costheta_i * costheta_o) / v)) / ((sinh((1.0e0 / v)) * 2.0e0) * v)
end function
function code(cosTheta_i, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(Float32(exp(Float32(-Float32(Float32(sinTheta_i * sinTheta_O) / v))) * Float32(Float32(cosTheta_i * cosTheta_O) / v)) / Float32(Float32(sinh(Float32(Float32(1.0) / v)) * Float32(2.0)) * v)) end
function tmp = code(cosTheta_i, cosTheta_O, sinTheta_i, sinTheta_O, v) tmp = (exp(-((sinTheta_i * sinTheta_O) / v)) * ((cosTheta_i * cosTheta_O) / v)) / ((sinh((single(1.0) / v)) * single(2.0)) * v); end
\begin{array}{l}
\\
\frac{e^{-\frac{sinTheta_i \cdot sinTheta_O}{v}} \cdot \frac{cosTheta_i \cdot cosTheta_O}{v}}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v}
\end{array}
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (* (* (/ 1.0 (* v 2.0)) (/ (/ cosTheta_i_m v) (sinh (/ 1.0 v)))) (/ cosTheta_O (pow (exp (/ sinTheta_O v)) sinTheta_i)))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (((1.0f / (v * 2.0f)) * ((cosTheta_i_m / v) / sinhf((1.0f / v)))) * (cosTheta_O / powf(expf((sinTheta_O / v)), sinTheta_i)));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (((1.0e0 / (v * 2.0e0)) * ((costheta_i_m / v) / sinh((1.0e0 / v)))) * (costheta_o / (exp((sintheta_o / v)) ** sintheta_i)))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(Float32(Float32(1.0) / Float32(v * Float32(2.0))) * Float32(Float32(cosTheta_i_m / v) / sinh(Float32(Float32(1.0) / v)))) * Float32(cosTheta_O / (exp(Float32(sinTheta_O / v)) ^ sinTheta_i)))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (((single(1.0) / (v * single(2.0))) * ((cosTheta_i_m / v) / sinh((single(1.0) / v)))) * (cosTheta_O / (exp((sinTheta_O / v)) ^ sinTheta_i)));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \left(\left(\frac{1}{v \cdot 2} \cdot \frac{\frac{cosTheta_i_m}{v}}{\sinh \left(\frac{1}{v}\right)}\right) \cdot \frac{cosTheta_O}{{\left(e^{\frac{sinTheta_O}{v}}\right)}^{sinTheta_i}}\right)
\end{array}
Initial program 98.5%
Simplified98.6%
associate-*r/98.5%
associate-/l*98.5%
Applied egg-rr98.5%
associate-/l/98.5%
associate-/r/98.6%
times-frac98.6%
*-commutative98.6%
associate-*l*98.6%
*-commutative98.6%
Applied egg-rr98.6%
*-un-lft-identity98.6%
*-commutative98.6%
times-frac98.7%
Applied egg-rr98.7%
Final simplification98.7%
cosTheta_i_m = (fabs.f32 cosTheta_i)
cosTheta_i_s = (copysign.f32 1 cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v)
:precision binary32
(*
cosTheta_i_s
(/
(*
(exp (/ (* sinTheta_O (- sinTheta_i)) v))
(* (/ 1.0 v) (* cosTheta_i_m cosTheta_O)))
(* v (* 2.0 (sinh (/ 1.0 v)))))))cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * ((expf(((sinTheta_O * -sinTheta_i) / v)) * ((1.0f / v) * (cosTheta_i_m * cosTheta_O))) / (v * (2.0f * sinhf((1.0f / v)))));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * ((exp(((sintheta_o * -sintheta_i) / v)) * ((1.0e0 / v) * (costheta_i_m * costheta_o))) / (v * (2.0e0 * sinh((1.0e0 / v)))))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(exp(Float32(Float32(sinTheta_O * Float32(-sinTheta_i)) / v)) * Float32(Float32(Float32(1.0) / v) * Float32(cosTheta_i_m * cosTheta_O))) / Float32(v * Float32(Float32(2.0) * sinh(Float32(Float32(1.0) / v)))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * ((exp(((sinTheta_O * -sinTheta_i) / v)) * ((single(1.0) / v) * (cosTheta_i_m * cosTheta_O))) / (v * (single(2.0) * sinh((single(1.0) / v)))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{e^{\frac{sinTheta_O \cdot \left(-sinTheta_i\right)}{v}} \cdot \left(\frac{1}{v} \cdot \left(cosTheta_i_m \cdot cosTheta_O\right)\right)}{v \cdot \left(2 \cdot \sinh \left(\frac{1}{v}\right)\right)}
\end{array}
Initial program 98.5%
div-inv98.7%
*-commutative98.7%
Applied egg-rr98.7%
Final simplification98.7%
cosTheta_i_m = (fabs.f32 cosTheta_i)
cosTheta_i_s = (copysign.f32 1 cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v)
:precision binary32
(*
cosTheta_i_s
(*
(/ cosTheta_O (/ v cosTheta_i_m))
(/
(/ (exp (* (/ sinTheta_O v) (- sinTheta_i))) (* v 2.0))
(sinh (/ 1.0 v))))))cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * ((cosTheta_O / (v / cosTheta_i_m)) * ((expf(((sinTheta_O / v) * -sinTheta_i)) / (v * 2.0f)) / sinhf((1.0f / v))));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * ((costheta_o / (v / costheta_i_m)) * ((exp(((sintheta_o / v) * -sintheta_i)) / (v * 2.0e0)) / sinh((1.0e0 / v))))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(cosTheta_O / Float32(v / cosTheta_i_m)) * Float32(Float32(exp(Float32(Float32(sinTheta_O / v) * Float32(-sinTheta_i))) / Float32(v * Float32(2.0))) / sinh(Float32(Float32(1.0) / v))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * ((cosTheta_O / (v / cosTheta_i_m)) * ((exp(((sinTheta_O / v) * -sinTheta_i)) / (v * single(2.0))) / sinh((single(1.0) / v))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \left(\frac{cosTheta_O}{\frac{v}{cosTheta_i_m}} \cdot \frac{\frac{e^{\frac{sinTheta_O}{v} \cdot \left(-sinTheta_i\right)}}{v \cdot 2}}{\sinh \left(\frac{1}{v}\right)}\right)
\end{array}
Initial program 98.5%
associate-/l*92.7%
*-commutative92.7%
distribute-neg-frac92.7%
distribute-rgt-neg-out92.7%
associate-/l*92.7%
*-commutative92.7%
*-commutative92.7%
associate-/l*92.7%
Simplified92.7%
add-exp-log92.7%
*-commutative92.7%
associate-*l*92.7%
*-commutative92.7%
Applied egg-rr92.7%
expm1-log1p-u92.7%
expm1-udef52.1%
Applied egg-rr52.1%
expm1-def98.5%
expm1-log1p98.5%
*-commutative98.5%
associate-*l/98.5%
*-commutative98.5%
associate-/l*98.5%
associate-/r*98.7%
Simplified98.7%
Final simplification98.7%
cosTheta_i_m = (fabs.f32 cosTheta_i)
cosTheta_i_s = (copysign.f32 1 cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v)
:precision binary32
(*
cosTheta_i_s
(/
(exp (/ sinTheta_i (/ v (- sinTheta_O))))
(/
(+ 2.0 (/ 0.3333333333333333 (pow v 2.0)))
(/ cosTheta_i_m (/ v cosTheta_O))))))cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (expf((sinTheta_i / (v / -sinTheta_O))) / ((2.0f + (0.3333333333333333f / powf(v, 2.0f))) / (cosTheta_i_m / (v / cosTheta_O))));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (exp((sintheta_i / (v / -sintheta_o))) / ((2.0e0 + (0.3333333333333333e0 / (v ** 2.0e0))) / (costheta_i_m / (v / costheta_o))))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(exp(Float32(sinTheta_i / Float32(v / Float32(-sinTheta_O)))) / Float32(Float32(Float32(2.0) + Float32(Float32(0.3333333333333333) / (v ^ Float32(2.0)))) / Float32(cosTheta_i_m / Float32(v / cosTheta_O))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (exp((sinTheta_i / (v / -sinTheta_O))) / ((single(2.0) + (single(0.3333333333333333) / (v ^ single(2.0)))) / (cosTheta_i_m / (v / cosTheta_O))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{e^{\frac{sinTheta_i}{\frac{v}{-sinTheta_O}}}}{\frac{2 + \frac{0.3333333333333333}{{v}^{2}}}{\frac{cosTheta_i_m}{\frac{v}{cosTheta_O}}}}
\end{array}
Initial program 98.5%
associate-/l*92.7%
*-commutative92.7%
distribute-neg-frac92.7%
distribute-rgt-neg-out92.7%
associate-/l*92.7%
*-commutative92.7%
*-commutative92.7%
associate-/l*92.7%
Simplified92.7%
Taylor expanded in v around inf 61.8%
associate-*r/61.8%
metadata-eval61.8%
Simplified61.8%
Final simplification61.8%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (/ (* cosTheta_O (/ (/ cosTheta_i_m v) (* (* v 2.0) (sinh (/ 1.0 v))))) (exp (* (/ sinTheta_O v) sinTheta_i)))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * ((cosTheta_O * ((cosTheta_i_m / v) / ((v * 2.0f) * sinhf((1.0f / v))))) / expf(((sinTheta_O / v) * sinTheta_i)));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * ((costheta_o * ((costheta_i_m / v) / ((v * 2.0e0) * sinh((1.0e0 / v))))) / exp(((sintheta_o / v) * sintheta_i)))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(cosTheta_O * Float32(Float32(cosTheta_i_m / v) / Float32(Float32(v * Float32(2.0)) * sinh(Float32(Float32(1.0) / v))))) / exp(Float32(Float32(sinTheta_O / v) * sinTheta_i)))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * ((cosTheta_O * ((cosTheta_i_m / v) / ((v * single(2.0)) * sinh((single(1.0) / v))))) / exp(((sinTheta_O / v) * sinTheta_i)));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{cosTheta_O \cdot \frac{\frac{cosTheta_i_m}{v}}{\left(v \cdot 2\right) \cdot \sinh \left(\frac{1}{v}\right)}}{e^{\frac{sinTheta_O}{v} \cdot sinTheta_i}}
\end{array}
Initial program 98.5%
Simplified98.6%
associate-*r/98.5%
associate-/l*98.5%
Applied egg-rr98.5%
associate-/l/98.5%
associate-/r/98.6%
times-frac98.6%
*-commutative98.6%
associate-*l*98.6%
*-commutative98.6%
Applied egg-rr98.6%
*-un-lft-identity98.6%
*-commutative98.6%
times-frac98.7%
Applied egg-rr98.7%
associate-*r/98.7%
frac-times98.6%
*-un-lft-identity98.6%
pow-exp98.6%
Applied egg-rr98.6%
Final simplification98.6%
cosTheta_i_m = (fabs.f32 cosTheta_i)
cosTheta_i_s = (copysign.f32 1 cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v)
:precision binary32
(*
cosTheta_i_s
(/
(exp (/ sinTheta_i (/ v (- sinTheta_O))))
(+
(* 2.0 (/ v (* cosTheta_i_m cosTheta_O)))
(* 0.3333333333333333 (/ 1.0 (* cosTheta_O (* v cosTheta_i_m))))))))cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (expf((sinTheta_i / (v / -sinTheta_O))) / ((2.0f * (v / (cosTheta_i_m * cosTheta_O))) + (0.3333333333333333f * (1.0f / (cosTheta_O * (v * cosTheta_i_m))))));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (exp((sintheta_i / (v / -sintheta_o))) / ((2.0e0 * (v / (costheta_i_m * costheta_o))) + (0.3333333333333333e0 * (1.0e0 / (costheta_o * (v * costheta_i_m))))))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(exp(Float32(sinTheta_i / Float32(v / Float32(-sinTheta_O)))) / Float32(Float32(Float32(2.0) * Float32(v / Float32(cosTheta_i_m * cosTheta_O))) + Float32(Float32(0.3333333333333333) * Float32(Float32(1.0) / Float32(cosTheta_O * Float32(v * cosTheta_i_m))))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (exp((sinTheta_i / (v / -sinTheta_O))) / ((single(2.0) * (v / (cosTheta_i_m * cosTheta_O))) + (single(0.3333333333333333) * (single(1.0) / (cosTheta_O * (v * cosTheta_i_m))))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{e^{\frac{sinTheta_i}{\frac{v}{-sinTheta_O}}}}{2 \cdot \frac{v}{cosTheta_i_m \cdot cosTheta_O} + 0.3333333333333333 \cdot \frac{1}{cosTheta_O \cdot \left(v \cdot cosTheta_i_m\right)}}
\end{array}
Initial program 98.5%
associate-/l*92.7%
*-commutative92.7%
distribute-neg-frac92.7%
distribute-rgt-neg-out92.7%
associate-/l*92.7%
*-commutative92.7%
*-commutative92.7%
associate-/l*92.7%
Simplified92.7%
Taylor expanded in v around inf 61.7%
Final simplification61.7%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (* (/ 1.0 (* (/ v cosTheta_i_m) (/ 1.0 (* v cosTheta_O)))) (/ (exp (* sinTheta_O (/ (- sinTheta_i) v))) (* v 2.0)))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * ((1.0f / ((v / cosTheta_i_m) * (1.0f / (v * cosTheta_O)))) * (expf((sinTheta_O * (-sinTheta_i / v))) / (v * 2.0f)));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * ((1.0e0 / ((v / costheta_i_m) * (1.0e0 / (v * costheta_o)))) * (exp((sintheta_o * (-sintheta_i / v))) / (v * 2.0e0)))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(Float32(1.0) / Float32(Float32(v / cosTheta_i_m) * Float32(Float32(1.0) / Float32(v * cosTheta_O)))) * Float32(exp(Float32(sinTheta_O * Float32(Float32(-sinTheta_i) / v))) / Float32(v * Float32(2.0))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * ((single(1.0) / ((v / cosTheta_i_m) * (single(1.0) / (v * cosTheta_O)))) * (exp((sinTheta_O * (-sinTheta_i / v))) / (v * single(2.0))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \left(\frac{1}{\frac{v}{cosTheta_i_m} \cdot \frac{1}{v \cdot cosTheta_O}} \cdot \frac{e^{sinTheta_O \cdot \frac{-sinTheta_i}{v}}}{v \cdot 2}\right)
\end{array}
Initial program 98.5%
*-commutative98.5%
associate-*l*98.5%
times-frac98.5%
*-commutative98.5%
associate-*l/98.5%
distribute-neg-frac98.5%
distribute-lft-neg-out98.5%
associate-*l/98.5%
*-commutative98.5%
Simplified98.5%
expm1-log1p-u98.5%
expm1-udef52.1%
Applied egg-rr52.1%
expm1-def98.5%
expm1-log1p98.5%
associate-*l/98.5%
associate-/l*98.5%
Simplified98.5%
clear-num92.6%
inv-pow92.6%
*-un-lft-identity92.6%
associate-/r/92.6%
*-commutative92.6%
clear-num92.5%
div-inv92.5%
associate-/r/92.6%
times-frac92.6%
clear-num92.6%
Applied egg-rr92.6%
unpow-192.6%
Simplified92.6%
Taylor expanded in v around inf 57.6%
*-commutative57.6%
Simplified57.6%
Final simplification57.6%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (/ (exp (/ sinTheta_i (/ v (- sinTheta_O)))) (* 2.0 (/ v (* cosTheta_i_m cosTheta_O))))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (expf((sinTheta_i / (v / -sinTheta_O))) / (2.0f * (v / (cosTheta_i_m * cosTheta_O))));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (exp((sintheta_i / (v / -sintheta_o))) / (2.0e0 * (v / (costheta_i_m * costheta_o))))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(exp(Float32(sinTheta_i / Float32(v / Float32(-sinTheta_O)))) / Float32(Float32(2.0) * Float32(v / Float32(cosTheta_i_m * cosTheta_O))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (exp((sinTheta_i / (v / -sinTheta_O))) / (single(2.0) * (v / (cosTheta_i_m * cosTheta_O))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{e^{\frac{sinTheta_i}{\frac{v}{-sinTheta_O}}}}{2 \cdot \frac{v}{cosTheta_i_m \cdot cosTheta_O}}
\end{array}
Initial program 98.5%
associate-/l*92.7%
*-commutative92.7%
distribute-neg-frac92.7%
distribute-rgt-neg-out92.7%
associate-/l*92.7%
*-commutative92.7%
*-commutative92.7%
associate-/l*92.7%
Simplified92.7%
Taylor expanded in v around inf 57.5%
Final simplification57.5%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (/ (exp (/ sinTheta_i (/ v (- sinTheta_O)))) (/ 2.0 (/ cosTheta_i_m (/ v cosTheta_O))))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (expf((sinTheta_i / (v / -sinTheta_O))) / (2.0f / (cosTheta_i_m / (v / cosTheta_O))));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (exp((sintheta_i / (v / -sintheta_o))) / (2.0e0 / (costheta_i_m / (v / costheta_o))))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(exp(Float32(sinTheta_i / Float32(v / Float32(-sinTheta_O)))) / Float32(Float32(2.0) / Float32(cosTheta_i_m / Float32(v / cosTheta_O))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (exp((sinTheta_i / (v / -sinTheta_O))) / (single(2.0) / (cosTheta_i_m / (v / cosTheta_O))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{e^{\frac{sinTheta_i}{\frac{v}{-sinTheta_O}}}}{\frac{2}{\frac{cosTheta_i_m}{\frac{v}{cosTheta_O}}}}
\end{array}
Initial program 98.5%
associate-/l*92.7%
*-commutative92.7%
distribute-neg-frac92.7%
distribute-rgt-neg-out92.7%
associate-/l*92.7%
*-commutative92.7%
*-commutative92.7%
associate-/l*92.7%
Simplified92.7%
Taylor expanded in v around inf 57.5%
Final simplification57.5%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (* 0.5 (/ 1.0 (/ v (* cosTheta_i_m cosTheta_O))))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (0.5f * (1.0f / (v / (cosTheta_i_m * cosTheta_O))));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (0.5e0 * (1.0e0 / (v / (costheta_i_m * costheta_o))))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(0.5) * Float32(Float32(1.0) / Float32(v / Float32(cosTheta_i_m * cosTheta_O))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (single(0.5) * (single(1.0) / (v / (cosTheta_i_m * cosTheta_O))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \left(0.5 \cdot \frac{1}{\frac{v}{cosTheta_i_m \cdot cosTheta_O}}\right)
\end{array}
Initial program 98.5%
*-commutative98.5%
associate-*l*98.5%
times-frac98.5%
*-commutative98.5%
associate-*l/98.5%
distribute-neg-frac98.5%
distribute-lft-neg-out98.5%
associate-*l/98.5%
*-commutative98.5%
Simplified98.5%
Taylor expanded in v around inf 57.1%
associate-*l/57.1%
*-commutative57.1%
Simplified57.1%
associate-*r/57.1%
clear-num57.4%
*-commutative57.4%
Applied egg-rr57.4%
Final simplification57.4%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (/ 1.0 (/ (/ v cosTheta_i_m) (* cosTheta_O 0.5)))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (1.0f / ((v / cosTheta_i_m) / (cosTheta_O * 0.5f)));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (1.0e0 / ((v / costheta_i_m) / (costheta_o * 0.5e0)))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(1.0) / Float32(Float32(v / cosTheta_i_m) / Float32(cosTheta_O * Float32(0.5))))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (single(1.0) / ((v / cosTheta_i_m) / (cosTheta_O * single(0.5))));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{1}{\frac{\frac{v}{cosTheta_i_m}}{cosTheta_O \cdot 0.5}}
\end{array}
Initial program 98.5%
*-commutative98.5%
associate-*l*98.5%
times-frac98.5%
*-commutative98.5%
associate-*l/98.5%
distribute-neg-frac98.5%
distribute-lft-neg-out98.5%
associate-*l/98.5%
*-commutative98.5%
Simplified98.5%
Taylor expanded in v around inf 57.1%
associate-*l/57.1%
*-commutative57.1%
Simplified57.1%
add-exp-log45.1%
clear-num45.1%
div-inv45.1%
associate-/r/45.1%
Applied egg-rr45.1%
Taylor expanded in cosTheta_i around 0 17.4%
+-commutative17.4%
log-prod17.4%
associate-+r+17.4%
+-commutative17.4%
log-prod45.1%
associate-*r/45.1%
associate-*l/45.1%
log-prod17.4%
associate-+l+17.4%
log-prod17.4%
log-prod45.1%
associate-*l*45.1%
associate-*l/45.1%
*-commutative45.1%
associate-/l*45.1%
associate-*r/45.1%
Simplified45.1%
rem-exp-log57.1%
clear-num57.5%
*-commutative57.5%
Applied egg-rr57.5%
Final simplification57.5%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (* 0.5 (* (/ cosTheta_i_m v) cosTheta_O))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (0.5f * ((cosTheta_i_m / v) * cosTheta_O));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (0.5e0 * ((costheta_i_m / v) * costheta_o))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(0.5) * Float32(Float32(cosTheta_i_m / v) * cosTheta_O))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (single(0.5) * ((cosTheta_i_m / v) * cosTheta_O));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \left(0.5 \cdot \left(\frac{cosTheta_i_m}{v} \cdot cosTheta_O\right)\right)
\end{array}
Initial program 98.5%
*-commutative98.5%
associate-*l*98.5%
times-frac98.5%
*-commutative98.5%
associate-*l/98.5%
distribute-neg-frac98.5%
distribute-lft-neg-out98.5%
associate-*l/98.5%
*-commutative98.5%
Simplified98.5%
Taylor expanded in v around inf 57.1%
associate-*l/57.1%
*-commutative57.1%
Simplified57.1%
Taylor expanded in cosTheta_i around 0 57.1%
associate-*r/57.1%
Simplified57.1%
Final simplification57.1%
cosTheta_i_m = (fabs.f32 cosTheta_i) cosTheta_i_s = (copysign.f32 1 cosTheta_i) NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function. (FPCore (cosTheta_i_s cosTheta_i_m cosTheta_O sinTheta_i sinTheta_O v) :precision binary32 (* cosTheta_i_s (/ 0.5 (/ v (* cosTheta_i_m cosTheta_O)))))
cosTheta_i_m = fabs(cosTheta_i);
cosTheta_i_s = copysign(1.0, cosTheta_i);
assert(cosTheta_i_m < cosTheta_O && cosTheta_O < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O, float sinTheta_i, float sinTheta_O, float v) {
return cosTheta_i_s * (0.5f / (v / (cosTheta_i_m * cosTheta_O)));
}
cosTheta_i_m = abs(cosTheta_i)
cosTheta_i_s = copysign(1.0d0, cosTheta_i)
NOTE: cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_i_s, costheta_i_m, costheta_o, sintheta_i, sintheta_o, v)
real(4), intent (in) :: costheta_i_s
real(4), intent (in) :: costheta_i_m
real(4), intent (in) :: costheta_o
real(4), intent (in) :: sintheta_i
real(4), intent (in) :: sintheta_o
real(4), intent (in) :: v
code = costheta_i_s * (0.5e0 / (v / (costheta_i_m * costheta_o)))
end function
cosTheta_i_m = abs(cosTheta_i) cosTheta_i_s = copysign(1.0, cosTheta_i) cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v]) function code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v) return Float32(cosTheta_i_s * Float32(Float32(0.5) / Float32(v / Float32(cosTheta_i_m * cosTheta_O)))) end
cosTheta_i_m = abs(cosTheta_i);
cosTheta_i_s = sign(double(cosTheta_i)) * abs(1.0);
cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_i_s, cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v)
tmp = cosTheta_i_s * (single(0.5) / (v / (cosTheta_i_m * cosTheta_O)));
end
\begin{array}{l}
cosTheta_i_m = \left|cosTheta_i\right|
\\
cosTheta_i_s = \mathsf{copysign}\left(1, cosTheta_i\right)
\\
[cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta_i_s \cdot \frac{0.5}{\frac{v}{cosTheta_i_m \cdot cosTheta_O}}
\end{array}
Initial program 98.5%
*-commutative98.5%
associate-*l*98.5%
times-frac98.5%
*-commutative98.5%
associate-*l/98.5%
distribute-neg-frac98.5%
distribute-lft-neg-out98.5%
associate-*l/98.5%
*-commutative98.5%
Simplified98.5%
Taylor expanded in v around inf 57.1%
associate-*l/57.1%
*-commutative57.1%
Simplified57.1%
add-exp-log45.1%
clear-num45.1%
div-inv45.1%
associate-/r/45.1%
Applied egg-rr45.1%
Taylor expanded in cosTheta_i around 0 17.4%
+-commutative17.4%
log-prod17.4%
associate-+r+17.4%
+-commutative17.4%
log-prod45.1%
associate-*r/45.1%
associate-*l/45.1%
log-prod17.4%
associate-+l+17.4%
log-prod17.4%
log-prod45.1%
associate-*l*45.1%
associate-*l/45.1%
*-commutative45.1%
associate-/l*45.1%
associate-*r/45.1%
Simplified45.1%
rem-exp-log57.1%
associate-/l*57.4%
Applied egg-rr57.4%
associate-/l/57.4%
*-commutative57.4%
Simplified57.4%
Final simplification57.4%
herbie shell --seed 2024020
(FPCore (cosTheta_i cosTheta_O sinTheta_i sinTheta_O v)
:name "HairBSDF, Mp, upper"
:precision binary32
:pre (and (and (and (and (and (and (<= -1.0 cosTheta_i) (<= cosTheta_i 1.0)) (and (<= -1.0 cosTheta_O) (<= cosTheta_O 1.0))) (and (<= -1.0 sinTheta_i) (<= sinTheta_i 1.0))) (and (<= -1.0 sinTheta_O) (<= sinTheta_O 1.0))) (< 0.1 v)) (<= v 1.5707964))
(/ (* (exp (- (/ (* sinTheta_i sinTheta_O) v))) (/ (* cosTheta_i cosTheta_O) v)) (* (* (sinh (/ 1.0 v)) 2.0) v)))