100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}\begin{array}{l}
\mathbf{if}\;i \le -0.0281548125542239701 \lor \neg \left(i \le 9.343203234098088 \cdot 10^{-18}\right):\\
\;\;\;\;\frac{100 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}{\frac{i}{n}}\\
\mathbf{else}:\\
\;\;\;\;100 \cdot \frac{\left(\mathsf{fma}\left(i, 0.5, \mathsf{fma}\left(\frac{1}{2}, \log 1 \cdot n, 1\right) - \sqrt{1}\right) \cdot n\right) \cdot \left({\left(1 + \frac{i}{n}\right)}^{\left(\frac{n}{2}\right)} + \sqrt{1}\right)}{i}\\
\end{array}double code(double i, double n) {
return (100.0 * ((pow((1.0 + (i / n)), n) - 1.0) / (i / n)));
}
double code(double i, double n) {
double temp;
if (((i <= -0.02815481255422397) || !(i <= 9.343203234098088e-18))) {
temp = ((100.0 * (pow((1.0 + (i / n)), n) - 1.0)) / (i / n));
} else {
temp = (100.0 * (((fma(i, 0.5, (fma(0.5, (log(1.0) * n), 1.0) - sqrt(1.0))) * n) * (pow((1.0 + (i / n)), (n / 2.0)) + sqrt(1.0))) / i));
}
return temp;
}




Bits error versus i




Bits error versus n
Results
| Original | 43.0 |
|---|---|
| Target | 42.4 |
| Herbie | 21.4 |
if i < -0.02815481255422397 or 9.343203234098088e-18 < i Initial program 31.1
rmApplied associate-*r/31.1
if -0.02815481255422397 < i < 9.343203234098088e-18Initial program 50.4
rmApplied div-inv50.4
Applied add-sqr-sqrt50.4
Applied sqr-pow50.4
Applied difference-of-squares50.4
Applied times-frac50.1
Applied associate-*r*50.1
Taylor expanded around 0 50.0
Simplified16.0
rmApplied associate-*l*15.6
Simplified15.6
rmApplied associate-*r/15.4
Final simplification21.4
herbie shell --seed 2020057 +o rules:numerics
(FPCore (i n)
:name "Compound Interest"
:precision binary64
:herbie-target
(* 100 (/ (- (exp (* n (if (== (+ 1 (/ i n)) 1) (/ i n) (/ (* (/ i n) (log (+ 1 (/ i n)))) (- (+ (/ i n) 1) 1))))) 1) (/ i n)))
(* 100 (/ (- (pow (+ 1 (/ i n)) n) 1) (/ i n))))