implemented c list creation
This commit is contained in:
parent
658dac758f
commit
644c0a238c
|
@ -106,8 +106,7 @@ impl FlowTable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let c_list = matrix.to_c_list();
|
let reduced_states = matrix.get_reduced_states();
|
||||||
matrix = dbg!(matrix);
|
|
||||||
todo!()
|
todo!()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use std::thread::current;
|
use std::{collections::HashSet, thread::current};
|
||||||
|
|
||||||
use crate::flowtable::FlowTableValue;
|
use crate::flowtable::FlowTableValue;
|
||||||
|
|
||||||
|
@ -103,7 +103,115 @@ impl StateMatrix {
|
||||||
incompatible_pairs.iter().for_each(|&pair| self.propagate_incompatibility(pair));
|
incompatible_pairs.iter().for_each(|&pair| self.propagate_incompatibility(pair));
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn to_c_list(&mut self) {
|
fn to_c_list(&mut self) -> Vec<HashSet<usize>> {
|
||||||
self.add_incompatible_states();
|
self.add_incompatible_states();
|
||||||
|
|
||||||
|
let mut c_list: Vec<HashSet<usize>> = Vec::new();
|
||||||
|
|
||||||
|
for k in (0..self.width).rev() {
|
||||||
|
for row in k+1..self.width+1 {
|
||||||
|
match &self.entries[row * (row - 1) / 2 + k] {
|
||||||
|
Entry::Implications(pairs) => {
|
||||||
|
for pair in pairs {
|
||||||
|
let mut entry: HashSet<usize> = HashSet::new();
|
||||||
|
entry.insert(k);
|
||||||
|
entry.insert(row);
|
||||||
|
|
||||||
|
c_list.push(entry);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if !c_list.is_empty() {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for k in (0..self.width - 1).rev() {
|
||||||
|
let mut valid_rows: HashSet<usize> = HashSet::new();
|
||||||
|
|
||||||
|
for row in k+1..self.width+1 {
|
||||||
|
match &self.entries[row * (row - 1) / 2 + k] {
|
||||||
|
Entry::Implications(_) => {
|
||||||
|
valid_rows.insert(row);
|
||||||
|
},
|
||||||
|
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if valid_rows.is_empty() {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut to_remove: Vec<HashSet<usize>> = vec![];
|
||||||
|
let mut new_entries: Vec<HashSet<usize>> = vec![];
|
||||||
|
for entry in &c_list {
|
||||||
|
let mut intersection: HashSet<&usize> = valid_rows.intersection(entry).collect();
|
||||||
|
|
||||||
|
if intersection.len() > 1 {
|
||||||
|
let mut current_col = HashSet::new();
|
||||||
|
current_col.insert(k);
|
||||||
|
|
||||||
|
intersection.extend(¤t_col);
|
||||||
|
|
||||||
|
new_entries.push(intersection.iter().map(|&&x| x).collect());
|
||||||
|
to_remove.push(entry.clone());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
c_list.retain(|x| !to_remove.contains(x));
|
||||||
|
c_list.append(&mut new_entries);
|
||||||
|
|
||||||
|
for row in k+1..self.width+1 {
|
||||||
|
match &self.entries[row * (row - 1) / 2 + k] {
|
||||||
|
Entry::Implications(_) => {
|
||||||
|
let mut entry: HashSet<usize> = HashSet::new();
|
||||||
|
entry.insert(k);
|
||||||
|
entry.insert(row);
|
||||||
|
|
||||||
|
if !c_list.iter().any(|x| entry.is_subset(x)) {
|
||||||
|
c_list.push(entry);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for k in 0..self.width+1 {
|
||||||
|
let mut entry: HashSet<usize> = HashSet::new();
|
||||||
|
entry.insert(k);
|
||||||
|
|
||||||
|
if !c_list.iter().any(|x| entry.is_subset(x)) {
|
||||||
|
c_list.push(entry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
dbg!(c_list)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn get_reduced_states(&mut self) {
|
||||||
|
let c_list = self.to_c_list();
|
||||||
|
|
||||||
|
let implications: Vec<(HashSet<usize>, HashSet<usize>)> = vec![];
|
||||||
|
for entry in &c_list {
|
||||||
|
let values: Vec<usize> = entry.iter().map(|&x| x).collect();
|
||||||
|
|
||||||
|
for first in &values {
|
||||||
|
for second in &values {
|
||||||
|
if first == second {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue