Merged a few branches in absorption law together
This commit is contained in:
parent
7044dc304d
commit
9b6a24e222
@ -16,4 +16,12 @@ impl BinaryOperator {
|
|||||||
BinaryOperator::Implication => !left || right,
|
BinaryOperator::Implication => !left || right,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn is_and(&self) -> bool {
|
||||||
|
matches!(self, BinaryOperator::And)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn is_or(&self) -> bool {
|
||||||
|
matches!(self, BinaryOperator::Or)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -124,6 +124,7 @@ impl From<SimplifyOptions> for Options {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO refactor, remove unnecessary code and split up into smaller functions
|
||||||
impl Expression {
|
impl Expression {
|
||||||
// TODO better track of operations
|
// TODO better track of operations
|
||||||
pub fn simplify(&self, options: Options) -> (Self, Vec<Operation>) {
|
pub fn simplify(&self, options: Options) -> (Self, Vec<Operation>) {
|
||||||
@ -228,22 +229,22 @@ impl Expression {
|
|||||||
}
|
}
|
||||||
left.absorption_law(operations, ignore_case)
|
left.absorption_law(operations, ignore_case)
|
||||||
}
|
}
|
||||||
Expression::Binary { left, operator: BinaryOperator::And, right }
|
Expression::Binary { left, operator, right }
|
||||||
if left.is_in(right) && right.is_or() => {
|
if operator.is_and() && (right.is_in(left) && left.is_and() || left.is_in(right) && right.is_or()) => {
|
||||||
if let Some(operation) = Operation::new(self, left, Law::AbsorptionLaw) {
|
if let Some(operation) = Operation::new(self, left, Law::AbsorptionLaw) {
|
||||||
operations.push(operation);
|
operations.push(operation);
|
||||||
}
|
}
|
||||||
left.absorption_law(operations, ignore_case)
|
left.absorption_law(operations, ignore_case)
|
||||||
}
|
}
|
||||||
Expression::Binary { left, operator: BinaryOperator::And, right }
|
Expression::Binary { left, operator, right }
|
||||||
if right.is_in(left) && left.is_or() => {
|
if operator.is_and() && (right.is_in(left) && left.is_or() || left.is_in(right) && right.is_and()) => {
|
||||||
if let Some(operation) = Operation::new(self, right, Law::AbsorptionLaw) {
|
if let Some(operation) = Operation::new(self, right, Law::AbsorptionLaw) {
|
||||||
operations.push(operation);
|
operations.push(operation);
|
||||||
}
|
}
|
||||||
right.absorption_law(operations, ignore_case)
|
right.absorption_law(operations, ignore_case)
|
||||||
}
|
}
|
||||||
Expression::Binary { left, operator: BinaryOperator::Or, right }
|
Expression::Binary { left, operator, right }
|
||||||
if right.is_in(left) && left.is_and() => {
|
if operator.is_or() && (right.is_in(left) && (left.is_and() || left.is_or()) || left.is_in(right) && right.is_or()) => {
|
||||||
if let Some(operation) = Operation::new(self, right, Law::AbsorptionLaw) {
|
if let Some(operation) = Operation::new(self, right, Law::AbsorptionLaw) {
|
||||||
operations.push(operation);
|
operations.push(operation);
|
||||||
}
|
}
|
||||||
@ -256,35 +257,6 @@ impl Expression {
|
|||||||
}
|
}
|
||||||
left.absorption_law(operations, ignore_case)
|
left.absorption_law(operations, ignore_case)
|
||||||
}
|
}
|
||||||
Expression::Binary { left, operator: BinaryOperator::Or, right }
|
|
||||||
if left.is_in(right) && right.is_or() => {
|
|
||||||
if let Some(operation) = Operation::new(self, left, Law::AbsorptionLaw) {
|
|
||||||
operations.push(operation);
|
|
||||||
}
|
|
||||||
right.absorption_law(operations, ignore_case)
|
|
||||||
}
|
|
||||||
Expression::Binary { left, operator: BinaryOperator::Or, right }
|
|
||||||
if right.is_in(left) && left.is_or() => {
|
|
||||||
if let Some(operation) = Operation::new(self, right, Law::AbsorptionLaw) {
|
|
||||||
operations.push(operation);
|
|
||||||
}
|
|
||||||
right.absorption_law(operations, ignore_case)
|
|
||||||
}
|
|
||||||
// TODO remove And from pattern and call matches instead of .is_and()
|
|
||||||
Expression::Binary { left, operator: BinaryOperator::And, right }
|
|
||||||
if left.is_in(right) && right.is_and() => {
|
|
||||||
if let Some(operation) = Operation::new(self, right, Law::AbsorptionLaw) {
|
|
||||||
operations.push(operation);
|
|
||||||
}
|
|
||||||
right.absorption_law(operations, ignore_case)
|
|
||||||
}
|
|
||||||
Expression::Binary { left, operator: BinaryOperator::And, right }
|
|
||||||
if right.is_in(left) && left.is_and() => {
|
|
||||||
if let Some(operation) = Operation::new(self, left, Law::AbsorptionLaw) {
|
|
||||||
operations.push(operation);
|
|
||||||
}
|
|
||||||
left.absorption_law(operations, ignore_case)
|
|
||||||
}
|
|
||||||
Expression::Binary { left, operator, right } => binary(
|
Expression::Binary { left, operator, right } => binary(
|
||||||
left.absorption_law(operations, ignore_case),
|
left.absorption_law(operations, ignore_case),
|
||||||
*operator,
|
*operator,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user