使用Rsolnp使用多个变量在R中进行优化

时间:2016-09-30 15:12:26

标签: r optimization mathematical-optimization constraint-programming hessian-matrix

我之前曾问过this question,并希望继续跟进,因为我尝试了其他一些事情并且他们没有完成任务。

我本质上是在尝试优化R中的NLP类型问题,它具有二进制和整数约束。相同的代码如下:

# Input Data
DTM <- sample(1:30,10,replace=T)
DIM <- rep(30,10)
Price <- 100 - seq(0.4,1,length.out=10)

# Variables that shall be changed to find optimal solution
Hike <- c(1,0,0,1,0,0,0,0,0,1)
Position <- c(0,1,-2,1,0,0,0,0,0,0)

# Bounds for Hikes/Positions
HikeLB <- rep(0,10)
HikeUB <- rep(1,10)
PositionLB <- rep(-2,10)
PositionUB <- rep(2,10)

library(Rsolnp)

# x <- c(Hike, Position)
# Combining two arrays into one since I want 
# to optimize using both these variables

opt_func <- function(x) {

  Hike <- head(x,length(x)/2)
  Position <- tail(x,length(x)/2)

  hikes_till_now <- cumsum(Hike) - Hike
  PostHike <- numeric(length(Hike))
  for (i in seq_along(Hike)){
    PostHike[i] <- 99.60 - 0.25*(Hike[i]*(1-DTM[i]/DIM[i]))
    if(i>1) {
      PostHike[i] <- PostHike[i] - 0.25*hikes_till_now[i]
    }
  }
  Pnl <- Position*(PostHike-Price)
  return(-sum(Pnl)) # Since I want to maximize sum(Pnl)

}

#specify the in-equality function for Hike
unequal <- function(x) {
  Hike <- head(x,length(x)/2)
  return(sum(Hike))
}

#specify the equality function for Position
equal <- function(x) {
  Position <- tail(x,length(x)/2)
  return(sum(Position))
}

#the optimiser
solnp(c(Hike,Position), opt_func, 
      eqfun=equal, eqB=0,   
      ineqfun=unequal, ineqUB=3, ineqLB=1, 
      LB=c(HikeLB,PositionLB), UB=c(HikeUB,PositionUB))

我收到以下警告/错误:

# solnp--> Solution not reliable....Problem Inverting Hessian.

据我所知,Hessian是一个稀疏矩阵,因此可能存在反转问题?此外,可能有一些更好的方法来进行这种优化,因为它似乎不是一个复杂的问题,我觉得我在这里缺少一些相当简单的东西!

问题的描述在this question中详细说明。

非常感谢任何帮助。

0 个答案:

没有答案