Average Error: 17.8 → 1.7
Time: 5.9s
Precision: binary64
\[\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)} \]
\[\begin{array}{l} t_1 := \sqrt[3]{-1 - \frac{u}{t1}}\\ \frac{{\left(\sqrt[3]{v}\right)}^{2}}{t_1 \cdot t_1} \cdot \frac{\frac{\sqrt[3]{v}}{u + t1}}{t_1} \end{array} \]
\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}
\begin{array}{l}
t_1 := \sqrt[3]{-1 - \frac{u}{t1}}\\
\frac{{\left(\sqrt[3]{v}\right)}^{2}}{t_1 \cdot t_1} \cdot \frac{\frac{\sqrt[3]{v}}{u + t1}}{t_1}
\end{array}
(FPCore (u v t1) :precision binary64 (/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))
(FPCore (u v t1)
 :precision binary64
 (let* ((t_1 (cbrt (- -1.0 (/ u t1)))))
   (* (/ (pow (cbrt v) 2.0) (* t_1 t_1)) (/ (/ (cbrt v) (+ u t1)) t_1))))
double code(double u, double v, double t1) {
	return (-t1 * v) / ((t1 + u) * (t1 + u));
}
double code(double u, double v, double t1) {
	double t_1 = cbrt(-1.0 - (u / t1));
	return (pow(cbrt(v), 2.0) / (t_1 * t_1)) * ((cbrt(v) / (u + t1)) / t_1);
}

Error

Bits error versus u

Bits error versus v

Bits error versus t1

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 17.8

    \[\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)} \]
  2. Simplified1.6

    \[\leadsto \color{blue}{\frac{\frac{v}{t1 + u}}{-1 - \frac{u}{t1}}} \]
  3. Applied add-cube-cbrt_binary641.8

    \[\leadsto \frac{\frac{v}{t1 + u}}{\color{blue}{\left(\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}\right) \cdot \sqrt[3]{-1 - \frac{u}{t1}}}} \]
  4. Applied *-un-lft-identity_binary641.8

    \[\leadsto \frac{\frac{v}{\color{blue}{1 \cdot \left(t1 + u\right)}}}{\left(\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}\right) \cdot \sqrt[3]{-1 - \frac{u}{t1}}} \]
  5. Applied add-cube-cbrt_binary642.4

    \[\leadsto \frac{\frac{\color{blue}{\left(\sqrt[3]{v} \cdot \sqrt[3]{v}\right) \cdot \sqrt[3]{v}}}{1 \cdot \left(t1 + u\right)}}{\left(\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}\right) \cdot \sqrt[3]{-1 - \frac{u}{t1}}} \]
  6. Applied times-frac_binary642.4

    \[\leadsto \frac{\color{blue}{\frac{\sqrt[3]{v} \cdot \sqrt[3]{v}}{1} \cdot \frac{\sqrt[3]{v}}{t1 + u}}}{\left(\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}\right) \cdot \sqrt[3]{-1 - \frac{u}{t1}}} \]
  7. Applied times-frac_binary641.7

    \[\leadsto \color{blue}{\frac{\frac{\sqrt[3]{v} \cdot \sqrt[3]{v}}{1}}{\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}} \cdot \frac{\frac{\sqrt[3]{v}}{t1 + u}}{\sqrt[3]{-1 - \frac{u}{t1}}}} \]
  8. Simplified1.7

    \[\leadsto \color{blue}{\frac{\sqrt[3]{v} \cdot \sqrt[3]{v}}{\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}}} \cdot \frac{\frac{\sqrt[3]{v}}{t1 + u}}{\sqrt[3]{-1 - \frac{u}{t1}}} \]
  9. Applied pow2_binary641.7

    \[\leadsto \frac{\color{blue}{{\left(\sqrt[3]{v}\right)}^{2}}}{\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}} \cdot \frac{\frac{\sqrt[3]{v}}{t1 + u}}{\sqrt[3]{-1 - \frac{u}{t1}}} \]
  10. Final simplification1.7

    \[\leadsto \frac{{\left(\sqrt[3]{v}\right)}^{2}}{\sqrt[3]{-1 - \frac{u}{t1}} \cdot \sqrt[3]{-1 - \frac{u}{t1}}} \cdot \frac{\frac{\sqrt[3]{v}}{u + t1}}{\sqrt[3]{-1 - \frac{u}{t1}}} \]

Reproduce

herbie shell --seed 2022067 
(FPCore (u v t1)
  :name "Rosa's DopplerBench"
  :precision binary64
  (/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))