The source code and dockerfile for the GSW2024 AI Lab.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.
 
 
 
 
 
 

55 lines
2.2 KiB

import stormpy
import stormpy.utility
import pytest
class TestSmtSolver():
def test_smtsolver_init(self):
manager = stormpy.ExpressionManager()
solver = stormpy.utility.Z3SmtSolver(manager)
def test_smtsolver_trivial(self):
manager = stormpy.ExpressionManager()
solver = stormpy.utility.Z3SmtSolver(manager)
solver.add(manager.create_boolean(True))
assert solver.check() != stormpy.utility.SmtCheckResult.Unsat
assert solver.check() == stormpy.utility.SmtCheckResult.Sat
solver.add(manager.create_boolean(False))
assert solver.check() == stormpy.utility.SmtCheckResult.Unsat
assert solver.check() != stormpy.utility.SmtCheckResult.Sat
def test_smtsolver_arithmetic_unsat(self):
manager = stormpy.ExpressionManager()
x = manager.create_integer_variable("x")
xe = x.get_expression()
c1 = stormpy.Expression.Geq(xe, manager.create_integer(1))
c2 = stormpy.Expression.Less(xe, manager.create_integer(0))
solver = stormpy.utility.Z3SmtSolver(manager)
solver.add(c1)
solver.add(c2)
assert solver.check() == stormpy.utility.SmtCheckResult.Unsat
def test_smtsolver_arithmetic_unsat(self):
manager = stormpy.ExpressionManager()
x = manager.create_integer_variable("x")
xe = x.get_expression()
c1 = stormpy.Expression.Geq(xe, manager.create_integer(1))
c2 = stormpy.Expression.Less(xe, manager.create_integer(0))
solver = stormpy.utility.Z3SmtSolver(manager)
solver.add(c1)
solver.add(c2)
assert solver.check() == stormpy.utility.SmtCheckResult.Unsat
def test_smtsolver_arithmetic_unsat(self):
manager = stormpy.ExpressionManager()
x = manager.create_integer_variable("x")
xe = x.get_expression()
c1 = stormpy.Expression.Geq(xe, manager.create_integer(1))
c2 = stormpy.Expression.Less(xe, manager.create_integer(2))
solver = stormpy.utility.Z3SmtSolver(manager)
solver.add(c1)
solver.add(c2)
assert solver.check() == stormpy.utility.SmtCheckResult.Sat
assert solver.model.get_integer_value(x) == 1