Skip to content

Logical NOT

y=Not(x)={1,¬x0,x

Discrete Case

Constants

m=max(x)

Additional Variables

y{0,1}: Logical value indicating the polynomial is false.

Derived Symbol

y=y

Mathematical Model

s.t.m(1y)x1yx

That is:

y={1,x=00,x1

Continuous (Non-Precise) Case

Constants

m=max(x)

Additional Variables

b[0,1]: Normalized value of the polynomial.

y{0,1}: Logical value indicating the polynomial is false.

Derived Symbol

y=y

Mathematical Model

s.t.x=mb1ybϵ(1y)b

That is:

y={1,x=00,xϵ

Continuous (Precise) Case

Derived Symbol

y=Ulp(x)

Ulp(x) can refer to Unit Linear Piecewise Function, using the sampling points {(0,1),(pϵ,1),(p,0),(max(x),0)}.

That is:

y={1,0x<p0,xp

Code Example

Discrete Case

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 = BinVar("x")
val not = NotFunction(x, name = "not")
val solver = ScipLinearSolver()

val model1 = LinearMetaModel()
model1.add(x)
model1.add(not)
model1.addConstraint(not)
model1.maximize(x)
val result1 = runBlocking { solver(model1) }
assert(result1.value!!.obj eq Flt64.zero)

val model2 = LinearMetaModel()
model2.add(x)
model2.add(not)
model2.addConstraint(!not)
model2.minimize(x)
val result2 = runBlocking { solver(model2) }
assert(result2.value!!.obj eq Flt64.one)

Continuous Case

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.leq(Flt64.one)
val not = NotFunction(x, name = "not")
val solver = ScipLinearSolver()

val model1 = LinearMetaModel()
model1.add(x)
model1.add(not)
model1.addConstraint(not)
model1.maximize(x)
val result1 = runBlocking { solver(model1) }
assert(result1.value!!.obj eq Flt64.zero)

val model2 = LinearMetaModel()
model2.add(x)
model2.add(not)
model2.addConstraint(!not)
model2.minimize(x)
val result2 = runBlocking { solver(model2) }
assert(result2.value!!.obj geq Flt64(1e-6))

Complete Implementation Reference:

Complete Example Reference: