有没有一个函数可以将使用对数回报构建的协方差矩阵转换为基于简单算术回报的协方差矩阵?
动机:我们想使用均值-方差效用函数,其中期望收益和方差是用算术术语指定的。然而,由于对数收益的可加性属性,估计收益和协方差通常是使用对数收益执行的,并且我们假设资产价格遵循对数正态随机过程。
Meucci描述了为Appendix page 5上的对数正态分布的通用/任意分布生成基于算术回报的协方差矩阵的过程。
发布于 2011-10-12 08:40:53
以下是我对公式的翻译:
linreturn <- function(mu,Sigma) {
m <- exp(mu+diag(Sigma)/2)-1
x1 <- outer(mu,mu,"+")
x2 <- outer(diag(Sigma),diag(Sigma),"+")/2
S <- exp(x1+x2)*(exp(Sigma)-1)
list(mean=m,vcov=S)
}编辑:修复基于评论的-1问题。
试着举个例子:
m1 <- c(1,2)
S1 <- matrix(c(1,0.2,0.2,1),nrow=2)生成多变量对数正态回报:
set.seed(1001)
r1 <- exp(MASS::mvrnorm(200000,mu=m1,Sigma=S1))-1
colMeans(r1)
## [1] 3.485976 11.214211
var(r1)
## [,1] [,2]
## [1,] 34.4021 12.4062
## [2,] 12.4062 263.7382与公式的预期结果进行比较:
linreturn(m1,S1)
## $mean
## [1] 3.481689 11.182494
## $vcov
## [,1] [,2]
## [1,] 34.51261 12.08818
## [2,] 12.08818 255.01563https://stackoverflow.com/questions/7663690
复制相似问题