---
source: hydroflow/tests/surface_stratum.rs
expression: "df.meta_graph().unwrap().to_mermaid(&Default::default())"
---
%%{init:{'theme':'base','themeVariables':{'clusterBkg':'#ddd','clusterBorder':'#888'}}}%%
flowchart TD
classDef pullClass fill:#8af,stroke:#000,text-align:left,white-space:pre
classDef pushClass fill:#ff8,stroke:#000,text-align:left,white-space:pre
classDef otherClass fill:#fdc,stroke:#000,text-align:left,white-space:pre
linkStyle default stroke:#aaa
1v1[\"(1v1) union()
"/]:::pullClass
2v1[\"(2v1) map(|v| (v, ()))
"/]:::pullClass
3v1[\"(3v1) source_iter(vec![0])
"/]:::pullClass
4v1[\"(4v1) source_stream(pairs_recv)
"/]:::pullClass
5v1[/"(5v1) tee()
"\]:::pushClass
6v1[\"(6v1) join()
"/]:::pullClass
7v1[\"(7v1) map(|(_src, ((), dst))| dst)
"/]:::pullClass
8v1[\"(8v1) map(|x| x)
"/]:::pullClass
9v1[\"(9v1) map(|x| x)
"/]:::pullClass
10v1[/"(10v1) tee()
"\]:::pushClass
11v1[\"(11v1) difference()
"/]:::pullClass
12v1[/"(12v1) for_each(|x| println!("Not reached: {}", x))
"\]:::pushClass
13v1[\"(13v1) flat_map(|(a, b)| [a, b])
"/]:::pullClass
14v1["(14v1) handoff
"]:::otherClass
15v1["(15v1) handoff
"]:::otherClass
16v1["(16v1) handoff
"]:::otherClass
17v1["(17v1) handoff
"]:::otherClass
1v1-->2v1
3v1-->|0|1v1
4v1-->5v1
9v1-->10v1
8v1-->9v1
7v1-->8v1
6v1-->7v1
2v1-->|0|6v1
5v1-->|1|14v1
10v1-->|0|15v1
11v1-->12v1
13v1-->|pos|11v1
5v1-->|0|16v1
10v1-->|1|17v1
14v1-->|1|6v1
15v1-->|1|1v1
16v1-->13v1
17v1--x|neg|11v1; linkStyle 17 stroke:red
subgraph sg_1v1 ["sg_1v1 stratum 0"]
4v1
5v1
subgraph sg_1v1_var_edges ["var edges"]
4v1
5v1
end
end
subgraph sg_2v1 ["sg_2v1 stratum 0"]
15v1
3v1
1v1
2v1
6v1
7v1
8v1
9v1
10v1
subgraph sg_2v1_var_my_join_tee ["var my_join_tee"]
6v1
7v1
8v1
9v1
10v1
end
subgraph sg_2v1_var_reached_vertices ["var reached_vertices"]
1v1
2v1
end
end
subgraph sg_3v1 ["sg_3v1 stratum 1"]
13v1
11v1
12v1
subgraph sg_3v1_var_diff ["var diff"]
11v1
12v1
end
end