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.
 
 
 
 

100 lines
3.4 KiB

#!/usr/bin/env python3
from util import randomSAT
from util import kSAT
import util.script as scriptUtils
import h5py
import numpy as np
import pymongo
import ssl
def main():
args = __parseArguments()
dbClient = __getDBClient(args["dbConfigPath"]);
db = dbClient["experiments"]
dbInstances = db["instances"]
dbExperimentScopes = db["experiment_scopes"]
experimentScope = {}
experimentScope["instances"] = []
description = "This experiment contains %d instances " % args["instances"]
description += "each with %d clauses, %d variables " % (args["clauses"],
args["variables"])
description += ("and %d variables per clause (c/v = %.2f)"
%(args["variablesPerClause"],
float(args["clauses"]) / float(args["variables"])))
experimentScope["description"] = description
for i in range(args["instances"]):
print("loop", i)
sat = randomSAT.generateRandomKSAT(args["clauses"],
args["variables"],
args["variablesPerClause"])
instanceId = dbInstances.insert_one(sat.writeJSONLike()).inserted_id
experimentScope["instances"].append(instanceId)
dbExperimentScopes.insert_one(experimentScope)
dbClient.close()
def __getDBClient(dbConfigPath):
dbConf = scriptUtils.readConfig(dbConfigPath)
dbConf["CONNECTION"]
return pymongo.MongoClient(
"mongodb://%s:%s@%s:%s/%s"
% ( dbConf["CONNECTION"]["user"],
dbConf["CONNECTION"]["pw"],
dbConf["CONNECTION"]["url"],
dbConf["CONNECTION"]["port"],
dbConf["CONNECTION"]["database"]),
ssl=True,
ssl_cert_reqs=ssl.CERT_NONE)
def __parseArguments():
parser = scriptUtils.ArgParser()
parser.addArg(alias="instances", shortFlag="i", longFlag="instances",
help="number of random kSAT instances", type=int,
ignoreDatabaseConfig=True)
parser.addArg(alias="variables", shortFlag="v", longFlag="variables",
help="number of variables in the ksat instances", type=int,
ignoreDatabaseConfig=True)
parser.addArg(alias="clauses", shortFlag="c", longFlag="clauses",
help="number of clauses in the ksat instances", type=int,
ignoreDatabaseConfig=True)
parser.addArg(alias="variablesPerClause", shortFlag="vpc",
longFlag="variables_per_clause",
help="variables per clause in the kSAT instances", type=int,
default=3, ignoreDatabaseConfig=True)
parser.addArg(alias="dbConfigPath", shortFlag="d", longFlag="db_config",
help="path to the database config file", type=str,
default="database.config", ignoreDatabaseConfig=True)
return parser.parse()
def __initFile(args):
f = h5py.File(args["fileName"], "w")
__SAT_TYPE__ = np.dtype([('bindings', (np.int32, (args["clauses"],
args["variablesPerClause"])))])
instances = f.create_dataset(name="instances",
shape=(args["instances"],),
dtype=__SAT_TYPE__)
return f, __SAT_TYPE__
if __name__ == "__main__":
main()