Skip to content

Commit

Permalink
add incremental_logging example for all languages
Browse files Browse the repository at this point in the history
  • Loading branch information
teh-cmc committed Mar 11, 2024
1 parent 7d656ec commit adbb1af
Show file tree
Hide file tree
Showing 14 changed files with 283 additions and 7 deletions.
11 changes: 11 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 4 additions & 4 deletions docs/code-examples/all/annotation_context_connections.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,10 +26,10 @@ int main() {
// Log some points with different keypoint IDs
rec.log(
"points",
rerun::Points3D({{0.0f, 0.0f, 0.0f},
{50.0f, 0.0f, 20.0f},
{100.0f, 100.0f, 30.0f},
{0.0f, 50.0f, 40.0f}})
rerun::Points3D(
{{0.0f, 0.0f, 0.0f}, {50.0f, 0.0f, 20.0f}, {100.0f, 100.0f, 30.0f}, {0.0f, 50.0f, 40.0f}
}
)
.with_keypoint_ids({0, 1, 2, 3})
.with_class_ids({0})
);
Expand Down
2 changes: 2 additions & 0 deletions examples/cpp/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ add_subdirectory(clock)
add_subdirectory(custom_collection_adapter)
add_subdirectory(dna)
add_subdirectory(external_data_loader)
add_subdirectory(incremental_logging)
add_subdirectory(log_file)
add_subdirectory(minimal)
add_subdirectory(shared_recording)
Expand All @@ -13,6 +14,7 @@ add_custom_target(examples)
add_dependencies(examples example_clock)
add_dependencies(examples example_custom_collection_adapter)
add_dependencies(examples example_dna)
add_dependencies(examples example_incremental_logging)
add_dependencies(examples example_log_file)
add_dependencies(examples example_minimal)
add_dependencies(examples example_shared_recording)
Expand Down
27 changes: 27 additions & 0 deletions examples/cpp/incremental_logging/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
cmake_minimum_required(VERSION 3.16...3.27)

# If you use the example outside of the Rerun SDK you need to specify
# where the rerun_c build is to be found by setting the `RERUN_CPP_URL` variable.
# This can be done by passing `-DRERUN_CPP_URL=<path to rerun_sdk_cpp zip>` to cmake.
if(DEFINED RERUN_REPOSITORY)
add_executable(example_incremental_logging main.cpp)
rerun_strict_warning_settings(example_incremental_logging)
else()
project(example_incremental_logging LANGUAGES CXX)

add_executable(example_incremental_logging main.cpp)

# Set the path to the rerun_c build.
set(RERUN_CPP_URL "https://github.com/rerun-io/rerun/releases/latest/download/rerun_cpp_sdk.zip" CACHE STRING "URL to the rerun_cpp zip.")

# Download the rerun_sdk
include(FetchContent)
FetchContent_Declare(rerun_sdk URL ${RERUN_CPP_URL})
FetchContent_MakeAvailable(rerun_sdk)

# Rerun requires at least C++17, but it should be compatible with newer versions.
set_property(TARGET example_incremental_logging PROPERTY CXX_STANDARD 17)
endif()

# Link against rerun_sdk.
target_link_libraries(example_incremental_logging PRIVATE rerun_sdk)
27 changes: 27 additions & 0 deletions examples/cpp/incremental_logging/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
<!--[metadata]
title = "Incremental Logging"
tags = ["3d", "api-example"]
description = "Showcases how to incrementally log data belonging to the same archetype."
thumbnail = "https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/480w.png"
thumbnail_dimensions = [480, 285]
channel = "main"
-->


<picture>
<img src="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/full.png" alt="">
<source media="(max-width: 480px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/480w.png">
<source media="(max-width: 768px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/768w.png">
<source media="(max-width: 1024px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/1024w.png">
<source media="(max-width: 1200px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/1200w.png">
</picture>

Showcases how to incrementally log data belonging to the same archetype, and re-use some or all of it across frames.


To build it from a checkout of the repository (requires a Rust toolchain):
```bash
cmake .
cmake --build . --target example_incremental_logging
./examples/cpp/incremental/example_incremental_logging
```
38 changes: 38 additions & 0 deletions examples/cpp/incremental_logging/main.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
// Showcase how to incrementally log data belonging to the same archetype, and re-use some or all
// of it across frames.

#include <rerun.hpp>

#include <algorithm>
#include <random>

int main() {
const auto rec = rerun::RecordingStream("rerun_example_incremental_logging");
rec.spawn().exit_on_failure();

// TODO(#5264): just log one once clamp-to-edge semantics land.
std::vector<rerun::Color> colors(10, rerun::Color(255, 0, 0));
std::vector<rerun::Radius> radii(10, rerun::Radius(0.1));

// Only log colors and radii once.
rec.set_time_sequence("frame_nr", 0);
rec.log("points", colors, radii);
// Logging timelessly with `RecordingStream::log_timeless` would also work.
// rec.log_timeless("points", colors, radii);

std::default_random_engine gen;
std::uniform_real_distribution<float> dist_pos(-5.0f, 5.0f);

// Then log only the points themselves each frame.
//
// They will automatically re-use the colors and radii logged at the beginning.
for (int i = 0; i < 10; ++i) {
rec.set_time_sequence("frame_nr", i);

std::vector<rerun::Position3D> points(10);
std::generate(points.begin(), points.end(), [&] {
return rerun::Position3D(dist_pos(gen), dist_pos(gen), dist_pos(gen));
});
rec.log("points", rerun::Points3D(points));
}
}
25 changes: 25 additions & 0 deletions examples/python/incremental_logging/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
<!--[metadata]
title = "Incremental Logging"
tags = ["3d", "api-example"]
description = "Showcases how to incrementally log data belonging to the same archetype."
thumbnail = "https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/480w.png"
thumbnail_dimensions = [480, 285]
channel = "main"
-->


<picture>
<img src="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/full.png" alt="">
<source media="(max-width: 480px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/480w.png">
<source media="(max-width: 768px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/768w.png">
<source media="(max-width: 1024px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/1024w.png">
<source media="(max-width: 1200px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/1200w.png">
</picture>

Showcases how to incrementally log data belonging to the same archetype, and re-use some or all of it across frames.


To build it from a checkout of the repository (requires a Rust toolchain):
```bash
python examples/python/incremental_logging/main.py
```
36 changes: 36 additions & 0 deletions examples/python/incremental_logging/main.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
#!/usr/bin/env python3
"""Showcases how to incrementally log data belonging to the same archetype, and re-use some or all of it across frames."""
from __future__ import annotations

import argparse

import numpy as np
import rerun as rr
from numpy.random import default_rng

parser = argparse.ArgumentParser(description="Showcases how to incrementally log data belonging to the same archetype.")
rr.script_add_args(parser)
args = parser.parse_args()

rr.script_setup(args, "rerun_example_incremental_logging")

# TODO(#5264): just log one once clamp-to-edge semantics land.
colors = rr.components.ColorBatch(np.repeat(0xFF0000FF, 10))
radii = rr.components.RadiusBatch(np.repeat(0.1, 10))

# Only log colors and radii once.
rr.set_time_sequence("frame_nr", 0)
rr.log_components("points", [colors, radii])
# Logging timelessly would also work.
# rr.log_components("points", [colors, radii], timeless=True)

rng = default_rng(12345)

# Then log only the points themselves each frame.
#
# They will automatically re-use the colors and radii logged at the beginning.
for i in range(10):
rr.set_time_sequence("frame_nr", i)
rr.log("points", rr.Points3D(rng.uniform(-5, 5, size=[10, 3])))

rr.script_teardown(args)
2 changes: 2 additions & 0 deletions examples/python/incremental_logging/requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
numpy
rerun-sdk
15 changes: 15 additions & 0 deletions examples/rust/incremental_logging/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
[package]
name = "incremental_logging"
version = "0.15.0-alpha.2"
edition = "2021"
rust-version = "1.74"
license = "MIT OR Apache-2.0"
publish = false

[dependencies]
rerun = { path = "../../../crates/rerun", features = ["web_viewer", "clap"] }

anyhow = "1.0"
clap = { version = "4.0", features = ["derive"] }
glam = "0.22"
rand = "0.8"
24 changes: 24 additions & 0 deletions examples/rust/incremental_logging/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<!--[metadata]
title = "Incremental Logging"
tags = ["3d", "api-example"]
description = "Showcases how to incrementally log data belonging to the same archetype."
thumbnail = "https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/480w.png"
thumbnail_dimensions = [480, 285]
channel = "main"
-->


<picture>
<img src="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/full.png" alt="">
<source media="(max-width: 480px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/480w.png">
<source media="(max-width: 768px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/768w.png">
<source media="(max-width: 1024px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/1024w.png">
<source media="(max-width: 1200px)" srcset="https://static.rerun.io/incremental_logging/b7a2bd889b09c3840f56dc31bd6d677934ab3126/1200w.png">
</picture>

Showcases how to incrementally log data belonging to the same archetype, and re-use some or all of it across frames.


```bash
cargo run --release
```
66 changes: 66 additions & 0 deletions examples/rust/incremental_logging/src/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
//! Showcase how to incrementally log data belonging to the same archetype, and re-use some or all
//! of it across frames.
//!
//! Usage:
//! ```
//! cargo run -p incremental -- --help
//! ```
use rand::{distributions::Uniform, Rng as _};
use rerun::external::re_log;

#[derive(Debug, clap::Parser)]
#[clap(author, version, about)]
struct Args {
#[command(flatten)]
rerun: rerun::clap::RerunArgs,
}

fn main() -> anyhow::Result<()> {
re_log::setup_logging();

use clap::Parser as _;
let args = Args::parse();

let (rec, _serve_guard) = args.rerun.init("rerun_example_incremental_logging")?;
run(&rec)
}

fn run(rec: &rerun::RecordingStream) -> anyhow::Result<()> {
// TODO(#5264): just log one once clamp-to-edge semantics land.
let colors = [rerun::Color::from_rgb(255, 0, 0); 10];
let radii = [rerun::Radius(0.1); 10];

// Only log colors and radii once.
rec.set_time_sequence("frame_nr", 0);
rec.log_component_batches(
"points",
false, /* timeless */
[&colors as &dyn rerun::ComponentBatch, &radii],
)?;
// Logging timelessly would also work.
// rec.log_component_batches(
// "points",
// true, /* timeless */
// [&colors as &dyn rerun::ComponentBatch, &radii],
// )?;

let mut rng = rand::thread_rng();
let dist = Uniform::new(-5., 5.);

// Then log only the points themselves each frame.
//
// They will automatically re-use the colors and radii logged at the beginning.
for i in 0..10 {
rec.set_time_sequence("frame_nr", i);

rec.log(
"points",
&rerun::Points3D::new(
(0..10).map(|_| (rng.sample(dist), rng.sample(dist), rng.sample(dist))),
),
)?;
}

Ok(())
}
3 changes: 2 additions & 1 deletion rerun_cpp/src/rerun/third_party/cxxopts.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -2038,7 +2038,8 @@ namespace cxxopts {
value->get_implicit_value(),
std::move(arg_help),
value->is_container(),
value->is_boolean()});
value->is_boolean()
});
}

inline void Options::add_one_option(
Expand Down
6 changes: 4 additions & 2 deletions rerun_cpp/tests/mat.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,8 @@ TEST_CASE("Construct Mat4x4 in different ways", TEST_TAG) {
12.0f,
13.0f,
14.f,
15.0f};
15.0f
};
Mat4x4 m4x4(carray);
ctor_checks(m4x4);
}
Expand All @@ -104,7 +105,8 @@ TEST_CASE("Construct Mat4x4 in different ways", TEST_TAG) {
12.0f,
13.0f,
14.f,
15.0f};
15.0f
};
Mat4x4 m4x4(elements.data());
ctor_checks(m4x4);
}
Expand Down

0 comments on commit adbb1af

Please sign in to comment.