0

现在我正在使用 Scala Breeze 中的线性程序类,我已经到了要使用以下代码优化我的线性规划问题的地步。

import breeze.stats.distributions
import breeze.stats._
import breeze.linalg._

val lp = new breeze.optimize.linear.LinearProgram()
val unif_dist = breeze.stats.distributions.Uniform(-1,1)

val U = DenseMatrix.rand(1, 3, unif_dist).toArray
val V = DenseMatrix.rand(2, 3, unif_dist).toArray.grouped(3).toArray
val B = Array.fill(3)(lp.Binary())

val Objective = V.map(vi => U.zip(vi).map(uv => uv._1 * uv._2)).map(uvi => B.zip(uvi).map(buv => buv._1 * buv._2)).map(x => x.reduce(_ + _)).reduce(_ + _)
val lpp = ( Objective subjectTo() )

lp.maximize(lpp)

我收到以下错误

scala> lp.minimize(lpp)
<console>:45: error: type mismatch;
found   : lp.Problem
required: lp.Problem
          lp.minimize(lpp)
                      ^

以前有没有人遇到过这个问题,如果有,你有没有想出办法来解决它?此外,我愿意接受有关以更简洁的方式编写我分配目标的行的建议。

4

0 回答 0