--- 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