From b13dacb99b3c981a72b1c5539f2f0715c704fe35 Mon Sep 17 00:00:00 2001 From: Andreas Reich Date: Wed, 18 Dec 2024 12:49:09 +0100 Subject: [PATCH 1/2] make graph examples use a single log call --- docs/snippets/all/archetypes/graph_directed.cpp | 7 +------ docs/snippets/all/archetypes/graph_directed.py | 3 --- docs/snippets/all/archetypes/graph_directed.rs | 14 ++++++-------- .../snippets/all/archetypes/graph_undirected.cpp | 7 +------ docs/snippets/all/archetypes/graph_undirected.py | 9 +++++---- docs/snippets/all/archetypes/graph_undirected.rs | 16 ++++++++-------- 6 files changed, 21 insertions(+), 35 deletions(-) diff --git a/docs/snippets/all/archetypes/graph_directed.cpp b/docs/snippets/all/archetypes/graph_directed.cpp index 3f09463b0eac..97b902d7bb4d 100644 --- a/docs/snippets/all/archetypes/graph_directed.cpp +++ b/docs/snippets/all/archetypes/graph_directed.cpp @@ -10,12 +10,7 @@ int main() { "simple", rerun::GraphNodes({"a", "b", "c"}) .with_positions({{0.0, 100.0}, {-100.0, 0.0}, {100.0, 0.0}}) - .with_labels({"A", "B", "C"}) - ); - - // Note: We log to the same entity here. - rec.log( - "simple", + .with_labels({"A", "B", "C"}), rerun::GraphEdges({{"a", "b"}, {"b", "c"}, {"c", "a"}}) // Graphs are undirected by default. .with_graph_type(rerun::components::GraphType::Directed) diff --git a/docs/snippets/all/archetypes/graph_directed.py b/docs/snippets/all/archetypes/graph_directed.py index 63a803138a3b..d4471994c178 100644 --- a/docs/snippets/all/archetypes/graph_directed.py +++ b/docs/snippets/all/archetypes/graph_directed.py @@ -9,8 +9,5 @@ rr.GraphNodes( node_ids=["a", "b", "c"], positions=[(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)], labels=["A", "B", "C"] ), -) -rr.log( - "simple", rr.GraphEdges(edges=[("a", "b"), ("b", "c"), ("c", "a")], graph_type="directed"), ) diff --git a/docs/snippets/all/archetypes/graph_directed.rs b/docs/snippets/all/archetypes/graph_directed.rs index be05ad8bd407..8a411238fb45 100644 --- a/docs/snippets/all/archetypes/graph_directed.rs +++ b/docs/snippets/all/archetypes/graph_directed.rs @@ -5,14 +5,12 @@ fn main() -> Result<(), Box> { rec.log( "simple", - &rerun::GraphNodes::new(["a", "b", "c"]) - .with_positions([(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)]) - .with_labels(["A", "B", "C"]), - )?; - // Note: We log to the same entity here. - rec.log( - "simple", - &rerun::GraphEdges::new([("a", "b"), ("b", "c"), ("c", "a")]).with_directed_edges(), + &[ + &rerun::GraphNodes::new(["a", "b", "c"]) + .with_positions([(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)]) + .with_labels(["A", "B", "C"]) as &dyn rerun::AsComponents, + &rerun::GraphEdges::new([("a", "b"), ("b", "c"), ("c", "a")]).with_directed_edges(), + ], )?; Ok(()) diff --git a/docs/snippets/all/archetypes/graph_undirected.cpp b/docs/snippets/all/archetypes/graph_undirected.cpp index 2d7e82ddba24..e81fecf36655 100644 --- a/docs/snippets/all/archetypes/graph_undirected.cpp +++ b/docs/snippets/all/archetypes/graph_undirected.cpp @@ -10,12 +10,7 @@ int main() { "simple", rerun::GraphNodes({"a", "b", "c"}) .with_positions({{0.0, 100.0}, {-100.0, 0.0}, {100.0, 0.0}}) - .with_labels({"A", "B", "C"}) - ); - - // Note: We log to the same entity here. - rec.log( - "simple", + .with_labels({"A", "B", "C"}), rerun::GraphEdges({{"a", "b"}, {"b", "c"}, {"c", "a"}}) // Optional: graphs are undirected by default. .with_graph_type(rerun::components::GraphType::Undirected) diff --git a/docs/snippets/all/archetypes/graph_undirected.py b/docs/snippets/all/archetypes/graph_undirected.py index 2397bfc31c5b..556a3782cfc0 100644 --- a/docs/snippets/all/archetypes/graph_undirected.py +++ b/docs/snippets/all/archetypes/graph_undirected.py @@ -9,8 +9,9 @@ rr.GraphNodes( node_ids=["a", "b", "c"], positions=[(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)], labels=["A", "B", "C"] ), -) -rr.log( - "simple", - rr.GraphEdges(edges=[("a", "b"), ("b", "c"), ("c", "a")], graph_type="undirected"), + rr.GraphEdges( + edges=[("a", "b"), ("b", "c"), ("c", "a")], + # Optional: graphs are undirected by default. + graph_type="undirected", + ), ) diff --git a/docs/snippets/all/archetypes/graph_undirected.rs b/docs/snippets/all/archetypes/graph_undirected.rs index affd0ec3d0ee..c87219a931f2 100644 --- a/docs/snippets/all/archetypes/graph_undirected.rs +++ b/docs/snippets/all/archetypes/graph_undirected.rs @@ -5,14 +5,14 @@ fn main() -> Result<(), Box> { rec.log( "simple", - &rerun::GraphNodes::new(["a", "b", "c"]) - .with_positions([(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)]) - .with_labels(["A", "B", "C"]), - )?; - // Note: We log to the same entity here. - rec.log( - "simple", - &rerun::GraphEdges::new([("a", "b"), ("b", "c"), ("c", "a")]).with_undirected_edges(), // Optional: graphs are undirected by default. + &[ + &rerun::GraphNodes::new(["a", "b", "c"]) + .with_positions([(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)]) + .with_labels(["A", "B", "C"]) as &dyn rerun::AsComponents, + &rerun::GraphEdges::new([("a", "b"), ("b", "c"), ("c", "a")]) + // Optional: graphs are undirected by default. + .with_undirected_edges(), + ], )?; Ok(()) From 9351b2ad0b8210a575b88e1532605b00f5ff73de Mon Sep 17 00:00:00 2001 From: Andreas Reich Date: Wed, 18 Dec 2024 12:53:30 +0100 Subject: [PATCH 2/2] embedd directed graph example in code comment --- .../rerun/archetypes/graph_edges.fbs | 2 +- .../rerun/archetypes/graph_nodes.fbs | 2 +- .../re_types/src/archetypes/graph_edges.rs | 30 +++++++++++++++++++ .../re_types/src/archetypes/graph_nodes.rs | 30 +++++++++++++++++++ .../src/rerun/archetypes/graph_edges.hpp | 24 +++++++++++++++ .../src/rerun/archetypes/graph_nodes.hpp | 24 +++++++++++++++ .../rerun_sdk/rerun/archetypes/graph_edges.py | 27 +++++++++++++++++ .../rerun_sdk/rerun/archetypes/graph_nodes.py | 27 +++++++++++++++++ 8 files changed, 164 insertions(+), 2 deletions(-) diff --git a/crates/store/re_types/definitions/rerun/archetypes/graph_edges.fbs b/crates/store/re_types/definitions/rerun/archetypes/graph_edges.fbs index a20ea2d39fa1..337787158f71 100644 --- a/crates/store/re_types/definitions/rerun/archetypes/graph_edges.fbs +++ b/crates/store/re_types/definitions/rerun/archetypes/graph_edges.fbs @@ -7,7 +7,7 @@ namespace rerun.archetypes; /// By default, edges are undirected. /// /// \example archetypes/graph_undirected !api title="Simple undirected graph" image="https://static.rerun.io/graph_undirected/15f46bec77452a8c6220558e4403b99cac188e2e/1200w.png" -/// \example archetypes/graph_directed !api title="Simple directed graph" image="https://static.rerun.io/graph_directed/ca29a37b65e1e0b6482251dce401982a0bc568fa/1200w.png" +/// \example archetypes/graph_directed title="Simple directed graph" image="https://static.rerun.io/graph_directed/ca29a37b65e1e0b6482251dce401982a0bc568fa/1200w.png" table GraphEdges ( "attr.docs.category": "Graph", "attr.docs.unreleased", diff --git a/crates/store/re_types/definitions/rerun/archetypes/graph_nodes.fbs b/crates/store/re_types/definitions/rerun/archetypes/graph_nodes.fbs index 7e7ddb535164..142a88dd2444 100644 --- a/crates/store/re_types/definitions/rerun/archetypes/graph_nodes.fbs +++ b/crates/store/re_types/definitions/rerun/archetypes/graph_nodes.fbs @@ -5,7 +5,7 @@ namespace rerun.archetypes; /// A list of nodes in a graph with optional labels, colors, etc. /// /// \example archetypes/graph_undirected !api title="Simple undirected graph" image="https://static.rerun.io/graph_undirected/15f46bec77452a8c6220558e4403b99cac188e2e/1200w.png" -/// \example archetypes/graph_directed !api title="Simple directed graph" image="https://static.rerun.io/graph_directed/ca29a37b65e1e0b6482251dce401982a0bc568fa/1200w.png" +/// \example archetypes/graph_directed title="Simple directed graph" image="https://static.rerun.io/graph_directed/ca29a37b65e1e0b6482251dce401982a0bc568fa/1200w.png" table GraphNodes ( "attr.docs.category": "Graph", "attr.docs.unreleased", diff --git a/crates/store/re_types/src/archetypes/graph_edges.rs b/crates/store/re_types/src/archetypes/graph_edges.rs index a4aee2905982..d30dfea19a76 100644 --- a/crates/store/re_types/src/archetypes/graph_edges.rs +++ b/crates/store/re_types/src/archetypes/graph_edges.rs @@ -23,6 +23,36 @@ use ::re_types_core::{DeserializationError, DeserializationResult}; /// By default, edges are undirected. /// /// ⚠️ **This type is experimental and may be removed in future versions** +/// +/// ## Example +/// +/// ### Simple directed graph +/// ```ignore +/// fn main() -> Result<(), Box> { +/// let rec = rerun::RecordingStreamBuilder::new("rerun_example_graph_directed").spawn()?; +/// +/// rec.log( +/// "simple", +/// &[ +/// &rerun::GraphNodes::new(["a", "b", "c"]) +/// .with_positions([(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)]) +/// .with_labels(["A", "B", "C"]) as &dyn rerun::AsComponents, +/// &rerun::GraphEdges::new([("a", "b"), ("b", "c"), ("c", "a")]).with_directed_edges(), +/// ], +/// )?; +/// +/// Ok(()) +/// } +/// ``` +///
+/// +/// +/// +/// +/// +/// +/// +///
#[derive(Clone, Debug, PartialEq, Eq)] pub struct GraphEdges { /// A list of node tuples. diff --git a/crates/store/re_types/src/archetypes/graph_nodes.rs b/crates/store/re_types/src/archetypes/graph_nodes.rs index 7a2c73d84601..3f3e707e185f 100644 --- a/crates/store/re_types/src/archetypes/graph_nodes.rs +++ b/crates/store/re_types/src/archetypes/graph_nodes.rs @@ -21,6 +21,36 @@ use ::re_types_core::{DeserializationError, DeserializationResult}; /// **Archetype**: A list of nodes in a graph with optional labels, colors, etc. /// /// ⚠️ **This type is experimental and may be removed in future versions** +/// +/// ## Example +/// +/// ### Simple directed graph +/// ```ignore +/// fn main() -> Result<(), Box> { +/// let rec = rerun::RecordingStreamBuilder::new("rerun_example_graph_directed").spawn()?; +/// +/// rec.log( +/// "simple", +/// &[ +/// &rerun::GraphNodes::new(["a", "b", "c"]) +/// .with_positions([(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)]) +/// .with_labels(["A", "B", "C"]) as &dyn rerun::AsComponents, +/// &rerun::GraphEdges::new([("a", "b"), ("b", "c"), ("c", "a")]).with_directed_edges(), +/// ], +/// )?; +/// +/// Ok(()) +/// } +/// ``` +///
+/// +/// +/// +/// +/// +/// +/// +///
#[derive(Clone, Debug, PartialEq)] pub struct GraphNodes { /// A list of node IDs. diff --git a/rerun_cpp/src/rerun/archetypes/graph_edges.hpp b/rerun_cpp/src/rerun/archetypes/graph_edges.hpp index 4e60d8e23d82..a19940a3a351 100644 --- a/rerun_cpp/src/rerun/archetypes/graph_edges.hpp +++ b/rerun_cpp/src/rerun/archetypes/graph_edges.hpp @@ -21,6 +21,30 @@ namespace rerun::archetypes { /// /// By default, edges are undirected. /// + /// ## Example + /// + /// ### Simple directed graph + /// ![image](https://static.rerun.io/graph_directed/ca29a37b65e1e0b6482251dce401982a0bc568fa/full.png) + /// + /// ```cpp + /// #include + /// + /// int main() { + /// const auto rec = rerun::RecordingStream("rerun_example_graph_directed"); + /// rec.spawn().exit_on_failure(); + /// + /// rec.log( + /// "simple", + /// rerun::GraphNodes({"a", "b", "c"}) + /// .with_positions({{0.0, 100.0}, {-100.0, 0.0}, {100.0, 0.0}}) + /// .with_labels({"A", "B", "C"}), + /// rerun::GraphEdges({{"a", "b"}, {"b", "c"}, {"c", "a"}}) + /// // Graphs are undirected by default. + /// .with_graph_type(rerun::components::GraphType::Directed) + /// ); + /// } + /// ``` + /// /// ⚠ **This is an experimental API! It is not fully supported, and is likely to change significantly in future versions.** struct GraphEdges { /// A list of node tuples. diff --git a/rerun_cpp/src/rerun/archetypes/graph_nodes.hpp b/rerun_cpp/src/rerun/archetypes/graph_nodes.hpp index 1323569a7137..3ee519b9e729 100644 --- a/rerun_cpp/src/rerun/archetypes/graph_nodes.hpp +++ b/rerun_cpp/src/rerun/archetypes/graph_nodes.hpp @@ -23,6 +23,30 @@ namespace rerun::archetypes { /// **Archetype**: A list of nodes in a graph with optional labels, colors, etc. /// + /// ## Example + /// + /// ### Simple directed graph + /// ![image](https://static.rerun.io/graph_directed/ca29a37b65e1e0b6482251dce401982a0bc568fa/full.png) + /// + /// ```cpp + /// #include + /// + /// int main() { + /// const auto rec = rerun::RecordingStream("rerun_example_graph_directed"); + /// rec.spawn().exit_on_failure(); + /// + /// rec.log( + /// "simple", + /// rerun::GraphNodes({"a", "b", "c"}) + /// .with_positions({{0.0, 100.0}, {-100.0, 0.0}, {100.0, 0.0}}) + /// .with_labels({"A", "B", "C"}), + /// rerun::GraphEdges({{"a", "b"}, {"b", "c"}, {"c", "a"}}) + /// // Graphs are undirected by default. + /// .with_graph_type(rerun::components::GraphType::Directed) + /// ); + /// } + /// ``` + /// /// ⚠ **This is an experimental API! It is not fully supported, and is likely to change significantly in future versions.** struct GraphNodes { /// A list of node IDs. diff --git a/rerun_py/rerun_sdk/rerun/archetypes/graph_edges.py b/rerun_py/rerun_sdk/rerun/archetypes/graph_edges.py index 4fa4c6017d9b..a1568b980108 100644 --- a/rerun_py/rerun_sdk/rerun/archetypes/graph_edges.py +++ b/rerun_py/rerun_sdk/rerun/archetypes/graph_edges.py @@ -26,6 +26,33 @@ class GraphEdges(Archetype): By default, edges are undirected. ⚠️ **This is an experimental API! It is not fully supported, and is likely to change significantly in future versions.** + + Example + ------- + ### Simple directed graph: + ```python + import rerun as rr + + rr.init("rerun_example_graph_directed", spawn=True) + + rr.log( + "simple", + rr.GraphNodes( + node_ids=["a", "b", "c"], positions=[(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)], labels=["A", "B", "C"] + ), + rr.GraphEdges(edges=[("a", "b"), ("b", "c"), ("c", "a")], graph_type="directed"), + ) + ``` +
+ + + + + + + +
+ """ def __init__(self: Any, edges: datatypes.Utf8PairArrayLike, *, graph_type: components.GraphTypeLike | None = None): diff --git a/rerun_py/rerun_sdk/rerun/archetypes/graph_nodes.py b/rerun_py/rerun_sdk/rerun/archetypes/graph_nodes.py index bed4372bbaad..13426e12ae29 100644 --- a/rerun_py/rerun_sdk/rerun/archetypes/graph_nodes.py +++ b/rerun_py/rerun_sdk/rerun/archetypes/graph_nodes.py @@ -24,6 +24,33 @@ class GraphNodes(Archetype): **Archetype**: A list of nodes in a graph with optional labels, colors, etc. ⚠️ **This is an experimental API! It is not fully supported, and is likely to change significantly in future versions.** + + Example + ------- + ### Simple directed graph: + ```python + import rerun as rr + + rr.init("rerun_example_graph_directed", spawn=True) + + rr.log( + "simple", + rr.GraphNodes( + node_ids=["a", "b", "c"], positions=[(0.0, 100.0), (-100.0, 0.0), (100.0, 0.0)], labels=["A", "B", "C"] + ), + rr.GraphEdges(edges=[("a", "b"), ("b", "c"), ("c", "a")], graph_type="directed"), + ) + ``` +
+ + + + + + + +
+ """ def __init__(