Skip to content

如果

形式

y=If(xrhs)={1,xrhs0,¬(xrhs)

其中, 可以是 =

额外变量

ki[0,1] :线性分段权重。

y{0,1} :不等式的逻辑值。

导出符号

y=y

数学模型

如果 ,有:

s.t.{{x=k0min(x)+k1rhs+k2max(x)k0yk21yk2ϵ(1y),rhs[min(x),max(x)]y=bin(max(x)rhs),rhs[min(x),max(x)]

如果 ,有:

s.t.{{x=k0min(x)+k1rhs+k2max(x)k01yk0ϵ(1y)k2y,rhs[min(x),max(x)]y=bin(max(x)rhs),rhs[min(x),max(x)]

如果 =,有:

s.t.{{x=k0min(x)+k1rhs+k2max(x)k0+k21yk0+k2ϵ(1y),rhs[min(x),max(x)]y=bin(max(x)rhs),rhs[min(x),max(x)]

其中,

bin(cond)={1,cond0,¬cond

并且 ϵ 满足以下性质:

(ϵ=0)((x=rhs)¬(xrhs))

样例

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 = URealVar("x")
x.range.geq(Flt64.two)
x.range.leq(Flt64.five)
val condition1 = IfFunction(x geq Flt64.three, name = "c1")
val condition2 = IfFunction(x geq Flt64.three, epsilon = Flt64.zero, name = "c2")
val condition3 = IfFunction(x leq Flt64.one, name = "c3")
val solver = ScipLinearSolver()

val model1 = LinearMetaModel()
model1.add(x)
model1.add(condition1)
model1.addConstraint(condition1 eq true)
model1.minimize(x)
val result1 = runBlocking { solver(model1) }
assert(result1.value!!.obj eq Flt64.three)

val model2 = LinearMetaModel()
model2.add(x)
model2.add(condition1)
model2.addConstraint(condition1 eq false)
model2.maximize(x)
val result2 = runBlocking { solver(model2) }
assert(result2.value!!.obj ls Flt64.three)

val model3 = LinearMetaModel()
model3.add(x)
model3.add(condition2)
model3.addConstraint(condition2 eq false)
model3.maximize(x)
val result3 = runBlocking { solver(model3) }
assert(result3.value!!.obj eq Flt64.three)

val model4 = LinearMetaModel()
model4.add(x)
model4.add(condition3)
model4.maximize(condition3)
val result4 = runBlocking { solver(model4) }
assert(result4.value!!.obj eq Flt64.zero)

完整实现请参考:

完整样例请参考: