|
|
- #!/usr/bin/env python3
-
- import SATquboResult
- import argparse
- from kSAT import kSAT
- import minisatUtils as mSatU
- import SATquboResult
- import os
- import json
-
- def main():
- args = __parseArguments()
-
-
- comparison = __compare(args["instancePath"],
- args["minisatResult"],
- args["quboResult"])
-
- outputFilePath = os.path.join(args["outputDir"],
- args["instanceFileName"] + ".cmp")
-
- __writeComparison(comparison, outputFilePath)
-
-
- def __parseArguments():
- parser = argparse.ArgumentParser()
- parser.add_argument("-i", "--instance", help="instance file, has to be in DIMACS format", type=str)
- parser.add_argument("-m", "--minisat_result", help="Minisat result file", type=str)
- parser.add_argument("-q", "--qubo_result", help="Qubo result file", type=str)
- parser.add_argument("-o", "--output", help="Directory to store the comparison (optional)", type=str)
- args = parser.parse_args()
-
- arguments = {}
-
- arguments["instancePath"] = args.instance
- if arguments["instancePath"] == None:
- arguments["instancePath"] = str(input("Instance file: "))
-
- #arguments["instancePath"]
- arguments["instanceFileName"] = os.path.basename(arguments["instancePath"])
-
- arguments["minisatResult"] = args.minisat_result
- if arguments["minisatResult"] == None:
- arguments["minisatResult"] = str(input("Minisat result file: "))
-
- arguments["quboResult"] = args.qubo_result
- if arguments["quboResult"] == None:
- arguments["quboResult"] = str(input("Qubo result file: "))
-
- arguments["outputDir"] = args.output
- if arguments["outputDir"] == None:
- arguments["outputDir"] = str(input("Output directory: "))
-
- arguments["outputDir"] = os.path.abspath(arguments["outputDir"])
-
-
-
- return arguments
-
- def __compare(instancePath, msatResultFile, quboResultFile):
- comparison = {}
- sat = kSAT()
- sat.readDIMACS(instancePath)
-
- comparison["instance"] = os.path.basename(instancePath)
- comparison["minisat_satisfiable"] = __getMinisatSatisfiability(msatResultFile)
- comparison["qubo_satisfiable"] = __getQuboSatisfiability(quboResultFile)
- comparison["degrees_of_variables"] = sat.getDegreesOfVariables()
- comparison["conflicts_per_variable"] = __countConflicts(sat.getConflicts())
-
- return comparison
-
-
- def __getMinisatSatisfiability(resultFile):
- minisatResult = mSatU.readMinisatResult(resultFile)
-
- return minisatResult["satisfiable"]
-
- def __getQuboSatisfiability(resultFile):
- results = SATquboResult.readResultsFromFile(resultFile)
-
- for result in results:
- if result.satisfiesInstance():
- return True
-
- return False
-
- def __writeComparison(comparison, outputFilePath):
- if outputFilePath == None:
- return
-
- outputFile = open(outputFilePath, "w+")
-
- outputFile.write(json.dumps(comparison) + "\n")
-
- outputFile.close()
-
- def __countConflicts(conflicts):
- conflictsPerVariable = {}
-
- for conflict in conflicts:
- varLabel = abs(conflict[0][1])
-
- if varLabel not in conflictsPerVariable:
- conflictsPerVariable[varLabel] = 1
- else:
- conflictsPerVariable[varLabel] += 1
-
- return conflictsPerVariable
-
- if __name__ == "__main__":
- main()
|