mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Rebase on rational solver.
This commit is contained in:
parent
9826efa461
commit
de338e60de
@ -61,14 +61,9 @@ public:
|
||||
{
|
||||
bool equality = static_cast<bool>(c[0]);
|
||||
vector<int> factors(c.begin() + 1, c.end());
|
||||
m_solvingState.constraints.push_back(
|
||||
{
|
||||
linearExpression(factors),
|
||||
equality
|
||||
}
|
||||
);
|
||||
auto it = find_if(factors.rbegin(), factors.rend(), [](auto const& _i) { return _i != 0; });
|
||||
size_t numVariablesInConstraint = factors.size() - 1 - static_cast<size_t>(distance(factors.rbegin(), it));
|
||||
m_solvingState.constraints.push_back({linearExpression(factors), equality});
|
||||
auto it = find_if(factors.rbegin(), factors.rend(), [](auto const& _i) { return _i != 0; });
|
||||
size_t numVariablesInConstraint = factors.size() - 1 - static_cast<size_t>(distance(factors.rbegin(), it));
|
||||
if (totalNumVariables < numVariablesInConstraint)
|
||||
totalNumVariables = numVariablesInConstraint;
|
||||
}
|
||||
@ -150,14 +145,6 @@ public:
|
||||
BOOST_CHECK_MESSAGE(suppliedReason == _reason, "Reasons are different");
|
||||
}
|
||||
|
||||
void sat()
|
||||
{
|
||||
auto [result, model] = m_solver.check(m_solvingState);
|
||||
for (auto const& [var, value]: model)
|
||||
cout << var << " = " << value << endl;
|
||||
BOOST_REQUIRE(result == LPResult::Feasible);
|
||||
}
|
||||
|
||||
protected:
|
||||
size_t variableIndex(string const& _name)
|
||||
{
|
||||
@ -179,15 +166,6 @@ protected:
|
||||
|
||||
BOOST_FIXTURE_TEST_SUITE(LP, LPTestFramework, *boost::unit_test::label("nooptions"))
|
||||
|
||||
BOOST_AUTO_TEST_CASE(fuzzer)
|
||||
{
|
||||
auto x = variable("x", -6);
|
||||
auto y = variable("y", -6);
|
||||
// expected result: -6x -6y = 8 is unsat since x >= 0 and y >= 0 are implied
|
||||
addEQConstraint(x + y, constant(8));
|
||||
sat();
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(fuzzer3)
|
||||
{
|
||||
addFuzzerInput(
|
||||
|
@ -45,7 +45,9 @@ LinearExpression FuzzerSolverInterface::linearExpression(vector<int> _factors)
|
||||
|
||||
void FuzzerSolverInterface::addLPConstraint(pair<bool, vector<int>> _constraint)
|
||||
{
|
||||
m_lpSolvingState.constraints.push_back({linearExpression(move(_constraint.second)), _constraint.first});
|
||||
m_lpSolvingState.constraints.push_back(
|
||||
{linearExpression(move(_constraint.second)), _constraint.first, {}}
|
||||
);
|
||||
}
|
||||
|
||||
void FuzzerSolverInterface::addLPVariable(string _varName)
|
||||
@ -95,7 +97,7 @@ void FuzzerSolverInterface::addZ3Constraints(vector<pair<bool, vector<int>>> _co
|
||||
addZ3Constraint(c);
|
||||
}
|
||||
|
||||
solution FuzzerSolverInterface::checkLP()
|
||||
Solution FuzzerSolverInterface::checkLP()
|
||||
{
|
||||
return m_lpSolver.check(m_lpSolvingState);
|
||||
}
|
||||
|
@ -28,10 +28,9 @@
|
||||
namespace solidity::test::fuzzer::lpsolver
|
||||
{
|
||||
|
||||
using solution = std::pair<
|
||||
solidity::util::LPResult,
|
||||
std::map<std::string, solidity::util::rational>
|
||||
>;
|
||||
using Model = std::map<std::string, solidity::util::rational>;
|
||||
using ReasonSet = std::set<size_t>;
|
||||
using Solution = std::pair<solidity::util::LPResult, std::variant<Model, ReasonSet>>;
|
||||
|
||||
class FuzzerSolverInterface
|
||||
{
|
||||
@ -54,7 +53,7 @@ public:
|
||||
solidity::util::LinearExpression linearExpression(std::vector<int> _factors);
|
||||
|
||||
/// Queries LP solver and @returns solution.
|
||||
solution checkLP();
|
||||
Solution checkLP();
|
||||
|
||||
/// Queries Z3 solver and @returns solution.
|
||||
z3::check_result checkZ3();
|
||||
|
Loading…
Reference in New Issue
Block a user