ubique
Version:
A mathematical and quantitative library for Javascript and Node.js
65 lines (63 loc) • 1.51 kB
JavaScript
/**
* Risk metrics
*/
module.exports = function($u) {
/**
* @method cdrawdown
* @summary Continuous Drawdown
* @description Continuous Drawdown
*
* @param {array|matrix} x asset/portfolio returns
* @param {number} dim dimension 0: row, 1: column (def: 0)
* @return {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];
*
* ubique.cdrawdown(x);
* // [ 0.009, 0.014 ]
*
* ubique.cdrawdown(ubique.cat(0,x,y));
* // [ [ 0.009, 0.014 ], [ 0.005, 0.095743, 0.068971 ] ]
*/
$u.cdrawdown = function(x,dim) {
if (arguments.length === 0) {
throw new Error('not enough input arguments');
}
dim = dim == null ? 0 : dim;
var _cdown = function(a) {
var cdd = [], tmp = 0, t = 0;
for (var i = 0; i < a.length; i++) {
if (i === 0 && a[i] < 0) {
tmp = 1 + a[i];
}
if (i > 0) {
if (a[i] < 0) {
if (tmp === 0) {
tmp = 1 + a[i];
} else {
tmp = tmp * (1 + a[i]);
}
}
if (a[i] >=0) {
if (tmp !== 0) {
cdd[t] = 1 - tmp;
t++;
tmp = 0;
}
}
}
}
if (tmp !== 0) {
cdd.push(1 - tmp);
tmp = 0;
}
return cdd;
}
if ($u.isnumber(x)) {
return 0;
}
return $u.vectorfun(dim,x,_cdown);
}
}