Files
ReactionSystems/src/rsprocess/classical.rs

14 lines
434 B
Rust
Raw Normal View History

2025-05-19 00:10:23 +02:00
use super::structure::{RSset, RSreaction};
pub fn compute_step<'a>(current_state: &RSset<'a>, reaction: &RSreaction<'a>) -> RSset<'a> {
if reaction.enabled(current_state) {
reaction.products_clone()
} else {
RSset::new()
}
}
pub fn compute_all<'a>(current_state: &RSset<'a>, reactions: Vec<&RSreaction<'a>>) -> RSset<'a> {
reactions.iter().fold(RSset::new(), |acc, r| acc.union(&compute_step(current_state, r)))
}