|
"""
|
|
This script is written for running Uwe Schöning's WalkSAT algorithm
|
|
[Uwe Schöning:
|
|
A probabilistic algorithm for k-SAT and constraint satisfaction problems.
|
|
In: Proceedings of FOCS 1999, IEEE, pages 410–414.]
|
|
via the command line
|
|
by specifying the instance to solve, and the seed to use.
|
|
Uwe Schöning's WalkSAT algorithm can be seen as a special case of the probSAT algorithm
|
|
[Adrian Balint, Uwe Schöning:
|
|
Choosing Probability Distributions for Stochastic Local Search and the Role of Make versus Break.
|
|
In: Lecture Notes in Computer Science, 2012, Volume 7317, Theory and Applications of Satisfiability Testing - SAT 2012, pages 16-29.
|
|
https://www.uni-ulm.de/fileadmin/website_uni_ulm/iui.inst.190/Mitarbeiter/balint/SAT2012.pdf]
|
|
with exponential function (break-only-exp-algorithm) and c_b = 1.
|
|
|
|
The script will record the number of flips, the time used, and the seed used.
|
|
"""
|
|
|
|
import argparse
|
|
from subprocess import Popen, PIPE
|
|
from time import sleep
|
|
from os.path import exists
|
|
import sys
|
|
from timeit import default_timer as timer
|
|
|
|
|
|
def run_alg(instance, seed):
|
|
p = Popen(['./uweAlg', '--cb', '1.0', '--fct', str(1), instance, str(abs(seed))], stdin = PIPE, stdout = PIPE, stderr=PIPE)
|
|
output, err = p.communicate()
|
|
rc = p.returncode
|
|
err = err.decode("utf-8")
|
|
if err != "":
|
|
print(err, file=sys.stderr)
|
|
return output.decode("utf-8").replace(" 1\n","").replace("\n","")
|
|
|
|
|
|
if __name__ == '__main__':
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument("-s", "--seed", type=int, default=1909, help="The seed.")
|
|
parser.add_argument("-i", "--instance", default='./instances/uf250-01.cnf', help="The instance.")
|
|
|
|
args = parser.parse_args()
|
|
|
|
start = timer()
|
|
flips = run_alg(args.instance, args.seed)
|
|
end = timer()
|
|
print(flips, end-start, str(abs(args.seed)))
|
|
|
|
|
|
|
|
|
|
|
|
|