Average Error: 5.9 → 1.0
Time: 1.9m
Precision: 64
Internal Precision: 384
\[x - \frac{y \cdot \left(z - t\right)}{a}\]
↓
\[\begin{array}{l}
\mathbf{if}\;a \le -5.273243369695188 \cdot 10^{-34}:\\
\;\;\;\;x - \frac{y}{\frac{a}{z - t}}\\
\mathbf{if}\;a \le 3.833302372270341 \cdot 10^{-33}:\\
\;\;\;\;x - \frac{y \cdot \left(z - t\right)}{a}\\
\mathbf{else}:\\
\;\;\;\;x - \left(\frac{y}{a} \cdot z + \frac{y}{a} \cdot \left(-t\right)\right)\\
\end{array}\]
Target
| Original | 5.9 |
|---|
| Target | 0.7 |
|---|
| Herbie | 1.0 |
|---|
\[\begin{array}{l}
\mathbf{if}\;y \lt -1.0761266216389975 \cdot 10^{-10}:\\
\;\;\;\;x - \frac{1}{\frac{\frac{a}{z - t}}{y}}\\
\mathbf{if}\;y \lt 2.894426862792089 \cdot 10^{-49}:\\
\;\;\;\;x - \frac{y \cdot \left(z - t\right)}{a}\\
\mathbf{else}:\\
\;\;\;\;x - \frac{y}{\frac{a}{z - t}}\\
\end{array}\]
Derivation
- Split input into 3 regimes
if a < -5.273243369695188e-34
Initial program 8.5
\[x - \frac{y \cdot \left(z - t\right)}{a}\]
- Using strategy
rm Applied associate-/l*0.6
\[\leadsto x - \color{blue}{\frac{y}{\frac{a}{z - t}}}\]
if -5.273243369695188e-34 < a < 3.833302372270341e-33
Initial program 0.8
\[x - \frac{y \cdot \left(z - t\right)}{a}\]
if 3.833302372270341e-33 < a
Initial program 7.9
\[x - \frac{y \cdot \left(z - t\right)}{a}\]
Taylor expanded around 0 8.0
\[\leadsto x - \color{blue}{\left(\frac{z \cdot y}{a} - \frac{y \cdot t}{a}\right)}\]
Applied simplify1.6
\[\leadsto \color{blue}{x - \frac{y}{a} \cdot \left(z - t\right)}\]
- Using strategy
rm Applied sub-neg1.6
\[\leadsto x - \frac{y}{a} \cdot \color{blue}{\left(z + \left(-t\right)\right)}\]
Applied distribute-lft-in1.6
\[\leadsto x - \color{blue}{\left(\frac{y}{a} \cdot z + \frac{y}{a} \cdot \left(-t\right)\right)}\]
- Recombined 3 regimes into one program.
- Removed slow
pow expressions.
Runtime
herbie shell --seed '#(1567391828 2030694642 2833800258 828025724 3004380912 3532991858)' +o setup:early-exit +o reduce:binary-search
(FPCore (x y z t a)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, F"
:herbie-target
(if (< y -1.0761266216389975e-10) (- x (/ 1 (/ (/ a (- z t)) y))) (if (< y 2.894426862792089e-49) (- x (/ (* y (- z t)) a)) (- x (/ y (/ a (- z t))))))
(- x (/ (* y (- z t)) a)))