HairBSDF, Mp, upper

Percentage Accurate: 98.6% → 98.5%
Time: 18.4s
Alternatives: 17
Speedup: N/A×

Specification

?
\[\left(\left(\left(\left(\left(-1 \leq cosTheta\_i \land cosTheta\_i \leq 1\right) \land \left(-1 \leq cosTheta\_O \land cosTheta\_O \leq 1\right)\right) \land \left(-1 \leq sinTheta\_i \land sinTheta\_i \leq 1\right)\right) \land \left(-1 \leq sinTheta\_O \land sinTheta\_O \leq 1\right)\right) \land 0.1 < v\right) \land v \leq 1.5707964\]
\[\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} \]
(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:

Local Percentage Accuracy vs ?

The average percentage accuracy by input value. Horizontal axis shows value of an input variable; the variable is choosen in the title. Vertical axis is accuracy; higher is better. Red represent the original program, while blue represents Herbie's suggestion. These can be toggled with buttons below the plot. The line is an average while dots represent individual samples.

Accuracy vs Speed?

Herbie found 17 alternatives:

AlternativeAccuracySpeedup
The accuracy (vertical axis) and speed (horizontal axis) of each alternatives. Up and to the right is better. The red square shows the initial program, and each blue circle shows an alternative.The line shows the best available speed-accuracy tradeoffs.

Initial Program: 98.6% accurate, 1.0× speedup?

\[\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} \]
(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}

Alternative 1: 98.5% accurate, 1.9× speedup?

\[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_i\_m}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}} \cdot \frac{cosTheta\_O\_m}{v}\right)\right) \end{array} \]
cosTheta_i\_m = (fabs.f32 cosTheta_i)
cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
cosTheta_O\_m = (fabs.f32 cosTheta_O)
cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
 :precision binary32
 (*
  cosTheta_O_s
  (*
   cosTheta_i_s
   (* (/ cosTheta_i_m (/ (sinh (/ 1.0 v)) (/ 0.5 v))) (/ cosTheta_O_m v)))))
cosTheta_i\_m = fabs(cosTheta_i);
cosTheta_i\_s = copysign(1.0, cosTheta_i);
cosTheta_O\_m = fabs(cosTheta_O);
cosTheta_O\_s = copysign(1.0, cosTheta_O);
assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_i_m / (sinhf((1.0f / v)) / (0.5f / v))) * (cosTheta_O_m / v)));
}
cosTheta_i\_m = abs(costheta_i)
cosTheta_i\_s = copysign(1.0d0, costheta_i)
cosTheta_O\_m = abs(costheta_o)
cosTheta_O\_s = copysign(1.0d0, costheta_o)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
    real(4), intent (in) :: costheta_o_s
    real(4), intent (in) :: costheta_i_s
    real(4), intent (in) :: costheta_i_m
    real(4), intent (in) :: costheta_o_m
    real(4), intent (in) :: sintheta_i
    real(4), intent (in) :: sintheta_o
    real(4), intent (in) :: v
    code = costheta_o_s * (costheta_i_s * ((costheta_i_m / (sinh((1.0e0 / v)) / (0.5e0 / v))) * (costheta_o_m / v)))
end function
cosTheta_i\_m = abs(cosTheta_i)
cosTheta_i\_s = copysign(1.0, cosTheta_i)
cosTheta_O\_m = abs(cosTheta_O)
cosTheta_O\_s = copysign(1.0, cosTheta_O)
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_i_m / Float32(sinh(Float32(Float32(1.0) / v)) / Float32(Float32(0.5) / v))) * Float32(cosTheta_O_m / v))))
end
cosTheta_i\_m = abs(cosTheta_i);
cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
cosTheta_O\_m = abs(cosTheta_O);
cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_i_m / (sinh((single(1.0) / v)) / (single(0.5) / v))) * (cosTheta_O_m / v)));
end
\begin{array}{l}
cosTheta_i\_m = \left|cosTheta\_i\right|
\\
cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
\\
cosTheta_O\_m = \left|cosTheta\_O\right|
\\
cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
\\
[cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_i\_m}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}} \cdot \frac{cosTheta\_O\_m}{v}\right)\right)
\end{array}
Derivation
  1. Initial program 98.5%

    \[\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} \]
  2. Step-by-step derivation
    1. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
    2. exp-negN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    3. associate-*l/N/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    4. *-lft-identityN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    5. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    6. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    7. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    8. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
    9. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    10. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    11. associate-*l*N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    12. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    13. sinh-lowering-sinh.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
    14. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
    15. *-commutativeN/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
    16. *-lowering-*.f3298.5%

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
  3. Simplified98.5%

    \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
  4. Add Preprocessing
  5. Step-by-step derivation
    1. clear-numN/A

      \[\leadsto \frac{\frac{1}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}}{\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot \left(v \cdot 2\right)} \]
    2. associate-/r*N/A

      \[\leadsto \frac{1}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}} \cdot \left(\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)\right)}} \]
    3. associate-/l/N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}} \]
    4. associate-/l*N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i \cdot \color{blue}{\frac{cosTheta\_O}{v}}}} \]
    5. associate-/r*N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}{\color{blue}{\frac{cosTheta\_O}{v}}}} \]
    6. associate-/r/N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
    7. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
  6. Applied egg-rr98.8%

    \[\leadsto \color{blue}{\frac{\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \frac{cosTheta\_O}{v}} \]
  7. Taylor expanded in sinTheta_i around 0

    \[\leadsto \mathsf{*.f32}\left(\color{blue}{\left(\frac{cosTheta\_i}{v \cdot \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)}\right)}, \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
  8. Step-by-step derivation
    1. associate-/r*N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}}\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
    2. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i}{v}\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
    3. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    4. --lowering--.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\left(e^{\frac{1}{v}}\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    5. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\left(\frac{1}{v}\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    6. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    7. rec-expN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\mathsf{neg}\left(\frac{1}{v}\right)}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    8. distribute-neg-fracN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{\mathsf{neg}\left(1\right)}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    9. metadata-evalN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{-1}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    10. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\left(\frac{-1}{v}\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    11. /-lowering-/.f3298.7%

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(-1, v\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
  9. Simplified98.7%

    \[\leadsto \color{blue}{\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}} \cdot \frac{cosTheta\_O}{v} \]
  10. Step-by-step derivation
    1. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
  11. Applied egg-rr99.0%

    \[\leadsto \color{blue}{\frac{cosTheta\_i}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}} \cdot \frac{cosTheta\_O}{v}} \]
  12. Add Preprocessing

Alternative 2: 98.6% accurate, 1.9× speedup?

\[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \left(cosTheta\_i\_m \cdot \frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}\right)\right)\right) \end{array} \]
cosTheta_i\_m = (fabs.f32 cosTheta_i)
cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
cosTheta_O\_m = (fabs.f32 cosTheta_O)
cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
 :precision binary32
 (*
  cosTheta_O_s
  (*
   cosTheta_i_s
   (* (/ cosTheta_O_m v) (* cosTheta_i_m (/ (/ 0.5 v) (sinh (/ 1.0 v))))))))
cosTheta_i\_m = fabs(cosTheta_i);
cosTheta_i\_s = copysign(1.0, cosTheta_i);
cosTheta_O\_m = fabs(cosTheta_O);
cosTheta_O\_s = copysign(1.0, cosTheta_O);
assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * (cosTheta_i_m * ((0.5f / v) / sinhf((1.0f / v))))));
}
cosTheta_i\_m = abs(costheta_i)
cosTheta_i\_s = copysign(1.0d0, costheta_i)
cosTheta_O\_m = abs(costheta_o)
cosTheta_O\_s = copysign(1.0d0, costheta_o)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
    real(4), intent (in) :: costheta_o_s
    real(4), intent (in) :: costheta_i_s
    real(4), intent (in) :: costheta_i_m
    real(4), intent (in) :: costheta_o_m
    real(4), intent (in) :: sintheta_i
    real(4), intent (in) :: sintheta_o
    real(4), intent (in) :: v
    code = costheta_o_s * (costheta_i_s * ((costheta_o_m / v) * (costheta_i_m * ((0.5e0 / v) / sinh((1.0e0 / v))))))
end function
cosTheta_i\_m = abs(cosTheta_i)
cosTheta_i\_s = copysign(1.0, cosTheta_i)
cosTheta_O\_m = abs(cosTheta_O)
cosTheta_O\_s = copysign(1.0, cosTheta_O)
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_O_m / v) * Float32(cosTheta_i_m * Float32(Float32(Float32(0.5) / v) / sinh(Float32(Float32(1.0) / v)))))))
end
cosTheta_i\_m = abs(cosTheta_i);
cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
cosTheta_O\_m = abs(cosTheta_O);
cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * (cosTheta_i_m * ((single(0.5) / v) / 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_O\_m = \left|cosTheta\_O\right|
\\
cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
\\
[cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \left(cosTheta\_i\_m \cdot \frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}\right)\right)\right)
\end{array}
Derivation
  1. Initial program 98.5%

    \[\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} \]
  2. Step-by-step derivation
    1. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
    2. exp-negN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    3. associate-*l/N/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    4. *-lft-identityN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    5. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    6. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    7. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    8. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
    9. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    10. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    11. associate-*l*N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    12. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    13. sinh-lowering-sinh.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
    14. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
    15. *-commutativeN/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
    16. *-lowering-*.f3298.5%

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
  3. Simplified98.5%

    \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
  4. Add Preprocessing
  5. Step-by-step derivation
    1. clear-numN/A

      \[\leadsto \frac{\frac{1}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}}{\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot \left(v \cdot 2\right)} \]
    2. associate-/r*N/A

      \[\leadsto \frac{1}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}} \cdot \left(\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)\right)}} \]
    3. associate-/l/N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}} \]
    4. associate-/l*N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i \cdot \color{blue}{\frac{cosTheta\_O}{v}}}} \]
    5. associate-/r*N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}{\color{blue}{\frac{cosTheta\_O}{v}}}} \]
    6. associate-/r/N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
    7. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
  6. Applied egg-rr98.8%

    \[\leadsto \color{blue}{\frac{\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \frac{cosTheta\_O}{v}} \]
  7. Taylor expanded in sinTheta_i around 0

    \[\leadsto \mathsf{*.f32}\left(\color{blue}{\left(\frac{cosTheta\_i}{v \cdot \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)}\right)}, \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
  8. Step-by-step derivation
    1. associate-/r*N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}}\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
    2. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i}{v}\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
    3. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    4. --lowering--.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\left(e^{\frac{1}{v}}\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    5. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\left(\frac{1}{v}\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    6. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    7. rec-expN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\mathsf{neg}\left(\frac{1}{v}\right)}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    8. distribute-neg-fracN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{\mathsf{neg}\left(1\right)}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    9. metadata-evalN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{-1}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    10. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\left(\frac{-1}{v}\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    11. /-lowering-/.f3298.7%

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(-1, v\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
  9. Simplified98.7%

    \[\leadsto \color{blue}{\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}} \cdot \frac{cosTheta\_O}{v} \]
  10. Step-by-step derivation
    1. div-invN/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{cosTheta\_i \cdot \frac{1}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    2. associate-/l*N/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
    3. div-invN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \left(\frac{1}{v} \cdot \frac{1}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    4. *-commutativeN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \left(\frac{1}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}} \cdot \frac{1}{v}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    5. div-invN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}}{v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    6. clear-numN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{\frac{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}{1}}}{v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    7. div-invN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{\frac{e^{\frac{1}{v}} - e^{-1 \cdot \frac{1}{v}}}{1}}}{v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    8. neg-mul-1N/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{\frac{e^{\frac{1}{v}} - e^{\mathsf{neg}\left(\frac{1}{v}\right)}}{1}}}{v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    9. metadata-evalN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{\frac{e^{\frac{1}{v}} - e^{\mathsf{neg}\left(\frac{1}{v}\right)}}{\frac{1}{2} \cdot 2}}}{v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    10. associate-/l/N/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{\frac{\frac{e^{\frac{1}{v}} - e^{\mathsf{neg}\left(\frac{1}{v}\right)}}{2}}{\frac{1}{2}}}}{v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    11. sinh-defN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{1}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{1}{2}}}}{v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    12. associate-/r*N/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{1}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{1}{2}} \cdot v}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    13. associate-/r/N/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{1}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{\frac{1}{2}}{v}}}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    14. clear-numN/A

      \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \frac{\frac{\frac{1}{2}}{v}}{\sinh \left(\frac{1}{v}\right)}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
  11. Applied egg-rr98.9%

    \[\leadsto \color{blue}{\left(\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)} \cdot cosTheta\_i\right)} \cdot \frac{cosTheta\_O}{v} \]
  12. Final simplification98.9%

    \[\leadsto \frac{cosTheta\_O}{v} \cdot \left(cosTheta\_i \cdot \frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}\right) \]
  13. Add Preprocessing

Alternative 3: 98.6% accurate, 1.9× speedup?

\[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_O\_m \cdot \frac{\frac{cosTheta\_i\_m}{v}}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}}\right)\right) \end{array} \]
cosTheta_i\_m = (fabs.f32 cosTheta_i)
cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
cosTheta_O\_m = (fabs.f32 cosTheta_O)
cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
 :precision binary32
 (*
  cosTheta_O_s
  (*
   cosTheta_i_s
   (* cosTheta_O_m (/ (/ cosTheta_i_m v) (/ (sinh (/ 1.0 v)) (/ 0.5 v)))))))
cosTheta_i\_m = fabs(cosTheta_i);
cosTheta_i\_s = copysign(1.0, cosTheta_i);
cosTheta_O\_m = fabs(cosTheta_O);
cosTheta_O\_s = copysign(1.0, cosTheta_O);
assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
	return cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m * ((cosTheta_i_m / v) / (sinhf((1.0f / v)) / (0.5f / v)))));
}
cosTheta_i\_m = abs(costheta_i)
cosTheta_i\_s = copysign(1.0d0, costheta_i)
cosTheta_O\_m = abs(costheta_o)
cosTheta_O\_s = copysign(1.0d0, costheta_o)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
    real(4), intent (in) :: costheta_o_s
    real(4), intent (in) :: costheta_i_s
    real(4), intent (in) :: costheta_i_m
    real(4), intent (in) :: costheta_o_m
    real(4), intent (in) :: sintheta_i
    real(4), intent (in) :: sintheta_o
    real(4), intent (in) :: v
    code = costheta_o_s * (costheta_i_s * (costheta_o_m * ((costheta_i_m / v) / (sinh((1.0e0 / v)) / (0.5e0 / v)))))
end function
cosTheta_i\_m = abs(cosTheta_i)
cosTheta_i\_s = copysign(1.0, cosTheta_i)
cosTheta_O\_m = abs(cosTheta_O)
cosTheta_O\_s = copysign(1.0, cosTheta_O)
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(cosTheta_O_m * Float32(Float32(cosTheta_i_m / v) / Float32(sinh(Float32(Float32(1.0) / v)) / Float32(Float32(0.5) / v))))))
end
cosTheta_i\_m = abs(cosTheta_i);
cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
cosTheta_O\_m = abs(cosTheta_O);
cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	tmp = cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m * ((cosTheta_i_m / v) / (sinh((single(1.0) / v)) / (single(0.5) / v)))));
end
\begin{array}{l}
cosTheta_i\_m = \left|cosTheta\_i\right|
\\
cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
\\
cosTheta_O\_m = \left|cosTheta\_O\right|
\\
cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
\\
[cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_O\_m \cdot \frac{\frac{cosTheta\_i\_m}{v}}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}}\right)\right)
\end{array}
Derivation
  1. Initial program 98.5%

    \[\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} \]
  2. Step-by-step derivation
    1. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
    2. exp-negN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    3. associate-*l/N/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    4. *-lft-identityN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    5. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    6. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    7. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    8. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
    9. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    10. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    11. associate-*l*N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    12. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    13. sinh-lowering-sinh.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
    14. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
    15. *-commutativeN/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
    16. *-lowering-*.f3298.5%

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
  3. Simplified98.5%

    \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
  4. Add Preprocessing
  5. Step-by-step derivation
    1. clear-numN/A

      \[\leadsto \frac{\frac{1}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}}{\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot \left(v \cdot 2\right)} \]
    2. associate-/r*N/A

      \[\leadsto \frac{1}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}} \cdot \left(\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)\right)}} \]
    3. associate-/l/N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}} \]
    4. associate-/l*N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i \cdot \color{blue}{\frac{cosTheta\_O}{v}}}} \]
    5. associate-/r*N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}{\color{blue}{\frac{cosTheta\_O}{v}}}} \]
    6. associate-/r/N/A

      \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
    7. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
  6. Applied egg-rr98.8%

    \[\leadsto \color{blue}{\frac{\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \frac{cosTheta\_O}{v}} \]
  7. Taylor expanded in sinTheta_i around 0

    \[\leadsto \mathsf{*.f32}\left(\color{blue}{\left(\frac{cosTheta\_i}{v \cdot \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)}\right)}, \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
  8. Step-by-step derivation
    1. associate-/r*N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}}\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
    2. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i}{v}\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
    3. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    4. --lowering--.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\left(e^{\frac{1}{v}}\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    5. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\left(\frac{1}{v}\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    6. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    7. rec-expN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\mathsf{neg}\left(\frac{1}{v}\right)}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    8. distribute-neg-fracN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{\mathsf{neg}\left(1\right)}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    9. metadata-evalN/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{-1}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    10. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\left(\frac{-1}{v}\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    11. /-lowering-/.f3298.7%

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(-1, v\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
  9. Simplified98.7%

    \[\leadsto \color{blue}{\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}} \cdot \frac{cosTheta\_O}{v} \]
  10. Step-by-step derivation
    1. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
  11. Applied egg-rr99.0%

    \[\leadsto \color{blue}{\frac{cosTheta\_i}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}} \cdot \frac{cosTheta\_O}{v}} \]
  12. Step-by-step derivation
    1. associate-*l/N/A

      \[\leadsto \frac{cosTheta\_i \cdot \frac{cosTheta\_O}{v}}{\color{blue}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{\frac{1}{2}}{v}}}} \]
    2. associate-*r/N/A

      \[\leadsto \frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{\frac{\color{blue}{\sinh \left(\frac{1}{v}\right)}}{\frac{\frac{1}{2}}{v}}} \]
    3. associate-*l/N/A

      \[\leadsto \frac{\frac{cosTheta\_i}{v} \cdot cosTheta\_O}{\frac{\color{blue}{\sinh \left(\frac{1}{v}\right)}}{\frac{\frac{1}{2}}{v}}} \]
    4. *-commutativeN/A

      \[\leadsto \frac{cosTheta\_O \cdot \frac{cosTheta\_i}{v}}{\frac{\color{blue}{\sinh \left(\frac{1}{v}\right)}}{\frac{\frac{1}{2}}{v}}} \]
    5. associate-/l*N/A

      \[\leadsto cosTheta\_O \cdot \color{blue}{\frac{\frac{cosTheta\_i}{v}}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{\frac{1}{2}}{v}}}} \]
    6. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(cosTheta\_O, \color{blue}{\left(\frac{\frac{cosTheta\_i}{v}}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{\frac{1}{2}}{v}}}\right)}\right) \]
    7. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\left(\frac{cosTheta\_i}{v}\right), \color{blue}{\left(\frac{\sinh \left(\frac{1}{v}\right)}{\frac{\frac{1}{2}}{v}}\right)}\right)\right) \]
    8. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(\frac{\color{blue}{\sinh \left(\frac{1}{v}\right)}}{\frac{\frac{1}{2}}{v}}\right)\right)\right) \]
    9. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{/.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(\frac{\frac{1}{2}}{v}\right)}\right)\right)\right) \]
    10. sinh-lowering-sinh.f32N/A

      \[\leadsto \mathsf{*.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{/.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\frac{\color{blue}{\frac{1}{2}}}{v}\right)\right)\right)\right) \]
    11. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{/.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(\frac{\frac{1}{2}}{v}\right)\right)\right)\right) \]
    12. /-lowering-/.f3298.8%

      \[\leadsto \mathsf{*.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{/.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{/.f32}\left(\frac{1}{2}, \color{blue}{v}\right)\right)\right)\right) \]
  13. Applied egg-rr98.8%

    \[\leadsto \color{blue}{cosTheta\_O \cdot \frac{\frac{cosTheta\_i}{v}}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}}} \]
  14. Add Preprocessing

Alternative 4: 98.6% accurate, 1.9× speedup?

\[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_O\_m \cdot \left(\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)} \cdot \frac{cosTheta\_i\_m}{v}\right)\right)\right) \end{array} \]
cosTheta_i\_m = (fabs.f32 cosTheta_i)
cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
cosTheta_O\_m = (fabs.f32 cosTheta_O)
cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
(FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
 :precision binary32
 (*
  cosTheta_O_s
  (*
   cosTheta_i_s
   (* cosTheta_O_m (* (/ (/ 0.5 v) (sinh (/ 1.0 v))) (/ cosTheta_i_m v))))))
cosTheta_i\_m = fabs(cosTheta_i);
cosTheta_i\_s = copysign(1.0, cosTheta_i);
cosTheta_O\_m = fabs(cosTheta_O);
cosTheta_O\_s = copysign(1.0, cosTheta_O);
assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
	return cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m * (((0.5f / v) / sinhf((1.0f / v))) * (cosTheta_i_m / v))));
}
cosTheta_i\_m = abs(costheta_i)
cosTheta_i\_s = copysign(1.0d0, costheta_i)
cosTheta_O\_m = abs(costheta_o)
cosTheta_O\_s = copysign(1.0d0, costheta_o)
NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
    real(4), intent (in) :: costheta_o_s
    real(4), intent (in) :: costheta_i_s
    real(4), intent (in) :: costheta_i_m
    real(4), intent (in) :: costheta_o_m
    real(4), intent (in) :: sintheta_i
    real(4), intent (in) :: sintheta_o
    real(4), intent (in) :: v
    code = costheta_o_s * (costheta_i_s * (costheta_o_m * (((0.5e0 / v) / sinh((1.0e0 / v))) * (costheta_i_m / v))))
end function
cosTheta_i\_m = abs(cosTheta_i)
cosTheta_i\_s = copysign(1.0, cosTheta_i)
cosTheta_O\_m = abs(cosTheta_O)
cosTheta_O\_s = copysign(1.0, cosTheta_O)
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(cosTheta_O_m * Float32(Float32(Float32(Float32(0.5) / v) / sinh(Float32(Float32(1.0) / v))) * Float32(cosTheta_i_m / v)))))
end
cosTheta_i\_m = abs(cosTheta_i);
cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
cosTheta_O\_m = abs(cosTheta_O);
cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
	tmp = cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m * (((single(0.5) / v) / sinh((single(1.0) / v))) * (cosTheta_i_m / v))));
end
\begin{array}{l}
cosTheta_i\_m = \left|cosTheta\_i\right|
\\
cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
\\
cosTheta_O\_m = \left|cosTheta\_O\right|
\\
cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
\\
[cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
\\
cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_O\_m \cdot \left(\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)} \cdot \frac{cosTheta\_i\_m}{v}\right)\right)\right)
\end{array}
Derivation
  1. Initial program 98.5%

    \[\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} \]
  2. Step-by-step derivation
    1. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
    2. exp-negN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    3. associate-*l/N/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    4. *-lft-identityN/A

      \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    5. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
    6. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    7. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
    8. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
    9. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    10. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
    11. associate-*l*N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    12. *-lowering-*.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
    13. sinh-lowering-sinh.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
    14. /-lowering-/.f32N/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
    15. *-commutativeN/A

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
    16. *-lowering-*.f3298.5%

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
  3. Simplified98.5%

    \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
  4. Add Preprocessing
  5. Step-by-step derivation
    1. div-invN/A

      \[\leadsto \frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \color{blue}{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    2. associate-/l/N/A

      \[\leadsto \frac{cosTheta\_i \cdot cosTheta\_O}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}} \cdot v} \cdot \frac{\color{blue}{1}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)} \]
    3. *-commutativeN/A

      \[\leadsto \frac{cosTheta\_O \cdot cosTheta\_i}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}} \cdot v} \cdot \frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)} \]
    4. times-fracN/A

      \[\leadsto \left(\frac{cosTheta\_O}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i}{v}\right) \cdot \frac{\color{blue}{1}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)} \]
    5. associate-*l*N/A

      \[\leadsto \frac{cosTheta\_O}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \color{blue}{\left(\frac{cosTheta\_i}{v} \cdot \frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)} \]
    6. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\left(\frac{cosTheta\_O}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \color{blue}{\left(\frac{cosTheta\_i}{v} \cdot \frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)}\right) \]
    7. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\frac{cosTheta\_i}{v}} \cdot \frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)\right) \]
    8. exp-lowering-exp.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\frac{cosTheta\_i}{\color{blue}{v}} \cdot \frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)\right) \]
    9. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\frac{cosTheta\_i}{v} \cdot \frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)\right) \]
    10. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\frac{cosTheta\_i}{v} \cdot \frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)\right) \]
    11. *-lowering-*.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\left(\frac{cosTheta\_i}{v}\right), \color{blue}{\left(\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)}\right)\right) \]
    12. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(\frac{\color{blue}{1}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}\right)\right)\right) \]
    13. associate-/l/N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(\frac{\frac{1}{v \cdot 2}}{\color{blue}{\sinh \left(\frac{1}{v}\right)}}\right)\right)\right) \]
    14. /-lowering-/.f32N/A

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{/.f32}\left(\left(\frac{1}{v \cdot 2}\right), \color{blue}{\sinh \left(\frac{1}{v}\right)}\right)\right)\right) \]
  6. Applied egg-rr98.8%

    \[\leadsto \color{blue}{\frac{cosTheta\_O}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \left(\frac{cosTheta\_i}{v} \cdot \frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}\right)} \]
  7. Taylor expanded in sinTheta_i around 0

    \[\leadsto \mathsf{*.f32}\left(\color{blue}{cosTheta\_O}, \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{/.f32}\left(\mathsf{/.f32}\left(\frac{1}{2}, v\right), \mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right)\right)\right)\right) \]
  8. Step-by-step derivation
    1. Simplified98.8%

      \[\leadsto \color{blue}{cosTheta\_O} \cdot \left(\frac{cosTheta\_i}{v} \cdot \frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}\right) \]
    2. Final simplification98.8%

      \[\leadsto cosTheta\_O \cdot \left(\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)} \cdot \frac{cosTheta\_i}{v}\right) \]
    3. Add Preprocessing

    Alternative 5: 70.3% accurate, 8.8× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \frac{cosTheta\_i\_m}{\frac{\frac{1 - \frac{-0.16666666666666666 + \frac{-0.008333333333333333}{v \cdot v}}{v \cdot v}}{v}}{\frac{0.5}{v}}}\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (*
        (/ cosTheta_O_m v)
        (/
         cosTheta_i_m
         (/
          (/
           (-
            1.0
            (/ (+ -0.16666666666666666 (/ -0.008333333333333333 (* v v))) (* v v)))
           v)
          (/ 0.5 v)))))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * (cosTheta_i_m / (((1.0f - ((-0.16666666666666666f + (-0.008333333333333333f / (v * v))) / (v * v))) / v) / (0.5f / v)))));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((costheta_o_m / v) * (costheta_i_m / (((1.0e0 - (((-0.16666666666666666e0) + ((-0.008333333333333333e0) / (v * v))) / (v * v))) / v) / (0.5e0 / v)))))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_O_m / v) * Float32(cosTheta_i_m / Float32(Float32(Float32(Float32(1.0) - Float32(Float32(Float32(-0.16666666666666666) + Float32(Float32(-0.008333333333333333) / Float32(v * v))) / Float32(v * v))) / v) / Float32(Float32(0.5) / v))))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * (cosTheta_i_m / (((single(1.0) - ((single(-0.16666666666666666) + (single(-0.008333333333333333) / (v * v))) / (v * v))) / v) / (single(0.5) / v)))));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \frac{cosTheta\_i\_m}{\frac{\frac{1 - \frac{-0.16666666666666666 + \frac{-0.008333333333333333}{v \cdot v}}{v \cdot v}}{v}}{\frac{0.5}{v}}}\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. clear-numN/A

        \[\leadsto \frac{\frac{1}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}}{\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot \left(v \cdot 2\right)} \]
      2. associate-/r*N/A

        \[\leadsto \frac{1}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}} \cdot \left(\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)\right)}} \]
      3. associate-/l/N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}} \]
      4. associate-/l*N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i \cdot \color{blue}{\frac{cosTheta\_O}{v}}}} \]
      5. associate-/r*N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}{\color{blue}{\frac{cosTheta\_O}{v}}}} \]
      6. associate-/r/N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
    6. Applied egg-rr98.8%

      \[\leadsto \color{blue}{\frac{\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \frac{cosTheta\_O}{v}} \]
    7. Taylor expanded in sinTheta_i around 0

      \[\leadsto \mathsf{*.f32}\left(\color{blue}{\left(\frac{cosTheta\_i}{v \cdot \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)}\right)}, \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    8. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}}\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i}{v}\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      4. --lowering--.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\left(e^{\frac{1}{v}}\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      5. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\left(\frac{1}{v}\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      7. rec-expN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\mathsf{neg}\left(\frac{1}{v}\right)}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      8. distribute-neg-fracN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{\mathsf{neg}\left(1\right)}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      9. metadata-evalN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{-1}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      10. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\left(\frac{-1}{v}\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      11. /-lowering-/.f3298.7%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(-1, v\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    9. Simplified98.7%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}} \cdot \frac{cosTheta\_O}{v} \]
    10. Step-by-step derivation
      1. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
    11. Applied egg-rr99.0%

      \[\leadsto \color{blue}{\frac{cosTheta\_i}{\frac{\sinh \left(\frac{1}{v}\right)}{\frac{0.5}{v}}} \cdot \frac{cosTheta\_O}{v}} \]
    12. Taylor expanded in v around -inf

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\color{blue}{\left(-1 \cdot \frac{-1 \cdot \frac{\frac{1}{6} + \frac{1}{120} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 1}{v}\right)}, \mathsf{/.f32}\left(\frac{1}{2}, v\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    13. Step-by-step derivation
      1. mul-1-negN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\left(\mathsf{neg}\left(\frac{-1 \cdot \frac{\frac{1}{6} + \frac{1}{120} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 1}{v}\right)\right), \mathsf{/.f32}\left(\frac{1}{2}, v\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      2. distribute-neg-frac2N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\left(\frac{-1 \cdot \frac{\frac{1}{6} + \frac{1}{120} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 1}{\mathsf{neg}\left(v\right)}\right), \mathsf{/.f32}\left(\frac{1}{2}, v\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(-1 \cdot \frac{\frac{1}{6} + \frac{1}{120} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 1\right), \left(\mathsf{neg}\left(v\right)\right)\right), \mathsf{/.f32}\left(\frac{1}{2}, v\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    14. Simplified69.6%

      \[\leadsto \frac{cosTheta\_i}{\frac{\color{blue}{\frac{-1 + \frac{-0.16666666666666666 + \frac{-0.008333333333333333}{v \cdot v}}{v \cdot v}}{-v}}}{\frac{0.5}{v}}} \cdot \frac{cosTheta\_O}{v} \]
    15. Final simplification69.6%

      \[\leadsto \frac{cosTheta\_O}{v} \cdot \frac{cosTheta\_i}{\frac{\frac{1 - \frac{-0.16666666666666666 + \frac{-0.008333333333333333}{v \cdot v}}{v \cdot v}}{v}}{\frac{0.5}{v}}} \]
    16. Add Preprocessing

    Alternative 6: 70.3% accurate, 9.6× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \frac{\frac{cosTheta\_i\_m}{v}}{\frac{\frac{0.3333333333333333 + \frac{0.016666666666666666}{v \cdot v}}{v \cdot v} - -2}{v}}\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (*
        (/ cosTheta_O_m v)
        (/
         (/ cosTheta_i_m v)
         (/
          (-
           (/ (+ 0.3333333333333333 (/ 0.016666666666666666 (* v v))) (* v v))
           -2.0)
          v))))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * ((cosTheta_i_m / v) / ((((0.3333333333333333f + (0.016666666666666666f / (v * v))) / (v * v)) - -2.0f) / v))));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((costheta_o_m / v) * ((costheta_i_m / v) / ((((0.3333333333333333e0 + (0.016666666666666666e0 / (v * v))) / (v * v)) - (-2.0e0)) / v))))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_O_m / v) * Float32(Float32(cosTheta_i_m / v) / Float32(Float32(Float32(Float32(Float32(0.3333333333333333) + Float32(Float32(0.016666666666666666) / Float32(v * v))) / Float32(v * v)) - Float32(-2.0)) / v)))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * ((cosTheta_i_m / v) / ((((single(0.3333333333333333) + (single(0.016666666666666666) / (v * v))) / (v * v)) - single(-2.0)) / v))));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \frac{\frac{cosTheta\_i\_m}{v}}{\frac{\frac{0.3333333333333333 + \frac{0.016666666666666666}{v \cdot v}}{v \cdot v} - -2}{v}}\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Step-by-step derivation
      1. clear-numN/A

        \[\leadsto \frac{\frac{1}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}}{\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot \left(v \cdot 2\right)} \]
      2. associate-/r*N/A

        \[\leadsto \frac{1}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}} \cdot \left(\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)\right)}} \]
      3. associate-/l/N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\color{blue}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}}} \]
      4. associate-/l*N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i \cdot \color{blue}{\frac{cosTheta\_O}{v}}}} \]
      5. associate-/r*N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}{\color{blue}{\frac{cosTheta\_O}{v}}}} \]
      6. associate-/r/N/A

        \[\leadsto \frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{1}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
    6. Applied egg-rr98.8%

      \[\leadsto \color{blue}{\frac{\frac{\frac{0.5}{v}}{\sinh \left(\frac{1}{v}\right)}}{\frac{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}{cosTheta\_i}} \cdot \frac{cosTheta\_O}{v}} \]
    7. Taylor expanded in sinTheta_i around 0

      \[\leadsto \mathsf{*.f32}\left(\color{blue}{\left(\frac{cosTheta\_i}{v \cdot \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)}\right)}, \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    8. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}}\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i}{v}\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(\color{blue}{cosTheta\_O}, v\right)\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(e^{\frac{1}{v}} - \frac{1}{e^{\frac{1}{v}}}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      4. --lowering--.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\left(e^{\frac{1}{v}}\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      5. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\left(\frac{1}{v}\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(\frac{1}{e^{\frac{1}{v}}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      7. rec-expN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\mathsf{neg}\left(\frac{1}{v}\right)}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      8. distribute-neg-fracN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{\mathsf{neg}\left(1\right)}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      9. metadata-evalN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(e^{\frac{-1}{v}}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      10. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\left(\frac{-1}{v}\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      11. /-lowering-/.f3298.7%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{\_.f32}\left(\mathsf{exp.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(-1, v\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    9. Simplified98.7%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_i}{v}}{e^{\frac{1}{v}} - e^{\frac{-1}{v}}}} \cdot \frac{cosTheta\_O}{v} \]
    10. Taylor expanded in v around -inf

      \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \color{blue}{\left(-1 \cdot \frac{-1 \cdot \frac{\frac{1}{3} + \frac{1}{60} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 2}{v}\right)}\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    11. Step-by-step derivation
      1. mul-1-negN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(\mathsf{neg}\left(\frac{-1 \cdot \frac{\frac{1}{3} + \frac{1}{60} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 2}{v}\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      2. distribute-neg-frac2N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \left(\frac{-1 \cdot \frac{\frac{1}{3} + \frac{1}{60} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 2}{\mathsf{neg}\left(v\right)}\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, v\right), \mathsf{/.f32}\left(\left(-1 \cdot \frac{\frac{1}{3} + \frac{1}{60} \cdot \frac{1}{{v}^{2}}}{{v}^{2}} - 2\right), \left(\mathsf{neg}\left(v\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, v\right)\right) \]
    12. Simplified69.6%

      \[\leadsto \frac{\frac{cosTheta\_i}{v}}{\color{blue}{\frac{\frac{0.3333333333333333 + \frac{0.016666666666666666}{v \cdot v}}{-v \cdot v} + -2}{-v}}} \cdot \frac{cosTheta\_O}{v} \]
    13. Final simplification69.6%

      \[\leadsto \frac{cosTheta\_O}{v} \cdot \frac{\frac{cosTheta\_i}{v}}{\frac{\frac{0.3333333333333333 + \frac{0.016666666666666666}{v \cdot v}}{v \cdot v} - -2}{v}} \]
    14. Add Preprocessing

    Alternative 7: 64.2% accurate, 14.7× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{1}{v} \cdot \frac{cosTheta\_i\_m}{\frac{2 + \frac{0.3333333333333333}{v \cdot v}}{cosTheta\_O\_m}}\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (*
        (/ 1.0 v)
        (/
         cosTheta_i_m
         (/ (+ 2.0 (/ 0.3333333333333333 (* v v))) cosTheta_O_m))))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((1.0f / v) * (cosTheta_i_m / ((2.0f + (0.3333333333333333f / (v * v))) / cosTheta_O_m))));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((1.0e0 / v) * (costheta_i_m / ((2.0e0 + (0.3333333333333333e0 / (v * v))) / costheta_o_m))))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(Float32(1.0) / v) * Float32(cosTheta_i_m / Float32(Float32(Float32(2.0) + Float32(Float32(0.3333333333333333) / Float32(v * v))) / cosTheta_O_m)))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((single(1.0) / v) * (cosTheta_i_m / ((single(2.0) + (single(0.3333333333333333) / (v * v))) / cosTheta_O_m))));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{1}{v} \cdot \frac{cosTheta\_i\_m}{\frac{2 + \frac{0.3333333333333333}{v \cdot v}}{cosTheta\_O\_m}}\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{cosTheta\_O \cdot cosTheta\_i}{\color{blue}{\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right) \cdot v}} \]
      2. times-fracN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \color{blue}{\frac{cosTheta\_i}{v}} \]
      3. clear-numN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \frac{1}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      4. un-div-invN/A

        \[\leadsto \frac{\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}\right), \color{blue}{\left(\frac{v}{cosTheta\_i}\right)}\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\frac{1}{3}}{v \cdot v}\right)\right), \left(\frac{\color{blue}{v}}{cosTheta\_i}\right)\right) \]
      7. frac-2negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{\mathsf{neg}\left(v \cdot v\right)}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      8. distribute-frac-neg2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \left(\mathsf{neg}\left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      9. unsub-negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 - \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      10. --lowering--.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      11. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\left(\mathsf{neg}\left(\frac{1}{3}\right)\right), \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      12. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      13. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      14. /-lowering-/.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \mathsf{/.f32}\left(v, \color{blue}{cosTheta\_i}\right)\right) \]
    12. Applied egg-rr63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O}{2 - \frac{-0.3333333333333333}{v \cdot v}}}{\frac{v}{cosTheta\_i}}} \]
    13. Step-by-step derivation
      1. div-invN/A

        \[\leadsto \frac{cosTheta\_O}{2 - \frac{\frac{-1}{3}}{v \cdot v}} \cdot \color{blue}{\frac{1}{\frac{v}{cosTheta\_i}}} \]
      2. clear-numN/A

        \[\leadsto \frac{1}{\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O}} \cdot \frac{\color{blue}{1}}{\frac{v}{cosTheta\_i}} \]
      3. frac-timesN/A

        \[\leadsto \frac{1 \cdot 1}{\color{blue}{\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O} \cdot \frac{v}{cosTheta\_i}}} \]
      4. metadata-evalN/A

        \[\leadsto \frac{1}{\color{blue}{\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O}} \cdot \frac{v}{cosTheta\_i}} \]
      5. associate-/l/N/A

        \[\leadsto \frac{\frac{1}{\frac{v}{cosTheta\_i}}}{\color{blue}{\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O}}} \]
      6. associate-/r/N/A

        \[\leadsto \frac{\frac{1}{v} \cdot cosTheta\_i}{\frac{\color{blue}{2 - \frac{\frac{-1}{3}}{v \cdot v}}}{cosTheta\_O}} \]
      7. associate-/l*N/A

        \[\leadsto \frac{1}{v} \cdot \color{blue}{\frac{cosTheta\_i}{\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O}}} \]
      8. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{1}{v}\right), \color{blue}{\left(\frac{cosTheta\_i}{\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O}}\right)}\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \left(\frac{\color{blue}{cosTheta\_i}}{\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O}}\right)\right) \]
      10. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \color{blue}{\left(\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{cosTheta\_O}\right)}\right)\right) \]
      11. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\left(2 - \frac{\frac{-1}{3}}{v \cdot v}\right), \color{blue}{cosTheta\_O}\right)\right)\right) \]
      12. div-invN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\left(2 - \frac{-1}{3} \cdot \frac{1}{v \cdot v}\right), cosTheta\_O\right)\right)\right) \]
      13. cancel-sign-sub-invN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\left(2 + \left(\mathsf{neg}\left(\frac{-1}{3}\right)\right) \cdot \frac{1}{v \cdot v}\right), cosTheta\_O\right)\right)\right) \]
      14. metadata-evalN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\left(2 + \frac{1}{3} \cdot \frac{1}{v \cdot v}\right), cosTheta\_O\right)\right)\right) \]
      15. div-invN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right), cosTheta\_O\right)\right)\right) \]
      16. +-lowering-+.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{v \cdot v}\right)\right), cosTheta\_O\right)\right)\right) \]
      17. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot v\right)\right)\right), cosTheta\_O\right)\right)\right) \]
      18. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(1, v\right), \mathsf{/.f32}\left(cosTheta\_i, \mathsf{/.f32}\left(\mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right), cosTheta\_O\right)\right)\right) \]
    14. Applied egg-rr63.3%

      \[\leadsto \color{blue}{\frac{1}{v} \cdot \frac{cosTheta\_i}{\frac{2 + \frac{0.3333333333333333}{v \cdot v}}{cosTheta\_O}}} \]
    15. Add Preprocessing

    Alternative 8: 64.2% accurate, 16.9× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{cosTheta\_O\_m \cdot \frac{cosTheta\_i\_m}{2 + \frac{0.3333333333333333}{v \cdot v}}}{v}\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (/
        (* cosTheta_O_m (/ cosTheta_i_m (+ 2.0 (/ 0.3333333333333333 (* v v)))))
        v))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m * (cosTheta_i_m / (2.0f + (0.3333333333333333f / (v * v))))) / v));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((costheta_o_m * (costheta_i_m / (2.0e0 + (0.3333333333333333e0 / (v * v))))) / v))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_O_m * Float32(cosTheta_i_m / Float32(Float32(2.0) + Float32(Float32(0.3333333333333333) / Float32(v * v))))) / v)))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m * (cosTheta_i_m / (single(2.0) + (single(0.3333333333333333) / (v * v))))) / v));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{cosTheta\_O\_m \cdot \frac{cosTheta\_i\_m}{2 + \frac{0.3333333333333333}{v \cdot v}}}{v}\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{cosTheta\_O \cdot cosTheta\_i}{\color{blue}{\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right) \cdot v}} \]
      2. times-fracN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \color{blue}{\frac{cosTheta\_i}{v}} \]
      3. clear-numN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \frac{1}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      4. un-div-invN/A

        \[\leadsto \frac{\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}\right), \color{blue}{\left(\frac{v}{cosTheta\_i}\right)}\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\frac{1}{3}}{v \cdot v}\right)\right), \left(\frac{\color{blue}{v}}{cosTheta\_i}\right)\right) \]
      7. frac-2negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{\mathsf{neg}\left(v \cdot v\right)}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      8. distribute-frac-neg2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \left(\mathsf{neg}\left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      9. unsub-negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 - \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      10. --lowering--.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      11. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\left(\mathsf{neg}\left(\frac{1}{3}\right)\right), \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      12. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      13. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      14. /-lowering-/.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \mathsf{/.f32}\left(v, \color{blue}{cosTheta\_i}\right)\right) \]
    12. Applied egg-rr63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O}{2 - \frac{-0.3333333333333333}{v \cdot v}}}{\frac{v}{cosTheta\_i}}} \]
    13. Taylor expanded in cosTheta_O around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    14. Step-by-step derivation
      1. times-fracN/A

        \[\leadsto \frac{cosTheta\_O}{v} \cdot \color{blue}{\frac{cosTheta\_i}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. *-commutativeN/A

        \[\leadsto \frac{cosTheta\_i}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
      3. associate-*r/N/A

        \[\leadsto \frac{\frac{cosTheta\_i}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}} \cdot cosTheta\_O}{\color{blue}{v}} \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_i}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}} \cdot cosTheta\_O\right), \color{blue}{v}\right) \]
      5. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\left(\frac{cosTheta\_i}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}\right), cosTheta\_O\right), v\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right), cosTheta\_O\right), v\right) \]
      7. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{+.f32}\left(2, \left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right)\right), cosTheta\_O\right), v\right) \]
      8. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{{v}^{2}}\right)\right)\right), cosTheta\_O\right), v\right) \]
      9. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{v}^{2}}\right)\right)\right), cosTheta\_O\right), v\right) \]
      10. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left({v}^{2}\right)\right)\right)\right), cosTheta\_O\right), v\right) \]
      11. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot v\right)\right)\right)\right), cosTheta\_O\right), v\right) \]
      12. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), cosTheta\_O\right), v\right) \]
    15. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_i}{2 + \frac{0.3333333333333333}{v \cdot v}} \cdot cosTheta\_O}{v}} \]
    16. Final simplification63.3%

      \[\leadsto \frac{cosTheta\_O \cdot \frac{cosTheta\_i}{2 + \frac{0.3333333333333333}{v \cdot v}}}{v} \]
    17. Add Preprocessing

    Alternative 9: 64.2% accurate, 16.9× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{cosTheta\_O\_m}{\frac{2 + \frac{0.3333333333333333}{v \cdot v}}{\frac{cosTheta\_i\_m}{v}}}\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (/
        cosTheta_O_m
        (/ (+ 2.0 (/ 0.3333333333333333 (* v v))) (/ cosTheta_i_m v))))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m / ((2.0f + (0.3333333333333333f / (v * v))) / (cosTheta_i_m / v))));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * (costheta_o_m / ((2.0e0 + (0.3333333333333333e0 / (v * v))) / (costheta_i_m / v))))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(cosTheta_O_m / Float32(Float32(Float32(2.0) + Float32(Float32(0.3333333333333333) / Float32(v * v))) / Float32(cosTheta_i_m / v)))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m / ((single(2.0) + (single(0.3333333333333333) / (v * v))) / (cosTheta_i_m / v))));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{cosTheta\_O\_m}{\frac{2 + \frac{0.3333333333333333}{v \cdot v}}{\frac{cosTheta\_i\_m}{v}}}\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{cosTheta\_O \cdot cosTheta\_i}{\color{blue}{\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right) \cdot v}} \]
      2. times-fracN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \color{blue}{\frac{cosTheta\_i}{v}} \]
      3. clear-numN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \frac{1}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      4. un-div-invN/A

        \[\leadsto \frac{\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}\right), \color{blue}{\left(\frac{v}{cosTheta\_i}\right)}\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\frac{1}{3}}{v \cdot v}\right)\right), \left(\frac{\color{blue}{v}}{cosTheta\_i}\right)\right) \]
      7. frac-2negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{\mathsf{neg}\left(v \cdot v\right)}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      8. distribute-frac-neg2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \left(\mathsf{neg}\left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      9. unsub-negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 - \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      10. --lowering--.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      11. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\left(\mathsf{neg}\left(\frac{1}{3}\right)\right), \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      12. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      13. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      14. /-lowering-/.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \mathsf{/.f32}\left(v, \color{blue}{cosTheta\_i}\right)\right) \]
    12. Applied egg-rr63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O}{2 - \frac{-0.3333333333333333}{v \cdot v}}}{\frac{v}{cosTheta\_i}}} \]
    13. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{cosTheta\_O}{\color{blue}{\frac{v}{cosTheta\_i} \cdot \left(2 - \frac{\frac{-1}{3}}{v \cdot v}\right)}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \color{blue}{\left(\frac{v}{cosTheta\_i} \cdot \left(2 - \frac{\frac{-1}{3}}{v \cdot v}\right)\right)}\right) \]
      3. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \left(\left(2 - \frac{\frac{-1}{3}}{v \cdot v}\right) \cdot \color{blue}{\frac{v}{cosTheta\_i}}\right)\right) \]
      4. clear-numN/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \left(\left(2 - \frac{\frac{-1}{3}}{v \cdot v}\right) \cdot \frac{1}{\color{blue}{\frac{cosTheta\_i}{v}}}\right)\right) \]
      5. div-invN/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \left(\frac{2 - \frac{\frac{-1}{3}}{v \cdot v}}{\color{blue}{\frac{cosTheta\_i}{v}}}\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\left(2 - \frac{\frac{-1}{3}}{v \cdot v}\right), \color{blue}{\left(\frac{cosTheta\_i}{v}\right)}\right)\right) \]
      7. div-invN/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\left(2 - \frac{-1}{3} \cdot \frac{1}{v \cdot v}\right), \left(\frac{cosTheta\_i}{v}\right)\right)\right) \]
      8. cancel-sign-sub-invN/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\left(2 + \left(\mathsf{neg}\left(\frac{-1}{3}\right)\right) \cdot \frac{1}{v \cdot v}\right), \left(\frac{\color{blue}{cosTheta\_i}}{v}\right)\right)\right) \]
      9. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\left(2 + \frac{1}{3} \cdot \frac{1}{v \cdot v}\right), \left(\frac{cosTheta\_i}{v}\right)\right)\right) \]
      10. div-invN/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right), \left(\frac{cosTheta\_i}{v}\right)\right)\right) \]
      11. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{v \cdot v}\right)\right), \left(\frac{\color{blue}{cosTheta\_i}}{v}\right)\right)\right) \]
      12. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot v\right)\right)\right), \left(\frac{cosTheta\_i}{v}\right)\right)\right) \]
      13. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right), \left(\frac{cosTheta\_i}{v}\right)\right)\right) \]
      14. /-lowering-/.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(\mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_i, \color{blue}{v}\right)\right)\right) \]
    14. Applied egg-rr63.3%

      \[\leadsto \color{blue}{\frac{cosTheta\_O}{\frac{2 + \frac{0.3333333333333333}{v \cdot v}}{\frac{cosTheta\_i}{v}}}} \]
    15. Add Preprocessing

    Alternative 10: 64.2% accurate, 16.9× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \frac{cosTheta\_i\_m}{2 - \frac{-0.3333333333333333}{v \cdot v}}\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (*
        (/ cosTheta_O_m v)
        (/ cosTheta_i_m (- 2.0 (/ -0.3333333333333333 (* v v))))))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * (cosTheta_i_m / (2.0f - (-0.3333333333333333f / (v * v))))));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((costheta_o_m / v) * (costheta_i_m / (2.0e0 - ((-0.3333333333333333e0) / (v * v))))))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_O_m / v) * Float32(cosTheta_i_m / Float32(Float32(2.0) - Float32(Float32(-0.3333333333333333) / Float32(v * v)))))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m / v) * (cosTheta_i_m / (single(2.0) - (single(-0.3333333333333333) / (v * v))))));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{cosTheta\_O\_m}{v} \cdot \frac{cosTheta\_i\_m}{2 - \frac{-0.3333333333333333}{v \cdot v}}\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{cosTheta\_O \cdot cosTheta\_i}{\color{blue}{\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right) \cdot v}} \]
      2. *-commutativeN/A

        \[\leadsto \frac{cosTheta\_i \cdot cosTheta\_O}{\color{blue}{\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right)} \cdot v} \]
      3. times-fracN/A

        \[\leadsto \frac{cosTheta\_i}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{cosTheta\_i}{2 + \frac{\frac{1}{3}}{v \cdot v}}\right), \color{blue}{\left(\frac{cosTheta\_O}{v}\right)}\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \left(2 + \frac{\frac{1}{3}}{v \cdot v}\right)\right), \left(\frac{\color{blue}{cosTheta\_O}}{v}\right)\right) \]
      6. frac-2negN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \left(2 + \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{\mathsf{neg}\left(v \cdot v\right)}\right)\right), \left(\frac{cosTheta\_O}{v}\right)\right) \]
      7. distribute-frac-neg2N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \left(2 + \left(\mathsf{neg}\left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right)\right), \left(\frac{cosTheta\_O}{v}\right)\right) \]
      8. unsub-negN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \left(2 - \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right), \left(\frac{cosTheta\_O}{v}\right)\right) \]
      9. --lowering--.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{\_.f32}\left(2, \left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right), \left(\frac{cosTheta\_O}{v}\right)\right) \]
      10. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\left(\mathsf{neg}\left(\frac{1}{3}\right)\right), \left(v \cdot v\right)\right)\right)\right), \left(\frac{cosTheta\_O}{v}\right)\right) \]
      11. metadata-evalN/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \left(v \cdot v\right)\right)\right)\right), \left(\frac{cosTheta\_O}{v}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \left(\frac{cosTheta\_O}{v}\right)\right) \]
      13. /-lowering-/.f3263.3%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(cosTheta\_i, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \mathsf{/.f32}\left(cosTheta\_O, \color{blue}{v}\right)\right) \]
    12. Applied egg-rr63.3%

      \[\leadsto \color{blue}{\frac{cosTheta\_i}{2 - \frac{-0.3333333333333333}{v \cdot v}} \cdot \frac{cosTheta\_O}{v}} \]
    13. Final simplification63.3%

      \[\leadsto \frac{cosTheta\_O}{v} \cdot \frac{cosTheta\_i}{2 - \frac{-0.3333333333333333}{v \cdot v}} \]
    14. Add Preprocessing

    Alternative 11: 64.2% accurate, 16.9× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_O\_m \cdot \frac{\frac{cosTheta\_i\_m}{2 + \frac{0.3333333333333333}{v \cdot v}}}{v}\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (*
        cosTheta_O_m
        (/ (/ cosTheta_i_m (+ 2.0 (/ 0.3333333333333333 (* v v)))) v)))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m * ((cosTheta_i_m / (2.0f + (0.3333333333333333f / (v * v)))) / v)));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * (costheta_o_m * ((costheta_i_m / (2.0e0 + (0.3333333333333333e0 / (v * v)))) / v)))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(cosTheta_O_m * Float32(Float32(cosTheta_i_m / Float32(Float32(2.0) + Float32(Float32(0.3333333333333333) / Float32(v * v)))) / v))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * (cosTheta_O_m * ((cosTheta_i_m / (single(2.0) + (single(0.3333333333333333) / (v * v)))) / v)));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_O\_m \cdot \frac{\frac{cosTheta\_i\_m}{2 + \frac{0.3333333333333333}{v \cdot v}}}{v}\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Step-by-step derivation
      1. associate-/l/N/A

        \[\leadsto \frac{cosTheta\_O \cdot cosTheta\_i}{\color{blue}{\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right) \cdot v}} \]
      2. times-fracN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \color{blue}{\frac{cosTheta\_i}{v}} \]
      3. clear-numN/A

        \[\leadsto \frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \frac{1}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      4. un-div-invN/A

        \[\leadsto \frac{\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}}{\color{blue}{\frac{v}{cosTheta\_i}}} \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O}{2 + \frac{\frac{1}{3}}{v \cdot v}}\right), \color{blue}{\left(\frac{v}{cosTheta\_i}\right)}\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\frac{1}{3}}{v \cdot v}\right)\right), \left(\frac{\color{blue}{v}}{cosTheta\_i}\right)\right) \]
      7. frac-2negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{\mathsf{neg}\left(v \cdot v\right)}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      8. distribute-frac-neg2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 + \left(\mathsf{neg}\left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      9. unsub-negN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \left(2 - \frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      10. --lowering--.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \left(\frac{\mathsf{neg}\left(\frac{1}{3}\right)}{v \cdot v}\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      11. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\left(\mathsf{neg}\left(\frac{1}{3}\right)\right), \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      12. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \left(v \cdot v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      13. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \left(\frac{v}{cosTheta\_i}\right)\right) \]
      14. /-lowering-/.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(cosTheta\_O, \mathsf{\_.f32}\left(2, \mathsf{/.f32}\left(\frac{-1}{3}, \mathsf{*.f32}\left(v, v\right)\right)\right)\right), \mathsf{/.f32}\left(v, \color{blue}{cosTheta\_i}\right)\right) \]
    12. Applied egg-rr63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O}{2 - \frac{-0.3333333333333333}{v \cdot v}}}{\frac{v}{cosTheta\_i}}} \]
    13. Step-by-step derivation
      1. div-invN/A

        \[\leadsto \frac{cosTheta\_O}{2 - \frac{\frac{-1}{3}}{v \cdot v}} \cdot \color{blue}{\frac{1}{\frac{v}{cosTheta\_i}}} \]
      2. clear-numN/A

        \[\leadsto \frac{cosTheta\_O}{2 - \frac{\frac{-1}{3}}{v \cdot v}} \cdot \frac{cosTheta\_i}{\color{blue}{v}} \]
      3. associate-*l/N/A

        \[\leadsto \frac{cosTheta\_O \cdot \frac{cosTheta\_i}{v}}{\color{blue}{2 - \frac{\frac{-1}{3}}{v \cdot v}}} \]
      4. associate-/l*N/A

        \[\leadsto cosTheta\_O \cdot \color{blue}{\frac{\frac{cosTheta\_i}{v}}{2 - \frac{\frac{-1}{3}}{v \cdot v}}} \]
      5. div-invN/A

        \[\leadsto cosTheta\_O \cdot \frac{\frac{cosTheta\_i}{v}}{2 - \frac{-1}{3} \cdot \color{blue}{\frac{1}{v \cdot v}}} \]
      6. cancel-sign-sub-invN/A

        \[\leadsto cosTheta\_O \cdot \frac{\frac{cosTheta\_i}{v}}{2 + \color{blue}{\left(\mathsf{neg}\left(\frac{-1}{3}\right)\right) \cdot \frac{1}{v \cdot v}}} \]
      7. metadata-evalN/A

        \[\leadsto cosTheta\_O \cdot \frac{\frac{cosTheta\_i}{v}}{2 + \frac{1}{3} \cdot \frac{\color{blue}{1}}{v \cdot v}} \]
      8. div-invN/A

        \[\leadsto cosTheta\_O \cdot \frac{\frac{cosTheta\_i}{v}}{2 + \frac{\frac{1}{3}}{\color{blue}{v \cdot v}}} \]
      9. *-commutativeN/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v}}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \color{blue}{cosTheta\_O} \]
      10. *-rgt-identityN/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v}}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \left(cosTheta\_O \cdot \color{blue}{1}\right) \]
      11. *-inversesN/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v}}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \left(cosTheta\_O \cdot \frac{\frac{1}{v}}{\color{blue}{\frac{1}{v}}}\right) \]
      12. associate-/l*N/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v}}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \frac{cosTheta\_O \cdot \frac{1}{v}}{\color{blue}{\frac{1}{v}}} \]
      13. div-invN/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v}}{2 + \frac{\frac{1}{3}}{v \cdot v}} \cdot \frac{\frac{cosTheta\_O}{v}}{\frac{\color{blue}{1}}{v}} \]
      14. times-fracN/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v} \cdot \frac{cosTheta\_O}{v}}{\color{blue}{\left(2 + \frac{\frac{1}{3}}{v \cdot v}\right) \cdot \frac{1}{v}}} \]
      15. div-invN/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v} \cdot \frac{cosTheta\_O}{v}}{\frac{2 + \frac{\frac{1}{3}}{v \cdot v}}{\color{blue}{v}}} \]
      16. associate-*l/N/A

        \[\leadsto \frac{\frac{cosTheta\_i}{v}}{\frac{2 + \frac{\frac{1}{3}}{v \cdot v}}{v}} \cdot \color{blue}{\frac{cosTheta\_O}{v}} \]
      17. associate-*r/N/A

        \[\leadsto \frac{\frac{\frac{cosTheta\_i}{v}}{\frac{2 + \frac{\frac{1}{3}}{v \cdot v}}{v}} \cdot cosTheta\_O}{\color{blue}{v}} \]
    14. Applied egg-rr63.3%

      \[\leadsto \color{blue}{cosTheta\_O \cdot \frac{\frac{cosTheta\_i}{2 + \frac{0.3333333333333333}{v \cdot v}}}{v}} \]
    15. Add Preprocessing

    Alternative 12: 59.0% accurate, 20.0× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{0.5 \cdot \frac{-1}{\frac{\frac{-1}{cosTheta\_i\_m}}{cosTheta\_O\_m}}}{v}\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (*
       cosTheta_i_s
       (/ (* 0.5 (/ -1.0 (/ (/ -1.0 cosTheta_i_m) cosTheta_O_m))) v))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((0.5f * (-1.0f / ((-1.0f / cosTheta_i_m) / cosTheta_O_m))) / v));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((0.5e0 * ((-1.0e0) / (((-1.0e0) / costheta_i_m) / costheta_o_m))) / v))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(Float32(0.5) * Float32(Float32(-1.0) / Float32(Float32(Float32(-1.0) / cosTheta_i_m) / cosTheta_O_m))) / v)))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((single(0.5) * (single(-1.0) / ((single(-1.0) / cosTheta_i_m) / cosTheta_O_m))) / v));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{0.5 \cdot \frac{-1}{\frac{\frac{-1}{cosTheta\_i\_m}}{cosTheta\_O\_m}}}{v}\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \color{blue}{\frac{1}{2} \cdot \frac{cosTheta\_O \cdot cosTheta\_i}{v}} \]
    6. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \frac{\frac{1}{2} \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)}{\color{blue}{v}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{2} \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right), \color{blue}{v}\right) \]
      3. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \frac{1}{2}\right), v\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), \frac{1}{2}\right), v\right) \]
      5. *-lowering-*.f3257.7%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), \frac{1}{2}\right), v\right) \]
    7. Simplified57.7%

      \[\leadsto \color{blue}{\frac{\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 0.5}{v}} \]
    8. Step-by-step derivation
      1. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), \frac{1}{2}\right), v\right) \]
      2. /-rgt-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{1}\right), \frac{1}{2}\right), v\right) \]
      3. clear-numN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\left(\frac{1}{\frac{1}{cosTheta\_i \cdot cosTheta\_O}}\right), \frac{1}{2}\right), v\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(1, \left(\frac{1}{cosTheta\_i \cdot cosTheta\_O}\right)\right), \frac{1}{2}\right), v\right) \]
      5. associate-/r*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(1, \left(\frac{\frac{1}{cosTheta\_i}}{cosTheta\_O}\right)\right), \frac{1}{2}\right), v\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(1, \mathsf{/.f32}\left(\left(\frac{1}{cosTheta\_i}\right), cosTheta\_O\right)\right), \frac{1}{2}\right), v\right) \]
      7. /-lowering-/.f3257.9%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{/.f32}\left(1, \mathsf{/.f32}\left(\mathsf{/.f32}\left(1, cosTheta\_i\right), cosTheta\_O\right)\right), \frac{1}{2}\right), v\right) \]
    9. Applied egg-rr57.9%

      \[\leadsto \frac{\color{blue}{\frac{1}{\frac{\frac{1}{cosTheta\_i}}{cosTheta\_O}}} \cdot 0.5}{v} \]
    10. Final simplification57.9%

      \[\leadsto \frac{0.5 \cdot \frac{-1}{\frac{\frac{-1}{cosTheta\_i}}{cosTheta\_O}}}{v} \]
    11. Add Preprocessing

    Alternative 13: 58.9% accurate, 31.4× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{0.5}{\frac{v}{cosTheta\_i\_m \cdot cosTheta\_O\_m}}\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (* cosTheta_O_s (* cosTheta_i_s (/ 0.5 (/ v (* cosTheta_i_m cosTheta_O_m))))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * (0.5f / (v / (cosTheta_i_m * cosTheta_O_m))));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * (0.5e0 / (v / (costheta_i_m * costheta_o_m))))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(0.5) / Float32(v / Float32(cosTheta_i_m * cosTheta_O_m)))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * (single(0.5) / (v / (cosTheta_i_m * cosTheta_O_m))));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \frac{0.5}{\frac{v}{cosTheta\_i\_m \cdot cosTheta\_O\_m}}\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \color{blue}{\frac{1}{2} \cdot \frac{cosTheta\_O \cdot cosTheta\_i}{v}} \]
    6. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \frac{\frac{1}{2} \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)}{\color{blue}{v}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{2} \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right), \color{blue}{v}\right) \]
      3. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \frac{1}{2}\right), v\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), \frac{1}{2}\right), v\right) \]
      5. *-lowering-*.f3257.7%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), \frac{1}{2}\right), v\right) \]
    7. Simplified57.7%

      \[\leadsto \color{blue}{\frac{\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 0.5}{v}} \]
    8. Step-by-step derivation
      1. *-commutativeN/A

        \[\leadsto \frac{\left(cosTheta\_i \cdot cosTheta\_O\right) \cdot \frac{1}{2}}{v} \]
      2. *-commutativeN/A

        \[\leadsto \frac{\frac{1}{2} \cdot \left(cosTheta\_i \cdot cosTheta\_O\right)}{v} \]
      3. associate-/l*N/A

        \[\leadsto \frac{1}{2} \cdot \color{blue}{\frac{cosTheta\_i \cdot cosTheta\_O}{v}} \]
      4. clear-numN/A

        \[\leadsto \frac{1}{2} \cdot \frac{1}{\color{blue}{\frac{v}{cosTheta\_i \cdot cosTheta\_O}}} \]
      5. un-div-invN/A

        \[\leadsto \frac{\frac{1}{2}}{\color{blue}{\frac{v}{cosTheta\_i \cdot cosTheta\_O}}} \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\frac{1}{2}, \color{blue}{\left(\frac{v}{cosTheta\_i \cdot cosTheta\_O}\right)}\right) \]
      7. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\frac{1}{2}, \mathsf{/.f32}\left(v, \color{blue}{\left(cosTheta\_i \cdot cosTheta\_O\right)}\right)\right) \]
      8. *-lowering-*.f3257.8%

        \[\leadsto \mathsf{/.f32}\left(\frac{1}{2}, \mathsf{/.f32}\left(v, \mathsf{*.f32}\left(cosTheta\_i, \color{blue}{cosTheta\_O}\right)\right)\right) \]
    9. Applied egg-rr57.8%

      \[\leadsto \color{blue}{\frac{0.5}{\frac{v}{cosTheta\_i \cdot cosTheta\_O}}} \]
    10. Add Preprocessing

    Alternative 14: 58.4% accurate, 31.4× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{0.5}{v} \cdot \left(cosTheta\_i\_m \cdot cosTheta\_O\_m\right)\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (* cosTheta_O_s (* cosTheta_i_s (* (/ 0.5 v) (* cosTheta_i_m cosTheta_O_m)))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((0.5f / v) * (cosTheta_i_m * cosTheta_O_m)));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((0.5e0 / v) * (costheta_i_m * costheta_o_m)))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(Float32(0.5) / v) * Float32(cosTheta_i_m * cosTheta_O_m))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((single(0.5) / v) * (cosTheta_i_m * cosTheta_O_m)));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\frac{0.5}{v} \cdot \left(cosTheta\_i\_m \cdot cosTheta\_O\_m\right)\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \color{blue}{\frac{1}{2} \cdot \frac{cosTheta\_O \cdot cosTheta\_i}{v}} \]
    6. Step-by-step derivation
      1. associate-*r/N/A

        \[\leadsto \frac{\frac{1}{2} \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)}{\color{blue}{v}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{2} \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right), \color{blue}{v}\right) \]
      3. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \frac{1}{2}\right), v\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), \frac{1}{2}\right), v\right) \]
      5. *-lowering-*.f3257.7%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), \frac{1}{2}\right), v\right) \]
    7. Simplified57.7%

      \[\leadsto \color{blue}{\frac{\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 0.5}{v}} \]
    8. Step-by-step derivation
      1. associate-/l*N/A

        \[\leadsto \left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \color{blue}{\frac{\frac{1}{2}}{v}} \]
      2. *-commutativeN/A

        \[\leadsto \left(cosTheta\_i \cdot cosTheta\_O\right) \cdot \frac{\color{blue}{\frac{1}{2}}}{v} \]
      3. *-commutativeN/A

        \[\leadsto \frac{\frac{1}{2}}{v} \cdot \color{blue}{\left(cosTheta\_i \cdot cosTheta\_O\right)} \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\frac{\frac{1}{2}}{v}\right), \color{blue}{\left(cosTheta\_i \cdot cosTheta\_O\right)}\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\frac{1}{2}, v\right), \left(\color{blue}{cosTheta\_i} \cdot cosTheta\_O\right)\right) \]
      6. *-lowering-*.f3257.7%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{/.f32}\left(\frac{1}{2}, v\right), \mathsf{*.f32}\left(cosTheta\_i, \color{blue}{cosTheta\_O}\right)\right) \]
    9. Applied egg-rr57.7%

      \[\leadsto \color{blue}{\frac{0.5}{v} \cdot \left(cosTheta\_i \cdot cosTheta\_O\right)} \]
    10. Add Preprocessing

    Alternative 15: 56.9% accurate, 31.4× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\left(cosTheta\_i\_m \cdot \left(v \cdot cosTheta\_O\_m\right)\right) \cdot 3\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (* cosTheta_O_s (* cosTheta_i_s (* (* cosTheta_i_m (* v cosTheta_O_m)) 3.0))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_i_m * (v * cosTheta_O_m)) * 3.0f));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((costheta_i_m * (v * costheta_o_m)) * 3.0e0))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_i_m * Float32(v * cosTheta_O_m)) * Float32(3.0))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_i_m * (v * cosTheta_O_m)) * single(3.0)));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\left(cosTheta\_i\_m \cdot \left(v \cdot cosTheta\_O\_m\right)\right) \cdot 3\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Taylor expanded in v around 0

      \[\leadsto \color{blue}{3 \cdot \left(cosTheta\_O \cdot \left(cosTheta\_i \cdot v\right)\right)} \]
    12. Step-by-step derivation
      1. associate-*r*N/A

        \[\leadsto 3 \cdot \left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \color{blue}{v}\right) \]
      2. associate-*r*N/A

        \[\leadsto \left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right) \cdot \color{blue}{v} \]
      3. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right), \color{blue}{v}\right) \]
      4. *-commutativeN/A

        \[\leadsto \mathsf{*.f32}\left(\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 3\right), v\right) \]
      5. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), 3\right), v\right) \]
      6. *-lowering-*.f3256.0%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), 3\right), v\right) \]
    13. Simplified56.0%

      \[\leadsto \color{blue}{\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 3\right) \cdot v} \]
    14. Step-by-step derivation
      1. *-commutativeN/A

        \[\leadsto \left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right) \cdot v \]
      2. associate-*l*N/A

        \[\leadsto 3 \cdot \color{blue}{\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot v\right)} \]
      3. *-commutativeN/A

        \[\leadsto \left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot v\right) \cdot \color{blue}{3} \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot v\right), \color{blue}{3}\right) \]
      5. *-commutativeN/A

        \[\leadsto \mathsf{*.f32}\left(\left(\left(cosTheta\_i \cdot cosTheta\_O\right) \cdot v\right), 3\right) \]
      6. associate-*l*N/A

        \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \left(cosTheta\_O \cdot v\right)\right), 3\right) \]
      7. *-commutativeN/A

        \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_i \cdot \left(v \cdot cosTheta\_O\right)\right), 3\right) \]
      8. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, \left(v \cdot cosTheta\_O\right)\right), 3\right) \]
      9. *-lowering-*.f3256.0%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, \mathsf{*.f32}\left(v, cosTheta\_O\right)\right), 3\right) \]
    15. Applied egg-rr56.0%

      \[\leadsto \color{blue}{\left(cosTheta\_i \cdot \left(v \cdot cosTheta\_O\right)\right) \cdot 3} \]
    16. Add Preprocessing

    Alternative 16: 56.9% accurate, 31.4× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_i\_m \cdot \left(cosTheta\_O\_m \cdot \frac{v}{0.3333333333333333}\right)\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (*
      cosTheta_O_s
      (* cosTheta_i_s (* cosTheta_i_m (* cosTheta_O_m (/ v 0.3333333333333333))))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * (cosTheta_i_m * (cosTheta_O_m * (v / 0.3333333333333333f))));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * (costheta_i_m * (costheta_o_m * (v / 0.3333333333333333e0))))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(cosTheta_i_m * Float32(cosTheta_O_m * Float32(v / Float32(0.3333333333333333))))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * (cosTheta_i_m * (cosTheta_O_m * (v / single(0.3333333333333333)))));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(cosTheta\_i\_m \cdot \left(cosTheta\_O\_m \cdot \frac{v}{0.3333333333333333}\right)\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Taylor expanded in v around 0

      \[\leadsto \color{blue}{3 \cdot \left(cosTheta\_O \cdot \left(cosTheta\_i \cdot v\right)\right)} \]
    12. Step-by-step derivation
      1. associate-*r*N/A

        \[\leadsto 3 \cdot \left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \color{blue}{v}\right) \]
      2. associate-*r*N/A

        \[\leadsto \left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right) \cdot \color{blue}{v} \]
      3. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right), \color{blue}{v}\right) \]
      4. *-commutativeN/A

        \[\leadsto \mathsf{*.f32}\left(\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 3\right), v\right) \]
      5. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), 3\right), v\right) \]
      6. *-lowering-*.f3256.0%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), 3\right), v\right) \]
    13. Simplified56.0%

      \[\leadsto \color{blue}{\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 3\right) \cdot v} \]
    14. Step-by-step derivation
      1. associate-*l*N/A

        \[\leadsto \left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \color{blue}{\left(3 \cdot v\right)} \]
      2. *-commutativeN/A

        \[\leadsto \left(cosTheta\_i \cdot cosTheta\_O\right) \cdot \left(\color{blue}{3} \cdot v\right) \]
      3. associate-*l*N/A

        \[\leadsto cosTheta\_i \cdot \color{blue}{\left(cosTheta\_O \cdot \left(3 \cdot v\right)\right)} \]
      4. *-commutativeN/A

        \[\leadsto \left(cosTheta\_O \cdot \left(3 \cdot v\right)\right) \cdot \color{blue}{cosTheta\_i} \]
      5. *-commutativeN/A

        \[\leadsto \left(cosTheta\_O \cdot \left(v \cdot 3\right)\right) \cdot cosTheta\_i \]
      6. metadata-evalN/A

        \[\leadsto \left(cosTheta\_O \cdot \left(v \cdot \frac{1}{\frac{1}{3}}\right)\right) \cdot cosTheta\_i \]
      7. div-invN/A

        \[\leadsto \left(cosTheta\_O \cdot \frac{v}{\frac{1}{3}}\right) \cdot cosTheta\_i \]
      8. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_O \cdot \frac{v}{\frac{1}{3}}\right), \color{blue}{cosTheta\_i}\right) \]
      9. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, \left(\frac{v}{\frac{1}{3}}\right)\right), cosTheta\_i\right) \]
      10. /-lowering-/.f3256.0%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, \mathsf{/.f32}\left(v, \frac{1}{3}\right)\right), cosTheta\_i\right) \]
    15. Applied egg-rr56.0%

      \[\leadsto \color{blue}{\left(cosTheta\_O \cdot \frac{v}{0.3333333333333333}\right) \cdot cosTheta\_i} \]
    16. Final simplification56.0%

      \[\leadsto cosTheta\_i \cdot \left(cosTheta\_O \cdot \frac{v}{0.3333333333333333}\right) \]
    17. Add Preprocessing

    Alternative 17: 56.9% accurate, 31.4× speedup?

    \[\begin{array}{l} cosTheta_i\_m = \left|cosTheta\_i\right| \\ cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right) \\ cosTheta_O\_m = \left|cosTheta\_O\right| \\ cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right) \\ [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\ \\ cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\left(cosTheta\_O\_m \cdot 3\right) \cdot \left(cosTheta\_i\_m \cdot v\right)\right)\right) \end{array} \]
    cosTheta_i\_m = (fabs.f32 cosTheta_i)
    cosTheta_i\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_i)
    cosTheta_O\_m = (fabs.f32 cosTheta_O)
    cosTheta_O\_s = (copysign.f32 #s(literal 1 binary32) cosTheta_O)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    (FPCore (cosTheta_O_s cosTheta_i_s cosTheta_i_m cosTheta_O_m sinTheta_i sinTheta_O v)
     :precision binary32
     (* cosTheta_O_s (* cosTheta_i_s (* (* cosTheta_O_m 3.0) (* cosTheta_i_m v)))))
    cosTheta_i\_m = fabs(cosTheta_i);
    cosTheta_i\_s = copysign(1.0, cosTheta_i);
    cosTheta_O\_m = fabs(cosTheta_O);
    cosTheta_O\_s = copysign(1.0, cosTheta_O);
    assert(cosTheta_i_m < cosTheta_O_m && cosTheta_O_m < sinTheta_i && sinTheta_i < sinTheta_O && sinTheta_O < v);
    float code(float cosTheta_O_s, float cosTheta_i_s, float cosTheta_i_m, float cosTheta_O_m, float sinTheta_i, float sinTheta_O, float v) {
    	return cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m * 3.0f) * (cosTheta_i_m * v)));
    }
    
    cosTheta_i\_m = abs(costheta_i)
    cosTheta_i\_s = copysign(1.0d0, costheta_i)
    cosTheta_O\_m = abs(costheta_o)
    cosTheta_O\_s = copysign(1.0d0, costheta_o)
    NOTE: cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, and v should be sorted in increasing order before calling this function.
    real(4) function code(costheta_o_s, costheta_i_s, costheta_i_m, costheta_o_m, sintheta_i, sintheta_o, v)
        real(4), intent (in) :: costheta_o_s
        real(4), intent (in) :: costheta_i_s
        real(4), intent (in) :: costheta_i_m
        real(4), intent (in) :: costheta_o_m
        real(4), intent (in) :: sintheta_i
        real(4), intent (in) :: sintheta_o
        real(4), intent (in) :: v
        code = costheta_o_s * (costheta_i_s * ((costheta_o_m * 3.0e0) * (costheta_i_m * v)))
    end function
    
    cosTheta_i\_m = abs(cosTheta_i)
    cosTheta_i\_s = copysign(1.0, cosTheta_i)
    cosTheta_O\_m = abs(cosTheta_O)
    cosTheta_O\_s = copysign(1.0, cosTheta_O)
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])
    function code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	return Float32(cosTheta_O_s * Float32(cosTheta_i_s * Float32(Float32(cosTheta_O_m * Float32(3.0)) * Float32(cosTheta_i_m * v))))
    end
    
    cosTheta_i\_m = abs(cosTheta_i);
    cosTheta_i\_s = sign(cosTheta_i) * abs(1.0);
    cosTheta_O\_m = abs(cosTheta_O);
    cosTheta_O\_s = sign(cosTheta_O) * abs(1.0);
    cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v = num2cell(sort([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])){:}
    function tmp = code(cosTheta_O_s, cosTheta_i_s, cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v)
    	tmp = cosTheta_O_s * (cosTheta_i_s * ((cosTheta_O_m * single(3.0)) * (cosTheta_i_m * v)));
    end
    
    \begin{array}{l}
    cosTheta_i\_m = \left|cosTheta\_i\right|
    \\
    cosTheta_i\_s = \mathsf{copysign}\left(1, cosTheta\_i\right)
    \\
    cosTheta_O\_m = \left|cosTheta\_O\right|
    \\
    cosTheta_O\_s = \mathsf{copysign}\left(1, cosTheta\_O\right)
    \\
    [cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v] = \mathsf{sort}([cosTheta_i_m, cosTheta_O_m, sinTheta_i, sinTheta_O, v])\\
    \\
    cosTheta\_O\_s \cdot \left(cosTheta\_i\_s \cdot \left(\left(cosTheta\_O\_m \cdot 3\right) \cdot \left(cosTheta\_i\_m \cdot v\right)\right)\right)
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\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} \]
    2. Step-by-step derivation
      1. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(e^{\mathsf{neg}\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \color{blue}{\left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)}\right) \]
      2. exp-negN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}} \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      3. associate-*l/N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{1 \cdot \frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      4. *-lft-identityN/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      5. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(\frac{cosTheta\_i \cdot cosTheta\_O}{v}\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\color{blue}{\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right)} \cdot v\right)\right) \]
      6. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_i \cdot cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\color{blue}{\sinh \left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      7. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \left(e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}\right)\right), \left(\left(\sinh \color{blue}{\left(\frac{1}{v}\right)} \cdot 2\right) \cdot v\right)\right) \]
      8. exp-lowering-exp.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\left(\frac{sinTheta\_i \cdot sinTheta\_O}{v}\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{2}\right) \cdot v\right)\right) \]
      9. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\left(sinTheta\_i \cdot sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      10. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\left(\sinh \left(\frac{1}{v}\right) \cdot 2\right) \cdot v\right)\right) \]
      11. associate-*l*N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \left(\sinh \left(\frac{1}{v}\right) \cdot \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      12. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\sinh \left(\frac{1}{v}\right), \color{blue}{\left(2 \cdot v\right)}\right)\right) \]
      13. sinh-lowering-sinh.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\left(\frac{1}{v}\right)\right), \left(\color{blue}{2} \cdot v\right)\right)\right) \]
      14. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(2 \cdot v\right)\right)\right) \]
      15. *-commutativeN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \left(v \cdot \color{blue}{2}\right)\right)\right) \]
      16. *-lowering-*.f3298.5%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{*.f32}\left(\mathsf{sinh.f32}\left(\mathsf{/.f32}\left(1, v\right)\right), \mathsf{*.f32}\left(v, \color{blue}{2}\right)\right)\right) \]
    3. Simplified98.5%

      \[\leadsto \color{blue}{\frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\sinh \left(\frac{1}{v}\right) \cdot \left(v \cdot 2\right)}} \]
    4. Add Preprocessing
    5. Taylor expanded in v around inf

      \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
    6. Step-by-step derivation
      1. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      2. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      3. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      4. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      5. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      6. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_i, cosTheta\_O\right), v\right), \mathsf{exp.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(sinTheta\_i, sinTheta\_O\right), v\right)\right)\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    7. Simplified63.3%

      \[\leadsto \frac{\frac{\frac{cosTheta\_i \cdot cosTheta\_O}{v}}{e^{\frac{sinTheta\_i \cdot sinTheta\_O}{v}}}}{\color{blue}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    8. Taylor expanded in sinTheta_i around 0

      \[\leadsto \color{blue}{\frac{cosTheta\_O \cdot cosTheta\_i}{v \cdot \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}} \]
    9. Step-by-step derivation
      1. associate-/r*N/A

        \[\leadsto \frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{\color{blue}{2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}}} \]
      2. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\left(\frac{cosTheta\_O \cdot cosTheta\_i}{v}\right), \color{blue}{\left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right) \]
      3. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), v\right), \left(\color{blue}{2} + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \left(2 + \frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)\right) \]
      5. +-lowering-+.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \color{blue}{\left(\frac{1}{3} \cdot \frac{1}{{v}^{2}}\right)}\right)\right) \]
      6. associate-*r/N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3} \cdot 1}{\color{blue}{{v}^{2}}}\right)\right)\right) \]
      7. metadata-evalN/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \left(\frac{\frac{1}{3}}{{\color{blue}{v}}^{2}}\right)\right)\right) \]
      8. /-lowering-/.f32N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \color{blue}{\left({v}^{2}\right)}\right)\right)\right) \]
      9. unpow2N/A

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \left(v \cdot \color{blue}{v}\right)\right)\right)\right) \]
      10. *-lowering-*.f3263.3%

        \[\leadsto \mathsf{/.f32}\left(\mathsf{/.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), v\right), \mathsf{+.f32}\left(2, \mathsf{/.f32}\left(\frac{1}{3}, \mathsf{*.f32}\left(v, \color{blue}{v}\right)\right)\right)\right) \]
    10. Simplified63.3%

      \[\leadsto \color{blue}{\frac{\frac{cosTheta\_O \cdot cosTheta\_i}{v}}{2 + \frac{0.3333333333333333}{v \cdot v}}} \]
    11. Taylor expanded in v around 0

      \[\leadsto \color{blue}{3 \cdot \left(cosTheta\_O \cdot \left(cosTheta\_i \cdot v\right)\right)} \]
    12. Step-by-step derivation
      1. associate-*r*N/A

        \[\leadsto 3 \cdot \left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot \color{blue}{v}\right) \]
      2. associate-*r*N/A

        \[\leadsto \left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right) \cdot \color{blue}{v} \]
      3. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right), \color{blue}{v}\right) \]
      4. *-commutativeN/A

        \[\leadsto \mathsf{*.f32}\left(\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 3\right), v\right) \]
      5. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(\left(cosTheta\_O \cdot cosTheta\_i\right), 3\right), v\right) \]
      6. *-lowering-*.f3256.0%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, cosTheta\_i\right), 3\right), v\right) \]
    13. Simplified56.0%

      \[\leadsto \color{blue}{\left(\left(cosTheta\_O \cdot cosTheta\_i\right) \cdot 3\right) \cdot v} \]
    14. Step-by-step derivation
      1. *-commutativeN/A

        \[\leadsto \left(3 \cdot \left(cosTheta\_O \cdot cosTheta\_i\right)\right) \cdot v \]
      2. associate-*r*N/A

        \[\leadsto \left(\left(3 \cdot cosTheta\_O\right) \cdot cosTheta\_i\right) \cdot v \]
      3. associate-*l*N/A

        \[\leadsto \left(3 \cdot cosTheta\_O\right) \cdot \color{blue}{\left(cosTheta\_i \cdot v\right)} \]
      4. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\left(3 \cdot cosTheta\_O\right), \color{blue}{\left(cosTheta\_i \cdot v\right)}\right) \]
      5. *-commutativeN/A

        \[\leadsto \mathsf{*.f32}\left(\left(cosTheta\_O \cdot 3\right), \left(\color{blue}{cosTheta\_i} \cdot v\right)\right) \]
      6. *-lowering-*.f32N/A

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, 3\right), \left(\color{blue}{cosTheta\_i} \cdot v\right)\right) \]
      7. *-lowering-*.f3256.0%

        \[\leadsto \mathsf{*.f32}\left(\mathsf{*.f32}\left(cosTheta\_O, 3\right), \mathsf{*.f32}\left(cosTheta\_i, \color{blue}{v}\right)\right) \]
    15. Applied egg-rr56.0%

      \[\leadsto \color{blue}{\left(cosTheta\_O \cdot 3\right) \cdot \left(cosTheta\_i \cdot v\right)} \]
    16. Add Preprocessing

    Reproduce

    ?
    herbie shell --seed 2024159 
    (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)))