/* * Copyright (c) 2012, 2013, Credit Suisse (Anatole Tresch), Werner Keil. Licensed under the Apache * License, Version 2.0 (the "License"); you may not use this file except in compliance with the * License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the License for the specific language governing permissions and limitations under * the License. */ package org.javamoney.calc.common; import org.javamoney.calc.CalculationContext; import java.math.BigDecimal; import java.util.Objects; import javax.money.MonetaryAmount; import javax.money.MonetaryOperator; /** * Future Value (FV) is a formula used in finance to calculate the value of a cash flow at a later * date than originally received. This idea that an amount today is worth a different amount than at * a future time is based on the time value of money. The time value of money is the concept that an * amount received earlier is worth more than if the same amount is received at a later time. For * example, if one was offered $100 today or $100 five years from now, the idea is that it is better * to receive this amount today. The opportunity cost for not having this amount in an investment or * savings is quantified using the future value formula. If one wanted to determine what amount they * would like to receive one year from now in lieu of receiving $100 today, the individual would use * the future value formula. See example at the bottom of the page. The future value formula also * looks at the effect of compounding. Earning .5% per month is not the same as earning 6% per year, * assuming that the monthly earnings are reinvested. As the months continue along, the next month's * earnings will make additional monies on the earnings from the prior months. For example, if one * earns interest of $40 in month one, the next month will earn interest on the original balance * plus the $40 from the previous month. This is known as compound interest. * * @author Anatole Tresch * @author Werner Keil * @see http://www.financeformulas.net/Future_Value.html * <p> * <img src= "http://www.financeformulas.net/Formula%20Images/Future%20Value%201.gif" /> * <p> * or... * <p> * <pre> * FV(<amount>) = <amount> * ((1 + <rate>).pow(<periods>)) * </pre> */ public final class FutureValue implements MonetaryOperator { /** * the target rate, not null. */ private final Rate rate; /** * the periods, >= 0. */ private final int periods; /** * Private constructor. * * @param rate the target rate, not null. * @param periods the periods, >= 0. */ private FutureValue(Rate rate, int periods) { this.rate = Objects.requireNonNull(rate); if (periods < 0) { throw new IllegalArgumentException("Periods < 0"); } this.periods = periods; } public int getPeriods() { return periods; } public Rate getRate() { return rate; } /** * Access a MonetaryOperator for calculation. * * @param rate the target rate, not null. * @param periods the periods, >= 0. * @return the operator, never null. */ public static FutureValue of(Rate rate, int periods) { return new FutureValue(rate, periods); } /** * Performs the calculation. * * @param amount the base amount, not null. * @param rate the target rate, not null. * @param periods the periods, >= 0. * @return the resulting amount, never null. */ public static MonetaryAmount calculate(MonetaryAmount amount, Rate rate, int periods) { BigDecimal f = (CalculationContext.one().add(rate.get())).pow(periods); return amount.multiply(f); } @Override public MonetaryAmount apply(MonetaryAmount amount) { return calculate(amount, rate, periods); } @Override public String toString() { return "FutureValue{" + "rate=" + rate + ", periods=" + periods + '}'; } }