-
Notifications
You must be signed in to change notification settings - Fork 373
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
Codegen/IDL 5: auto-generated Python code for Points2D
#2374
Changes from all commits
b44c087
6bb6b2b
40483d7
aa918bd
3f6f388
262597a
61ceeba
e67d12a
c95a659
6fe324e
796c7ea
7f086dd
3ddb05d
edb7ec8
2c0621e
9e1f6fd
dc1336a
e4e24a2
0c608d1
a0f7d9c
24f5124
974f735
33fed4f
67c37f8
aa2d5c0
77b06f4
7f8d182
eaa57a4
5e3c2f5
06062e3
2917bc1
78098c0
b6711ad
9c98dfb
08a412f
29d3de8
3c6bb40
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
# This is a sha256 hash for all direct and indirect dependencies of this crate's build script. | ||
# It can be safely removed at anytime to force the build script to run again. | ||
# Check out build.rs to see how it's computed. | ||
95c13226f31d47e4639e155fc80ee6830579c50e38ee1d997b4bda4d23ba03b6 | ||
95c13226f31d47e4639e155fc80ee6830579c50e38ee1d997b4bda4d23ba03b6 |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
""" | ||
A shim necessary to make maturin dev builds work properly. | ||
|
||
Our maturin builds stick our package inside of a "rerun_sdk" folder | ||
to avoid conflicting with the non-rerun "rerun" package. In released | ||
builds, we include a rerun_sdk.pth file that makes things work properly, | ||
but that doesn't work in dev builds where maturin generates its own | ||
.pth file that points 1 level too high. | ||
|
||
When we encounter this file on import, we instead redirect to the | ||
real rerun module by adding it to the path and then, and then | ||
replacing our own module content with it. | ||
""" | ||
from __future__ import annotations | ||
|
||
import pathlib | ||
import sys | ||
|
||
real_path = pathlib.Path(__file__).parent.parent.joinpath("rerun_sdk").resolve() | ||
|
||
print(f"DEV ENVIRONMENT DETECTED! Re-importing rerun2 from: {real_path}", file=sys.stderr) | ||
|
||
sys.path.insert(0, str(real_path)) | ||
|
||
del sys.modules["rerun2"] | ||
sys.modules["rerun2"] = __import__("rerun2") |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
# NOTE: This file was autogenerated by re_types_builder; DO NOT EDIT. | ||
|
||
from __future__ import annotations | ||
|
||
__all__ = ["Points2D"] | ||
|
||
from rerun2.archetypes import Points2D |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
# NOTE: This file was autogenerated by re_types_builder; DO NOT EDIT. | ||
|
||
from __future__ import annotations | ||
|
||
__all__ = ["Points2D"] | ||
|
||
# NOTE: we use fully qualified paths to prevent lazy circular imports. | ||
from rerun2.archetypes.points2d import Points2D |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
# NOTE: This file was autogenerated by re_types_builder; DO NOT EDIT. | ||
|
||
from __future__ import annotations | ||
|
||
__all__ = ["Points2D"] | ||
|
||
|
||
from dataclasses import dataclass | ||
|
||
from rerun2 import components | ||
|
||
|
||
@dataclass | ||
class Points2D: | ||
"""A 2D point cloud with positions and optional colors, radii, labels, etc.""" | ||
|
||
points: components.Point2DArray | ||
""" | ||
All the actual 2D points that make up the point cloud. | ||
""" | ||
|
||
radii: components.RadiusArray | None = None | ||
""" | ||
Optional radii for the points, effectively turning them into circles. | ||
""" | ||
|
||
colors: components.ColorArray | None = None | ||
""" | ||
Optional colors for the points. | ||
The colors are interpreted as RGB or RGBA in sRGB gamma-space, | ||
As either 0-1 floats or 0-255 integers, with separate alpha. | ||
""" | ||
|
||
labels: components.LabelArray | None = None | ||
""" | ||
Optional text labels for the points. | ||
""" | ||
|
||
draw_order: components.DrawOrderArray | None = None | ||
""" | ||
An optional floating point value that specifies the 2D drawing order. | ||
Objects with higher values are drawn on top of those with lower values. | ||
teh-cmc marked this conversation as resolved.
Show resolved
Hide resolved
|
||
The default for 2D points is 30.0. | ||
""" | ||
|
||
class_ids: components.ClassIdArray | None = None | ||
""" | ||
Optional class Ids for the points. | ||
The class ID provides colors and labels if not specified explicitly. | ||
""" | ||
|
||
keypoint_ids: components.KeypointIdArray | None = None | ||
""" | ||
Optional keypoint IDs for the points, identifying them within a class. | ||
If keypoint IDs are passed in but no class IDs were specified, the class ID will | ||
default to 0. | ||
This is useful to identify points within a single classification (which is identified | ||
with `class_id`). | ||
E.g. the classification might be 'Person' and the keypoints refer to joints on a | ||
detected skeleton. | ||
""" | ||
|
||
instance_keys: components.InstanceKeyArray | None = None | ||
""" | ||
Unique identifiers for each individual point in the batch. | ||
""" | ||
|
||
def __str__(self): | ||
s = f"rr.{type(self).__name__}(\n" | ||
|
||
from dataclasses import fields | ||
|
||
for field in fields(self): | ||
data = getattr(self, field.name) | ||
datatype = getattr(data, "type", None) | ||
if datatype: | ||
name = datatype.extension_name | ||
typ = datatype.storage_type | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. nit: Don't think in python anything is preventing us to call this There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Sure but I already have enough issues with python as it is, I don't really feel like shadowing keywords... |
||
s += f" {name}<{typ}>(\n {data.to_pylist()}\n )\n" | ||
|
||
s += ")" | ||
|
||
return s | ||
|
||
def __repr__(self): | ||
return str(self) | ||
|
||
def __init__( | ||
self, | ||
points: components.Point2DArrayLike, | ||
*, | ||
radii: components.RadiusArrayLike | None = None, | ||
colors: components.ColorArrayLike | None = None, | ||
labels: components.LabelArrayLike | None = None, | ||
draw_order: components.DrawOrderLike | None = None, | ||
class_ids: components.ClassIdArrayLike | None = None, | ||
keypoint_ids: components.KeypointIdArrayLike | None = None, | ||
instance_keys: components.InstanceKeyArrayLike | None = None, | ||
) -> None: | ||
# Required components | ||
self.points = components.Point2DArray.from_similar(points) | ||
|
||
# Optional components | ||
|
||
self.radii = components.RadiusArray.from_similar(radii) | ||
self.colors = components.ColorArray.from_similar(colors) | ||
Comment on lines
+109
to
+110
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Not wrong but those two were under "recommended" components, so it's a bit confusing There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah I mean, backends are free to do whatever they want with that information; in this case I didn't bother coming up with anything better than just ignoring it, for now. I'll open an issue and add a link. |
||
self.labels = components.LabelArray.from_similar(labels) | ||
self.draw_order = components.DrawOrderArray.from_similar(draw_order) | ||
self.class_ids = components.ClassIdArray.from_similar(class_ids) | ||
self.keypoint_ids = components.KeypointIdArray.from_similar(keypoint_ids) | ||
self.instance_keys = components.InstanceKeyArray.from_similar(instance_keys) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
# NOTE: This file was autogenerated by re_types_builder; DO NOT EDIT. | ||
|
||
from __future__ import annotations | ||
|
||
__all__ = [ | ||
"ClassId", | ||
"ClassIdArray", | ||
"ClassIdArrayLike", | ||
"ClassIdLike", | ||
"ClassIdType", | ||
"Color", | ||
"ColorArray", | ||
"ColorArrayLike", | ||
"ColorLike", | ||
"ColorType", | ||
"DrawOrder", | ||
"DrawOrderArray", | ||
"DrawOrderArrayLike", | ||
"DrawOrderLike", | ||
"DrawOrderType", | ||
"InstanceKey", | ||
"InstanceKeyArray", | ||
"InstanceKeyArrayLike", | ||
"InstanceKeyLike", | ||
"InstanceKeyType", | ||
"KeypointId", | ||
"KeypointIdArray", | ||
"KeypointIdArrayLike", | ||
"KeypointIdLike", | ||
"KeypointIdType", | ||
"Label", | ||
"LabelArray", | ||
"LabelArrayLike", | ||
"LabelLike", | ||
"LabelType", | ||
"Point2D", | ||
"Point2DArray", | ||
"Point2DArrayLike", | ||
"Point2DLike", | ||
"Point2DType", | ||
"Radius", | ||
"RadiusArray", | ||
"RadiusArrayLike", | ||
"RadiusLike", | ||
"RadiusType", | ||
] | ||
|
||
# NOTE: we use fully qualified paths to prevent lazy circular imports. | ||
from rerun2.components.class_id import ClassId, ClassIdArray, ClassIdArrayLike, ClassIdLike, ClassIdType | ||
from rerun2.components.color import Color, ColorArray, ColorArrayLike, ColorLike, ColorType | ||
from rerun2.components.draw_order import DrawOrder, DrawOrderArray, DrawOrderArrayLike, DrawOrderLike, DrawOrderType | ||
from rerun2.components.instance_key import ( | ||
InstanceKey, | ||
InstanceKeyArray, | ||
InstanceKeyArrayLike, | ||
InstanceKeyLike, | ||
InstanceKeyType, | ||
) | ||
from rerun2.components.keypoint_id import ( | ||
KeypointId, | ||
KeypointIdArray, | ||
KeypointIdArrayLike, | ||
KeypointIdLike, | ||
KeypointIdType, | ||
) | ||
from rerun2.components.label import Label, LabelArray, LabelArrayLike, LabelLike, LabelType | ||
from rerun2.components.point2d import Point2D, Point2DArray, Point2DArrayLike, Point2DLike, Point2DType | ||
from rerun2.components.radius import Radius, RadiusArray, RadiusArrayLike, RadiusLike, RadiusType |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
# NOTE: This file was autogenerated by re_types_builder; DO NOT EDIT. | ||
|
||
from __future__ import annotations | ||
|
||
__all__ = ["ClassId", "ClassIdArray", "ClassIdArrayLike", "ClassIdLike", "ClassIdType"] | ||
|
||
from dataclasses import dataclass | ||
from typing import Any, Sequence, Union | ||
|
||
import numpy as np | ||
import numpy.typing as npt | ||
import pyarrow as pa | ||
|
||
|
||
@dataclass | ||
class ClassId: | ||
"""A 16-bit ID representing a type of semantic class.""" | ||
|
||
id: int | ||
|
||
def __array__(self): | ||
return np.asarray(self.id) | ||
|
||
|
||
ClassIdLike = Union[ClassId, float] | ||
|
||
ClassIdArrayLike = Union[ | ||
ClassIdLike, Sequence[ClassIdLike], npt.NDArray[np.uint8], npt.NDArray[np.uint16], npt.NDArray[np.uint32] | ||
] | ||
|
||
|
||
# --- Arrow support --- | ||
|
||
from rerun2.components.class_id_ext import ClassIdArrayExt # noqa: E402 | ||
|
||
|
||
class ClassIdType(pa.ExtensionType): | ||
def __init__(self: type[pa.ExtensionType]) -> None: | ||
pa.ExtensionType.__init__(self, pa.uint16(), "rerun.components.ClassId") | ||
|
||
def __arrow_ext_serialize__(self: type[pa.ExtensionType]) -> bytes: | ||
# since we don't have a parameterized type, we don't need extra metadata to be deserialized | ||
return b"" | ||
|
||
@classmethod | ||
def __arrow_ext_deserialize__( | ||
cls: type[pa.ExtensionType], storage_type: Any, serialized: Any | ||
) -> type[pa.ExtensionType]: | ||
# return an instance of this subclass given the serialized metadata. | ||
return ClassIdType() | ||
|
||
def __arrow_ext_class__(self: type[pa.ExtensionType]) -> type[pa.ExtensionArray]: | ||
return ClassIdArray | ||
|
||
|
||
pa.register_extension_type(ClassIdType()) | ||
|
||
|
||
class ClassIdArray(pa.ExtensionArray, ClassIdArrayExt): # type: ignore[misc] | ||
@staticmethod | ||
def from_similar(data: ClassIdArrayLike | None): | ||
if data is None: | ||
return ClassIdType().wrap_array(pa.array([], type=ClassIdType().storage_type)) | ||
else: | ||
return ClassIdArrayExt._from_similar( | ||
data, | ||
mono=ClassId, | ||
mono_aliases=ClassIdLike, | ||
many=ClassIdArray, | ||
many_aliases=ClassIdArrayLike, | ||
arrow=ClassIdType, | ||
) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should the top level file not specify all exposed components and archetypes as well?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's pretty good the way it is now.
Keep in mind: