Analisi di portafoglio intermedia in R
Ross Bennett
Instructor
Ottimizzazione a singolo periodo con optimize.portfolio()
Ottimizzazione con ribilanciamento periodico (backtesting) con optimize.portfolio.rebalancing()
optimize.portfolio(R, portfolio = NULL,
optimize_method = c("DEoptim", "random", "ROI", ...),
search_size = 20000, trace = TRUE,
momentFUN = "set.portfolio.moments",
...)
optimize.portfolio.rebalancing(R, portfolio = NULL,
optimize_method = c("DEoptim", "random", "ROI", ...),
search_size = 20000, trace = TRUE,
rebalance_on = "quarters",
training_period,
rolling_window,
momentFUN = "set.portfolio.moments",
...)
Sono supportati i seguenti metodi di ottimizzazione:
Solver globali:
DEoptim: ottimizzazione per evoluzione differenziale
random: portafogli casuali
GenSA: ricottura simulata generalizzata
pso: ottimizzazione a sciame di particelle
Solver LP e QP:
data(edhec) ret <- edhec[,1:6]# Portfolio p <- portfolio.spec(assets = colnames(ret)) p <- add.constraint(portfolio = p, type = "full_investment") p <- add.constraint(portfolio = p, type = "long_only") p <- add.objective(portfolio = p, type = "risk", name = "StdDev")# Ottimizzazioni opt_single <- optimize.portfolio(R = ret, portfolio = p, optimize_method = "ROI")opt_rebal <- optimize.portfolio.rebalancing(R = ret, portfolio = p, optimize_method = "ROI", rebalance_on = "years", training_period = 60, rolling_window = 60)
Analisi di portafoglio intermedia in R