blob: 7de97c9f466845b2491fbc3dab11867ccd8b2520 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.fineract.portfolio.loanaccount.loanschedule.domain;
public class FinanicalFunctions {
/**
* PMT calculates a fixed monthly payment to be paid by borrower every
* 'period' to ensure loan is paid off in full (with interest).
*
* This monthly payment c depends upon the monthly interest rate r
* (expressed as a fraction, not a percentage, i.e., divide the quoted
* yearly percentage rate by 100 and by 12 to obtain the monthly interest
* rate), the number of monthly payments N called the loan's term, and the
* amount borrowed P known as the loan's principal; c is given by the
* formula:
*
* c = (r / (1 - (1 + r)^-N))P
*
* @param interestRateFraction
* @param numberOfPayments
* @param principal
* @param futureValue
* @param type
*/
public static double pmt(final double interestRateFraction, final double numberOfPayments, final double principal,
final double futureValue, final boolean type) {
double payment = 0;
if (interestRateFraction == 0) {
payment = -1 * (futureValue + principal) / numberOfPayments;
} else {
final double r1 = interestRateFraction + 1;
payment = (futureValue + principal * Math.pow(r1, numberOfPayments)) * interestRateFraction
/ ((type ? r1 : 1) * (1 - Math.pow(r1, numberOfPayments)));
}
return payment;
}
public static int nop(final double interestRateFraction, final double emiAmount, final double principal, final double futureValue,
final boolean type) {
double numberOfPayments = 0;
if (interestRateFraction == 0) {
numberOfPayments = ((Double) (-1 * (futureValue + principal) / emiAmount)).intValue();
} else {
final double r1 = interestRateFraction + 1;
numberOfPayments = (futureValue + principal * Math.pow(r1, emiAmount)) * interestRateFraction
/ ((type ? r1 : 1) * (1 - Math.pow(r1, emiAmount)));
}
return Double.valueOf(numberOfPayments).intValue();
}
}