Impl generate_truth_table

This commit is contained in:
Martin Berg Alstad 2024-06-09 20:09:36 +02:00
parent 4599b952fe
commit 1afd9d9848
2 changed files with 24 additions and 5 deletions

View File

@ -82,7 +82,9 @@ impl TruthTable {
return vec![]; return vec![];
} }
let helper = Self::helper_matrix(count); let helper = Self::helper_matrix(count);
let truths = Self::generate_truth_table(&helper, expression); for row in &helper {
let truths = Self::generate_truth_table(row, expression);
}
todo!() todo!()
} }
@ -100,11 +102,29 @@ impl TruthTable {
// TODO store the expressions along with their values in a list tree structure // TODO store the expressions along with their values in a list tree structure
// For each node. Their left child is index * 2 + 1 and right child is index * 2 + 2 // For each node. Their left child is index * 2 + 1 and right child is index * 2 + 2
// Ex: 0 -> (1, 2), 1 -> (3, 4), 2 -> (5, 6) // Ex: 0 -> (1, 2), 1 -> (3, 4), 2 -> (5, 6)
fn generate_truth_table<'a>(helper: &TruthMatrix, expression: &'a Expression) -> Vec<Option<(&'a Expression, bool)>> { fn generate_truth_table<'a>(truth_row: &[bool], expression: &'a Expression) -> Vec<Option<(&'a Expression, bool)>> {
todo!("Generate the truth table for the given expression") match expression {
not @ Expression::Not(expr) => {
[
vec![Some((not, Self::resolve_expression(not, truth_row)))],
Self::generate_truth_table(truth_row, expr),
vec![None]
].concat()
}
binary @ Expression::Binary { left, right, .. } => {
[
vec![Some((binary, Self::resolve_expression(binary, truth_row)))],
Self::generate_truth_table(truth_row, left),
Self::generate_truth_table(truth_row, right)
].concat()
}
atomic @ Expression::Atomic(_) => {
vec![Some((expression, Self::resolve_expression(atomic, truth_row)))]
}
}
} }
fn resolve_expression(expression: &Expression, truths: &[Option<(&Expression, bool)>]) -> bool { fn resolve_expression(expression: &Expression, helper: &[bool]) -> bool {
todo!("Resolve the expression with the given row of booleans") todo!("Resolve the expression with the given row of booleans")
} }
} }

View File

@ -1,5 +1,4 @@
use std::cmp::max; use std::cmp::max;
use std::ops::{Deref, DerefMut};
#[macro_export] #[macro_export]
macro_rules! set { macro_rules! set {