#!/usr/bin/env python3
|
|
|
|
import kSAT
|
|
import minisatUtils as mSatU
|
|
import argparse
|
|
|
|
|
|
def main():
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument("-i", "--instance", help="instance file, has to be in DIMACS format", type=str)
|
|
parser.add_argument("-r", "--result", help="minisat result file", type=str)
|
|
args = parser.parse_args()
|
|
|
|
instancePath = args.instance
|
|
if instancePath == None:
|
|
instancePath = str(input("Instance file: "))
|
|
|
|
minisatResultFile = args.result
|
|
if minisatResultFile == None:
|
|
minisatResultFile = str(input("Minisat result file: "))
|
|
|
|
print("Checking...")
|
|
print("Instance:\t%s" % instancePath)
|
|
print("Minisat result:\t%s" % minisatResultFile)
|
|
|
|
checkStr = __checkResult(instancePath, minisatResultFile)
|
|
|
|
print("check:\t\t%s" % checkStr)
|
|
|
|
|
|
def __checkResult(instancePath, minisatResultFile):
|
|
sat = kSAT.kSAT()
|
|
|
|
sat.readDIMACS(instancePath)
|
|
|
|
minisatResult = mSatU.readMinisatResult(minisatResultFile)
|
|
|
|
if minisatResult["satisfiable"]:
|
|
if sat.checkAssignment(minisatResult["assignments"]):
|
|
return "results do match"
|
|
else:
|
|
return "results do NOT match"
|
|
else:
|
|
return "unsatisfiable"
|
|
|
|
if __name__ == "__main__":
|
|
main()
|