Skip to content

Commit

Permalink
ezsat: New Sat class to call an external command
Browse files Browse the repository at this point in the history
  • Loading branch information
Coloquinte committed Apr 9, 2024
1 parent bc14999 commit d62a47b
Show file tree
Hide file tree
Showing 3 changed files with 121 additions and 0 deletions.
2 changes: 2 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -633,6 +633,7 @@ $(eval $(call add_include_file,kernel/yosys_common.h))
$(eval $(call add_include_file,kernel/yw.h))
$(eval $(call add_include_file,libs/ezsat/ezsat.h))
$(eval $(call add_include_file,libs/ezsat/ezminisat.h))
$(eval $(call add_include_file,libs/ezsat/ezcommand.h))
ifeq ($(ENABLE_ZLIB),1)
$(eval $(call add_include_file,libs/fst/fstapi.h))
endif
Expand Down Expand Up @@ -673,6 +674,7 @@ OBJS += libs/json11/json11.o

OBJS += libs/ezsat/ezsat.o
OBJS += libs/ezsat/ezminisat.o
OBJS += libs/ezsat/ezcommand.o

OBJS += libs/minisat/Options.o
OBJS += libs/minisat/SimpSolver.o
Expand Down
83 changes: 83 additions & 0 deletions libs/ezsat/ezcommand.cc
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@

#include "ezcommand.h"

#include "../../kernel/yosys.h"

ezSATCommand::ezSATCommand(const std::string &cmd) : command(cmd) {}

ezSATCommand::~ezSATCommand() {}

bool ezSATCommand::solver(const std::vector<int> &modelExpressions, std::vector<bool> &modelValues, const std::vector<int> &assumptions)
{
if (!assumptions.empty()) {
Yosys::log_error("Assumptions are not supported yet by command-based Sat solver\n");
}
const std::string tempdir_name = Yosys::make_temp_dir(Yosys::get_base_tmpdir() + "/yosys-sat-XXXXXX");
const std::string cnf_filename = Yosys::stringf("%s/problem.cnf", tempdir_name.c_str());
const std::string sat_command = Yosys::stringf("%s %s", command.c_str(), cnf_filename.c_str());
FILE *dimacs = fopen(cnf_filename.c_str(), "w");
printDIMACS(dimacs);
fclose(dimacs);

std::vector<int> modelIdx;
for (auto id : modelExpressions)
modelIdx.push_back(bind(id));

bool status_sat = false;
bool status_unsat = false;
std::vector<bool> values;

auto line_callback = [&](const std::string &line) {
if (line.empty()) {
return;
}
if (line[0] == 's') {
if (line.substr(0, 5) == "s SAT") {
status_sat = true;
}
if (line.substr(0, 7) == "s UNSAT") {
status_unsat = true;
}
return;
}
if (line[0] == 'v') {
std::stringstream ss(line.substr(1));
int lit;
while (ss >> lit) {
if (lit == 0) {
return;
}
bool val = lit >= 0;
int ind = lit >= 0 ? lit - 1 : -lit - 1;
if (Yosys::GetSize(values) <= ind) {
values.resize(ind + 1);
}
values[ind] = val;
}
}
};
if (Yosys::run_command(sat_command, line_callback) != 0) {
Yosys::log_cmd_error("Shell command failed!\n");
}

modelValues.clear();
modelValues.resize(modelIdx.size());

if (!status_sat && !status_unsat) {
solverTimoutStatus = true;
}
if (!status_sat) {
return false;
}

for (size_t i = 0; i < modelIdx.size(); i++) {
int idx = modelIdx[i];
bool refvalue = true;

if (idx < 0)
idx = -idx, refvalue = false;

modelValues[i] = (values.at(idx - 1) == refvalue);
}
return true;
}
36 changes: 36 additions & 0 deletions libs/ezsat/ezcommand.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/*
* ezSAT -- A simple and easy to use CNF generator for SAT solvers
*
* Copyright (C) 2013 Claire Xenia Wolf <[email protected]>
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
*/

#ifndef EZSATCOMMAND_H
#define EZSATCOMMAND_H

#include "ezsat.h"

class ezSATCommand : public ezSAT
{
private:
std::string command;

public:
ezSATCommand(const std::string &cmd);
virtual ~ezSATCommand();
bool solver(const std::vector<int> &modelExpressions, std::vector<bool> &modelValues, const std::vector<int> &assumptions) override;
};

#endif

0 comments on commit d62a47b

Please sign in to comment.