financemaximairr

How to calculate internal rate of return (IRR) and yield to maturity (YTM) in Maxima


How do I calculate internal rate of return (IRR) and yield to maturity (YTM) in Maxima? I am trying to calculate the YTM of a bond of $1000 face value that pays $50 in coupons every year. The bond is currently selling for $900, and matures in 3 years. Using the formula for the YTM:

900 = [50 / (1 + r)] + [50 / (1 + r)^2] + [50 / (1 + r)^3] + [1000 / (1 + r)^3]

How do I use Maxima to solve for r, the YTM?


Solution

  • The equation is a cubic polynomial, so it has an exact solution, which Maxima can find, but for problems like it's probably more useful to just look for a numerical approximation.

    First note that Maxima only recognizes parentheses for grouping; square brackets are only for lists.

    (%i1) eqn: 900 = (50 / (1 + r)) + (50 / (1 + r)^2) + (50 / (1 + r)^3) + (1000 / (1 + r)^3);
                                  50        50        1050
    (%o1)                  900 = ----- + -------- + --------
                                 r + 1          2          3
                                         (r + 1)    (r + 1)
    

    Call find_root to find an approximate root.

    (%i2) find_root (eqn, r, 0, 1);
    (%o2)                         0.08946802632716268
    

    By the way, there is an add-on package named finance which might be relevant. Try: ?? finance to get some info.