| Alternative 1 | |
|---|---|
| Accuracy | 98.4% |
| Cost | 13056 |
\[\sqrt{-\mathsf{log1p}\left(-u1\right)} \cdot \sin \left(2 \cdot \left(\pi \cdot u2\right)\right)
\]

(FPCore (cosTheta_i u1 u2) :precision binary32 (* (sqrt (- (log (- 1.0 u1)))) (sin (* (* 2.0 PI) u2))))
(FPCore (cosTheta_i u1 u2) :precision binary32 (* (sqrt (- (log1p (- u1)))) (sin (* 2.0 (* PI u2)))))
float code(float cosTheta_i, float u1, float u2) {
return sqrtf(-logf((1.0f - u1))) * sinf(((2.0f * ((float) M_PI)) * u2));
}
float code(float cosTheta_i, float u1, float u2) {
return sqrtf(-log1pf(-u1)) * sinf((2.0f * (((float) M_PI) * u2)));
}
function code(cosTheta_i, u1, u2) return Float32(sqrt(Float32(-log(Float32(Float32(1.0) - u1)))) * sin(Float32(Float32(Float32(2.0) * Float32(pi)) * u2))) end
function code(cosTheta_i, u1, u2) return Float32(sqrt(Float32(-log1p(Float32(-u1)))) * sin(Float32(Float32(2.0) * Float32(Float32(pi) * u2)))) end
\sqrt{-\log \left(1 - u1\right)} \cdot \sin \left(\left(2 \cdot \pi\right) \cdot u2\right)
\begin{array}{l}
\\
\sqrt{-\mathsf{log1p}\left(-u1\right)} \cdot \sin \left(2 \cdot \left(\pi \cdot u2\right)\right)
\end{array}
Herbie found 9 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Results
Initial program 62.3%
Simplified98.4%
[Start]62.3% | \[ \sqrt{-\log \left(1 - u1\right)} \cdot \sin \left(\left(2 \cdot \pi\right) \cdot u2\right)
\] |
|---|---|
sub-neg [=>]62.3% | \[ \sqrt{-\log \color{blue}{\left(1 + \left(-u1\right)\right)}} \cdot \sin \left(\left(2 \cdot \pi\right) \cdot u2\right)
\] |
log1p-def [=>]98.4% | \[ \sqrt{-\color{blue}{\mathsf{log1p}\left(-u1\right)}} \cdot \sin \left(\left(2 \cdot \pi\right) \cdot u2\right)
\] |
associate-*l* [=>]98.4% | \[ \sqrt{-\mathsf{log1p}\left(-u1\right)} \cdot \sin \color{blue}{\left(2 \cdot \left(\pi \cdot u2\right)\right)}
\] |
Final simplification98.4%
| Alternative 1 | |
|---|---|
| Accuracy | 98.4% |
| Cost | 13056 |
| Alternative 2 | |
|---|---|
| Accuracy | 95.7% |
| Cost | 13476 |
| Alternative 3 | |
|---|---|
| Accuracy | 94.4% |
| Cost | 13348 |
| Alternative 4 | |
|---|---|
| Accuracy | 90.8% |
| Cost | 13220 |
| Alternative 5 | |
|---|---|
| Accuracy | 86.3% |
| Cost | 9860 |
| Alternative 6 | |
|---|---|
| Accuracy | 77.3% |
| Cost | 6912 |
| Alternative 7 | |
|---|---|
| Accuracy | 66.6% |
| Cost | 6592 |
| Alternative 8 | |
|---|---|
| Accuracy | 66.6% |
| Cost | 6592 |
| Alternative 9 | |
|---|---|
| Accuracy | 7.1% |
| Cost | 32 |
herbie shell --seed 2023171
(FPCore (cosTheta_i u1 u2)
:name "Beckmann 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 (- (log (- 1.0 u1)))) (sin (* (* 2.0 PI) u2))))