x + \left(y \cdot z\right) \cdot \left(\tanh \left(\frac{t}{y}\right) - \tanh \left(\frac{x}{y}\right)\right)\left(\sqrt[3]{z} \cdot \sqrt[3]{z}\right) \cdot \left(\left(\left(\tanh \left(\frac{t}{y}\right) - \tanh \left(\frac{x}{y}\right)\right) \cdot y\right) \cdot \sqrt[3]{z}\right) + xdouble f(double x, double y, double z, double t) {
double r269978 = x;
double r269979 = y;
double r269980 = z;
double r269981 = r269979 * r269980;
double r269982 = t;
double r269983 = r269982 / r269979;
double r269984 = tanh(r269983);
double r269985 = r269978 / r269979;
double r269986 = tanh(r269985);
double r269987 = r269984 - r269986;
double r269988 = r269981 * r269987;
double r269989 = r269978 + r269988;
return r269989;
}
double f(double x, double y, double z, double t) {
double r269990 = z;
double r269991 = cbrt(r269990);
double r269992 = r269991 * r269991;
double r269993 = t;
double r269994 = y;
double r269995 = r269993 / r269994;
double r269996 = tanh(r269995);
double r269997 = x;
double r269998 = r269997 / r269994;
double r269999 = tanh(r269998);
double r270000 = r269996 - r269999;
double r270001 = r270000 * r269994;
double r270002 = r270001 * r269991;
double r270003 = r269992 * r270002;
double r270004 = r270003 + r269997;
return r270004;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 4.8 |
|---|---|
| Target | 2.1 |
| Herbie | 2.0 |
Initial program 4.8
Simplified4.8
rmApplied fma-udef4.8
Simplified1.6
rmApplied add-cube-cbrt2.0
Applied associate-*l*2.0
Final simplification2.0
herbie shell --seed 2019194 +o rules:numerics
(FPCore (x y z t)
:name "SynthBasics:moogVCF from YampaSynth-0.2"
:herbie-target
(+ x (* y (* z (- (tanh (/ t y)) (tanh (/ x y))))))
(+ x (* (* y z) (- (tanh (/ t y)) (tanh (/ x y))))))