一元分段线性函数
形式
常量
记该线性分段的点集为
额外变量
导出符号
数学模型
样例
kotlin
import kotlinx.coroutines.*
import fuookami.ospf.kotlin.utils.math.*
import fuookami.ospf.kotlin.utils.math.geometry.*
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.model.mechanism.*
import fuookami.ospf.kotlin.core.backend.plugins.scip.*
val x = URealVar("x")
x.range.leq(Flt64.two)
val ulp = UnivariateLinearPiecewiseFunction(
x = x,
points = listOf(
point2(),
point2(x = Flt64.one, y = Flt64.two),
point2(x = Flt64.two, y = Flt64.one)
),
name = "y"
)
val model = LinearMetaModel()
model.add(x)
model.add(ulp)
model.maximize(ulp)
val solver = ScipLinearSolver()
val result = runBlocking { solver(model) }
assert(result.value!!.obj eq Flt64.two)
assert(result.value!!.solution[0] eq Flt64.one)
完整实现请参考:
完整样例请参考: