1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
use crate::async_graph::{AsyncGraphEdgeParams, DefaultEdgeParams};
use crate::bdd_params::{build_static_constraints, BddParameterEncoder, BddParams};
use crate::biodivine_std::structs::IdState;
use crate::biodivine_std::traits::Set;
use crate::{BooleanNetwork, VariableId};
impl DefaultEdgeParams {
pub fn new(network: BooleanNetwork) -> Result<DefaultEdgeParams, String> {
let encoder = BddParameterEncoder::new(&network);
Self::new_with_custom_encoder(network, encoder)
}
pub fn new_with_custom_encoder(
network: BooleanNetwork,
encoder: BddParameterEncoder,
) -> Result<DefaultEdgeParams, String> {
let unit_set = BddParams::from(build_static_constraints(&network, &encoder));
if unit_set.is_empty() {
Err("No update functions satisfy given constraints".to_string())
} else {
Ok(DefaultEdgeParams {
empty_set: BddParams::from(encoder.bdd_variables.mk_false()),
network,
encoder,
unit_set,
})
}
}
}
impl AsyncGraphEdgeParams for DefaultEdgeParams {
type ParamSet = BddParams;
fn network(&self) -> &BooleanNetwork {
&self.network
}
fn empty_params(&self) -> &Self::ParamSet {
&self.empty_set
}
fn unit_params(&self) -> &Self::ParamSet {
&self.unit_set
}
fn edge_params(&self, state: IdState, variable: VariableId) -> BddParams {
let update_function = &self.network.update_functions[variable.0];
let edge_params = if let Some(update_function) = update_function {
update_function.symbolic_eval_true(state, &self.encoder)
} else {
let var = self.encoder.get_implicit(state, variable);
BddParams::from(self.encoder.bdd_variables.mk_var(var))
};
if state.get_bit(variable.0) {
BddParams::from(edge_params.into_bdd().not())
} else {
edge_params
}
}
fn make_witness(&self, params: &Self::ParamSet) -> BooleanNetwork {
self.network.make_witness(params, &self.encoder)
}
}