Crate rerun

source ·
Expand description

§Rerun - Visualize streams of multimodal data.

Add the rerun library to your crate with cargo add rerun.

There is also a rerun binary. The binary is required in order to stream log data over the networks, and to open our .rrd data files. If you need it, install the rerun binary with cargo install rerun-cli --locked.

§Feature flags

  • analytics (enabled by default) — Enable telemetry using our analytics SDK.

  • clap — Integration with clap.

  • data_loaders (enabled by default) — Support for using Rerun’s data-loaders directly from the SDK.

    See our log_file example and https://www.rerun.io/docs/reference/data-loaders/overview for more information.

  • demo (enabled by default) — Demo helpers for examples.

  • dataframe (enabled by default) — Access to Rerun’s dataframe API and related types.

  • glam (enabled by default) — Add support for some math operations using glam. Only relevant if feature sdk is enabled.

  • mint — Add support for math type conversions using mint. Only relevant if feature sdk is enabled.

  • image (enabled by default) — Integration with the image crate, plus JPEG support.

  • ecolor — Integration with the ecolor crate.

  • log (enabled by default) — Integration with the log crate.

  • nasm — Enable faster native video decoding with assembly. You need to install nasm to compile with this feature.

  • native_viewer — Support spawning a native viewer. This adds a lot of extra dependencies, so only enable this feature if you need it!

  • map_view (enabled by default) — Support the map view. This adds a lot of extra dependencies.

  • grpc — Enable the gRPC Rerun Data Platform data source.

  • run — Add support for the run() function, which acts like a main-function for a CLI, acting the same as the rerun binary.

  • server (enabled by default) — Support for running a TCP server that listens to incoming log messages from a Rerun SDK.

  • sdk (enabled by default) — Embed the Rerun SDK & built-in types and re-export all of their public symbols.

  • web_viewer — Support serving a web viewer over HTTP.

    Enabling this inflates the binary size quite a bit, since it embeds the viewer wasm.

    For faster & easier builds, a pre-built web-views comes bundled with the crate as a Wasm binary. Enabling this feature will embed this pre-built web viewer.

    However, when building from source in the repository, this feature adds quite a bit to the compile time since it requires compiling and bundling the viewer as wasm.

There are many different ways of sending data to the Rerun Viewer depending on what you’re trying to achieve and whether the viewer is running in the same process as your code, in another process, or even as a separate web application.

Checkout SDK Operating Modes for an overview of what’s possible and how.

If you get stuck on anything, open an issue at https://github.com/rerun-io/rerun/issues. You can also ask questions on the Rerun Discord.

§Using the rerun binary

The rerun binary is required in order to stream log data over the networks, and to open our .rrd data files.

The binary can act either as a server, a viewer, or both, depending on which options you use when you start it.

Install it with cargo install rerun-cli --locked.

Running just rerun will start the viewer, waiting for the logging library to connect using RecordingStreamBuilder::connect (see below).

You can run rerun --help for more info.

§Using the rerun library

§Logging

You first create a RecordingStream using RecordingStreamBuilder. You then use it to log some archetypes to a given EntityPath using RecordingStream::log:

// Stream log data to an awaiting `rerun` process.
let rec = rerun::RecordingStreamBuilder::new("rerun_example_app").connect()?;

let points: Vec<rerun::Position3D> = positions();
let colors: Vec<rerun::Color> = colors();
let image: image::DynamicImage = capture_image();

rec.set_time_sequence("frame", 42);
rec.log("path/to/points", &rerun::Points3D::new(points).with_colors(colors))?;
rec.log("path/to/image", &rerun::Image::from_color_model_and_tensor(rerun::ColorModel::RGB, image)?)?;
§Streaming to disk

Streaming data to a file on disk using the .rrd format:

let rec = rerun::RecordingStreamBuilder::new("rerun_example_app").save("my_data.rrd")?;
§Buffering

You can buffer the log messages in memory and then show them in an embedded viewer:

let (rec, storage) = rerun::RecordingStreamBuilder::new("rerun_example_app").memory()?;
log_to(&rec);

// Will block program execution!
rerun::native_viewer::show(main_thread_token, storage.take());
cargo install rerun
rerun --help

§Forwarding text log events to Rerun

See Logger.

Re-exports§

  • pub use log_integration::Logger;

Modules§

Macros§

Structs§

  • Component: A color multiplier, usually applied to a whole entity, e.g. a mesh.
  • Datatype: Angle in radians.
  • Archetype: The annotation context provides additional information on how to display entities.
  • Datatype: Annotation info annotating a class id or key-point id.
  • The user-chosen name of the application doing the logging.
  • The fully-qualified name of an Archetype, e.g. rerun.archetypes.Points3D.
  • Archetype: 2D arrows with optional colors, radii, labels, etc.
  • Archetype: 3D arrows with optional colors, radii, labels, etc.
  • Archetype: A prepacked 3D asset (.gltf, .glb, .obj, .stl, etc.).
  • Archetype: A video binary.
  • Archetype: A bar chart.
  • Archetype: 2D boxes with half-extents and optional center, colors etc.
  • Archetype: 3D boxes with half-extents and optional center, rotations, colors etc.
  • Archetype: 3D capsules; cylinders with hemispherical caps.
  • Everything needed to build custom ChunkStoreSubscribers. A complete chunk store: covers all timelines, all entities, everything.
  • Everything needed to build custom ChunkStoreSubscribers.
  • Everything needed to build custom ChunkStoreSubscribers. Describes an atomic change in the Rerun ChunkStore: a chunk has been added or deleted.
  • Everything needed to build custom ChunkStoreSubscribers. The atomic unit of change in the Rerun ChunkStore.
  • Everything needed to build custom ChunkStoreSubscribers. Incremented on each edit.
  • Everything needed to build custom ChunkStoreSubscribers. A ref-counted, inner-mutable handle to a ChunkStore.
  • Datatype: The description of a semantic Class.
  • Archetype: Empties all the components of an entity.
  • Component: An RGBA color with unmultiplied/separate alpha, in sRGB gamma space with linear alpha.
  • Some ComponentBatch, optionally with an overridden ComponentDescriptor.
  • A ComponentDescriptor fully describes the semantics of a column of data.
  • The fully-qualified name of a Component, e.g. rerun.components.Position2D.
  • Recommended settings for the DataLoader.
  • The fully-qualified name of a [Datatype], e.g. rerun.datatypes.Vec2D.
  • Archetype: A depth image, i.e. as captured by a depth camera.
  • Archetype: Spatially disconnect this entity from its parent.
  • Archetype: 3D ellipsoids or spheres.
  • Archetype: An image encoded as e.g. a JPEG or PNG.
  • The unique identifier of an entity, e.g. camera/3/points
  • The different parts that make up an EntityPath.
  • Datatype: A single-precision 32-bit IEEE 754 floating point number.
  • A generic indicator component that can be specialized for any Archetype.
  • Archetype: Geospatial line strings with positions expressed in EPSG:4326 altitude and longitude (North/East-positive degrees), and optional colors and radii.
  • Archetype: Geospatial points with positions expressed in EPSG:4326 latitude and longitude (North/East-positive degrees), and optional colors and radii.
  • Archetype: A list of edges in a graph.
  • Archetype: A list of nodes in a graph with optional labels, colors, etc.
  • Component: Half-size (radius) of a 2D box.
  • Component: Half-size (radius) of a 3D box.
  • Archetype: A monochrome or color image.
  • Component: The metadata describing the contents of a components::ImageBuffer.
  • A unique numeric index for each individual instance within a batch.
  • Archetype: One or more transforms between the current entity and its parent. Unlike archetypes::Transform3D, it is not propagated in the transform hierarchy.
  • Datatype: A connection between two datatypes::KeypointIds.
  • Component: A line strip in 2D space.
  • Component: A line strip in 3D space.
  • Archetype: 2D line strips with positions and optional colors, radii, labels, etc.
  • Archetype: 3D line strips with positions and optional colors, radii, labels, etc.
  • A token that (almost) proves we are on the main thread.
  • Datatype: A 3x3 Matrix.
  • Component: A standardized media type (RFC2046, formerly known as MIME types), encoded as a string.
  • Represents a limit in how much RAM to use for the entire process.
  • Archetype: A 3D triangle mesh as specified by its per-mesh and per-vertex properties.
  • An arbitrary named indicator component.
  • Archetype: Camera perspective projection (a.k.a. intrinsics).
  • Archetype: A 2D point cloud with positions and optional colors, radii, labels, etc.
  • Archetype: A 3D point cloud with positions and optional colors, radii, labels, etc.
  • Component: A position in 2D space.
  • Component: A position in 3D space.
  • Datatype: A Quaternion represented by 4 real numbers.
  • Component: The radius of something, e.g. a point.
  • A RecordingStream handles everything related to logging data into Rerun.
  • Construct a RecordingStream.
  • Datatype: An RGBA color with unmultiplied/separate alpha, in sRGB gamma space with linear alpha.
  • Datatype: 3D rotation represented by a rotation around a given axis.
  • Archetype: A double-precision scalar, e.g. for use for time-series plots.
  • Component: A 3D scale factor.
  • Archetype: An image made up of integer components::ClassIds.
  • Archetype: Define the style properties for a line series in a chart.
  • Archetype: Define the style properties for a point series in a chart.
  • Options to control the behavior of spawn.
  • A unique id per store.
  • Archetype: An N-dimensional array of numbers.
  • Datatype: An N-dimensional array of numbers.
  • Datatype: A single dimension within a multi-dimensional tensor.
  • Component: A string of text, e.g. for labels and text documents.
  • Archetype: A text element intended to be displayed in its own text box.
  • Archetype: A log entry in a text log, comprised of a text body and its log level.
  • Component: The severity level of a text log message.
  • A date-time represented as nanoseconds since unix epoch
  • A point in time on any number of Timelines.
  • A time frame/space, e.g. log_time or frame_nr, coupled with the type of time it keeps.
  • Archetype: A transform between two 3D spaces, i.e. a pose.
  • Component: The three indices of a triangle in a triangle mesh.
  • Datatype: A vector in 2D space.
  • Datatype: A vector in 3D space.
  • Datatype: A vector in 4D space.
  • Component: A vector in 2D space.
  • Component: A vector in 3D space.
  • Archetype: References a single video frame.
  • Archetype: How we interpret the coordinate system of an entity/space.

Enums§

Constants§

Traits§

Functions§

Type Aliases§