Skip to content

Commit

Permalink
fix parsing of numbers
Browse files Browse the repository at this point in the history
  • Loading branch information
rkaminsk committed Nov 29, 2023
1 parent b3535b7 commit c8031c1
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 7 deletions.
21 changes: 16 additions & 5 deletions libclingcon/src/parsing.cc
Original file line number Diff line number Diff line change
Expand Up @@ -374,10 +374,10 @@ struct VectorHash {

void push_co(val_t co, CoVarVec &res) { res.emplace_back(co, INVALID_VAR); }

void push_co_var(val_t co, var_t var, CoVarVec &res) { res.emplace_back(co, var); }

void push_co(val_t co, NonlinearTermVec &res) { res.emplace_back(co, VarVec{}); }

void push_co_var(val_t co, var_t var, CoVarVec &res) { res.emplace_back(co, var); }

void push_co_var(val_t co, var_t var, NonlinearTermVec &res) { res.emplace_back(co, VarVec{var}); }

void push_co_vars(val_t co, var_t l_var, var_t r_var, CoVarVec &res) {
Expand All @@ -396,6 +396,15 @@ void push_co_vars(val_t co, VarVec const &l_vars, VarVec const &r_vars, Nonlinea
res.emplace_back(co, std::move(vars));
}

void push_value(Clingo::Symbol const &sym, CoVarVec &res) {
check_syntax(sym.type() == Clingo::SymbolType::Number);
push_co(sym.number(), res);
}

void push_value(Clingo::Symbol const &sym, NonlinearTermVec &res) {
check_syntax(sym.type() == Clingo::SymbolType::Number);
push_co(sym.number(), res);
}
using Clingcon::simplify;

auto simplify(NonlinearTermVec &vec, bool drop_zero) -> val_t {
Expand Down Expand Up @@ -493,7 +502,7 @@ void parse_constraint_elem(AbstractConstraintBuilder &builder, Clingo::TheoryTer

auto b = evaluate(args.back());
if (b.type() == Clingo::SymbolType::Number) {
push_co(-b.number(), res);
push_co(safe_inv(b.number()), res);
} else {
push_co_var(-1, builder.add_variable(b), res);
}
Expand Down Expand Up @@ -532,6 +541,8 @@ void parse_constraint_elem(AbstractConstraintBuilder &builder, Clingo::TheoryTer
push_co_vars(safe_mul(l_co, r_co), l_vars, r_vars, res);
}
}
} else if (match(term, "**", 2) || match(term, "/", 2) || match(term, "\\", 2)) {
push_value(evaluate(term), res);
} else if (term.type() == Clingo::TheoryTermType::Symbol || term.type() == Clingo::TheoryTermType::Function ||
term.type() == Clingo::TheoryTermType::Tuple) {
push_co_var(1, builder.add_variable(evaluate(term)), res);
Expand Down Expand Up @@ -887,8 +898,8 @@ auto parse(AbstractConstraintBuilder &builder, Clingo::TheoryAtoms theory_atoms)
bool is_sum_h = match(atom.term(), "__sum_h", 0);
bool is_diff_b = match(atom.term(), "__diff_b", 0);
bool is_diff_h = match(atom.term(), "__diff_h", 0);
bool is_nsum_h = match(atom.term(), "__nsum_b", 0);
bool is_nsum_b = match(atom.term(), "__nsum_h", 0);
bool is_nsum_h = match(atom.term(), "__nsum_h", 0);
bool is_nsum_b = match(atom.term(), "__nsum_b", 0);
if (is_sum_b || is_sum_h) {
if (!parse_constraint<CoVarVec>(builder, atom, is_sum_b)) {
return false;
Expand Down
5 changes: 3 additions & 2 deletions libclingcon/tests/parsing.cc
Original file line number Diff line number Diff line change
Expand Up @@ -248,6 +248,7 @@ TEST_CASE("parsing", "[parsing]") {
}
SECTION("parse") {
SECTION("sum head") {
REQUIRE(parse("&sum { 7; 2**3 } >= 0.") == "2 -> 0 <= 15.");
REQUIRE(parse("&sum { x; y; z } = 0.") == "2 -> 1*x + 1*y + 1*z <= 0."
"2 -> -1*x + -1*y + -1*z <= 0.");
REQUIRE(parse("&sum { x; y; z } != 0.") == "{ 3, 4, -2 }."
Expand Down Expand Up @@ -311,8 +312,8 @@ TEST_CASE("parsing", "[parsing]") {
REQUIRE(parse("&maximize { x - z }.") == "#minimize { -1*x + 1*z }.");
}
SECTION("nonlinear") {
REQUIRE(parse("&nsum { 2*x*y + 3*z + 4 } <= 5.") == "2 -> 2*x*y + 3*z <= 1."
"-2 -> -2*x*y + -3*z <= -2.");
REQUIRE(parse("&nsum { 2*x*y + 3*z + 4 } <= 5.") == "2 -> 2*x*y + 3*z <= 1.");
REQUIRE(parse("&nsum { (2**3)*x*y + (3**4)*z + (5**6) } <= 5.") == "2 -> 8*x*y + 81*z <= -15620.");
}
}
}

0 comments on commit c8031c1

Please sign in to comment.