Rerun C++ SDK
Loading...
Searching...
No Matches
tensor_view_fit.hpp
1// DO NOT EDIT! This file was auto-generated by crates/build/re_types_builder/src/codegen/cpp/mod.rs
2// Based on "crates/store/re_types/definitions/rerun/blueprint/archetypes/tensor_view_fit.fbs".
3
4#pragma once
5
6#include "../../blueprint/components/view_fit.hpp"
7#include "../../collection.hpp"
8#include "../../component_batch.hpp"
9#include "../../component_column.hpp"
10#include "../../indicator_component.hpp"
11#include "../../result.hpp"
12
13#include <cstdint>
14#include <optional>
15#include <utility>
16#include <vector>
17
18namespace rerun::blueprint::archetypes {
19 /// **Archetype**: Configures how a selected tensor slice is shown on screen.
20 ///
21 /// ⚠ **This type is _unstable_ and may change significantly in a way that the data won't be backwards compatible.**
22 ///
24 /// How the image is scaled to fit the view.
25 std::optional<ComponentBatch> scaling;
26
27 public:
28 static constexpr const char IndicatorComponentName[] =
29 "rerun.blueprint.components.TensorViewFitIndicator";
30
31 /// Indicator component, used to identify the archetype when converting to a list of components.
33 /// The name of the archetype as used in `ComponentDescriptor`s.
34 static constexpr const char ArchetypeName[] = "rerun.blueprint.archetypes.TensorViewFit";
35
36 /// `ComponentDescriptor` for the `scaling` field.
37 static constexpr auto Descriptor_scaling = ComponentDescriptor(
38 ArchetypeName, "scaling",
40 );
41
42 public:
43 TensorViewFit() = default;
44 TensorViewFit(TensorViewFit&& other) = default;
45 TensorViewFit(const TensorViewFit& other) = default;
46 TensorViewFit& operator=(const TensorViewFit& other) = default;
47 TensorViewFit& operator=(TensorViewFit&& other) = default;
48
49 /// Update only some specific fields of a `TensorViewFit`.
51 return TensorViewFit();
52 }
53
54 /// Clear all the fields of a `TensorViewFit`.
56
57 /// How the image is scaled to fit the view.
58 TensorViewFit with_scaling(const rerun::blueprint::components::ViewFit& _scaling) && {
59 scaling = ComponentBatch::from_loggable(_scaling, Descriptor_scaling).value_or_throw();
60 return std::move(*this);
61 }
62
63 /// Partitions the component data into multiple sub-batches.
64 ///
65 /// Specifically, this transforms the existing `ComponentBatch` data into `ComponentColumn`s
66 /// instead, via `ComponentBatch::partitioned`.
67 ///
68 /// This makes it possible to use `RecordingStream::send_columns` to send columnar data directly into Rerun.
69 ///
70 /// The specified `lengths` must sum to the total length of the component batch.
72
73 /// Partitions the component data into unit-length sub-batches.
74 ///
75 /// This is semantically similar to calling `columns` with `std::vector<uint32_t>(n, 1)`,
76 /// where `n` is automatically guessed.
78 };
79
80} // namespace rerun::blueprint::archetypes
81
82namespace rerun {
83 /// \private
84 template <typename T>
85 struct AsComponents;
86
87 /// \private
88 template <>
89 struct AsComponents<blueprint::archetypes::TensorViewFit> {
90 /// Serialize all set component batches.
91 static Result<Collection<ComponentBatch>> as_batches(
93 );
94 };
95} // namespace rerun
Generic collection of elements that are roughly contiguous in memory.
Definition collection.hpp:49
A class for representing either a usable value, or an error.
Definition result.hpp:14
All Rerun C++ types and functions are in the rerun namespace or one of its nested namespaces.
Definition rerun.hpp:23
static Result< ComponentBatch > from_loggable(const rerun::Collection< T > &components, const ComponentDescriptor &descriptor=rerun::Loggable< T >::Descriptor)
Creates a new component batch from a collection of component instances.
Definition component_batch.hpp:46
A ComponentDescriptor fully describes the semantics of a column of data.
Definition component_descriptor.hpp:14
The Loggable trait is used by all built-in implementation of rerun::AsComponents to serialize a colle...
Definition loggable.hpp:11
Archetype: Configures how a selected tensor slice is shown on screen.
Definition tensor_view_fit.hpp:23
Collection< ComponentColumn > columns()
Partitions the component data into unit-length sub-batches.
static constexpr const char ArchetypeName[]
The name of the archetype as used in ComponentDescriptors.
Definition tensor_view_fit.hpp:34
static constexpr auto Descriptor_scaling
ComponentDescriptor for the scaling field.
Definition tensor_view_fit.hpp:37
static TensorViewFit update_fields()
Update only some specific fields of a TensorViewFit.
Definition tensor_view_fit.hpp:50
Collection< ComponentColumn > columns(const Collection< uint32_t > &lengths_)
Partitions the component data into multiple sub-batches.
static TensorViewFit clear_fields()
Clear all the fields of a TensorViewFit.
std::optional< ComponentBatch > scaling
How the image is scaled to fit the view.
Definition tensor_view_fit.hpp:25
TensorViewFit with_scaling(const rerun::blueprint::components::ViewFit &_scaling) &&
How the image is scaled to fit the view.
Definition tensor_view_fit.hpp:58
Indicator component used by archetypes when converting them to component lists.
Definition indicator_component.hpp:32