Skip to content

Commit

Permalink
abstract it all away
Browse files Browse the repository at this point in the history
  • Loading branch information
teh-cmc committed Apr 26, 2024
1 parent c5e73e6 commit b67e5ca
Show file tree
Hide file tree
Showing 9 changed files with 464 additions and 846 deletions.
161 changes: 53 additions & 108 deletions crates/re_space_view_spatial/src/visualizers/arrows2d.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use re_entity_db::{EntityPath, InstancePathHash};
use re_query_cache2::{range_zip_1x6, CachedResults};
use re_query_cache2::range_zip_1x6;
use re_renderer::{renderer::LineStripFlags, LineDrawableBuilder, PickingLayerInstanceId};
use re_types::{
archetypes::Arrows2D,
Expand Down Expand Up @@ -218,121 +218,66 @@ impl VisualizerSystem for Arrows2DVisualizer {
view_ctx,
view_ctx.get::<EntityDepthOffsets>()?.points,
|ctx, entity_path, _entity_props, spatial_ctx, results| {
match results {
CachedResults::LatestAt(_query, results) => {
re_tracing::profile_scope!(format!("{entity_path} @ {_query:?}"));
re_tracing::profile_scope!(format!("{entity_path}"));

use crate::visualizers::CachedLatestAtResultsExt as _;
use crate::visualizers::CachedRangeResultsExt as _;

let resolver = ctx.recording().resolver();
let resolver = ctx.recording().resolver();

let vectors = match results.get_dense::<Vector2D>(resolver) {
Some(Ok(vectors)) if !vectors.is_empty() => vectors,
Some(err @ Err(_)) => err?,
_ => return Ok(()),
};
let vectors = match results.get_dense::<Vector2D>(resolver) {
Some(Ok(vectors)) => vectors,
Some(err @ Err(_)) => err?,
_ => return Ok(()),
};

line_builder.reserve_strips(vectors.len())?;
line_builder.reserve_vertices(vectors.len() * 2)?;

let origins = results.get_or_empty_dense(resolver)?;
let colors = results.get_or_empty_dense(resolver)?;
let radii = results.get_or_empty_dense(resolver)?;
let labels = results.get_or_empty_dense(resolver)?;
let class_ids = results.get_or_empty_dense(resolver)?;
let keypoint_ids = results.get_or_empty_dense(resolver)?;
let num_vectors = vectors
.range_indexed()
.map(|(_, vectors)| vectors.len())
.sum::<usize>();
if num_vectors == 0 {
return Ok(());
}

let data = Arrows2DComponentData {
line_builder.reserve_strips(num_vectors)?;
line_builder.reserve_vertices(num_vectors * 2)?;

let origins = results.get_or_empty_dense(resolver)?;
let colors = results.get_or_empty_dense(resolver)?;
let radii = results.get_or_empty_dense(resolver)?;
let labels = results.get_or_empty_dense(resolver)?;
let class_ids = results.get_or_empty_dense(resolver)?;
let keypoint_ids = results.get_or_empty_dense(resolver)?;

let data = range_zip_1x6(
vectors.range_indexed(),
origins.range_indexed(),
colors.range_indexed(),
radii.range_indexed(),
labels.range_indexed(),
class_ids.range_indexed(),
keypoint_ids.range_indexed(),
)
.map(
|(_index, vectors, origins, colors, radii, labels, class_ids, keypoint_ids)| {
Arrows2DComponentData {
vectors,
origins,
colors,
radii,
labels,
keypoint_ids,
class_ids,
};

self.process_data(
&mut line_builder,
view_query,
entity_path,
spatial_ctx,
std::iter::once(data),
);
}

CachedResults::Range(_query, results) => {
re_tracing::profile_scope!(format!("{entity_path} @ {_query:?}"));

use crate::visualizers::CachedRangeResultsExt as _;

let resolver = ctx.recording().resolver();

let vectors = match results.get_dense::<Vector2D>(resolver) {
Some(Ok(vectors)) => vectors,
Some(err @ Err(_)) => err?,
_ => return Ok(()),
};

let num_vectors = vectors
.range_indexed()
.map(|(_, vectors)| vectors.len())
.sum::<usize>();
if num_vectors == 0 {
return Ok(());
origins: origins.unwrap_or_default(),
colors: colors.unwrap_or_default(),
radii: radii.unwrap_or_default(),
labels: labels.unwrap_or_default(),
class_ids: class_ids.unwrap_or_default(),
keypoint_ids: keypoint_ids.unwrap_or_default(),
}
},
);

line_builder.reserve_strips(num_vectors)?;
line_builder.reserve_vertices(num_vectors * 2)?;

let origins = results.get_or_empty_dense(resolver)?;
let colors = results.get_or_empty_dense(resolver)?;
let radii = results.get_or_empty_dense(resolver)?;
let labels = results.get_or_empty_dense(resolver)?;
let class_ids = results.get_or_empty_dense(resolver)?;
let keypoint_ids = results.get_or_empty_dense(resolver)?;

let data = range_zip_1x6(
vectors.range_indexed(),
origins.range_indexed(),
colors.range_indexed(),
radii.range_indexed(),
labels.range_indexed(),
class_ids.range_indexed(),
keypoint_ids.range_indexed(),
)
.map(
|(
_index,
vectors,
origins,
colors,
radii,
labels,
class_ids,
keypoint_ids,
)| {
Arrows2DComponentData {
vectors,
origins: origins.unwrap_or_default(),
colors: colors.unwrap_or_default(),
radii: radii.unwrap_or_default(),
labels: labels.unwrap_or_default(),
class_ids: class_ids.unwrap_or_default(),
keypoint_ids: keypoint_ids.unwrap_or_default(),
}
},
);

self.process_data(
&mut line_builder,
view_query,
entity_path,
spatial_ctx,
data,
);
}
}
self.process_data(
&mut line_builder,
view_query,
entity_path,
spatial_ctx,
data,
);

Ok(())
},
Expand Down
161 changes: 53 additions & 108 deletions crates/re_space_view_spatial/src/visualizers/arrows3d.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use re_entity_db::{EntityPath, InstancePathHash};
use re_query_cache2::{range_zip_1x6, CachedResults};
use re_query_cache2::range_zip_1x6;
use re_renderer::{renderer::LineStripFlags, LineDrawableBuilder, PickingLayerInstanceId};
use re_types::{
archetypes::Arrows3D,
Expand Down Expand Up @@ -221,121 +221,66 @@ impl VisualizerSystem for Arrows3DVisualizer {
view_ctx,
view_ctx.get::<EntityDepthOffsets>()?.points,
|ctx, entity_path, _entity_props, spatial_ctx, results| {
match results {
CachedResults::LatestAt(_query, results) => {
re_tracing::profile_scope!(format!("{entity_path} @ {_query:?}"));
re_tracing::profile_scope!(format!("{entity_path}"));

use crate::visualizers::CachedLatestAtResultsExt as _;
use crate::visualizers::CachedRangeResultsExt as _;

let resolver = ctx.recording().resolver();
let resolver = ctx.recording().resolver();

let vectors = match results.get_dense::<Vector3D>(resolver) {
Some(Ok(vectors)) if !vectors.is_empty() => vectors,
Some(err @ Err(_)) => err?,
_ => return Ok(()),
};
let vectors = match results.get_dense::<Vector3D>(resolver) {
Some(Ok(vectors)) => vectors,
Some(err @ Err(_)) => err?,
_ => return Ok(()),
};

line_builder.reserve_strips(vectors.len())?;
line_builder.reserve_vertices(vectors.len() * 2)?;

let origins = results.get_or_empty_dense(resolver)?;
let colors = results.get_or_empty_dense(resolver)?;
let radii = results.get_or_empty_dense(resolver)?;
let labels = results.get_or_empty_dense(resolver)?;
let class_ids = results.get_or_empty_dense(resolver)?;
let keypoint_ids = results.get_or_empty_dense(resolver)?;
let num_vectors = vectors
.range_indexed()
.map(|(_, vectors)| vectors.len())
.sum::<usize>();
if num_vectors == 0 {
return Ok(());
}

let data = Arrows3DComponentData {
line_builder.reserve_strips(num_vectors)?;
line_builder.reserve_vertices(num_vectors * 2)?;

let origins = results.get_or_empty_dense(resolver)?;
let colors = results.get_or_empty_dense(resolver)?;
let radii = results.get_or_empty_dense(resolver)?;
let labels = results.get_or_empty_dense(resolver)?;
let class_ids = results.get_or_empty_dense(resolver)?;
let keypoint_ids = results.get_or_empty_dense(resolver)?;

let data = range_zip_1x6(
vectors.range_indexed(),
origins.range_indexed(),
colors.range_indexed(),
radii.range_indexed(),
labels.range_indexed(),
class_ids.range_indexed(),
keypoint_ids.range_indexed(),
)
.map(
|(_index, vectors, origins, colors, radii, labels, class_ids, keypoint_ids)| {
Arrows3DComponentData {
vectors,
origins,
colors,
radii,
labels,
keypoint_ids,
class_ids,
};

self.process_data(
&mut line_builder,
view_query,
entity_path,
spatial_ctx,
std::iter::once(data),
);
}

CachedResults::Range(_query, results) => {
re_tracing::profile_scope!(format!("{entity_path} @ {_query:?}"));

use crate::visualizers::CachedRangeResultsExt as _;

let resolver = ctx.recording().resolver();

let vectors = match results.get_dense::<Vector3D>(resolver) {
Some(Ok(vectors)) => vectors,
Some(err @ Err(_)) => err?,
_ => return Ok(()),
};

let num_vectors = vectors
.range_indexed()
.map(|(_, vectors)| vectors.len())
.sum::<usize>();
if num_vectors == 0 {
return Ok(());
origins: origins.unwrap_or_default(),
colors: colors.unwrap_or_default(),
radii: radii.unwrap_or_default(),
labels: labels.unwrap_or_default(),
class_ids: class_ids.unwrap_or_default(),
keypoint_ids: keypoint_ids.unwrap_or_default(),
}
},
);

line_builder.reserve_strips(num_vectors)?;
line_builder.reserve_vertices(num_vectors * 2)?;

let origins = results.get_or_empty_dense(resolver)?;
let colors = results.get_or_empty_dense(resolver)?;
let radii = results.get_or_empty_dense(resolver)?;
let labels = results.get_or_empty_dense(resolver)?;
let class_ids = results.get_or_empty_dense(resolver)?;
let keypoint_ids = results.get_or_empty_dense(resolver)?;

let data = range_zip_1x6(
vectors.range_indexed(),
origins.range_indexed(),
colors.range_indexed(),
radii.range_indexed(),
labels.range_indexed(),
class_ids.range_indexed(),
keypoint_ids.range_indexed(),
)
.map(
|(
_index,
vectors,
origins,
colors,
radii,
labels,
class_ids,
keypoint_ids,
)| {
Arrows3DComponentData {
vectors,
origins: origins.unwrap_or_default(),
colors: colors.unwrap_or_default(),
radii: radii.unwrap_or_default(),
labels: labels.unwrap_or_default(),
class_ids: class_ids.unwrap_or_default(),
keypoint_ids: keypoint_ids.unwrap_or_default(),
}
},
);

self.process_data(
&mut line_builder,
view_query,
entity_path,
spatial_ctx,
data,
);
}
}
self.process_data(
&mut line_builder,
view_query,
entity_path,
spatial_ctx,
data,
);

Ok(())
},
Expand Down
Loading

0 comments on commit b67e5ca

Please sign in to comment.