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
use crate::{HyperedgeIndex, HyperedgeTrait, Hypergraph, VertexTrait};
impl<V, HE> Hypergraph<V, HE>
where
V: VertexTrait,
HE: HyperedgeTrait,
{
pub(crate) fn add_hyperedge_index(&mut self, internal_index: usize) -> HyperedgeIndex {
match self.hyperedges_mapping.left.get(&internal_index) {
Some(hyperedge_index) => *hyperedge_index,
None => {
let hyperedge_index = HyperedgeIndex(self.hyperedges_count);
if self
.hyperedges_mapping
.left
.insert(internal_index, hyperedge_index)
.is_none()
{
self.hyperedges_count += 1;
}
self.hyperedges_mapping
.right
.insert(hyperedge_index, internal_index);
hyperedge_index
}
}
}
}