The tvm-calculator package is a library of time value of money calculations that you would find on a financial calculator. This includes functions to find present value, future value, payment amount, number of payments, and interest rate given a set of input parameters.
Using npm:
$ npm i tvm-calculator
Note: add --save if you are using npm < 5.0.0
or
- Download or fork the repository from GitHub.
- Extract the file tvm-calculator from the project and include it in your application on the client side.
var tvmCalculator = require('tvm-calculator');
// Specify params as object
const tvmParams = { pv: -100000, fv: 0, nper: 30, rate: 4 };
// Calculate payment amount of a loan
const periodicPayment = tvmCalculator.calcPMT(tvmParams);
// Log calculated result (3508.33)
console.log('Payment amount (PMT): ', periodicPayment);
Parameters are listed below. When solving for a value such as PMT, that parameter can be omitted. Parameters specified as "Optional" will default to the values described below. All parameters should be passed in as a single object.
rate, // Number: Interest Rate as whole number nper, // Number: Number of Periods in term pmt, // Number: Payment Amount pv, // Number: Present Value (should be entered as negative) fv, // Number: Future Value isBeginning, // Boolean: Is payment made at the BEGINNING of period? (Optional: defaults to false) isDiscrete, // Boolean: Is compounding DISCRETE? (Optional: defaults to true) cf, // Number: Compounding Frequency (Optional: defaults to 12 for monthly) pf, // Number: Payment Frequency (Optional: defaults to 12 for monthly)
Example method calls listed below. Further details to come.
Calculate number of periods. Required params: rate, pmt, pv, fv.
const numberPeriods = tvmCalculator.calcNPer({ pv: -100000, fv: 0, pmt: 3508, rate: 4 });
console.log('Number of Periods (N)', numberPeriods); // 30.00
Calculate interest rate. Required params: nper, pmt, pv, fv.
const interestRate = tvmCalculator.calcInterestRate({ pv: -100000, fv: 0, nper: 30, pmt: 3508 });
console.log('Interest Rate (I/Y)', interestRate); // 3.993
Calculate present value. Required params: nper, pmt, fv, rate.
const presentValue = tvmCalculator.calcPV({ nper: 30, fv: 0, pmt: 3508, rate: 4 });
console.log('Present Value (PV)', presentValue); // -99990.73
Calculate payment amount. Required params: nper, pv, fv, rate.
const paymentAmount = tvmCalculator.calcPMT({ pv: -100000, fv: 0, nper: 30, rate: 4 });
console.log('Payment Amount (PMT)', paymentAmount); // 3508.33
Calculate future value. Required params: nper, pv, pmt, rate.
const futureValue = tvmCalculator.calcFV({ pv: -100000, pmt: 3508, nper: 30, rate: 4 });
console.log('Future Value (FV)', futureValue); // 10.24
Full Params Example:
const tvmParams = {
pv: -100000,
fv: 0,
nper: 30,
rate: 4,
isBeginning: false,
isDiscrete: true,
cf: 1,
pf: 1,
};
const periodicPayment = tvmCalculator.calcPMT(tvmParams);
console.log("Payment Amount (PMT): ", periodicPayment); // 5783.01
- Add unit testing
- Improve documentation