gpt4 book ai didi

r - 使用 Optimize R 优化向量

转载 作者:行者123 更新时间:2023-12-03 16:08:22 25 4
gpt4 key购买 nike

我想使用 R 的优化函数构建我自己的优化。

目标函数是多样化比率,最大化它(希望它是正确的):

div.ratio<-function(weight,vol,cov.mat){
dr<-(t(weight) %*% vol) / (sqrt(t(weight) %*% cov.mat %*% (weight)))
return(-dr)
}

一个例子:
rm(list=ls())
require(RCurl)
sit = getURLContent('https://github.com/systematicinvestor/SIT/raw/master/sit.gz', binary=TRUE, followlocation = TRUE, ssl.verifypeer = FALSE)
con = gzcon(rawConnection(sit, 'rb'))
source(con)
close(con)
load.packages('quantmod')


data <- new.env()

tickers<-spl("VTI,VGK,VWO,GLD,VNQ,TIP,TLT,AGG,LQD")
getSymbols(tickers, src = 'yahoo', from = '1980-01-01', env = data, auto.assign = T)
for(i in ls(data)) data[[i]] = adjustOHLC(data[[i]], use.Adjusted=T)

bt.prep(data, align='remove.na', dates='1990::2013')

prices<-data$prices[,-10] #don't include cash
ret<-na.omit(prices/mlag(prices) - 1)
vol<-apply(ret,2,sd)
cov.mat<-cov(ret)

optimize(div.ratio,
weight,
vol=vol,
cov.mat=cov.mat,
lower=0, #min constraints
upper=1, #max
tol = 0.00001)$minimum

我收到以下错误消息,这似乎是优化包没有进行矢量优化。我做错了什么?
Error in t(weight) %*% cov.mat : non-conformable arguments

最佳答案

首先,weight如果这就是您要优化的内容,则没有理由参与优化调用。
然后,optimize用于在您尝试求解权重向量时进行一维优化。您可以使用 optim函数代替。

关于您在评论中的第二个问题,您如何设置该函数的总和为 1 的约束?你可以使用这里提出的技巧:How to set parameters' sum to 1 in constrained optimization ,即重写您的目标函数如下:

div.ratio <- function(weight, vol, cov.mat){
weight <- weight / sum(weight)
dr <- (t(weight) %*% vol) / (sqrt(t(weight) %*% cov.mat %*% (weight)))
return(-dr)
}

这给出:
out <- optim(par     = rep(1 / length(vol), length(vol)),  # initial guess
fn = div.ratio,
vol = vol,
cov.mat = cov.mat,
method = "L-BFGS-B",
lower = 0,
upper = 1)

您的最佳体重:
opt.weights <- out$par / sum(out$par)
# [1] 0.154271776 0.131322307 0.073752360 0.030885856 0.370706931 0.049627627
# [7] 0.055785740 0.126062746 0.007584657

pie(opt.weights, names(vol))

enter image description here

关于r - 使用 Optimize R 优化向量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16410400/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com