Skip to content

松弛

形式

z=slack(x,y)={max(0,xy),计算正松弛max(0,yx),计算负松弛|xy|,计算正负松弛

额外变量

negRR:负松弛。

posRR:正松弛。

导出符号

z=neg+pos

数学模型

计算正负松弛

s.t.x+negpos=y

计算正松弛

s.t.xposy

计算负松弛

s.t.x+negy

样例

kotlin
import kotlinx.coroutines.*
import fuookami.ospf.kotlin.utils.math.*
import fuookami.ospf.kotlin.core.frontend.variable.*
import fuookami.ospf.kotlin.core.frontend.expression.polynomial.*
import fuookami.ospf.kotlin.core.frontend.expression.symbol.linear_function.*
import fuookami.ospf.kotlin.core.frontend.inequality.*
import fuookami.ospf.kotlin.core.frontend.model.mechanism.*
import fuookami.ospf.kotlin.core.backend.plugins.scip.*

val x = RealVar("x")
x.range.leq(Flt64.two)
x.range.geq(-Flt64.three)
val slack = SlackFunction(
    x = x,
    y = Flt64.five,
    name = "slack"
)

val model = LinearMetaModel()
model.add(x)
model.add(slack)
model.minimize(slack)

val solver = ScipLinearSolver()
val result = runBlocking { solver(model) }
assert(result.value!!.obj eq Flt64.three)
assert(result.value!!.solution[0] eq Flt64.two)

完整实现请参考:

完整样例请参考: