Migrating from 0.8 to 0.9
Rerun-0.9 introduces a new set of type-oriented logging APIs built on top of an updated, more concrete, data model.
Rather than using different functions to log different kinds of data, all data logging now goes through a singular log
function. The easiest way to use the log function is with the Rerun-provided "Archetypes."
Archetypes are a newly introduced concept in the data model to go alongside "Components" and "DataTypes." Archetypes
represent common objects that are natively understood by the viewer, e.g. Image or Points3D. Every legacy logging
API has been replaced by one (or more) new Archetypes. You can find more information in the Entity Component section, and a list of available archetypes in the
Archetype Overview. All Archetypes are part of the top-level rerun namespace.
In practice, the changes are mostly demonstrated in the following example:
// 0.8 use rerun::{components::Point3D, MsgSender}; let positions = vec![Point3D::from([1.0, 2.0, 3.0])]; MsgSender::new("points") .with_component(&positions)? .send(&rec)?; // 0.9 rec.log( "points", &rerun::Points3D::new([(1.0, 2.0, 3.0)]), )?;
Note that for any Archetype that supports batching the object names are now plural. For example, points are now logged
with the Points3D archetype. Even if you are logging a single point, under the hood it is always implemented as a
batch of size 1.
For more information on the relationship between Archetypes, Components, and DataTypes, please see our guide to the Rerun Data Model.
Migrating Python code
All of the previous log_* functions have been marked as deprecated and will be removed in 0.10. We have done our
best to keep these functions working as thin wrappers on top of the new logging APIs, though there may be subtle
behavioral differences.
The log module has become the log function
This is one area where we were forced to make breaking changes. Rerun previously had an internal log module where the
assorted log-functions and helper classes were implemented. In general, these symbols were all re-exported to the
top-level rerun namespace. However, in some cases these fully-qualified paths were used for imports. Because
rerun.log is now a function rather than a module, any such imports will result in an import error. Look for the
corresponding symbol in the top-level rerun namespace instead. For instance: rr.log.text.LoggingHandler → rr.LoggingHandler
Updating to the log APIs
In most cases migrating your code to the new APIs should be straightforward. The legacy functions have been marked as deprecated and the deprecation warning should point you to the correct Archetype to use instead. Additionally, in most cases, the old parameter names match the parameters taken by the new Archetype constructors, though exceptions are noted below.
log_annotation_context
Replace with AnnotationContext
Python docs: AnnotationContext
Notes:
- class_descriptionshas become- context
- rr.ClassDescriptionnow requires- infoto be provided rather than defaulting to 0.
- rr.AnnotationInfonow requires- idto be provided rather than defaulting to 0.
log_arrow
Replace with Arrows3D
Python docs: Arrows3D
Notes:
- with_scalehas become- radii, which entails dividing by 2 as necessary.
- identifiershas become- instance_keys.
log_cleared
Replace with Clear
Python docs: Clear
log_depth_image
Replace with DepthImage
Python docs: DepthImage
Notes:
- imagehas become- data
log_disconnected_space
Replace with DisconnectedSpace
Python docs: DisconnectedSpace
log_extension_components
Replace with AnyValues
Python docs: AnyValues
Notes:
- Instead of passing extas a dictionary,AnyValuesnow maps all keyword arguments directly to components.- rr.log_extension_components(…, ext={'mydata': 1})becomes- rr.log(… rr.AnyValues(mydata=1))
 
log_image
Replace with Image
Python docs: Image
Notes:
- imagehas become- data
- jpeg_qualityis now handled by calling- .compress(jpeg_quality=…)on the image after constructing it.
log_image_file
Replace with ImageEncoded
Python docs: ImageEncoded
Notes:
- img_bytesand- img_path
log_line_strip, log_line_strips_2d, log_line_strips_3d, log_line_segments
Replace with LineStrips2D or LineStrips3D
Python docs: LineStrips2D, LineStrips3D
Notes:
- log_line_segmentsused to take an array of shape (2 * num_segments, 2 or 3) (where points were connected in even-odd pairs). Instead this is now handled by a batch of- LineStripsall of length 2. Note that- LineStripsnow takes any sequence of arrays of shape (num_points_per_strip, 2 or 3). You can use convert to the new format using the snippets:
line_strips2d=line_segments.reshape(-1, 2, 2) line_strips3d=line_segments.reshape(-1, 2, 3)
- positionshas become- strips.
- stroke_widthhas become- radii, which entails dividing by 2 as necessary.
- identifiershas become- instance_keys.
log_mesh, log_meshes
Replace with Mesh3D
Python docs: Mesh3D
Notes:
- Meshes are no longer batch objects. Instead they are treated as a batch of vertices, as such there is no longer a
direct equivalent of log_meshes.
- positionshas become- vertex_positions.
- normalshas become- vertex_normals.
- albedo_factorhas become- mesh_material, and can be logged using- rr.Material(albedo_factor=…).
- identifiershas become- instance_keys.
log_mesh_file
Replace with Asset3D
Python docs: Asset3D
Notes:
- mesh_bytesand- mesh_pathare both now jut- data. Strings and paths will be opened as files, while file-descriptors or bytes objects will be read.
- mesh_formatis now- media_type.
- transformcan now take anything that is compatible with- rr.Transform3Dinstead of an affine 3x4 matrix.- To convert an existing affine 3x4 matrix to an rr.Transform3D, you can use,rr.Transform3D(translation=transform[:,3], mat3x3=transform[:,0:3])
 
- To convert an existing affine 3x4 matrix to an 
log_obb, log_obbs
Replace with Boxes3D
Python docs: Boxes3D
Notes:
- positionshas become- centers.
- rotations_qhas become- rotationsand can now take any- Rotation3DArrayLikesuch as- rr.Quaternionor- rr.RotationAxisAngle.
- stroke_widthhas become- radii, which entails dividing by 2 as necessary.
- identifiershas become- instance_keys.
log_pinhole
Replace with Pinhole
Python docs: Pinhole
Notes:
- child_from_parenthas become- image_from_parent.
- focal_length_pxhas become- focal_length.
- principal_point_pxhas become- principal_point.
- New argument resolutionto specify width and height usingVec2D
- camera_xyzno longer take a string. Now use one of the constants from- rr.ViewCoordinates
log_point, log_points
Replace with Points2D or Points3D.
Python docs: Points2D, Points3D
Notes:
- stroke_widthhas become- radii, which entails dividing by 2 as necessary.
- identifiershas become- instance_keys
log_rect, log_rects
Replace with Boxes2D
Python docs: Boxes2D
Notes:
- Can now be constructed with 2 arrays: centers, and eitherhalf_sizesosizes.- The legacy behavior of a single array can be matched by using the params arrayandarray_format.array_formattakes anrr.Box2DFormat.
 
- The legacy behavior of a single array can be matched by using the params 
- identifiershas become- instance_keys.
log_scalar
Replace with TimeSeriesScalar
log_segmentation_image
Replace with SegmentationImage
Python docs: SegmentationImage
Notes:
- imagehas become- data
log_tensor
Replace with Tensor
Python docs: Tensor
Notes:
- tensorhas become- data.
- nameshas become- dim_names.
- meteris no longer supported -- use- rr.DepthImageinstead.
- 1D Tensors can now be logged with BarChart
log_text_entry
Replace with TextLog
Python docs: TextLog
log_transform3d
Replace with Transform3D
Python docs: Transform3D
Notes:
- Now takes optional parameters for translation,rotation,scale, ormat3x3to simplify construction.
log_view_coordinates
Replace with ViewCoordinates
Python docs: ViewCoordinates
Notes:
- Rather than providing xyzorupas strings,rr.ViewCoordinatesexposes a large number of constants that can be logged directly. For example:rr.ViewCoordinates.RDForrr.ViewCoordinates.RIGHT_HAND_Z_DOWN)
Migrating Rust code
Rust already used a more type oriented interface, so the changes are not as drastic as to the Python API.
Removal of MsgSender
The biggest change that MsgSender is gone and all logging happens instead directly on the RecordingStream::RecordingStream
using its log and RecordingStream::log_timeless functions.
Logging time
The new log function logs time implicitly. log_time and log_tick are always included, as well as any custom timeline set using RecordingStream::set_timepoint, or one of the shorthands RecordingStream::set_time_sequence/RecordingStream::set_time_seconds/RecordingStream::set_time_nanos
Components -> archetypes
The new log messages consume any type that implements the AsComponents trait
which is implemented by all archetypes.
All previously separately logged components have corresponding types and are used in one or more archetypes.
See the respective API docs as well as the Archetype Overview to learn more and find self-contained code examples.
For continuing to log collections of components without implementing the AsComponents trait, use RecordingStream::log_component_batches
Splatting
Splatting is no longer done explicitly (before MsgSender::splat), but automatically inferred whenever
there is a single component together with larger component batches on the same entity path.
See also RecordingStream::log_component_batches for more information.