Skip to content

Commit

Permalink
refactor(bool fn trait): removed redundant code from table's substitute
Browse files Browse the repository at this point in the history
  • Loading branch information
AurumTheEnd authored and daemontus committed May 9, 2024
1 parent ea06433 commit 381c69e
Showing 1 changed file with 2 additions and 6 deletions.
8 changes: 2 additions & 6 deletions src/table/traits/boolean_function.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
use crate::iterators::DomainIterator;
use crate::table::iterators::{ImageIterator, RelationIterator, SupportIterator};
use crate::table::utils::values_to_row_index;
use crate::table::TruthTable;
use crate::traits::{
BooleanFunction, BooleanValuation, Evaluate, GatherLiterals, PowerSet, SemanticEq,
Expand Down Expand Up @@ -109,9 +108,7 @@ impl<T: Debug + Clone + Ord + 'static> BooleanFunction<T> for TruthTable<T> {
);

// alter current valuation based on mappings
for (index, (_bool, variable)) in
original_point.into_iter().zip(&final_inputs).enumerate()
{
for (index, variable) in final_inputs.iter().enumerate() {
if let Some(substitution_table) = mapping.get(variable) {
let output = substitution_table.evaluate(&original_valuation);
final_point[index] = output;
Expand All @@ -122,8 +119,7 @@ impl<T: Debug + Clone + Ord + 'static> BooleanFunction<T> for TruthTable<T> {
.expect(
"Point should be from domain of the same dimension as the number of inputs",
);
let final_index = values_to_row_index(&self.inputs, &final_valuation);
outputs.push(self.outputs[final_index])
outputs.push(self.evaluate(&final_valuation))
}

TruthTable::new(Vec::from_iter(final_inputs), outputs)
Expand Down

0 comments on commit 381c69e

Please sign in to comment.