Average Error: 42.9 → 23.4
Time: 36.2s
Precision: 64
\[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}\]
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;
}

Error

Bits error versus i

Bits error versus n

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original42.9
Target43.3
Herbie23.4
\[100 \cdot \frac{e^{n \cdot \begin{array}{l} \mathbf{if}\;1 + \frac{i}{n} = 1:\\ \;\;\;\;\frac{i}{n}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{i}{n} \cdot \log \left(1 + \frac{i}{n}\right)}{\left(\frac{i}{n} + 1\right) - 1}\\ \end{array}} - 1}{\frac{i}{n}}\]

Derivation

  1. Split input into 4 regimes
  2. if n < -5.454213675553863e+117 or -8.946323817142764e+69 < n < -5.024789071547713e+16 or 2.1282130468923694e-175 < n

    1. Initial program 53.5

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}\]
    2. Taylor expanded around 0 40.2

      \[\leadsto 100 \cdot \frac{\color{blue}{\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)}}{\frac{i}{n}}\]
    3. Using strategy rm
    4. Applied associate-/r/23.2

      \[\leadsto 100 \cdot \color{blue}{\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)}\]

    if -5.454213675553863e+117 < n < -8.946323817142764e+69

    1. Initial program 38.0

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}\]
    2. Using strategy rm
    3. Applied div-inv38.0

      \[\leadsto 100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\color{blue}{i \cdot \frac{1}{n}}}\]
    4. Applied *-un-lft-identity38.0

      \[\leadsto 100 \cdot \frac{\color{blue}{1 \cdot \left({\left(1 + \frac{i}{n}\right)}^{n} - 1\right)}}{i \cdot \frac{1}{n}}\]
    5. Applied times-frac37.8

      \[\leadsto 100 \cdot \color{blue}{\left(\frac{1}{i} \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{1}{n}}\right)}\]
    6. Applied associate-*r*37.8

      \[\leadsto \color{blue}{\left(100 \cdot \frac{1}{i}\right) \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{1}{n}}}\]
    7. Simplified37.8

      \[\leadsto \color{blue}{\frac{100}{i}} \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{1}{n}}\]

    if -5.024789071547713e+16 < n < -5.8053964764311714e-192

    1. Initial program 20.8

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}\]
    2. Using strategy rm
    3. Applied flip--20.8

      \[\leadsto 100 \cdot \frac{\color{blue}{\frac{{\left(1 + \frac{i}{n}\right)}^{n} \cdot {\left(1 + \frac{i}{n}\right)}^{n} - 1 \cdot 1}{{\left(1 + \frac{i}{n}\right)}^{n} + 1}}}{\frac{i}{n}}\]
    4. Simplified20.7

      \[\leadsto 100 \cdot \frac{\frac{\color{blue}{{\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}}\]

    if -5.8053964764311714e-192 < n < 2.1282130468923694e-175

    1. Initial program 26.9

      \[100 \cdot \frac{{\left(1 + \frac{i}{n}\right)}^{n} - 1}{\frac{i}{n}}\]
    2. Taylor expanded around 0 22.3

      \[\leadsto 100 \cdot \frac{\color{blue}{\left(1 \cdot i + \left(\log 1 \cdot n + 1\right)\right)} - 1}{\frac{i}{n}}\]
  3. Recombined 4 regimes into one program.
  4. Final simplification23.4

    \[\leadsto \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}\]

Reproduce

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))))