Skip to content

A feature-rich library for performing simple to advanced instalment credit financial calculations.

License

Notifications You must be signed in to change notification settings

andrewmurphy353/curo

Repository files navigation

Curo

Build Status codecov GitHub

October 2024: I no longer have access to the g-mail account associated with the Curo pub.dev package repository, and cannot retrieve it from the faceless monolith Google has become, so please be aware there are to be no further updates to the Curo pub.dev package. Download, clone or pull the repo and reference it directly from within your project pubspec.yaml file to continue to benefit from interim updates. Thanks.


A feature-rich library for performing simple to advanced instalment credit financial calculations.

Note: This library is a port of the curo-calculator TypeScript repository and includes a small number of refactorings and some code reorganisation.

Overview

This financial calculator library is for solving unknown cash flow values and unknown interest rates implicit in fixed-term instalment credit products, for example leasing, loans and hire purchase contracts [^1], and incorporates features that are likely to be found only in commercially developed software. It has been designed for use in applications with requirements that extend beyond what can be achieved using standard financial algebra.

For an introduction to many of the features be sure to check out the GitHub repository examples and the accompanying cash flow diagrams which pictorially represent the cash inflows and outflows [^2] of each example.

Using the calculator is straightforward as the following examples demonstrate.

Example using solveValue(...) to find an unknown cash flow value:

// Step 1: Instantiate the calculator
final calculator = Calculator();

// Step 2: Define the advance, payment, and/or charge cash flow series
calculator.add(
  SeriesAdvance(
    label: 'Loan',
    value: 10000.0,
  ),
);
calculator.add(
  SeriesPayment(
    numberOf: 6,
    label: 'Instalment',
    value: null, // leave undefined or null when it is the unknown to solve
    mode: Mode.arrear,
  ),
);

// 3. Calculate the unknown cash flow value (result = 1707.00 to 2 decimal places)
final valueResult = await calculator.solveValue(
  dayCount: const US30360(),
  interestRate: 0.0825,
);

In the 2nd step we set the payment series value to null. We could also simply omit the value attribute. This is how the unknown cash flow values that are to be computed are identified, and is the protocol to be followed when defining the unknown cash flow values you wish to calculate.

In the 3rd and final step we invoke the solveValue(...) method, passing in a day count convention instance and the annual interest rate to use in the calculation, expressed as a decimal.

The various day count conventions available in this library are described in more detail below.

Example using solveRate(...) to find the implicit interest rate in a cash flow series:

// Step 1: Instantiate the calculator
final calculator = Calculator();

// Step 2: Define the advance, payment, and/or charge cash flow series
calculator.add(
  SeriesAdvance(
    label: 'Loan',
    value: 10000.0,
  ),
);
calculator.add(
  SeriesPayment(
    numberOf: 6,
    label: 'Instalment',
    value: 1707.00,
    mode: Mode.arrear,
  ),
);

// 3. Calculate the IRR or Internal Rate of Return (result = 8.250040%)
final irrRate = await calculator.solveRate(
    dayCount: const US30360(),
);
  // ...or the APR for regulated EU Consumer Credit agreements (result = 8.569257%)
final aprRate = await calculator.solveRate(
    dayCount: const EU200848EC(),
);

Day Count Conventions

A day count convention is a key component of every financial calculation as it determines the method to be used in measuring the time interval between each cash flow in a series.

There are dozens of convention's defined but the more important ones supported by this calculator are as follows:

Convention Description
Actual ISDA Convention accounts for actual days between cash flow dates based on the portion in a leap year and the portion in a non-leap year as documented here.
Actual/360 Convention accounts for actual days between cash flow dates and considers a year to have 360 days as documented here
Actual/365 Convention accounts for actual days between cash flow dates and considers a year to have 365 days as documented here.
EU 30/360 Convention accounts for days between cash flow dates based on a 30 day month, 360 day year as documented here.
EU 2008/48/EC Convention based on the time periods between cash flow dates and the initial drawdown date, expressed in days and/or whole weeks, months or years. This convention is used specifically in APR (Annual Percentage Rate) consumer credit calculations within the European Union and is compliant with the EU2008/49/EC directive available here.
US 30/360 Convention accounts for days between cash flow dates based on a 30 day month, 360 day year as documented here. This is the default convention used by the Hewlett Packard HP12C and similar financial calculators, so choose this convention when unsure as it is the defacto convention used in the majority of fixed-term credit calculations.
US 30U/360 Convention accounts for days between cash flow dates as per US 30/360, except for the month of February where the 28th, and 29th in a leap-year, are treated as 30 days. Note, the use of U in the naming signifies Uniform, so can be read as 30 uniform days in a month.

All conventions, except EU 2008/48/EC, will by default compute time intervals between cash flows with reference to the dates of adjacent cash flows.

To override this so that time intervals are computed with reference to the first drawdown date, as in XIRR (eXtended Internal Rate of Return) based calculations, simply pass useXirrMethod: true to the respective day count convention constructor (refer to the code documentation for details).

When the Actual/365 convention is used in this manner, e.g. Act365(useXirrMethod: true) the XIRR result will equal that produced by the equivalent Microsoft Excel XIRR function.

Installation

With Dart

$ dart pub add curo

With Flutter

$ flutter pub add curo

License

Copyright © 2022, Andrew Murphy. Released under the MIT License.

Footnotes


[^1] Whilst the library uses asset finance nomenclature, it is equally capable of solving problems in investment-type scenarios.

[^2] A cash flow diagram is simply a pictorial representation of the timing and direction of financial transactions.

The diagram begins with a horizontal line, called a time line. The line represents the duration or contract term, and is commonly divided into compounding periods. The exchange of money in the financial arrangement is depicted by vertical arrows. Money a lender receives is represented by an arrow pointing up from the point in the time line when the transaction occurs; money paid out by the lender is represented by an arrow pointing down. The collection of all up and down arrow cash flows are what is referred to throughout the calculator documentation as a cash flow series.

To illustrate using the example above, that is a 10,000.00 loan repayable by 6 monthly instalments in arrears (due at the end of each compounding period), the cash flow diagram would resemble something like this:

image

About

A feature-rich library for performing simple to advanced instalment credit financial calculations.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages