我想找到函数的最大值:
Fd <- 224 * d1 + 84 * d2 + d1 * d2 - 2 * d1^2 - d2^2
我可以使用以下代码进行“详尽”搜索:
my.data <- expand.grid(x1 = seq(0, 200, 1), x2 = seq(0, 200, 1))
d1 <- my.data[,1]
d2 <- my.data[,2]
Fd <- 224 * d1 + 84 * d2 + d1 * d2 - 2 * d1^2 - d2^2
new.data <- data.frame(Fd = Fd, d1 = d1, d2 = d2)
# identify values of d1 and d2 that maximize Fd
new.data[new.data$Fd == max(new.data$Fd),]
# Fd d1 d2
# 16157 11872 76 80
该函数的最大值为11872
whend1 = 76
和d2 = 80
。
我还可以使用optim
以下代码找到最大值:
Fd <- function(betas) {
b1 = betas[1]
b2 = betas[2]
-1 * (224 * b1 + 84 * b2 + b1 * b2 - 2 * b1^2 - b2^2)
}
optim(c(1,1), Fd, hessian = TRUE)
我将上面的函数乘以-1
得到最大值,并注意到这段代码返回的最大值是真正最大值的负数。此外,此代码返回的 Hessian 是真正的 Hessian * -1:
true.hessian <- matrix(c(-4, 1, 1, -2), nrow = 2, byrow = TRUE)
true.hessian
estimated.hessian <- -1 * true.hessian
estimated.hessian
直到现在我才意识到这一点,也没有在optim
页面上看到它。我应该担心吗?如果有,在什么情况下?
语句中是否有一个选项可以在optim
找到最大值时返回原始函数的真正 Hessian 而不是 -1 * 原始函数?或者我应该知道,当我搜索最大值(而不是搜索最小值)并自己更正 Hessian 时,Hessian 乘以 -1?