我正在運行具有各種初始值的模型,並且我試圖按行向循環中的數據框添加值(3個估計值)。我給循環內的估計器賦值,但我不記得它們產生一個數據幀。通過循環中的數據幀行追加值
我的代碼:f
是估算的模型。三個參數:模型中的alpha,rho和lambda。我想輸出這3個值。發生
library("maxLik")
f <- function(param) {
alpha <- param[1]
rho <- param[2]
lambda <- param[3]
u <- 0.5 * (dataset$v_50_1)^alpha - 0.5 * lambda * (dataset$v_50_2)^alpha
p <- 1/(1 + exp(-rho * u))
logl <- sum(dataset$gamble * log(p) + (1 - dataset$gamble) * log(1 - p))
}
df <- data.frame(alpha = numeric(), rho = numeric(), lambda = numeric())
for (j in 1:20) {
tryCatch({
ml <- maxLik(f, start = c(alpha = runif(1, 0, 2), rho = runif(1, 0, 4), lambda = runif(1,
0, 10)), method = "NM")
alpha[j] <- ml$estimate[1]
rho[j] <- ml$estimate[2]
lambda[j] <- ml$estimate[3]
}, error = function(e) {NA})
}
output <- data.frame(alpha, rho, lambda)
錯誤:
Error in data.frame(alpha, rho, lambda) : object 'alpha' not found
預計輸出
alpha rho lambda
0.4 1 2 # estimators append by row.
0.6 1.1 3 # each row has estimators that are estimated
0.7 1.5 4 # by one set of initial values, there are 20
# rows, as the estimation loops for 20 times.
請註明maxLik屬於庫 –
1.做到這一點全部在列表中,然後do.call(rbind,mylist),2.我寧願用RUN-INDEX創建一個新列,而不是自己的行。在錯誤函數中,我會記錄失敗的運行。無論如何,你可以擺脫它。 –
也請提一下f是什麼? –