Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improved 3D transform ingestion & affine transform support #2102

Merged
merged 65 commits into from
May 24, 2023
Merged
Show file tree
Hide file tree
Changes from 62 commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
4b66859
Transform is now Transform3D and has an affine transform with various…
Wumpf May 8, 2023
ff40336
todo notes on sparse enums in transform3d
Wumpf May 8, 2023
d002def
from instead of into glam impls
Wumpf May 8, 2023
a83cb04
add more utilities, port rust examples
Wumpf May 8, 2023
feb56ee
better ui display for transform3d
Wumpf May 8, 2023
c5bfec1
transform3d now also captures direction parent/child child/parent
Wumpf May 9, 2023
dc4e45a
Fix images with same render order not layering transparently
Wumpf May 10, 2023
a456898
nicer draw order sample
Wumpf May 10, 2023
5fd0c32
every draw order given out is individual again to avoid z fighting
Wumpf May 10, 2023
7e35d83
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 11, 2023
de15d89
affine3 python interface wip
Wumpf May 11, 2023
1254df0
unified affine transform logging from python
Wumpf May 11, 2023
28b3935
hide zero translations
Wumpf May 11, 2023
4e75162
fix up log_rigid3 and deprecate it
Wumpf May 11, 2023
3a38814
example for log_affine3
Wumpf May 11, 2023
45db487
Rename RotationAxisAngle
Wumpf May 11, 2023
276b859
py-lint fixes
Wumpf May 11, 2023
aff556c
re-enable data_table_sizes_basics test
Wumpf May 11, 2023
7920c27
more docs and doc tests for transform3d
Wumpf May 11, 2023
f405d96
implement pinhole via transform3d.py
Wumpf May 11, 2023
314626f
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 12, 2023
3270cb6
Merge remote-tracking branch 'origin/main' into andreas/2d-layering-f…
Wumpf May 12, 2023
bd7763d
spelling
Wumpf May 12, 2023
acf8e9d
better affine transform error messages on python, fix tensor logging …
Wumpf May 12, 2023
d4bb47a
linting, small improvements
Wumpf May 12, 2023
d49c7af
update all uses of log_rigid3 in python examples
Wumpf May 12, 2023
a52d7ee
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 12, 2023
4be743d
fix old python incompatibility issues
Wumpf May 12, 2023
b0686c9
Merge branch 'andreas/2d-layering-fixes' into andreas/transform3d
Wumpf May 12, 2023
a0b490b
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 16, 2023
87488ff
split up transform enum into three different components
Wumpf May 16, 2023
aea1bde
wire up python sdk again to new components
Wumpf May 16, 2023
8fee5fe
fix pinhole camera not being categorized as spatial
Wumpf May 16, 2023
97249ac
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 16, 2023
e38ecf6
enable custom pinhole ui
Wumpf May 16, 2023
d527a99
Merge remote-tracking branch 'origin/main' into andreas/transform3d-new
Wumpf May 16, 2023
ac0dda6
Rename to TranslationAndMat3
Wumpf May 16, 2023
7d3bf79
fixup some tests in re_log_types
Wumpf May 16, 2023
0edf749
mono component documentation
Wumpf May 16, 2023
c77c03c
fixup test_clean_for_polars_modify
Wumpf May 17, 2023
832f3d2
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 17, 2023
018e472
change python api to log_transform3d
Wumpf May 17, 2023
f7a2bc1
explicit quaternion type for python
Wumpf May 17, 2023
33c47a7
Translation3D is now its own enum to allow explicit non-logged transl…
Wumpf May 17, 2023
19d299f
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 17, 2023
e8c85e8
fix quaternion logging in examples
Wumpf May 17, 2023
93bbdd8
slightly better error messages on wrong type in python transform api
Wumpf May 17, 2023
4bebaf3
Rust fmt
Wumpf May 17, 2023
5765764
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 22, 2023
5d62264
rust test fix
Wumpf May 22, 2023
2b3b520
Avoid using attr.dataclass
jleibs May 22, 2023
e1a9fbb
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 24, 2023
4eebd94
comment and cosmetic fixes, fixes for ros demo
Wumpf May 24, 2023
d0a6e7c
translation/rotation/scale are now options
Wumpf May 24, 2023
04f4191
rename creation methods in rust api fro Transform3D
Wumpf May 24, 2023
31aa422
fixup SpaceInfoConnection to be more versatile
Wumpf May 24, 2023
f498052
Rigid3D helper class on python
Wumpf May 24, 2023
cbcaf0a
a bit nicer rust api, less word duplication
Wumpf May 24, 2023
f4be39e
Quaternion is no longer a dataclass in order to enforce spelling out…
Wumpf May 24, 2023
fac8319
fix documentation of datalayout for matrix on python transform api
Wumpf May 24, 2023
232fde7
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 24, 2023
515a27e
test/lint fixes
Wumpf May 24, 2023
08c3b17
doc fix
Wumpf May 24, 2023
72ed12a
fixup ros demo
Wumpf May 24, 2023
c7ebfc8
Merge remote-tracking branch 'origin/main' into andreas/transform3d
Wumpf May 24, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
151 changes: 53 additions & 98 deletions crates/re_arrow_store/src/arrow_util.rs
Original file line number Diff line number Diff line change
Expand Up @@ -233,109 +233,64 @@ fn test_clean_for_polars_nomodify() {
assert_eq!(cell.as_arrow_ref(), &*cleaned);
}

#[test]
fn test_clean_for_polars_modify() {
use re_log_types::{DataCell, Pinhole, Transform};
// transforms are a nice pathological type with both Unions and FixedSizeLists
let transforms = vec![Transform::Pinhole(Pinhole {
image_from_cam: [[1.0, 2.0, 3.0], [4.0, 5.0, 6.0], [7.0, 8.0, 9.0]].into(),
resolution: None,
})];
#[cfg(test)]
mod tests {
use arrow2::datatypes::{DataType, Field, UnionMode};
use arrow2_convert::{ArrowDeserialize, ArrowField, ArrowSerialize};
use re_log_types::{component_types::Vec3D, Component, DataCell};

let cell: DataCell = transforms.try_into().unwrap();
assert_eq!(
*cell.datatype(),
DataType::Union(
vec![
Field::new("Unknown", DataType::Boolean, false),
Field::new(
"Rigid3",
DataType::Struct(vec![
Field::new(
"rotation",
DataType::FixedSizeList(
Box::new(Field::new("item", DataType::Float32, false)),
4
),
false
),
Field::new(
"translation",
DataType::FixedSizeList(
Box::new(Field::new("item", DataType::Float32, false)),
3
),
false
)
]),
false
),
Field::new(
"Pinhole",
DataType::Struct(vec![
Field::new(
"image_from_cam",
DataType::FixedSizeList(
Box::new(Field::new("item", DataType::Float32, false)),
9
),
false,
),
Field::new(
"resolution",
DataType::FixedSizeList(
Box::new(Field::new("item", DataType::Float32, false)),
2
),
true,
),
]),
false
)
],
None,
UnionMode::Dense
),
);
use crate::ArrayExt;

let cleaned = cell.as_arrow_ref().clean_for_polars();
#[derive(Clone, Copy, Debug, PartialEq, ArrowField, ArrowSerialize, ArrowDeserialize)]
#[arrow_field(type = "dense")]
enum TestComponentWithUnionAndFixedSizeList {
Bool(bool),
Vec3D(Vec3D),
}

assert_eq!(
*cleaned.data_type(),
DataType::Struct(vec![
Field::new("Unknown", DataType::Boolean, false),
Field::new(
"Rigid3",
DataType::Struct(vec![
Field::new(
"rotation",
DataType::List(Box::new(Field::new("item", DataType::Float32, false)),),
false
),
impl Component for TestComponentWithUnionAndFixedSizeList {
fn name() -> re_log_types::ComponentName {
"test_component_with_union_and_fixed_size_list".into()
}
}

#[test]
fn test_clean_for_polars_modify() {
// Pick a type with both Unions and FixedSizeLists
let elements = vec![TestComponentWithUnionAndFixedSizeList::Bool(false)];

let cell: DataCell = elements.try_into().unwrap();
assert_eq!(
*cell.datatype(),
DataType::Union(
vec![
Field::new("Bool", DataType::Boolean, false),
Field::new(
"translation",
DataType::List(Box::new(Field::new("item", DataType::Float32, false)),),
"Vec3D",
DataType::FixedSizeList(
Box::new(Field::new("item", DataType::Float32, false)),
3
),
false
)
]),
false
),
Field::new(
"Pinhole",
DataType::Struct(vec![
Field::new(
"image_from_cam",
DataType::List(Box::new(Field::new("item", DataType::Float32, false))),
false,
),
Field::new(
"resolution",
DataType::List(Box::new(Field::new("item", DataType::Float32, false))),
true,
),
]),
false
],
None,
UnionMode::Dense
)
],),
);
);

let cleaned = cell.as_arrow_ref().clean_for_polars();

assert_eq!(
*cleaned.data_type(),
DataType::Struct(vec![
Field::new("Bool", DataType::Boolean, false),
Field::new(
"Vec3D",
DataType::List(Box::new(Field::new("item", DataType::Float32, false))),
false
)
],)
);
}
}
3 changes: 2 additions & 1 deletion crates/re_data_ui/src/component_ui_registry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ pub fn create_component_ui_registry() -> ComponentUiRegistry {
add::<re_log_types::component_types::Mesh3D>(&mut registry);
// add::<re_log_types::component_types::Point2D>(&mut registry);
// add::<re_log_types::component_types::Point3D>(&mut registry);
add::<re_log_types::component_types::Pinhole>(&mut registry);
// add::<re_log_types::component_types::Quaternion>(&mut registry);
// add::<re_log_types::component_types::Radius>(&mut registry);
add::<re_log_types::component_types::Rect2D>(&mut registry);
Expand All @@ -59,7 +60,7 @@ pub fn create_component_ui_registry() -> ComponentUiRegistry {
// add::<re_log_types::component_types::Size3D>(&mut registry);
add::<re_log_types::component_types::Tensor>(&mut registry);
add::<re_log_types::component_types::TextEntry>(&mut registry);
add::<re_log_types::component_types::Transform>(&mut registry);
add::<re_log_types::component_types::Transform3D>(&mut registry);
add::<re_log_types::component_types::Vec2D>(&mut registry);
add::<re_log_types::component_types::Vec3D>(&mut registry);
add::<re_log_types::ViewCoordinates>(&mut registry);
Expand Down
108 changes: 2 additions & 106 deletions crates/re_data_ui/src/data.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,8 @@
use egui::Vec2;

use re_format::format_f32;
use re_log_types::{
component_types::ColorRGBA,
component_types::{LineStrip2D, LineStrip3D, Mat3x3, Rect2D, Vec2D, Vec3D, Vec4D},
Pinhole, Rigid3, Transform, ViewCoordinates,
use re_log_types::component_types::{
ColorRGBA, LineStrip2D, LineStrip3D, Mat3x3, Rect2D, Vec2D, Vec3D, Vec4D, ViewCoordinates,
};
use re_viewer_context::{UiVerbosity, ViewerContext};

Expand Down Expand Up @@ -53,24 +51,6 @@ impl DataUi for ColorRGBA {
}
}

impl DataUi for Transform {
fn data_ui(
&self,
ctx: &mut ViewerContext<'_>,
ui: &mut egui::Ui,
verbosity: UiVerbosity,
query: &re_arrow_store::LatestAtQuery,
) {
match self {
Transform::Unknown => {
ui.label("Unknown transform");
}
Transform::Rigid3(rigid3) => rigid3.data_ui(ctx, ui, verbosity, query),
Transform::Pinhole(pinhole) => pinhole.data_ui(ctx, ui, verbosity, query),
}
}
}

impl DataUi for ViewCoordinates {
fn data_ui(
&self,
Expand All @@ -90,90 +70,6 @@ impl DataUi for ViewCoordinates {
}
}

impl DataUi for Rigid3 {
#[allow(clippy::only_used_in_recursion)]
fn data_ui(
&self,
ctx: &mut ViewerContext<'_>,
ui: &mut egui::Ui,
verbosity: UiVerbosity,
query: &re_arrow_store::LatestAtQuery,
) {
match verbosity {
UiVerbosity::Small => {
ui.label("Rigid 3D transform").on_hover_ui(|ui| {
self.data_ui(ctx, ui, UiVerbosity::All, query);
});
}

UiVerbosity::All | UiVerbosity::Reduced => {
let pose = self.parent_from_child(); // TODO(emilk): which one to show?
let rotation = pose.rotation();
let translation = pose.translation();

ui.vertical(|ui| {
ui.label("Rigid 3D transform:");
ui.indent("rigid3", |ui| {
egui::Grid::new("rigid3").num_columns(2).show(ui, |ui| {
ui.label("rotation");
ui.monospace(format!("{rotation:?}"));
ui.end_row();

ui.label("translation");
ui.monospace(format!("{translation:?}"));
ui.end_row();
});
});
});
}
}
}
}

impl DataUi for Pinhole {
fn data_ui(
&self,
ctx: &mut ViewerContext<'_>,
ui: &mut egui::Ui,
verbosity: UiVerbosity,
query: &re_arrow_store::LatestAtQuery,
) {
match verbosity {
UiVerbosity::Small => {
ui.label("Pinhole transform").on_hover_ui(|ui| {
self.data_ui(ctx, ui, UiVerbosity::All, query);
});
}

UiVerbosity::All | UiVerbosity::Reduced => {
let Pinhole {
image_from_cam: image_from_view,
resolution,
} = self;

ui.vertical(|ui| {
ui.label("Pinhole transform:");
ui.indent("pinole", |ui| {
ui.horizontal(|ui| {
ui.label("resolution:");
if let Some(re_log_types::component_types::Vec2D([x, y])) = resolution {
ui.monospace(format!("{x}x{y}"));
} else {
ui.weak("(none)");
}
});

ui.label("image from view:");
ui.indent("image_from_view", |ui| {
image_from_view.data_ui(ctx, ui, verbosity, query);
});
});
});
}
}
}
}

impl DataUi for Mat3x3 {
fn data_ui(
&self,
Expand Down
2 changes: 2 additions & 0 deletions crates/re_data_ui/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ mod instance_path;
mod item;
pub mod item_ui;
mod log_msg;
mod pinhole;
mod transform3d;

pub use crate::image::{
show_zoomed_image_region, show_zoomed_image_region_area_outline,
Expand Down
48 changes: 48 additions & 0 deletions crates/re_data_ui/src/pinhole.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
use re_log_types::component_types::Pinhole;
use re_viewer_context::{UiVerbosity, ViewerContext};

use crate::DataUi;

impl DataUi for Pinhole {
fn data_ui(
&self,
ctx: &mut ViewerContext<'_>,
ui: &mut egui::Ui,
verbosity: UiVerbosity,
query: &re_arrow_store::LatestAtQuery,
) {
match verbosity {
UiVerbosity::Small => {
ui.label("Pinhole transform").on_hover_ui(|ui| {
self.data_ui(ctx, ui, UiVerbosity::All, query);
});
}

UiVerbosity::All | UiVerbosity::Reduced => {
let Pinhole {
image_from_cam: image_from_view,
resolution,
} = self;

ui.vertical(|ui| {
ui.label("Pinhole transform:");
ui.indent("pinole", |ui| {
ui.horizontal(|ui| {
ui.label("resolution:");
if let Some(re_log_types::component_types::Vec2D([x, y])) = resolution {
ui.monospace(format!("{x}x{y}"));
} else {
ui.weak("(none)");
}
});

ui.label("image from view:");
ui.indent("image_from_view", |ui| {
image_from_view.data_ui(ctx, ui, verbosity, query);
});
});
});
}
}
}
}
Loading