100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}\begin{array}{l}
\mathbf{if}\;n \le -5.45421367555386284 \cdot 10^{117}:\\
\;\;\;\;100 \cdot \left(\frac{\left(1 \cdot i + \left(0.5 \cdot {i}^{2} + \log 1 \cdot n\right)\right) - 0.5 \cdot \left({i}^{2} \cdot \log 1\right)}{i} \cdot n\right)\\
\mathbf{elif}\;n \le -8.94632381714276356 \cdot 10^{69}:\\
\;\;\;\;\frac{100}{i} \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{1}{n}}\\
\mathbf{elif}\;n \le -50247890715477128:\\
\;\;\;\;100 \cdot \left(\frac{\left(1 \cdot i + \left(0.5 \cdot {i}^{2} + \log 1 \cdot n\right)\right) - 0.5 \cdot \left({i}^{2} \cdot \log 1\right)}{i} \cdot n\right)\\
\mathbf{elif}\;n \le -5.80539647643117144 \cdot 10^{-192}:\\
\;\;\;\;100 \cdot \frac{\frac{{\left(1 + \frac{i}{n}\right)}^{\left(2 \cdot n\right)} - 1 \cdot 1}{{\left(1 + \frac{i}{n}\right)}^{n} + 1}}{\frac{i}{n}}\\
\mathbf{elif}\;n \le 2.12821304689236942 \cdot 10^{-175}:\\
\;\;\;\;100 \cdot \frac{\left(1 \cdot i + \left(\log 1 \cdot n + 1\right)\right) - 1}{\frac{i}{n}}\\
\mathbf{else}:\\
\;\;\;\;100 \cdot \left(\frac{\left(1 \cdot i + \left(0.5 \cdot {i}^{2} + \log 1 \cdot n\right)\right) - 0.5 \cdot \left({i}^{2} \cdot \log 1\right)}{i} \cdot n\right)\\
\end{array}double f(double i, double n) {
double r127114 = 100.0;
double r127115 = 1.0;
double r127116 = i;
double r127117 = n;
double r127118 = r127116 / r127117;
double r127119 = r127115 + r127118;
double r127120 = pow(r127119, r127117);
double r127121 = r127120 - r127115;
double r127122 = r127121 / r127118;
double r127123 = r127114 * r127122;
return r127123;
}
double f(double i, double n) {
double r127124 = n;
double r127125 = -5.454213675553863e+117;
bool r127126 = r127124 <= r127125;
double r127127 = 100.0;
double r127128 = 1.0;
double r127129 = i;
double r127130 = r127128 * r127129;
double r127131 = 0.5;
double r127132 = 2.0;
double r127133 = pow(r127129, r127132);
double r127134 = r127131 * r127133;
double r127135 = log(r127128);
double r127136 = r127135 * r127124;
double r127137 = r127134 + r127136;
double r127138 = r127130 + r127137;
double r127139 = r127133 * r127135;
double r127140 = r127131 * r127139;
double r127141 = r127138 - r127140;
double r127142 = r127141 / r127129;
double r127143 = r127142 * r127124;
double r127144 = r127127 * r127143;
double r127145 = -8.946323817142764e+69;
bool r127146 = r127124 <= r127145;
double r127147 = r127127 / r127129;
double r127148 = r127129 / r127124;
double r127149 = r127128 + r127148;
double r127150 = pow(r127149, r127124);
double r127151 = r127150 - r127128;
double r127152 = 1.0;
double r127153 = r127152 / r127124;
double r127154 = r127151 / r127153;
double r127155 = r127147 * r127154;
double r127156 = -5.024789071547713e+16;
bool r127157 = r127124 <= r127156;
double r127158 = -5.8053964764311714e-192;
bool r127159 = r127124 <= r127158;
double r127160 = r127132 * r127124;
double r127161 = pow(r127149, r127160);
double r127162 = r127128 * r127128;
double r127163 = r127161 - r127162;
double r127164 = r127150 + r127128;
double r127165 = r127163 / r127164;
double r127166 = r127165 / r127148;
double r127167 = r127127 * r127166;
double r127168 = 2.1282130468923694e-175;
bool r127169 = r127124 <= r127168;
double r127170 = r127136 + r127152;
double r127171 = r127130 + r127170;
double r127172 = r127171 - r127128;
double r127173 = r127172 / r127148;
double r127174 = r127127 * r127173;
double r127175 = r127169 ? r127174 : r127144;
double r127176 = r127159 ? r127167 : r127175;
double r127177 = r127157 ? r127144 : r127176;
double r127178 = r127146 ? r127155 : r127177;
double r127179 = r127126 ? r127144 : r127178;
return r127179;
}




Bits error versus i




Bits error versus n
Results
| Original | 42.9 |
|---|---|
| Target | 43.3 |
| Herbie | 23.4 |
if n < -5.454213675553863e+117 or -8.946323817142764e+69 < n < -5.024789071547713e+16 or 2.1282130468923694e-175 < n Initial program 53.5
Taylor expanded around 0 40.2
rmApplied associate-/r/23.2
if -5.454213675553863e+117 < n < -8.946323817142764e+69Initial program 38.0
rmApplied div-inv38.0
Applied *-un-lft-identity38.0
Applied times-frac37.8
Applied associate-*r*37.8
Simplified37.8
if -5.024789071547713e+16 < n < -5.8053964764311714e-192Initial program 20.8
rmApplied flip--20.8
Simplified20.7
if -5.8053964764311714e-192 < n < 2.1282130468923694e-175Initial program 26.9
Taylor expanded around 0 22.3
Final simplification23.4
herbie shell --seed 2019199
(FPCore (i n)
:name "Compound Interest"
:herbie-target
(* 100.0 (/ (- (exp (* n (if (== (+ 1.0 (/ i n)) 1.0) (/ i n) (/ (* (/ i n) (log (+ 1.0 (/ i n)))) (- (+ (/ i n) 1.0) 1.0))))) 1.0) (/ i n)))
(* 100.0 (/ (- (pow (+ 1.0 (/ i n)) n) 1.0) (/ i n))))