GitXplorerGitXplorer
i

pg_financial

public
23 stars
3 forks
0 issues

Commits

List of commits on branch master.
Verified
034a9765b4811fdadf66a481e0e12f0b5c6c8e2d

CI: Fix package installation (#6)

iintgr committed 2 years ago
Verified
3416bb35346501e384f638d8576897d94182578b

Readme: Update supported versions (#5)

iintgr committed 2 years ago
Verified
5ab1fd1098e17ad87fc3529ca7e84d99fa9171cd

Update copyright notice dates, tweak comment (#4)

iintgr committed 2 years ago
Verified
eca49c11d0cb7bce119a6ccaa340f9a836ecc5eb

CI: Test with PostgreSQL versions 10 to 15 (#3)

iintgr committed 2 years ago
Verified
361870ca2656b07134311ede75f50951c868a1c4

Migrate from Travis to GitHub Actions CI (#2)

iintgr committed 2 years ago
Unverified
b058ab3ce524cc8ad931c913780ec6adc2fd6e18

Add Travis CI testing with PostgreSQL 11

iintgr committed 6 years ago

README

The README file for this repository.

PostgreSQL Financial Extension

PGXN version Tests status

This is a PostgreSQL extension for financial calculations.

Functions provided:

  • xirr(amounts, dates [, guess]) - Irregular Internal Rate of Return. Aggregate function, much like XIRR in spreadsheet programs (Excel, LibreOffice, etc).

Installation

pg_financial is tested with PostgreSQL versions from 10 to 15.

To build and install this extension, simply run:

% make
% sudo make install

Then, to activate this extension in your database, run the SQL:

CREATE EXTENSION financial;

If you run into problems with building, see PostgreSQL wiki for troubleshooting

xirr aggregate function

The basic form of the XIRR function is: xirr(amounts, dates [, guess])

Since XIRR is fundamentally an imprecise function, amounts is of type float8 (double precision). dates is timestamp with time zone.

For example, if table transaction has columns amount and time, do this:

db=# SELECT xirr(amount, time ORDER BY time) FROM transaction;
        xirr        
--------------------
 0.0176201237088334

The guess argument (also float8) is an optional initial guess. When omitted, the function will use annualized return as the guess, which is usually reliable. Excel and LibreOffice, however, use a guess of 0.1 by default:

SELECT xirr(amount, time, 0.1 ORDER BY time) FROM transaction;

Like any aggregate function, you can use xirr with GROUP BY or as a window function, e.g:

SELECT portfolio, xirr(amount, time ORDER BY time)
    FROM transaction GROUP BY portfolio;

SELECT xirr(amount, time) OVER (ORDER BY time)
    FROM transaction;

There are situations where XIRR (Newton's method) fails to arrive at a result. In these cases, the function returns NULL. Sometimes providing a better guess helps, but some inputs are simply indeterminate.

Because XIRR needs to do multiple passes over input data, all inputs to the aggregate function are held in memory (16 bytes per row). Beware that this can cause the server to run out of memory with extremely large data sets.

Changelog

Unreleased (2023):

  • Migrate from Travis to GitHub Actions CI
  • Run CI tests with PostgreSQL versions 10 ... 15 (no code changes were necessary)

1.0.1 (2015-06-18)

  • Fix read of uninitialized data
  • Implemented continuous integration via Travis-CI
  • Minor tweaks to documentation and code

1.0.0 (2014-09-18)

  • First stable release, fixes two Makefile issues

0.0.2 (2013-06-05)

  • First release, contains xirr aggregate function

Copyright and License

Copyright (c) 2013-2023 Marti Raudsepp marti@juffo.org

pg_financial and all related files are available under The PostgreSQL License. See LICENSE file for details.