Trowbridge-Reitz Sample, near normal, slope_y

Percentage Accurate: 98.4% → 98.4%
Time: 13.0s
Alternatives: 19
Speedup: 1.0×

Specification

?
\[\left(\left(cosTheta\_i > 0.9999 \land cosTheta\_i \leq 1\right) \land \left(2.328306437 \cdot 10^{-10} \leq u1 \land u1 \leq 1\right)\right) \land \left(2.328306437 \cdot 10^{-10} \leq u2 \land u2 \leq 1\right)\]
\[\begin{array}{l} \\ \sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \end{array} \]
(FPCore (cosTheta_i u1 u2)
 :precision binary32
 (* (sqrt (/ u1 (- 1.0 u1))) (sin (* 6.28318530718 u2))))
float code(float cosTheta_i, float u1, float u2) {
	return sqrtf((u1 / (1.0f - u1))) * sinf((6.28318530718f * u2));
}
real(4) function code(costheta_i, u1, u2)
    real(4), intent (in) :: costheta_i
    real(4), intent (in) :: u1
    real(4), intent (in) :: u2
    code = sqrt((u1 / (1.0e0 - u1))) * sin((6.28318530718e0 * u2))
end function
function code(cosTheta_i, u1, u2)
	return Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * sin(Float32(Float32(6.28318530718) * u2)))
end
function tmp = code(cosTheta_i, u1, u2)
	tmp = sqrt((u1 / (single(1.0) - u1))) * sin((single(6.28318530718) * u2));
end
\begin{array}{l}

\\
\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right)
\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 19 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.4% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \end{array} \]
(FPCore (cosTheta_i u1 u2)
 :precision binary32
 (* (sqrt (/ u1 (- 1.0 u1))) (sin (* 6.28318530718 u2))))
float code(float cosTheta_i, float u1, float u2) {
	return sqrtf((u1 / (1.0f - u1))) * sinf((6.28318530718f * u2));
}
real(4) function code(costheta_i, u1, u2)
    real(4), intent (in) :: costheta_i
    real(4), intent (in) :: u1
    real(4), intent (in) :: u2
    code = sqrt((u1 / (1.0e0 - u1))) * sin((6.28318530718e0 * u2))
end function
function code(cosTheta_i, u1, u2)
	return Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * sin(Float32(Float32(6.28318530718) * u2)))
end
function tmp = code(cosTheta_i, u1, u2)
	tmp = sqrt((u1 / (single(1.0) - u1))) * sin((single(6.28318530718) * u2));
end
\begin{array}{l}

\\
\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right)
\end{array}

Alternative 1: 98.4% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \end{array} \]
(FPCore (cosTheta_i u1 u2)
 :precision binary32
 (* (sqrt (/ u1 (- 1.0 u1))) (sin (* 6.28318530718 u2))))
float code(float cosTheta_i, float u1, float u2) {
	return sqrtf((u1 / (1.0f - u1))) * sinf((6.28318530718f * u2));
}
real(4) function code(costheta_i, u1, u2)
    real(4), intent (in) :: costheta_i
    real(4), intent (in) :: u1
    real(4), intent (in) :: u2
    code = sqrt((u1 / (1.0e0 - u1))) * sin((6.28318530718e0 * u2))
end function
function code(cosTheta_i, u1, u2)
	return Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * sin(Float32(Float32(6.28318530718) * u2)))
end
function tmp = code(cosTheta_i, u1, u2)
	tmp = sqrt((u1 / (single(1.0) - u1))) * sin((single(6.28318530718) * u2));
end
\begin{array}{l}

\\
\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right)
\end{array}
Derivation
  1. Initial program 98.5%

    \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
  2. Add Preprocessing
  3. Add Preprocessing

Alternative 2: 93.9% accurate, 1.2× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\frac{u1}{1 - u1}}\\ \mathsf{fma}\left(\mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right), t\_0 \cdot u2, \left(t\_0 \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right)\right) \cdot \left(u2 \cdot \left(u2 \cdot u2\right)\right)\right) \end{array} \end{array} \]
(FPCore (cosTheta_i u1 u2)
 :precision binary32
 (let* ((t_0 (sqrt (/ u1 (- 1.0 u1)))))
   (fma
    (fma u2 (* u2 -41.341702240407926) 6.28318530718)
    (* t_0 u2)
    (*
     (* t_0 (* u2 (* u2 (fma u2 (* u2 -76.70585975309672) 81.6052492761019))))
     (* u2 (* u2 u2))))))
float code(float cosTheta_i, float u1, float u2) {
	float t_0 = sqrtf((u1 / (1.0f - u1)));
	return fmaf(fmaf(u2, (u2 * -41.341702240407926f), 6.28318530718f), (t_0 * u2), ((t_0 * (u2 * (u2 * fmaf(u2, (u2 * -76.70585975309672f), 81.6052492761019f)))) * (u2 * (u2 * u2))));
}
function code(cosTheta_i, u1, u2)
	t_0 = sqrt(Float32(u1 / Float32(Float32(1.0) - u1)))
	return fma(fma(u2, Float32(u2 * Float32(-41.341702240407926)), Float32(6.28318530718)), Float32(t_0 * u2), Float32(Float32(t_0 * Float32(u2 * Float32(u2 * fma(u2, Float32(u2 * Float32(-76.70585975309672)), Float32(81.6052492761019))))) * Float32(u2 * Float32(u2 * u2))))
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sqrt{\frac{u1}{1 - u1}}\\
\mathsf{fma}\left(\mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right), t\_0 \cdot u2, \left(t\_0 \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right)\right) \cdot \left(u2 \cdot \left(u2 \cdot u2\right)\right)\right)
\end{array}
\end{array}
Derivation
  1. Initial program 98.5%

    \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
  2. Add Preprocessing
  3. Taylor expanded in u2 around 0

    \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)\right)\right)} \]
  4. Applied rewrites95.6%

    \[\leadsto \color{blue}{u2 \cdot \mathsf{fma}\left(\sqrt{\frac{u1}{1 - u1}}, \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)} \]
  5. Applied rewrites95.8%

    \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right), \color{blue}{u2 \cdot \sqrt{\frac{u1}{1 - u1}}}, \left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right)\right) \cdot \left(u2 \cdot \left(u2 \cdot u2\right)\right)\right) \]
  6. Final simplification95.8%

    \[\leadsto \mathsf{fma}\left(\mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right), \sqrt{\frac{u1}{1 - u1}} \cdot u2, \left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right)\right) \cdot \left(u2 \cdot \left(u2 \cdot u2\right)\right)\right) \]
  7. Add Preprocessing

Alternative 3: 93.9% accurate, 1.2× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\frac{u1}{1 - u1}}\\ \mathsf{fma}\left(\left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right) \cdot \left(t\_0 \cdot \left(u2 \cdot u2\right)\right), u2, \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \left(t\_0 \cdot u2\right)\right) \end{array} \end{array} \]
(FPCore (cosTheta_i u1 u2)
 :precision binary32
 (let* ((t_0 (sqrt (/ u1 (- 1.0 u1)))))
   (fma
    (*
     (* u2 (* u2 (fma u2 (* u2 -76.70585975309672) 81.6052492761019)))
     (* t_0 (* u2 u2)))
    u2
    (* (fma u2 (* u2 -41.341702240407926) 6.28318530718) (* t_0 u2)))))
float code(float cosTheta_i, float u1, float u2) {
	float t_0 = sqrtf((u1 / (1.0f - u1)));
	return fmaf(((u2 * (u2 * fmaf(u2, (u2 * -76.70585975309672f), 81.6052492761019f))) * (t_0 * (u2 * u2))), u2, (fmaf(u2, (u2 * -41.341702240407926f), 6.28318530718f) * (t_0 * u2)));
}
function code(cosTheta_i, u1, u2)
	t_0 = sqrt(Float32(u1 / Float32(Float32(1.0) - u1)))
	return fma(Float32(Float32(u2 * Float32(u2 * fma(u2, Float32(u2 * Float32(-76.70585975309672)), Float32(81.6052492761019)))) * Float32(t_0 * Float32(u2 * u2))), u2, Float32(fma(u2, Float32(u2 * Float32(-41.341702240407926)), Float32(6.28318530718)) * Float32(t_0 * u2)))
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \sqrt{\frac{u1}{1 - u1}}\\
\mathsf{fma}\left(\left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right) \cdot \left(t\_0 \cdot \left(u2 \cdot u2\right)\right), u2, \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \left(t\_0 \cdot u2\right)\right)
\end{array}
\end{array}
Derivation
  1. Initial program 98.5%

    \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
  2. Add Preprocessing
  3. Taylor expanded in u2 around 0

    \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)\right)\right)} \]
  4. Applied rewrites95.6%

    \[\leadsto \color{blue}{u2 \cdot \mathsf{fma}\left(\sqrt{\frac{u1}{1 - u1}}, \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)} \]
  5. Step-by-step derivation
    1. Applied rewrites95.8%

      \[\leadsto \mathsf{fma}\left(\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right) \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right), \color{blue}{u2}, \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)\right) \]
    2. Final simplification95.8%

      \[\leadsto \mathsf{fma}\left(\left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right)\right)\right) \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right), u2, \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)\right) \]
    3. Add Preprocessing

    Alternative 4: 94.0% accurate, 1.3× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\frac{u1}{1 - u1}}\\ u2 \cdot \mathsf{fma}\left(\mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right), \left(u2 \cdot u2\right) \cdot \left(t\_0 \cdot \left(u2 \cdot u2\right)\right), t\_0 \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right) \end{array} \end{array} \]
    (FPCore (cosTheta_i u1 u2)
     :precision binary32
     (let* ((t_0 (sqrt (/ u1 (- 1.0 u1)))))
       (*
        u2
        (fma
         (fma u2 (* u2 -76.70585975309672) 81.6052492761019)
         (* (* u2 u2) (* t_0 (* u2 u2)))
         (* t_0 (fma u2 (* u2 -41.341702240407926) 6.28318530718))))))
    float code(float cosTheta_i, float u1, float u2) {
    	float t_0 = sqrtf((u1 / (1.0f - u1)));
    	return u2 * fmaf(fmaf(u2, (u2 * -76.70585975309672f), 81.6052492761019f), ((u2 * u2) * (t_0 * (u2 * u2))), (t_0 * fmaf(u2, (u2 * -41.341702240407926f), 6.28318530718f)));
    }
    
    function code(cosTheta_i, u1, u2)
    	t_0 = sqrt(Float32(u1 / Float32(Float32(1.0) - u1)))
    	return Float32(u2 * fma(fma(u2, Float32(u2 * Float32(-76.70585975309672)), Float32(81.6052492761019)), Float32(Float32(u2 * u2) * Float32(t_0 * Float32(u2 * u2))), Float32(t_0 * fma(u2, Float32(u2 * Float32(-41.341702240407926)), Float32(6.28318530718)))))
    end
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    t_0 := \sqrt{\frac{u1}{1 - u1}}\\
    u2 \cdot \mathsf{fma}\left(\mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right), \left(u2 \cdot u2\right) \cdot \left(t\_0 \cdot \left(u2 \cdot u2\right)\right), t\_0 \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right)
    \end{array}
    \end{array}
    
    Derivation
    1. Initial program 98.5%

      \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
    2. Add Preprocessing
    3. Taylor expanded in u2 around 0

      \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)\right)\right)} \]
    4. Applied rewrites95.6%

      \[\leadsto \color{blue}{u2 \cdot \mathsf{fma}\left(\sqrt{\frac{u1}{1 - u1}}, \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)} \]
    5. Step-by-step derivation
      1. Applied rewrites95.6%

        \[\leadsto u2 \cdot \mathsf{fma}\left(\mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right), \color{blue}{\left(u2 \cdot u2\right) \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right)}, \sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right) \]
      2. Add Preprocessing

      Alternative 5: 94.0% accurate, 1.3× speedup?

      \[\begin{array}{l} \\ \begin{array}{l} t_0 := \sqrt{\frac{u1}{1 - u1}}\\ u2 \cdot \mathsf{fma}\left(t\_0, \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\left(t\_0 \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right) \end{array} \end{array} \]
      (FPCore (cosTheta_i u1 u2)
       :precision binary32
       (let* ((t_0 (sqrt (/ u1 (- 1.0 u1)))))
         (*
          u2
          (fma
           t_0
           (fma -41.341702240407926 (* u2 u2) 6.28318530718)
           (*
            (* u2 u2)
            (*
             (* t_0 (* u2 u2))
             (fma (* u2 u2) -76.70585975309672 81.6052492761019)))))))
      float code(float cosTheta_i, float u1, float u2) {
      	float t_0 = sqrtf((u1 / (1.0f - u1)));
      	return u2 * fmaf(t_0, fmaf(-41.341702240407926f, (u2 * u2), 6.28318530718f), ((u2 * u2) * ((t_0 * (u2 * u2)) * fmaf((u2 * u2), -76.70585975309672f, 81.6052492761019f))));
      }
      
      function code(cosTheta_i, u1, u2)
      	t_0 = sqrt(Float32(u1 / Float32(Float32(1.0) - u1)))
      	return Float32(u2 * fma(t_0, fma(Float32(-41.341702240407926), Float32(u2 * u2), Float32(6.28318530718)), Float32(Float32(u2 * u2) * Float32(Float32(t_0 * Float32(u2 * u2)) * fma(Float32(u2 * u2), Float32(-76.70585975309672), Float32(81.6052492761019))))))
      end
      
      \begin{array}{l}
      
      \\
      \begin{array}{l}
      t_0 := \sqrt{\frac{u1}{1 - u1}}\\
      u2 \cdot \mathsf{fma}\left(t\_0, \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\left(t\_0 \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)
      \end{array}
      \end{array}
      
      Derivation
      1. Initial program 98.5%

        \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
      2. Add Preprocessing
      3. Taylor expanded in u2 around 0

        \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
      4. Step-by-step derivation
        1. *-commutativeN/A

          \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
        2. associate-*r*N/A

          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
        3. lower-*.f32N/A

          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
        4. lower-*.f32N/A

          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
        5. *-rgt-identityN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
        6. sub-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
        7. rgt-mult-inverseN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
        8. mul-1-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
        9. distribute-neg-frac2N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
        10. mul-1-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
        11. *-rgt-identityN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
        12. distribute-lft-inN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
        13. +-commutativeN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
        14. sub-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
        15. associate-*r*N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
        16. lower-sqrt.f32N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
        17. *-rgt-identityN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
        18. lower-/.f32N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
        19. associate-*r*N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
        20. sub-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
        21. +-commutativeN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
      5. Applied rewrites85.7%

        \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
      6. Taylor expanded in u2 around 0

        \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)\right)\right)} \]
      7. Applied rewrites95.6%

        \[\leadsto \color{blue}{u2 \cdot \mathsf{fma}\left(\sqrt{\frac{u1}{1 - u1}}, \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)} \]
      8. Add Preprocessing

      Alternative 6: 93.7% accurate, 1.3× speedup?

      \[\begin{array}{l} \\ \frac{u2 \cdot \mathsf{fma}\left(\sqrt{u1}, \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\sqrt{u1} \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)\right)\right)}{\sqrt{1 - u1}} \end{array} \]
      (FPCore (cosTheta_i u1 u2)
       :precision binary32
       (/
        (*
         u2
         (fma
          (sqrt u1)
          (fma -41.341702240407926 (* u2 u2) 6.28318530718)
          (*
           (* u2 u2)
           (*
            (sqrt u1)
            (* u2 (* u2 (fma (* u2 u2) -76.70585975309672 81.6052492761019)))))))
        (sqrt (- 1.0 u1))))
      float code(float cosTheta_i, float u1, float u2) {
      	return (u2 * fmaf(sqrtf(u1), fmaf(-41.341702240407926f, (u2 * u2), 6.28318530718f), ((u2 * u2) * (sqrtf(u1) * (u2 * (u2 * fmaf((u2 * u2), -76.70585975309672f, 81.6052492761019f))))))) / sqrtf((1.0f - u1));
      }
      
      function code(cosTheta_i, u1, u2)
      	return Float32(Float32(u2 * fma(sqrt(u1), fma(Float32(-41.341702240407926), Float32(u2 * u2), Float32(6.28318530718)), Float32(Float32(u2 * u2) * Float32(sqrt(u1) * Float32(u2 * Float32(u2 * fma(Float32(u2 * u2), Float32(-76.70585975309672), Float32(81.6052492761019)))))))) / sqrt(Float32(Float32(1.0) - u1)))
      end
      
      \begin{array}{l}
      
      \\
      \frac{u2 \cdot \mathsf{fma}\left(\sqrt{u1}, \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\sqrt{u1} \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)\right)\right)}{\sqrt{1 - u1}}
      \end{array}
      
      Derivation
      1. Initial program 98.5%

        \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-/.f32N/A

          \[\leadsto \sqrt{\color{blue}{\frac{u1}{1 - u1}}} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        2. clear-numN/A

          \[\leadsto \sqrt{\color{blue}{\frac{1}{\frac{1 - u1}{u1}}}} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        3. frac-2negN/A

          \[\leadsto \sqrt{\frac{1}{\color{blue}{\frac{\mathsf{neg}\left(\left(1 - u1\right)\right)}{\mathsf{neg}\left(u1\right)}}}} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        4. associate-/r/N/A

          \[\leadsto \sqrt{\color{blue}{\frac{1}{\mathsf{neg}\left(\left(1 - u1\right)\right)} \cdot \left(\mathsf{neg}\left(u1\right)\right)}} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        5. lower-*.f32N/A

          \[\leadsto \sqrt{\color{blue}{\frac{1}{\mathsf{neg}\left(\left(1 - u1\right)\right)} \cdot \left(\mathsf{neg}\left(u1\right)\right)}} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        6. lower-/.f32N/A

          \[\leadsto \sqrt{\color{blue}{\frac{1}{\mathsf{neg}\left(\left(1 - u1\right)\right)}} \cdot \left(\mathsf{neg}\left(u1\right)\right)} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        7. neg-sub0N/A

          \[\leadsto \sqrt{\frac{1}{\color{blue}{0 - \left(1 - u1\right)}} \cdot \left(\mathsf{neg}\left(u1\right)\right)} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        8. lift--.f32N/A

          \[\leadsto \sqrt{\frac{1}{0 - \color{blue}{\left(1 - u1\right)}} \cdot \left(\mathsf{neg}\left(u1\right)\right)} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        9. associate--r-N/A

          \[\leadsto \sqrt{\frac{1}{\color{blue}{\left(0 - 1\right) + u1}} \cdot \left(\mathsf{neg}\left(u1\right)\right)} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        10. metadata-evalN/A

          \[\leadsto \sqrt{\frac{1}{\color{blue}{-1} + u1} \cdot \left(\mathsf{neg}\left(u1\right)\right)} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        11. +-commutativeN/A

          \[\leadsto \sqrt{\frac{1}{\color{blue}{u1 + -1}} \cdot \left(\mathsf{neg}\left(u1\right)\right)} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        12. lower-+.f32N/A

          \[\leadsto \sqrt{\frac{1}{\color{blue}{u1 + -1}} \cdot \left(\mathsf{neg}\left(u1\right)\right)} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \]
        13. lower-neg.f3298.4

          \[\leadsto \sqrt{\frac{1}{u1 + -1} \cdot \color{blue}{\left(-u1\right)}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
      4. Applied rewrites98.4%

        \[\leadsto \sqrt{\color{blue}{\frac{1}{u1 + -1} \cdot \left(-u1\right)}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
      5. Applied rewrites98.1%

        \[\leadsto \color{blue}{\frac{\sqrt{u1} \cdot \sin \left(6.28318530718 \cdot u2\right)}{\sqrt{1 - u1}}} \]
      6. Taylor expanded in u2 around 0

        \[\leadsto \frac{\color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{u1} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{u1} + {u2}^{2} \cdot \left(\frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{u1} \cdot {u2}^{2}\right) + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \sqrt{u1}\right)\right)\right)}}{\sqrt{1 - u1}} \]
      7. Applied rewrites95.5%

        \[\leadsto \frac{\color{blue}{u2 \cdot \mathsf{fma}\left(\sqrt{u1}, \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right), \left(u2 \cdot u2\right) \cdot \left(\sqrt{u1} \cdot \left(u2 \cdot \left(u2 \cdot \mathsf{fma}\left(u2 \cdot u2, -76.70585975309672, 81.6052492761019\right)\right)\right)\right)\right)}}{\sqrt{1 - u1}} \]
      8. Add Preprocessing

      Alternative 7: 93.9% accurate, 1.8× speedup?

      \[\begin{array}{l} \\ \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right), -41.341702240407926\right), 6.28318530718\right)}{\sqrt{\frac{1}{u1} + -1}} \end{array} \]
      (FPCore (cosTheta_i u1 u2)
       :precision binary32
       (/
        (*
         u2
         (fma
          (* u2 u2)
          (fma
           u2
           (* u2 (fma u2 (* u2 -76.70585975309672) 81.6052492761019))
           -41.341702240407926)
          6.28318530718))
        (sqrt (+ (/ 1.0 u1) -1.0))))
      float code(float cosTheta_i, float u1, float u2) {
      	return (u2 * fmaf((u2 * u2), fmaf(u2, (u2 * fmaf(u2, (u2 * -76.70585975309672f), 81.6052492761019f)), -41.341702240407926f), 6.28318530718f)) / sqrtf(((1.0f / u1) + -1.0f));
      }
      
      function code(cosTheta_i, u1, u2)
      	return Float32(Float32(u2 * fma(Float32(u2 * u2), fma(u2, Float32(u2 * fma(u2, Float32(u2 * Float32(-76.70585975309672)), Float32(81.6052492761019))), Float32(-41.341702240407926)), Float32(6.28318530718))) / sqrt(Float32(Float32(Float32(1.0) / u1) + Float32(-1.0))))
      end
      
      \begin{array}{l}
      
      \\
      \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right), -41.341702240407926\right), 6.28318530718\right)}{\sqrt{\frac{1}{u1} + -1}}
      \end{array}
      
      Derivation
      1. Initial program 98.5%

        \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
      2. Add Preprocessing
      3. Step-by-step derivation
        1. lift-*.f32N/A

          \[\leadsto \color{blue}{\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(\frac{314159265359}{50000000000} \cdot u2\right)} \]
        2. *-commutativeN/A

          \[\leadsto \color{blue}{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
        3. lift-sqrt.f32N/A

          \[\leadsto \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1}{1 - u1}}} \]
        4. lift-/.f32N/A

          \[\leadsto \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{1 - u1}}} \]
        5. clear-numN/A

          \[\leadsto \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{1}{\frac{1 - u1}{u1}}}} \]
        6. sqrt-divN/A

          \[\leadsto \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\frac{\sqrt{1}}{\sqrt{\frac{1 - u1}{u1}}}} \]
        7. metadata-evalN/A

          \[\leadsto \sin \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \frac{\color{blue}{1}}{\sqrt{\frac{1 - u1}{u1}}} \]
        8. un-div-invN/A

          \[\leadsto \color{blue}{\frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\frac{1 - u1}{u1}}}} \]
        9. lower-/.f32N/A

          \[\leadsto \color{blue}{\frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\frac{1 - u1}{u1}}}} \]
        10. lower-sqrt.f32N/A

          \[\leadsto \frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\color{blue}{\sqrt{\frac{1 - u1}{u1}}}} \]
        11. lift--.f32N/A

          \[\leadsto \frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\frac{\color{blue}{1 - u1}}{u1}}} \]
        12. div-subN/A

          \[\leadsto \frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\color{blue}{\frac{1}{u1} - \frac{u1}{u1}}}} \]
        13. sub-negN/A

          \[\leadsto \frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\color{blue}{\frac{1}{u1} + \left(\mathsf{neg}\left(\frac{u1}{u1}\right)\right)}}} \]
        14. *-inversesN/A

          \[\leadsto \frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\frac{1}{u1} + \left(\mathsf{neg}\left(\color{blue}{1}\right)\right)}} \]
        15. metadata-evalN/A

          \[\leadsto \frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\frac{1}{u1} + \color{blue}{-1}}} \]
        16. lower-+.f32N/A

          \[\leadsto \frac{\sin \left(\frac{314159265359}{50000000000} \cdot u2\right)}{\sqrt{\color{blue}{\frac{1}{u1} + -1}}} \]
        17. lower-/.f3298.1

          \[\leadsto \frac{\sin \left(6.28318530718 \cdot u2\right)}{\sqrt{\color{blue}{\frac{1}{u1}} + -1}} \]
      4. Applied rewrites98.1%

        \[\leadsto \color{blue}{\frac{\sin \left(6.28318530718 \cdot u2\right)}{\sqrt{\frac{1}{u1} + -1}}} \]
      5. Taylor expanded in u2 around 0

        \[\leadsto \frac{\color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} + {u2}^{2} \cdot \left({u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) - \frac{31006276680305942139213528068663279}{750000000000000000000000000000000}\right)\right)}}{\sqrt{\frac{1}{u1} + -1}} \]
      6. Step-by-step derivation
        1. lower-*.f32N/A

          \[\leadsto \frac{\color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} + {u2}^{2} \cdot \left({u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) - \frac{31006276680305942139213528068663279}{750000000000000000000000000000000}\right)\right)}}{\sqrt{\frac{1}{u1} + -1}} \]
        2. +-commutativeN/A

          \[\leadsto \frac{u2 \cdot \color{blue}{\left({u2}^{2} \cdot \left({u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) - \frac{31006276680305942139213528068663279}{750000000000000000000000000000000}\right) + \frac{314159265359}{50000000000}\right)}}{\sqrt{\frac{1}{u1} + -1}} \]
        3. lower-fma.f32N/A

          \[\leadsto \frac{u2 \cdot \color{blue}{\mathsf{fma}\left({u2}^{2}, {u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) - \frac{31006276680305942139213528068663279}{750000000000000000000000000000000}, \frac{314159265359}{50000000000}\right)}}{\sqrt{\frac{1}{u1} + -1}} \]
        4. unpow2N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(\color{blue}{u2 \cdot u2}, {u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) - \frac{31006276680305942139213528068663279}{750000000000000000000000000000000}, \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        5. lower-*.f32N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(\color{blue}{u2 \cdot u2}, {u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) - \frac{31006276680305942139213528068663279}{750000000000000000000000000000000}, \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        6. sub-negN/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \color{blue}{{u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) + \left(\mathsf{neg}\left(\frac{31006276680305942139213528068663279}{750000000000000000000000000000000}\right)\right)}, \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        7. unpow2N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \color{blue}{\left(u2 \cdot u2\right)} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right) + \left(\mathsf{neg}\left(\frac{31006276680305942139213528068663279}{750000000000000000000000000000000}\right)\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        8. associate-*l*N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \color{blue}{u2 \cdot \left(u2 \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right)\right)} + \left(\mathsf{neg}\left(\frac{31006276680305942139213528068663279}{750000000000000000000000000000000}\right)\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        9. metadata-evalN/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, u2 \cdot \left(u2 \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right)\right) + \color{blue}{\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}}, \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        10. lower-fma.f32N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \color{blue}{\mathsf{fma}\left(u2, u2 \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right), \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right)}, \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        11. lower-*.f32N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, \color{blue}{u2 \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} + \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2}\right)}, \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        12. +-commutativeN/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \color{blue}{\left(\frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} \cdot {u2}^{2} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000}\right)}, \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        13. *-commutativeN/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \left(\color{blue}{{u2}^{2} \cdot \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000}\right), \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        14. unpow2N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \left(\color{blue}{\left(u2 \cdot u2\right)} \cdot \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000}\right), \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        15. associate-*l*N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \left(\color{blue}{u2 \cdot \left(u2 \cdot \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000}\right)} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000}\right), \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        16. lower-fma.f32N/A

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \color{blue}{\mathsf{fma}\left(u2, u2 \cdot \frac{-302029322777818351566783844332719832329455959975176141755859165754785028165295919}{3937500000000000000000000000000000000000000000000000000000000000000000000000000}, \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000}\right)}, \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right), \frac{314159265359}{50000000000}\right)}{\sqrt{\frac{1}{u1} + -1}} \]
        17. lower-*.f3295.4

          \[\leadsto \frac{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2, \color{blue}{u2 \cdot -76.70585975309672}, 81.6052492761019\right), -41.341702240407926\right), 6.28318530718\right)}{\sqrt{\frac{1}{u1} + -1}} \]
      7. Applied rewrites95.4%

        \[\leadsto \frac{\color{blue}{u2 \cdot \mathsf{fma}\left(u2 \cdot u2, \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -76.70585975309672, 81.6052492761019\right), -41.341702240407926\right), 6.28318530718\right)}}{\sqrt{\frac{1}{u1} + -1}} \]
      8. Add Preprocessing

      Alternative 8: 91.8% accurate, 2.4× speedup?

      \[\begin{array}{l} \\ u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)\right) \end{array} \]
      (FPCore (cosTheta_i u1 u2)
       :precision binary32
       (*
        u2
        (*
         (sqrt (/ u1 (- 1.0 u1)))
         (fma
          u2
          (* u2 (fma (* u2 u2) 81.6052492761019 -41.341702240407926))
          6.28318530718))))
      float code(float cosTheta_i, float u1, float u2) {
      	return u2 * (sqrtf((u1 / (1.0f - u1))) * fmaf(u2, (u2 * fmaf((u2 * u2), 81.6052492761019f, -41.341702240407926f)), 6.28318530718f));
      }
      
      function code(cosTheta_i, u1, u2)
      	return Float32(u2 * Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * fma(u2, Float32(u2 * fma(Float32(u2 * u2), Float32(81.6052492761019), Float32(-41.341702240407926))), Float32(6.28318530718))))
      end
      
      \begin{array}{l}
      
      \\
      u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)\right)
      \end{array}
      
      Derivation
      1. Initial program 98.5%

        \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
      2. Add Preprocessing
      3. Taylor expanded in u2 around 0

        \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
      4. Step-by-step derivation
        1. *-commutativeN/A

          \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
        2. associate-*r*N/A

          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
        3. lower-*.f32N/A

          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
        4. lower-*.f32N/A

          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
        5. *-rgt-identityN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
        6. sub-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
        7. rgt-mult-inverseN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
        8. mul-1-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
        9. distribute-neg-frac2N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
        10. mul-1-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
        11. *-rgt-identityN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
        12. distribute-lft-inN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
        13. +-commutativeN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
        14. sub-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
        15. associate-*r*N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
        16. lower-sqrt.f32N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
        17. *-rgt-identityN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
        18. lower-/.f32N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
        19. associate-*r*N/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
        20. sub-negN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
        21. +-commutativeN/A

          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
      5. Applied rewrites85.7%

        \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
      6. Taylor expanded in u2 around 0

        \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right)} \]
      7. Step-by-step derivation
        1. lower-*.f32N/A

          \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right)} \]
        2. lower-fma.f32N/A

          \[\leadsto u2 \cdot \color{blue}{\mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 - u1}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right)} \]
        3. lower-sqrt.f32N/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \color{blue}{\sqrt{\frac{u1}{1 - u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
        4. sub-negN/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
        5. mul-1-negN/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 + \color{blue}{-1 \cdot u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
        6. lower-/.f32N/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\color{blue}{\frac{u1}{1 + -1 \cdot u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
        7. mul-1-negN/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 + \color{blue}{\left(\mathsf{neg}\left(u1\right)\right)}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
        8. sub-negN/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{\color{blue}{1 - u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
        9. lower--.f32N/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{\color{blue}{1 - u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
        10. distribute-rgt-inN/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 - u1}}, \color{blue}{\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \cdot {u2}^{2} + \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right) \cdot {u2}^{2}}\right) \]
        11. associate-*r*N/A

          \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 - u1}}, \color{blue}{\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)} + \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right) \cdot {u2}^{2}\right) \]
      8. Applied rewrites93.8%

        \[\leadsto \color{blue}{u2 \cdot \mathsf{fma}\left(6.28318530718, \sqrt{\frac{u1}{1 - u1}}, \left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right)\right)} \]
      9. Step-by-step derivation
        1. Applied rewrites93.8%

          \[\leadsto \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)\right) \cdot \color{blue}{u2} \]
        2. Final simplification93.8%

          \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)\right) \]
        3. Add Preprocessing

        Alternative 9: 85.6% accurate, 2.5× speedup?

        \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;6.28318530718 \cdot u2 \leq 0.0024999999441206455:\\ \;\;\;\;6.28318530718 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)\\ \mathbf{else}:\\ \;\;\;\;u2 \cdot \left(\sqrt{u1} \cdot \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)\right)\\ \end{array} \end{array} \]
        (FPCore (cosTheta_i u1 u2)
         :precision binary32
         (if (<= (* 6.28318530718 u2) 0.0024999999441206455)
           (* 6.28318530718 (* (sqrt (/ u1 (- 1.0 u1))) u2))
           (*
            u2
            (*
             (sqrt u1)
             (fma
              u2
              (* u2 (fma (* u2 u2) 81.6052492761019 -41.341702240407926))
              6.28318530718)))))
        float code(float cosTheta_i, float u1, float u2) {
        	float tmp;
        	if ((6.28318530718f * u2) <= 0.0024999999441206455f) {
        		tmp = 6.28318530718f * (sqrtf((u1 / (1.0f - u1))) * u2);
        	} else {
        		tmp = u2 * (sqrtf(u1) * fmaf(u2, (u2 * fmaf((u2 * u2), 81.6052492761019f, -41.341702240407926f)), 6.28318530718f));
        	}
        	return tmp;
        }
        
        function code(cosTheta_i, u1, u2)
        	tmp = Float32(0.0)
        	if (Float32(Float32(6.28318530718) * u2) <= Float32(0.0024999999441206455))
        		tmp = Float32(Float32(6.28318530718) * Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * u2));
        	else
        		tmp = Float32(u2 * Float32(sqrt(u1) * fma(u2, Float32(u2 * fma(Float32(u2 * u2), Float32(81.6052492761019), Float32(-41.341702240407926))), Float32(6.28318530718))));
        	end
        	return tmp
        end
        
        \begin{array}{l}
        
        \\
        \begin{array}{l}
        \mathbf{if}\;6.28318530718 \cdot u2 \leq 0.0024999999441206455:\\
        \;\;\;\;6.28318530718 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)\\
        
        \mathbf{else}:\\
        \;\;\;\;u2 \cdot \left(\sqrt{u1} \cdot \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)\right)\\
        
        
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 2 regimes
        2. if (*.f32 #s(literal 314159265359/50000000000 binary32) u2) < 0.00249999994

          1. Initial program 98.5%

            \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
          2. Add Preprocessing
          3. Taylor expanded in u2 around 0

            \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
          4. Step-by-step derivation
            1. *-commutativeN/A

              \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
            2. associate-*r*N/A

              \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
            3. lower-*.f32N/A

              \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
            4. lower-*.f32N/A

              \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
            5. *-rgt-identityN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
            6. sub-negN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
            7. rgt-mult-inverseN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
            8. mul-1-negN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
            9. distribute-neg-frac2N/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
            10. mul-1-negN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
            11. *-rgt-identityN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
            12. distribute-lft-inN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
            13. +-commutativeN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
            14. sub-negN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
            15. associate-*r*N/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
            16. lower-sqrt.f32N/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
            17. *-rgt-identityN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
            18. lower-/.f32N/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
            19. associate-*r*N/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
            20. sub-negN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
            21. +-commutativeN/A

              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
          5. Applied rewrites98.1%

            \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
          6. Step-by-step derivation
            1. Applied rewrites98.2%

              \[\leadsto \left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right) \cdot \color{blue}{6.28318530718} \]

            if 0.00249999994 < (*.f32 #s(literal 314159265359/50000000000 binary32) u2)

            1. Initial program 98.4%

              \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
            2. Add Preprocessing
            3. Taylor expanded in u2 around 0

              \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
            4. Step-by-step derivation
              1. *-commutativeN/A

                \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
              2. associate-*r*N/A

                \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
              3. lower-*.f32N/A

                \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
              4. lower-*.f32N/A

                \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
              5. *-rgt-identityN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
              6. sub-negN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
              7. rgt-mult-inverseN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
              8. mul-1-negN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
              9. distribute-neg-frac2N/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
              10. mul-1-negN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
              11. *-rgt-identityN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
              12. distribute-lft-inN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
              13. +-commutativeN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
              14. sub-negN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
              15. associate-*r*N/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
              16. lower-sqrt.f32N/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
              17. *-rgt-identityN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
              18. lower-/.f32N/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
              19. associate-*r*N/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
              20. sub-negN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
              21. +-commutativeN/A

                \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
            5. Applied rewrites53.5%

              \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
            6. Taylor expanded in u2 around 0

              \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right)} \]
            7. Step-by-step derivation
              1. lower-*.f32N/A

                \[\leadsto \color{blue}{u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right)} \]
              2. lower-fma.f32N/A

                \[\leadsto u2 \cdot \color{blue}{\mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 - u1}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right)} \]
              3. lower-sqrt.f32N/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \color{blue}{\sqrt{\frac{u1}{1 - u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
              4. sub-negN/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
              5. mul-1-negN/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 + \color{blue}{-1 \cdot u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
              6. lower-/.f32N/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\color{blue}{\frac{u1}{1 + -1 \cdot u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
              7. mul-1-negN/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 + \color{blue}{\left(\mathsf{neg}\left(u1\right)\right)}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
              8. sub-negN/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{\color{blue}{1 - u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
              9. lower--.f32N/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{\color{blue}{1 - u1}}}, {u2}^{2} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}} + \frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right)\right) \]
              10. distribute-rgt-inN/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 - u1}}, \color{blue}{\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \cdot {u2}^{2} + \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right) \cdot {u2}^{2}}\right) \]
              11. associate-*r*N/A

                \[\leadsto u2 \cdot \mathsf{fma}\left(\frac{314159265359}{50000000000}, \sqrt{\frac{u1}{1 - u1}}, \color{blue}{\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)} + \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right)\right) \cdot {u2}^{2}\right) \]
            8. Applied rewrites81.8%

              \[\leadsto \color{blue}{u2 \cdot \mathsf{fma}\left(6.28318530718, \sqrt{\frac{u1}{1 - u1}}, \left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot u2\right)\right) \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right)\right)} \]
            9. Taylor expanded in u1 around 0

              \[\leadsto u2 \cdot \left(\frac{314159265359}{50000000000} \cdot \sqrt{u1} + \color{blue}{\sqrt{u1} \cdot \left({u2}^{2} \cdot \left(\frac{3060196847853821555298148281676017575122444629042460390799}{37500000000000000000000000000000000000000000000000000000} \cdot {u2}^{2} - \frac{31006276680305942139213528068663279}{750000000000000000000000000000000}\right)\right)}\right) \]
            10. Step-by-step derivation
              1. Applied rewrites67.5%

                \[\leadsto u2 \cdot \left(\sqrt{u1} \cdot \color{blue}{\mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)}\right) \]
            11. Recombined 2 regimes into one program.
            12. Final simplification89.7%

              \[\leadsto \begin{array}{l} \mathbf{if}\;6.28318530718 \cdot u2 \leq 0.0024999999441206455:\\ \;\;\;\;6.28318530718 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)\\ \mathbf{else}:\\ \;\;\;\;u2 \cdot \left(\sqrt{u1} \cdot \mathsf{fma}\left(u2, u2 \cdot \mathsf{fma}\left(u2 \cdot u2, 81.6052492761019, -41.341702240407926\right), 6.28318530718\right)\right)\\ \end{array} \]
            13. Add Preprocessing

            Alternative 10: 89.3% accurate, 2.9× speedup?

            \[\begin{array}{l} \\ \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right) \end{array} \]
            (FPCore (cosTheta_i u1 u2)
             :precision binary32
             (*
              (fma u2 (* u2 -41.341702240407926) 6.28318530718)
              (* (sqrt (/ u1 (- 1.0 u1))) u2)))
            float code(float cosTheta_i, float u1, float u2) {
            	return fmaf(u2, (u2 * -41.341702240407926f), 6.28318530718f) * (sqrtf((u1 / (1.0f - u1))) * u2);
            }
            
            function code(cosTheta_i, u1, u2)
            	return Float32(fma(u2, Float32(u2 * Float32(-41.341702240407926)), Float32(6.28318530718)) * Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * u2))
            end
            
            \begin{array}{l}
            
            \\
            \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)
            \end{array}
            
            Derivation
            1. Initial program 98.5%

              \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
            2. Add Preprocessing
            3. Taylor expanded in u2 around 0

              \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
            4. Step-by-step derivation
              1. lower-*.f32N/A

                \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
              2. *-commutativeN/A

                \[\leadsto u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \color{blue}{\left({u2}^{2} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
              3. associate-*r*N/A

                \[\leadsto u2 \cdot \left(\color{blue}{\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2}\right) \cdot \sqrt{\frac{u1}{1 - u1}}} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
              4. distribute-rgt-outN/A

                \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
              5. lower-*.f32N/A

                \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
            5. Applied rewrites91.3%

              \[\leadsto \color{blue}{u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right)} \]
            6. Step-by-step derivation
              1. Applied rewrites91.5%

                \[\leadsto \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
              2. Final simplification91.5%

                \[\leadsto \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right) \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right) \]
              3. Add Preprocessing

              Alternative 11: 89.3% accurate, 2.9× speedup?

              \[\begin{array}{l} \\ \sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right) \end{array} \]
              (FPCore (cosTheta_i u1 u2)
               :precision binary32
               (*
                (sqrt (/ u1 (- 1.0 u1)))
                (* u2 (fma u2 (* u2 -41.341702240407926) 6.28318530718))))
              float code(float cosTheta_i, float u1, float u2) {
              	return sqrtf((u1 / (1.0f - u1))) * (u2 * fmaf(u2, (u2 * -41.341702240407926f), 6.28318530718f));
              }
              
              function code(cosTheta_i, u1, u2)
              	return Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * Float32(u2 * fma(u2, Float32(u2 * Float32(-41.341702240407926)), Float32(6.28318530718))))
              end
              
              \begin{array}{l}
              
              \\
              \sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right)
              \end{array}
              
              Derivation
              1. Initial program 98.5%

                \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
              2. Add Preprocessing
              3. Taylor expanded in u2 around 0

                \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
              4. Step-by-step derivation
                1. lower-*.f32N/A

                  \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                2. *-commutativeN/A

                  \[\leadsto u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \color{blue}{\left({u2}^{2} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
                3. associate-*r*N/A

                  \[\leadsto u2 \cdot \left(\color{blue}{\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2}\right) \cdot \sqrt{\frac{u1}{1 - u1}}} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
                4. distribute-rgt-outN/A

                  \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
                5. lower-*.f32N/A

                  \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
              5. Applied rewrites91.3%

                \[\leadsto \color{blue}{u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right)} \]
              6. Step-by-step derivation
                1. Applied rewrites91.4%

                  \[\leadsto \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right) \cdot \color{blue}{\sqrt{\frac{u1}{1 - u1}}} \]
                2. Final simplification91.4%

                  \[\leadsto \sqrt{\frac{u1}{1 - u1}} \cdot \left(u2 \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right) \]
                3. Add Preprocessing

                Alternative 12: 89.4% accurate, 2.9× speedup?

                \[\begin{array}{l} \\ u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right) \end{array} \]
                (FPCore (cosTheta_i u1 u2)
                 :precision binary32
                 (*
                  u2
                  (*
                   (sqrt (/ u1 (- 1.0 u1)))
                   (fma u2 (* u2 -41.341702240407926) 6.28318530718))))
                float code(float cosTheta_i, float u1, float u2) {
                	return u2 * (sqrtf((u1 / (1.0f - u1))) * fmaf(u2, (u2 * -41.341702240407926f), 6.28318530718f));
                }
                
                function code(cosTheta_i, u1, u2)
                	return Float32(u2 * Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * fma(u2, Float32(u2 * Float32(-41.341702240407926)), Float32(6.28318530718))))
                end
                
                \begin{array}{l}
                
                \\
                u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right)
                \end{array}
                
                Derivation
                1. Initial program 98.5%

                  \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                2. Add Preprocessing
                3. Taylor expanded in u2 around 0

                  \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                4. Step-by-step derivation
                  1. lower-*.f32N/A

                    \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                  2. *-commutativeN/A

                    \[\leadsto u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \color{blue}{\left({u2}^{2} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
                  3. associate-*r*N/A

                    \[\leadsto u2 \cdot \left(\color{blue}{\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2}\right) \cdot \sqrt{\frac{u1}{1 - u1}}} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
                  4. distribute-rgt-outN/A

                    \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
                  5. lower-*.f32N/A

                    \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
                5. Applied rewrites91.3%

                  \[\leadsto \color{blue}{u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(u2, u2 \cdot -41.341702240407926, 6.28318530718\right)\right)} \]
                6. Add Preprocessing

                Alternative 13: 89.4% accurate, 2.9× speedup?

                \[\begin{array}{l} \\ u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right)\right) \end{array} \]
                (FPCore (cosTheta_i u1 u2)
                 :precision binary32
                 (*
                  u2
                  (*
                   (sqrt (/ u1 (- 1.0 u1)))
                   (fma -41.341702240407926 (* u2 u2) 6.28318530718))))
                float code(float cosTheta_i, float u1, float u2) {
                	return u2 * (sqrtf((u1 / (1.0f - u1))) * fmaf(-41.341702240407926f, (u2 * u2), 6.28318530718f));
                }
                
                function code(cosTheta_i, u1, u2)
                	return Float32(u2 * Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * fma(Float32(-41.341702240407926), Float32(u2 * u2), Float32(6.28318530718))))
                end
                
                \begin{array}{l}
                
                \\
                u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right)\right)
                \end{array}
                
                Derivation
                1. Initial program 98.5%

                  \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                2. Add Preprocessing
                3. Taylor expanded in u2 around 0

                  \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
                4. Step-by-step derivation
                  1. *-commutativeN/A

                    \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                  2. associate-*r*N/A

                    \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                  3. lower-*.f32N/A

                    \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                  4. lower-*.f32N/A

                    \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
                  5. *-rgt-identityN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
                  6. sub-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
                  7. rgt-mult-inverseN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                  8. mul-1-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                  9. distribute-neg-frac2N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                  10. mul-1-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
                  11. *-rgt-identityN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
                  12. distribute-lft-inN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                  13. +-commutativeN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                  14. sub-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
                  15. associate-*r*N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                  16. lower-sqrt.f32N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                  17. *-rgt-identityN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
                  18. lower-/.f32N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                  19. associate-*r*N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
                  20. sub-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                  21. +-commutativeN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                5. Applied rewrites85.7%

                  \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                6. Taylor expanded in u2 around 0

                  \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                7. Step-by-step derivation
                  1. lower-*.f32N/A

                    \[\leadsto \color{blue}{u2 \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot {u2}^{2}\right) + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                  2. associate-*r*N/A

                    \[\leadsto u2 \cdot \left(\color{blue}{\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \cdot {u2}^{2}} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
                  3. *-commutativeN/A

                    \[\leadsto u2 \cdot \left(\color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}\right)} \cdot {u2}^{2} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
                  4. associate-*l*N/A

                    \[\leadsto u2 \cdot \left(\color{blue}{\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2}\right)} + \frac{314159265359}{50000000000} \cdot \sqrt{\frac{u1}{1 - u1}}\right) \]
                  5. *-commutativeN/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2}\right) + \color{blue}{\sqrt{\frac{u1}{1 - u1}} \cdot \frac{314159265359}{50000000000}}\right) \]
                  6. distribute-lft-outN/A

                    \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
                  7. lower-*.f32N/A

                    \[\leadsto u2 \cdot \color{blue}{\left(\sqrt{\frac{u1}{1 - u1}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right)} \]
                  8. lower-sqrt.f32N/A

                    \[\leadsto u2 \cdot \left(\color{blue}{\sqrt{\frac{u1}{1 - u1}}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right) \]
                  9. sub-negN/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right) \]
                  10. mul-1-negN/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{1 + \color{blue}{-1 \cdot u1}}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right) \]
                  11. lower-/.f32N/A

                    \[\leadsto u2 \cdot \left(\sqrt{\color{blue}{\frac{u1}{1 + -1 \cdot u1}}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right) \]
                  12. mul-1-negN/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{1 + \color{blue}{\left(\mathsf{neg}\left(u1\right)\right)}}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right) \]
                  13. sub-negN/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{\color{blue}{1 - u1}}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right) \]
                  14. lower--.f32N/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{\color{blue}{1 - u1}}} \cdot \left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000} \cdot {u2}^{2} + \frac{314159265359}{50000000000}\right)\right) \]
                  15. lower-fma.f32N/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \color{blue}{\mathsf{fma}\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}, {u2}^{2}, \frac{314159265359}{50000000000}\right)}\right) \]
                  16. unpow2N/A

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(\frac{-31006276680305942139213528068663279}{750000000000000000000000000000000}, \color{blue}{u2 \cdot u2}, \frac{314159265359}{50000000000}\right)\right) \]
                  17. lower-*.f3291.3

                    \[\leadsto u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(-41.341702240407926, \color{blue}{u2 \cdot u2}, 6.28318530718\right)\right) \]
                8. Applied rewrites91.3%

                  \[\leadsto \color{blue}{u2 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot \mathsf{fma}\left(-41.341702240407926, u2 \cdot u2, 6.28318530718\right)\right)} \]
                9. Add Preprocessing

                Alternative 14: 81.7% accurate, 3.9× speedup?

                \[\begin{array}{l} \\ 6.28318530718 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right) \end{array} \]
                (FPCore (cosTheta_i u1 u2)
                 :precision binary32
                 (* 6.28318530718 (* (sqrt (/ u1 (- 1.0 u1))) u2)))
                float code(float cosTheta_i, float u1, float u2) {
                	return 6.28318530718f * (sqrtf((u1 / (1.0f - u1))) * u2);
                }
                
                real(4) function code(costheta_i, u1, u2)
                    real(4), intent (in) :: costheta_i
                    real(4), intent (in) :: u1
                    real(4), intent (in) :: u2
                    code = 6.28318530718e0 * (sqrt((u1 / (1.0e0 - u1))) * u2)
                end function
                
                function code(cosTheta_i, u1, u2)
                	return Float32(Float32(6.28318530718) * Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * u2))
                end
                
                function tmp = code(cosTheta_i, u1, u2)
                	tmp = single(6.28318530718) * (sqrt((u1 / (single(1.0) - u1))) * u2);
                end
                
                \begin{array}{l}
                
                \\
                6.28318530718 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)
                \end{array}
                
                Derivation
                1. Initial program 98.5%

                  \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                2. Add Preprocessing
                3. Taylor expanded in u2 around 0

                  \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
                4. Step-by-step derivation
                  1. *-commutativeN/A

                    \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                  2. associate-*r*N/A

                    \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                  3. lower-*.f32N/A

                    \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                  4. lower-*.f32N/A

                    \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
                  5. *-rgt-identityN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
                  6. sub-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
                  7. rgt-mult-inverseN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                  8. mul-1-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                  9. distribute-neg-frac2N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                  10. mul-1-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
                  11. *-rgt-identityN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
                  12. distribute-lft-inN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                  13. +-commutativeN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                  14. sub-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
                  15. associate-*r*N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                  16. lower-sqrt.f32N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                  17. *-rgt-identityN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
                  18. lower-/.f32N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                  19. associate-*r*N/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
                  20. sub-negN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                  21. +-commutativeN/A

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                5. Applied rewrites85.7%

                  \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                6. Step-by-step derivation
                  1. Applied rewrites85.8%

                    \[\leadsto \left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right) \cdot \color{blue}{6.28318530718} \]
                  2. Final simplification85.8%

                    \[\leadsto 6.28318530718 \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right) \]
                  3. Add Preprocessing

                  Alternative 15: 81.7% accurate, 3.9× speedup?

                  \[\begin{array}{l} \\ \sqrt{\frac{u1}{1 - u1}} \cdot \left(6.28318530718 \cdot u2\right) \end{array} \]
                  (FPCore (cosTheta_i u1 u2)
                   :precision binary32
                   (* (sqrt (/ u1 (- 1.0 u1))) (* 6.28318530718 u2)))
                  float code(float cosTheta_i, float u1, float u2) {
                  	return sqrtf((u1 / (1.0f - u1))) * (6.28318530718f * u2);
                  }
                  
                  real(4) function code(costheta_i, u1, u2)
                      real(4), intent (in) :: costheta_i
                      real(4), intent (in) :: u1
                      real(4), intent (in) :: u2
                      code = sqrt((u1 / (1.0e0 - u1))) * (6.28318530718e0 * u2)
                  end function
                  
                  function code(cosTheta_i, u1, u2)
                  	return Float32(sqrt(Float32(u1 / Float32(Float32(1.0) - u1))) * Float32(Float32(6.28318530718) * u2))
                  end
                  
                  function tmp = code(cosTheta_i, u1, u2)
                  	tmp = sqrt((u1 / (single(1.0) - u1))) * (single(6.28318530718) * u2);
                  end
                  
                  \begin{array}{l}
                  
                  \\
                  \sqrt{\frac{u1}{1 - u1}} \cdot \left(6.28318530718 \cdot u2\right)
                  \end{array}
                  
                  Derivation
                  1. Initial program 98.5%

                    \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                  2. Add Preprocessing
                  3. Taylor expanded in u2 around 0

                    \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
                  4. Step-by-step derivation
                    1. *-commutativeN/A

                      \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                    2. associate-*r*N/A

                      \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                    3. lower-*.f32N/A

                      \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                    4. lower-*.f32N/A

                      \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
                    5. *-rgt-identityN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
                    6. sub-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
                    7. rgt-mult-inverseN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                    8. mul-1-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                    9. distribute-neg-frac2N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                    10. mul-1-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
                    11. *-rgt-identityN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
                    12. distribute-lft-inN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                    13. +-commutativeN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                    14. sub-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
                    15. associate-*r*N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                    16. lower-sqrt.f32N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                    17. *-rgt-identityN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
                    18. lower-/.f32N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                    19. associate-*r*N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
                    20. sub-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                    21. +-commutativeN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                  5. Applied rewrites85.7%

                    \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                  6. Final simplification85.7%

                    \[\leadsto \sqrt{\frac{u1}{1 - u1}} \cdot \left(6.28318530718 \cdot u2\right) \]
                  7. Add Preprocessing

                  Alternative 16: 76.0% accurate, 4.1× speedup?

                  \[\begin{array}{l} \\ \left(6.28318530718 \cdot u2\right) \cdot \sqrt{\mathsf{fma}\left(u1, \mathsf{fma}\left(u1, u1, u1\right), u1\right)} \end{array} \]
                  (FPCore (cosTheta_i u1 u2)
                   :precision binary32
                   (* (* 6.28318530718 u2) (sqrt (fma u1 (fma u1 u1 u1) u1))))
                  float code(float cosTheta_i, float u1, float u2) {
                  	return (6.28318530718f * u2) * sqrtf(fmaf(u1, fmaf(u1, u1, u1), u1));
                  }
                  
                  function code(cosTheta_i, u1, u2)
                  	return Float32(Float32(Float32(6.28318530718) * u2) * sqrt(fma(u1, fma(u1, u1, u1), u1)))
                  end
                  
                  \begin{array}{l}
                  
                  \\
                  \left(6.28318530718 \cdot u2\right) \cdot \sqrt{\mathsf{fma}\left(u1, \mathsf{fma}\left(u1, u1, u1\right), u1\right)}
                  \end{array}
                  
                  Derivation
                  1. Initial program 98.5%

                    \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                  2. Add Preprocessing
                  3. Taylor expanded in u2 around 0

                    \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
                  4. Step-by-step derivation
                    1. *-commutativeN/A

                      \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                    2. associate-*r*N/A

                      \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                    3. lower-*.f32N/A

                      \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                    4. lower-*.f32N/A

                      \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
                    5. *-rgt-identityN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
                    6. sub-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
                    7. rgt-mult-inverseN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                    8. mul-1-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                    9. distribute-neg-frac2N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                    10. mul-1-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
                    11. *-rgt-identityN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
                    12. distribute-lft-inN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                    13. +-commutativeN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                    14. sub-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
                    15. associate-*r*N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                    16. lower-sqrt.f32N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                    17. *-rgt-identityN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
                    18. lower-/.f32N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                    19. associate-*r*N/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
                    20. sub-negN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                    21. +-commutativeN/A

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                  5. Applied rewrites85.7%

                    \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                  6. Taylor expanded in u1 around 0

                    \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{u1 \cdot \left(1 + u1 \cdot \left(1 + u1\right)\right)} \]
                  7. Step-by-step derivation
                    1. Applied rewrites79.1%

                      \[\leadsto \left(6.28318530718 \cdot u2\right) \cdot \sqrt{\mathsf{fma}\left(u1, \mathsf{fma}\left(u1, u1, u1\right), u1\right)} \]
                    2. Add Preprocessing

                    Alternative 17: 73.3% accurate, 5.0× speedup?

                    \[\begin{array}{l} \\ \left(6.28318530718 \cdot u2\right) \cdot \sqrt{\mathsf{fma}\left(u1, u1, u1\right)} \end{array} \]
                    (FPCore (cosTheta_i u1 u2)
                     :precision binary32
                     (* (* 6.28318530718 u2) (sqrt (fma u1 u1 u1))))
                    float code(float cosTheta_i, float u1, float u2) {
                    	return (6.28318530718f * u2) * sqrtf(fmaf(u1, u1, u1));
                    }
                    
                    function code(cosTheta_i, u1, u2)
                    	return Float32(Float32(Float32(6.28318530718) * u2) * sqrt(fma(u1, u1, u1)))
                    end
                    
                    \begin{array}{l}
                    
                    \\
                    \left(6.28318530718 \cdot u2\right) \cdot \sqrt{\mathsf{fma}\left(u1, u1, u1\right)}
                    \end{array}
                    
                    Derivation
                    1. Initial program 98.5%

                      \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                    2. Add Preprocessing
                    3. Taylor expanded in u2 around 0

                      \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
                    4. Step-by-step derivation
                      1. *-commutativeN/A

                        \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                      2. associate-*r*N/A

                        \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                      3. lower-*.f32N/A

                        \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                      4. lower-*.f32N/A

                        \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
                      5. *-rgt-identityN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
                      6. sub-negN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
                      7. rgt-mult-inverseN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                      8. mul-1-negN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                      9. distribute-neg-frac2N/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                      10. mul-1-negN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
                      11. *-rgt-identityN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
                      12. distribute-lft-inN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                      13. +-commutativeN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                      14. sub-negN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
                      15. associate-*r*N/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                      16. lower-sqrt.f32N/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                      17. *-rgt-identityN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
                      18. lower-/.f32N/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                      19. associate-*r*N/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
                      20. sub-negN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                      21. +-commutativeN/A

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                    5. Applied rewrites85.7%

                      \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                    6. Taylor expanded in u1 around 0

                      \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{u1 \cdot \left(1 + u1\right)} \]
                    7. Step-by-step derivation
                      1. Applied rewrites76.5%

                        \[\leadsto \left(6.28318530718 \cdot u2\right) \cdot \sqrt{\mathsf{fma}\left(u1, u1, u1\right)} \]
                      2. Add Preprocessing

                      Alternative 18: 65.0% accurate, 6.4× speedup?

                      \[\begin{array}{l} \\ 6.28318530718 \cdot \left(u2 \cdot \sqrt{u1}\right) \end{array} \]
                      (FPCore (cosTheta_i u1 u2)
                       :precision binary32
                       (* 6.28318530718 (* u2 (sqrt u1))))
                      float code(float cosTheta_i, float u1, float u2) {
                      	return 6.28318530718f * (u2 * sqrtf(u1));
                      }
                      
                      real(4) function code(costheta_i, u1, u2)
                          real(4), intent (in) :: costheta_i
                          real(4), intent (in) :: u1
                          real(4), intent (in) :: u2
                          code = 6.28318530718e0 * (u2 * sqrt(u1))
                      end function
                      
                      function code(cosTheta_i, u1, u2)
                      	return Float32(Float32(6.28318530718) * Float32(u2 * sqrt(u1)))
                      end
                      
                      function tmp = code(cosTheta_i, u1, u2)
                      	tmp = single(6.28318530718) * (u2 * sqrt(u1));
                      end
                      
                      \begin{array}{l}
                      
                      \\
                      6.28318530718 \cdot \left(u2 \cdot \sqrt{u1}\right)
                      \end{array}
                      
                      Derivation
                      1. Initial program 98.5%

                        \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                      2. Add Preprocessing
                      3. Taylor expanded in u2 around 0

                        \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
                      4. Step-by-step derivation
                        1. *-commutativeN/A

                          \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                        2. associate-*r*N/A

                          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                        3. lower-*.f32N/A

                          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                        4. lower-*.f32N/A

                          \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
                        5. *-rgt-identityN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
                        6. sub-negN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
                        7. rgt-mult-inverseN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                        8. mul-1-negN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                        9. distribute-neg-frac2N/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                        10. mul-1-negN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
                        11. *-rgt-identityN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
                        12. distribute-lft-inN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                        13. +-commutativeN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                        14. sub-negN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
                        15. associate-*r*N/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                        16. lower-sqrt.f32N/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                        17. *-rgt-identityN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
                        18. lower-/.f32N/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                        19. associate-*r*N/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
                        20. sub-negN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                        21. +-commutativeN/A

                          \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                      5. Applied rewrites85.7%

                        \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                      6. Taylor expanded in u1 around 0

                        \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{u1} \]
                      7. Step-by-step derivation
                        1. Applied rewrites67.8%

                          \[\leadsto \left(6.28318530718 \cdot u2\right) \cdot \sqrt{u1} \]
                        2. Step-by-step derivation
                          1. Applied rewrites67.8%

                            \[\leadsto \left(u2 \cdot \sqrt{u1}\right) \cdot \color{blue}{6.28318530718} \]
                          2. Final simplification67.8%

                            \[\leadsto 6.28318530718 \cdot \left(u2 \cdot \sqrt{u1}\right) \]
                          3. Add Preprocessing

                          Alternative 19: 65.0% accurate, 6.4× speedup?

                          \[\begin{array}{l} \\ \left(6.28318530718 \cdot u2\right) \cdot \sqrt{u1} \end{array} \]
                          (FPCore (cosTheta_i u1 u2)
                           :precision binary32
                           (* (* 6.28318530718 u2) (sqrt u1)))
                          float code(float cosTheta_i, float u1, float u2) {
                          	return (6.28318530718f * u2) * sqrtf(u1);
                          }
                          
                          real(4) function code(costheta_i, u1, u2)
                              real(4), intent (in) :: costheta_i
                              real(4), intent (in) :: u1
                              real(4), intent (in) :: u2
                              code = (6.28318530718e0 * u2) * sqrt(u1)
                          end function
                          
                          function code(cosTheta_i, u1, u2)
                          	return Float32(Float32(Float32(6.28318530718) * u2) * sqrt(u1))
                          end
                          
                          function tmp = code(cosTheta_i, u1, u2)
                          	tmp = (single(6.28318530718) * u2) * sqrt(u1);
                          end
                          
                          \begin{array}{l}
                          
                          \\
                          \left(6.28318530718 \cdot u2\right) \cdot \sqrt{u1}
                          \end{array}
                          
                          Derivation
                          1. Initial program 98.5%

                            \[\sqrt{\frac{u1}{1 - u1}} \cdot \sin \left(6.28318530718 \cdot u2\right) \]
                          2. Add Preprocessing
                          3. Taylor expanded in u2 around 0

                            \[\leadsto \color{blue}{\frac{314159265359}{50000000000} \cdot \left(\sqrt{\frac{u1}{1 - u1}} \cdot u2\right)} \]
                          4. Step-by-step derivation
                            1. *-commutativeN/A

                              \[\leadsto \frac{314159265359}{50000000000} \cdot \color{blue}{\left(u2 \cdot \sqrt{\frac{u1}{1 - u1}}\right)} \]
                            2. associate-*r*N/A

                              \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                            3. lower-*.f32N/A

                              \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                            4. lower-*.f32N/A

                              \[\leadsto \color{blue}{\left(\frac{314159265359}{50000000000} \cdot u2\right)} \cdot \sqrt{\frac{u1}{1 - u1}} \]
                            5. *-rgt-identityN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1 \cdot 1}}{1 - u1}} \]
                            6. sub-negN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{1 + \left(\mathsf{neg}\left(u1\right)\right)}}} \]
                            7. rgt-mult-inverseN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \frac{1}{-1 \cdot u1}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                            8. mul-1-negN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \frac{1}{\color{blue}{\mathsf{neg}\left(u1\right)}} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                            9. distribute-neg-frac2N/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)} + \left(\mathsf{neg}\left(u1\right)\right)}} \]
                            10. mul-1-negN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{-1 \cdot u1}}} \]
                            11. *-rgt-identityN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + \color{blue}{\left(-1 \cdot u1\right) \cdot 1}}} \]
                            12. distribute-lft-inN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                            13. +-commutativeN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                            14. sub-negN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 - \frac{1}{u1}\right)}}} \]
                            15. associate-*r*N/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1 \cdot 1}{\color{blue}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                            16. lower-sqrt.f32N/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \color{blue}{\sqrt{\frac{u1 \cdot 1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                            17. *-rgt-identityN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{\color{blue}{u1}}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}} \]
                            18. lower-/.f32N/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\color{blue}{\frac{u1}{-1 \cdot \left(u1 \cdot \left(1 - \frac{1}{u1}\right)\right)}}} \]
                            19. associate-*r*N/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\color{blue}{\left(-1 \cdot u1\right) \cdot \left(1 - \frac{1}{u1}\right)}}} \]
                            20. sub-negN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(1 + \left(\mathsf{neg}\left(\frac{1}{u1}\right)\right)\right)}}} \]
                            21. +-commutativeN/A

                              \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{\frac{u1}{\left(-1 \cdot u1\right) \cdot \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{u1}\right)\right) + 1\right)}}} \]
                          5. Applied rewrites85.7%

                            \[\leadsto \color{blue}{\left(6.28318530718 \cdot u2\right) \cdot \sqrt{\frac{u1}{1 - u1}}} \]
                          6. Taylor expanded in u1 around 0

                            \[\leadsto \left(\frac{314159265359}{50000000000} \cdot u2\right) \cdot \sqrt{u1} \]
                          7. Step-by-step derivation
                            1. Applied rewrites67.8%

                              \[\leadsto \left(6.28318530718 \cdot u2\right) \cdot \sqrt{u1} \]
                            2. Add Preprocessing

                            Reproduce

                            ?
                            herbie shell --seed 2024222 
                            (FPCore (cosTheta_i u1 u2)
                              :name "Trowbridge-Reitz Sample, near normal, slope_y"
                              :precision binary32
                              :pre (and (and (and (> cosTheta_i 0.9999) (<= cosTheta_i 1.0)) (and (<= 2.328306437e-10 u1) (<= u1 1.0))) (and (<= 2.328306437e-10 u2) (<= u2 1.0)))
                              (* (sqrt (/ u1 (- 1.0 u1))) (sin (* 6.28318530718 u2))))