DownsideDeviation {PerformanceAnalytics} | R Documentation |
Downside deviation, semideviation, and semivariance are measures of downside risk.
DownsideDeviation(R, MAR = 0, method=c("subset","full")) SemiDeviation(R) SemiVariance(R)
R |
an xts, vector, matrix, data frame, timeSeries or zoo object of asset returns |
MAR |
Minimum Acceptable Return, in the same periodicity as your returns |
method |
one of "full" or "subset", indicating whether to use the length of the full series or the length of the subset of the series below the MAR as the denominator, defaults to "subset" |
Downside deviation, similar to semi deviation, eliminates positive returns when calculating risk. Instead of using the mean return or zero, it uses the Minimum Acceptable Return as proposed by Sharpe (which may be the mean historical return or zero).
To calculate it, we take the subset of returns that are less than the target (or Minimum Acceptable Returns (MAR)) returns and take the differences of those to the target. We sum the squares and divide by the total number of returns to get a below-target semi-variance.
DownsideDeviation(R , MAR)= delta_{MAR} = sqrt{ frac{sum^{n}_{t=1}(R_{t} - MAR)^{2}}{n} }
where n is either the number of observations of the entire series or the number of observations in the subset of the series falling below the MAR.
SemiDeviation or SemiVariance is a popular alternative downside risk measure that may be used in place of standard deviation or variance. SemiDeviation and SemiVariance are implemented as a wrapper of DownsideDeviation with MAR=mean(R).
In many functions like Markowitz optimization, semideviation may be substituted directly, and the covariance matrix may be constructed from semideviation or the vector of returns below the mean rather than from variance or the full vector of returns.
In semideviation, by convention, the value of n is set to the full number of observations. In semivariance the the value of n is set to the subset of returns below the mean. It should be noted that while this is the correct mathematical definition of semivariance, this result doesn't make any sense if you are also going to be using the time series of returns below the mean or below a MAR to construct a semi-covariance matrix for portfolio optimization.
Sortino recommends calculating downside deviation utilizing a continuous fitted distribution rather than the discrete distribution of observations. This would have significant utility, especially in cases of a small number of observations. He recommends using a lognormal distribution, or a fitted distribution based on a relevant style index, to construct the returns below the MAR to increase the confidence in the final result. Hopefully, in the future, we'll add a fitted option to this function, and would be happy to accept a contribution of this nature.
float value of the calculation
Peter Carl, Brian G. Peterson
Sortino, F. and Price, L. Performance Measurement in a Downside Risk Framework. Journal of Investing. Fall 1994, 59-65.
Plantinga, A., van der Meer, R. and Sortino, F. The Impact of Downside Risk on Risk-Adjusted Performance of Mutual Funds in the Euronext Markets. July 19, 2001. Available at SSRN: http://ssrn.com/abstract=277352
http://www.sortino.com/htm/performance.htm see especially end note 10
http://en.wikipedia.org/wiki/Semivariance
data(managers) sd(managers[,1:6], na.rm=TRUE) DownsideDeviation(managers[,1:6]) # MAR 0% DownsideDeviation(managers[,1:6], MAR = .04/12) #MAR 4% SemiDeviation(managers[,1,drop=FALSE]) SemiDeviation(managers[,1:6]) SemiVariance (managers[,1,drop=FALSE]) SemiVariance (managers[,1:6]) #calculated using method="subset"