Skip to content

Commit

Permalink
rewriter: log new top level vars to human rule trace
Browse files Browse the repository at this point in the history
  • Loading branch information
niklasdewally committed Jan 6, 2025
1 parent 1d34710 commit a1b5753
Show file tree
Hide file tree
Showing 27 changed files with 112 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ Not((c != 0)),
(a != SafeDiv(b, c)),
~~> flatten_binop ([("Minion", 4400)])
(a != __0)
with new top level expressions:
__0 =aux SafeDiv(b, c)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ And([(c != 0)]),
(a != SafeDiv(b, c)),
~~> flatten_binop ([("Minion", 4400)])
(a != __0)
with new top level expressions:
__0 =aux SafeDiv(b, c)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ Not((c != 0)),
(a != SafeDiv(b, c)),
~~> flatten_binop ([("Minion", 4400)])
(a != __0)
with new top level expressions:
__0 =aux SafeDiv(b, c)

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
Max([2, a]),
~~> max_to_var ([("Base", 100)])
__0
with new top level expressions:
(__0 >= 2)
(__0 >= a)
Or([(__0 = 2), (__0 = a)])

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
Min([a, b]),
~~> min_to_var ([("Base", 2000)])
__0
with new top level expressions:
(__0 <= a)
(__0 <= b)
Or([(__0 = a), (__0 = b)])

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
Min([a, b]),
~~> min_to_var ([("Base", 2000)])
__0
with new top level expressions:
(__0 <= a)
(__0 <= b)
Or([(__0 = a), (__0 = b)])

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
Min([a, b]),
~~> min_to_var ([("Base", 2000)])
__0
with new top level expressions:
(__0 <= a)
(__0 <= b)
Or([(__0 = a), (__0 = b)])

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
Min([a, b]),
~~> min_to_var ([("Base", 2000)])
__0
with new top level expressions:
(__0 <= a)
(__0 <= b)
Or([(__0 = a), (__0 = b)])

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
Min([a, b]),
~~> min_to_var ([("Base", 2000)])
__0
with new top level expressions:
(__0 <= a)
(__0 <= b)
Or([(__0 = a), (__0 = b)])

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ Not((c != 0)),
(a != SafeMod(b,c)),
~~> flatten_binop ([("Minion", 4400)])
(a != __0)
with new top level expressions:
__0 =aux SafeMod(b,c)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ And([(c != 0)]),
(a != SafeMod(b,c)),
~~> flatten_binop ([("Minion", 4400)])
(a != __0)
with new top level expressions:
__0 =aux SafeMod(b,c)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ Not((c != 0)),
(a != SafeMod(b,c)),
~~> flatten_binop ([("Minion", 4400)])
(a != __0)
with new top level expressions:
__0 =aux SafeMod(b,c)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ And([(z != 0)]),
SafeDiv(-(y), z),
~~> flatten_binop ([("Minion", 4400)])
SafeDiv(__0, z)
with new top level expressions:
__0 =aux -(y)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ And([(z != 0)]),
(x = -(SafeDiv(y, z))),
~~> flatten_minuseq ([("Minion", 4400)])
MinusEq(x,__0)
with new top level expressions:
__0 =aux SafeDiv(y, z)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -79,12 +79,16 @@ And([(x = SafeDiv(-(SafeDiv(y, z)), z)), (z != 0), (z != 0)])
SafeDiv(-(SafeDiv(y, z)), z),
~~> flatten_binop ([("Minion", 4400)])
SafeDiv(__0, z)
with new top level expressions:
__0 =aux -(SafeDiv(y, z))

--

__0 =aux -(SafeDiv(y, z)),
~~> flatten_minuseq ([("Minion", 4400)])
MinusEq(__0,__1)
with new top level expressions:
__1 =aux SafeDiv(y, z)

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
Sum([-(y), z]),
~~> flatten_vecop ([("Minion", 4400)])
Sum([__0, z])
with new top level expressions:
__0 =aux -(y)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,9 @@ a
Sum([-(y), -(z), -1, a, b]),
~~> flatten_vecop ([("Minion", 4400)])
Sum([__0, __1, -1, a, b])
with new top level expressions:
__0 =aux -(y)
__1 =aux -(z)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ And([(a != 0)]),
SafeDiv(Sum([x, y, z]), a),
~~> flatten_binop ([("Minion", 4400)])
SafeDiv(__0, a)
with new top level expressions:
__0 =aux Sum([x, y, z])

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
Sum([Min([a, b]), 6]),
~~> flatten_vecop ([("Minion", 4400)])
Sum([__0, 6])
with new top level expressions:
__0 =aux Min([a, b])

--

Expand All @@ -13,6 +15,10 @@ SumLeq([__0, 6], 10)
Min([a, b]),
~~> min_to_var ([("Base", 2000)])
__1
with new top level expressions:
(__1 <= a)
(__1 <= b)
Or([(__1 = a), (__1 = b)])

--

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
Sum([Max([a, b]), 1]),
~~> flatten_vecop ([("Minion", 4400)])
Sum([__0, 1])
with new top level expressions:
__0 =aux Max([a, b])

--

Expand All @@ -19,6 +21,10 @@ And([SumLeq([__0, 1], x), SumGeq([__0, 1], x)])
Max([a, b]),
~~> max_to_var ([("Base", 100)])
__1
with new top level expressions:
(__1 >= a)
(__1 >= b)
Or([(__1 = a), (__1 = b)])

--

Expand All @@ -43,6 +49,10 @@ Ineq(b, __1, 0)
Max([a, b]),
~~> max_to_var ([("Base", 100)])
__2
with new top level expressions:
(__2 >= a)
(__2 >= b)
Or([(__2 = a), (__2 = b)])

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -67,12 +67,16 @@ And([(SafeDiv(x, SafeDiv(y, z)) = 10), (SafeDiv(y, z) != 0), (z != 0)])
SafeDiv(x, SafeDiv(y, z)),
~~> flatten_binop ([("Minion", 4400)])
SafeDiv(x, __0)
with new top level expressions:
__0 =aux SafeDiv(y, z)

--

(SafeDiv(y, z) != 0),
~~> flatten_binop ([("Minion", 4400)])
(__1 != 0)
with new top level expressions:
__1 =aux SafeDiv(y, z)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -67,18 +67,24 @@ And([(SafeDiv(x, SafeDiv(y, z)) != 10), (SafeDiv(y, z) != 0), (z != 0)])
(SafeDiv(x, SafeDiv(y, z)) != 10),
~~> flatten_binop ([("Minion", 4400)])
(__0 != 10)
with new top level expressions:
__0 =aux SafeDiv(x, SafeDiv(y, z))

--

(SafeDiv(y, z) != 0),
~~> flatten_binop ([("Minion", 4400)])
(__1 != 0)
with new top level expressions:
__1 =aux SafeDiv(y, z)

--

SafeDiv(x, SafeDiv(y, z)),
~~> flatten_binop ([("Minion", 4400)])
SafeDiv(x, __2)
with new top level expressions:
__2 =aux SafeDiv(y, z)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,12 +97,16 @@ Or([(SafeDiv(x, SafeDiv(y, z)) != 10), (SafeDiv(y, z) = 0), (z = 0)])
(SafeDiv(x, SafeDiv(y, z)) != 10),
~~> flatten_binop ([("Minion", 4400)])
(__0 != 10)
with new top level expressions:
__0 =aux SafeDiv(x, SafeDiv(y, z))

--

SafeDiv(x, SafeDiv(y, z)),
~~> flatten_binop ([("Minion", 4400)])
SafeDiv(x, __1)
with new top level expressions:
__1 =aux SafeDiv(y, z)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -67,12 +67,16 @@ And([(SafeMod(x,SafeMod(y,z)) = 3), (SafeMod(y,z) != 0), (z != 0)])
SafeMod(x,SafeMod(y,z)),
~~> flatten_binop ([("Minion", 4400)])
SafeMod(x,__0)
with new top level expressions:
__0 =aux SafeMod(y,z)

--

(SafeMod(y,z) != 0),
~~> flatten_binop ([("Minion", 4400)])
(__1 != 0)
with new top level expressions:
__1 =aux SafeMod(y,z)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -67,18 +67,24 @@ And([(SafeMod(x,SafeMod(y,z)) != 3), (SafeMod(y,z) != 0), (z != 0)])
(SafeMod(x,SafeMod(y,z)) != 3),
~~> flatten_binop ([("Minion", 4400)])
(__0 != 3)
with new top level expressions:
__0 =aux SafeMod(x,SafeMod(y,z))

--

(SafeMod(y,z) != 0),
~~> flatten_binop ([("Minion", 4400)])
(__1 != 0)
with new top level expressions:
__1 =aux SafeMod(y,z)

--

SafeMod(x,SafeMod(y,z)),
~~> flatten_binop ([("Minion", 4400)])
SafeMod(x,__2)
with new top level expressions:
__2 =aux SafeMod(y,z)

--

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,12 +97,16 @@ Or([(SafeMod(x,SafeMod(y,z)) != 3), (SafeMod(y,z) = 0), (z = 0)])
(SafeMod(x,SafeMod(y,z)) != 3),
~~> flatten_binop ([("Minion", 4400)])
(__0 != 3)
with new top level expressions:
__0 =aux SafeMod(x,SafeMod(y,z))

--

SafeMod(x,SafeMod(y,z)),
~~> flatten_binop ([("Minion", 4400)])
SafeMod(x,__1)
with new top level expressions:
__1 =aux SafeMod(y,z)

--

Expand Down
18 changes: 17 additions & 1 deletion crates/conjure_core/src/rule_engine/rewriter_common.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
use super::{resolve_rules::ResolveRulesError, Reduction, Rule};
use crate::ast::{pretty::pretty_vec, Expression};

use itertools::Itertools;
use thiserror::Error;
use tracing::{info, trace};

Expand All @@ -28,13 +29,28 @@ pub fn log_rule_application(result: &RuleResult, initial_expression: &Expression
red.new_expression
);

let top_level_str = if !red.new_top.is_empty() {
let mut exprs: Vec<String> = vec![];

for expr in &red.new_top {
exprs.push(format!(" {}", expr));
}

let exprs = exprs.iter().join("\n");

format!("with new top level expressions:\n{}\n", exprs)
} else {
String::new()
};

trace!(
target: "rule_engine_human",
"{}, \n ~~> {} ({:?}) \n{} \n\n--\n",
"{}, \n ~~> {} ({:?}) \n{} \n{}\n--\n",
initial_expression,
rule.name,
rule.rule_sets,
red.new_expression,
top_level_str
);
}

Expand Down

0 comments on commit a1b5753

Please sign in to comment.