UNPKG

ubique

Version:

A mathematical and quantitative library for Javascript and Node.js

55 lines (52 loc) 1.68 kB
/** * Performance metrics */ module.exports = function($u) { /** * @method annreturn * @summary Annualized Return * @description Average annualized returns over a period, convenient when comparing returns. * It can be an Arithmetic or Geometric (default) average return: if compounded with itself the * geometric average will be equal to the cumulative return * * @param {array|matrix} x asset/portfolio returns * @param {number} t frequencey of data. 1: yearly, 4: quarterly, 12: monthly, 52: weekly, 252: daily * @param {string} mode 'geometric' or 'simple' (def: 'geometric') * @param {number} dim dimension 0: row, 1: column (def: 0) * @return {number|array|matrix} * * @example * var x = [0.003,0.026,0.015,-0.009,0.014,0.024,0.015,0.066,-0.014,0.039]; * var y = [-0.005,0.081,0.04,-0.037,-0.061,0.058,-0.049,-0.021,0.062,0.058]; * var cat = ubique.cat; * * ubique.annreturn(x,12); * // 0.233815 * * ubique.annreturn(cat(0,x,y),12); * // [ [ 0.233815 ], [ 0.14509 ] ] */ $u.annreturn = function(x,t,mode,dim) { if (arguments.length === 0) { throw new Error('not enough input arguments'); } t = t == null ? 252 : t; mode = mode == null ? 'geometric' : mode; dim = dim == null ? 0 : dim; var _annreturn = function(arr,t,mode) { var n = arr.length; if (mode === 'geometric') { return $u.power($u.prod($u.plus(1,arr)),(t/n)) - 1; } else if (mode === 'simple') { return $u.mean(arr) * t; } else { throw new Error('unknown mode'); } } if ($u.isnumber(x)) { return NaN; } return $u.vectorfun(dim,x,_annreturn,t,mode); } }