New set for positive rs
This commit is contained in:
@ -171,16 +171,6 @@ impl BasicReaction<Set> for Reaction {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Reaction {
|
|
||||||
pub fn from(reactants: Set, inhibitors: Set, products: Set) -> Self {
|
|
||||||
Reaction {
|
|
||||||
reactants,
|
|
||||||
inhibitors,
|
|
||||||
products,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl PrintableWithTranslator for Reaction {
|
impl PrintableWithTranslator for Reaction {
|
||||||
fn print(&self, f: &mut std::fmt::Formatter, translator: &Translator)
|
fn print(&self, f: &mut std::fmt::Formatter, translator: &Translator)
|
||||||
-> std::fmt::Result {
|
-> std::fmt::Result {
|
||||||
@ -193,3 +183,13 @@ impl PrintableWithTranslator for Reaction {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Reaction {
|
||||||
|
pub fn from(reactants: Set, inhibitors: Set, products: Set) -> Self {
|
||||||
|
Reaction {
|
||||||
|
reactants,
|
||||||
|
inhibitors,
|
||||||
|
products,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::collections::BTreeSet;
|
use std::collections::{BTreeSet, BTreeMap};
|
||||||
use std::hash::Hash;
|
use std::hash::Hash;
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
|
|
||||||
@ -75,13 +75,13 @@ impl BasicSet for Set {
|
|||||||
|
|
||||||
// returns the new set a \cup b
|
// returns the new set a \cup b
|
||||||
fn union(&self, other: &Self) -> Self {
|
fn union(&self, other: &Self) -> Self {
|
||||||
let mut ret: Set = other.clone();
|
let mut ret: Self = other.clone();
|
||||||
ret.identifiers.extend(self.identifiers.iter());
|
ret.identifiers.extend(self.identifiers.iter());
|
||||||
ret
|
ret
|
||||||
}
|
}
|
||||||
|
|
||||||
fn push(&mut self, b: &Self) {
|
fn push(&mut self, other: &Self) {
|
||||||
self.identifiers.extend(b.iter())
|
self.identifiers.extend(other.iter())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn extend(&mut self, other: Option<&Self>) {
|
fn extend(&mut self, other: Option<&Self>) {
|
||||||
@ -198,3 +198,161 @@ impl From<Vec<IdType>> for Set {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// -----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#[derive(Clone, Copy, Debug, PartialEq, Eq, PartialOrd, Ord, Serialize,
|
||||||
|
Deserialize)]
|
||||||
|
pub enum IdState {
|
||||||
|
Positive,
|
||||||
|
Negative
|
||||||
|
}
|
||||||
|
|
||||||
|
impl std::fmt::Display for IdState {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
|
match self {
|
||||||
|
Self::Positive => write!(f, "+"),
|
||||||
|
Self::Negative => write!(f, "-")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, Default, PartialOrd, Eq, Ord, Serialize, Deserialize)]
|
||||||
|
pub struct PositiveSet {
|
||||||
|
pub identifiers: BTreeMap<IdType, IdState>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BasicSet for PositiveSet {
|
||||||
|
fn is_subset(&self, other: &Self) -> bool {
|
||||||
|
for (id, s) in self.iter() {
|
||||||
|
if let Some(s1) = other.identifiers.get(id) {
|
||||||
|
if s1 != s {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
true
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_disjoint(&self, other: &Self) -> bool {
|
||||||
|
for (id, _s) in self.iter() {
|
||||||
|
if other.identifiers.contains_key(id) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
true
|
||||||
|
}
|
||||||
|
|
||||||
|
/// ☞ The operation cannot fail, so we prefer self elements to other,
|
||||||
|
/// but if the reaction system is consistent there wont be any problem.
|
||||||
|
fn union(&self, other: &Self) -> Self {
|
||||||
|
let mut ret: Self = other.clone();
|
||||||
|
ret.identifiers.extend(self.identifiers.iter());
|
||||||
|
ret
|
||||||
|
}
|
||||||
|
|
||||||
|
fn push(&mut self, other: &Self) {
|
||||||
|
self.identifiers.extend(other.iter())
|
||||||
|
}
|
||||||
|
|
||||||
|
fn extend(&mut self, other: Option<&Self>) {
|
||||||
|
if let Some(other) = other {
|
||||||
|
self.identifiers.extend(other);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// ☞ only returns values that are shared among both, meaning if they have
|
||||||
|
/// different state (positive, negative) they are considered different.
|
||||||
|
fn intersection(&self, other: &Self) -> Self {
|
||||||
|
let res: BTreeMap<_, _> = other
|
||||||
|
.identifiers
|
||||||
|
.iter()
|
||||||
|
.filter(|(id, s)| {
|
||||||
|
if let Some(s1) = self.identifiers.get(id) && s1 == *s {
|
||||||
|
true
|
||||||
|
} else {
|
||||||
|
false
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.map(|(id, s)| (*id, *s))
|
||||||
|
.collect();
|
||||||
|
PositiveSet { identifiers: res }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// ☞ returns a ∖ b, values that are shared but with different state are
|
||||||
|
/// preserved in the subtraction.
|
||||||
|
fn subtraction(&self, other: &Self) -> Self {
|
||||||
|
let res: BTreeMap<_, _> = self
|
||||||
|
.identifiers
|
||||||
|
.iter()
|
||||||
|
.filter(|(id, s)| {
|
||||||
|
if let Some(s1) = other.identifiers.get(id) && s1 == *s {
|
||||||
|
false
|
||||||
|
} else {
|
||||||
|
true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.map(|(id, s)| (*id, *s))
|
||||||
|
.collect();
|
||||||
|
PositiveSet { identifiers: res }
|
||||||
|
}
|
||||||
|
|
||||||
|
fn len(&self) -> usize {
|
||||||
|
self.identifiers.len()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn is_empty(&self) -> bool {
|
||||||
|
self.identifiers.is_empty()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PrintableWithTranslator for PositiveSet {
|
||||||
|
fn print(
|
||||||
|
&self,
|
||||||
|
f: &mut fmt::Formatter,
|
||||||
|
translator: &Translator,
|
||||||
|
) -> fmt::Result {
|
||||||
|
write!(f, "{{")?;
|
||||||
|
let mut it = self.iter().peekable();
|
||||||
|
while let Some((id, s)) = it.next() {
|
||||||
|
if it.peek().is_none() {
|
||||||
|
write!(f,
|
||||||
|
"{}{}",
|
||||||
|
s,
|
||||||
|
translator.decode(*id).unwrap_or("Missing".into()))?;
|
||||||
|
} else {
|
||||||
|
write!(f,
|
||||||
|
"{}{}, ",
|
||||||
|
s,
|
||||||
|
translator.decode(*id).unwrap_or("Missing".into()))?;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
write!(f, "}}")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl PartialEq for PositiveSet {
|
||||||
|
fn eq(&self, other: &Self) -> bool {
|
||||||
|
self.identifiers.eq(&other.identifiers)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl IntoIterator for PositiveSet {
|
||||||
|
type Item = (IdType, IdState);
|
||||||
|
type IntoIter = std::collections::btree_map::IntoIter<IdType, IdState>;
|
||||||
|
|
||||||
|
fn into_iter(self) -> Self::IntoIter {
|
||||||
|
self.identifiers.into_iter()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> IntoIterator for &'a PositiveSet {
|
||||||
|
type Item = (&'a IdType, &'a IdState);
|
||||||
|
type IntoIter = std::collections::btree_map::Iter<'a, IdType, IdState>;
|
||||||
|
|
||||||
|
fn into_iter(self) -> Self::IntoIter {
|
||||||
|
self.identifiers.iter()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user