Skip to content

Commit

Permalink
re_format: barebone support for custom formatting (#1776)
Browse files Browse the repository at this point in the history
* implement barebone support for custom formatting and apply to Tuid

* unwrap

* <ERR> rather than []

* use re_tuid
  • Loading branch information
teh-cmc authored Apr 6, 2023
1 parent d6cce1c commit 3be747c
Show file tree
Hide file tree
Showing 7 changed files with 159 additions and 31 deletions.
3 changes: 3 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

9 changes: 8 additions & 1 deletion crates/re_arrow_store/src/arrow_util.rs
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,14 @@ impl ArrayExt for dyn Array {
///
/// Nested types are expanded and cleaned recursively
fn clean_for_polars(&self) -> Box<dyn Array> {
match self.data_type() {
let datatype = self.data_type();
let datatype = if let DataType::Extension(_, inner, _) = datatype {
(**inner).clone()
} else {
datatype.clone()
};

match &datatype {
DataType::List(field) => {
// Recursively clean the contents
let typed_arr = self.as_any().downcast_ref::<ListArray<i32>>().unwrap();
Expand Down
4 changes: 3 additions & 1 deletion crates/re_format/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,9 @@ version.workspace = true
[package.metadata.docs.rs]
all-features = true


[dependencies]
arrow2.workspace = true
arrow2_convert.workspace = true
comfy-table.workspace = true
parking_lot.workspace = true
re_tuid.workspace = true
93 changes: 85 additions & 8 deletions crates/re_format/src/arrow.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,22 +3,91 @@
use std::fmt::Formatter;

use arrow2::{
array::{get_display, Array},
array::{get_display, Array, ListArray, StructArray},
datatypes::{DataType, IntervalUnit, TimeUnit},
};
use arrow2_convert::deserialize::TryIntoCollection;
use comfy_table::{presets, Cell, Table};

use re_tuid::Tuid;

// ---

// TODO(#1775): Registering custom formatters should be done from other crates:
// A) Because `re_format` cannot depend on other crates (cyclic deps)
// B) Because how to deserialize and inspect some type is a private implementation detail of that
// type, re_format shouldn't know how to deserialize a TUID...

type CustomFormatter<'a, F> = Box<dyn Fn(&mut F, usize) -> std::fmt::Result + 'a>;

pub fn get_custom_display<'a, F: std::fmt::Write + 'a>(
_column_name: &'a str,
array: &'a dyn Array,
null: &'static str,
) -> CustomFormatter<'a, F> {
// NOTE: If the top-level array is a list, it's probably not the type we're looking for: we're
// interested in the type of the array that's underneath.
let datatype = (|| match array.data_type().to_logical_type() {
DataType::List(_) => array
.as_any()
.downcast_ref::<ListArray<i32>>()?
.iter()
.next()?
.map(|array| array.data_type().clone()),
_ => Some(array.data_type().clone()),
})();

if let Some(DataType::Extension(name, _, _)) = datatype {
match name.as_str() {
// TODO(#1775): This should be registered dynamically.
// NOTE: Can't call `Tuid::name()`, `Component` lives in `re_log_types`.
"rerun.tuid" => Box::new(|w, index| {
if let Some(tuid) = parse_tuid(array, index) {
w.write_fmt(format_args!("{tuid}"))
} else {
w.write_str("<ERR>")
}
}),
_ => get_display(array, null),
}
} else {
get_display(array, null)
}
}

// TODO(#1775): This should be defined and registered by the `re_tuid` crate.
fn parse_tuid(array: &dyn Array, index: usize) -> Option<Tuid> {
let (array, index) = match array.data_type().to_logical_type() {
// Legacy MsgId lists: just grab the first value, they're all identical
DataType::List(_) => (
array
.as_any()
.downcast_ref::<ListArray<i32>>()?
.value(index),
0,
),
// New control columns: it's not a list to begin with!
_ => (array.to_boxed(), index),
};
let array = array.as_any().downcast_ref::<StructArray>()?;

let tuids: Vec<Tuid> = TryIntoCollection::try_into_collection(array.to_boxed()).ok()?;
tuids.get(index).copied()
}

// ---

//TODO(john) move this and the Display impl upstream into arrow2
#[repr(transparent)]
pub struct DisplayTimeUnit(TimeUnit);

impl std::fmt::Display for DisplayTimeUnit {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
let s = match self.0 {
arrow2::datatypes::TimeUnit::Second => "s",
arrow2::datatypes::TimeUnit::Millisecond => "ms",
arrow2::datatypes::TimeUnit::Microsecond => "us",
arrow2::datatypes::TimeUnit::Nanosecond => "ns",
TimeUnit::Second => "s",
TimeUnit::Millisecond => "ms",
TimeUnit::Microsecond => "us",
TimeUnit::Nanosecond => "ns",
};
f.write_str(s)
}
Expand Down Expand Up @@ -133,24 +202,32 @@ where
let mut table = Table::new();
table.load_preset(presets::UTF8_FULL);

let names = names
.into_iter()
.map(|name| name.as_ref().to_owned())
.collect::<Vec<_>>();
let arrays = columns.into_iter().collect::<Vec<_>>();

let (displayers, lengths): (Vec<_>, Vec<_>) = arrays
.iter()
.map(|array| (get_display(array.as_ref(), "-"), array.as_ref().len()))
.zip(names.iter())
.map(|(array, name)| {
let formatter = get_custom_display(name, array.as_ref(), "-");
(formatter, array.as_ref().len())
})
.unzip();

if displayers.is_empty() {
return table;
}

let header = names
.into_iter()
.iter()
.zip(arrays.iter().map(|array| array.as_ref().data_type()))
.map(|(name, data_type)| {
Cell::new(format!(
"{}\n---\n{}",
name.as_ref(),
name,
DisplayDataType(data_type.clone())
))
});
Expand Down
4 changes: 2 additions & 2 deletions crates/re_log_types/src/component_types/msg_id.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,10 @@ use crate::{Component, ComponentName};
/// # use arrow2::datatypes::{DataType, Field};
/// assert_eq!(
/// MsgId::data_type(),
/// DataType::Struct(vec![
/// DataType::Extension("rerun.tuid".into(), Box::new(DataType::Struct(vec![
/// Field::new("time_ns", DataType::UInt64, false),
/// Field::new("inc", DataType::UInt64, false),
/// ])
/// ])), None),
/// );
/// ```
#[derive(
Expand Down
49 changes: 34 additions & 15 deletions crates/re_log_types/src/data_table.rs
Original file line number Diff line number Diff line change
Expand Up @@ -150,15 +150,15 @@ impl std::ops::IndexMut<usize> for DataCellColumn {
///
/// The table above translates to the following, where each column is contiguous in memory:
/// ```text
/// ┌──────────────────────────────────────────────────────────┬────────────────────┬─────────────────────┬─────────────┬──────────────────────────────────┬─────────────────┐
/// │ rerun.row_id ┆ rerun.timepoint ┆ rerun.entity_path ┆ rerun.num_instances ┆ rerun.label ┆ rerun.point2d ┆ rerun.colorrgba │
/// ╞══════════════════════════════════════════════════════════╪════════════════════╪═════════════════════╪═════════════╪══════════════════════════════════╪═════════════════╡
/// │ {167967218, 54449486} ┆ [{frame_nr, 1, 1}, {clock, 1, 1}] ┆ a ┆ 2 ┆ [] ┆ [{x: 10, y: 10}, {x: 20, y: 20}] ┆ [2155905279] │
/// ├╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┤
/// │ {167967218, 54449486} ┆ [{frame_nr, 1, 1}, {clock, 1, 2}] ┆ b ┆ 0 ┆ - ┆ - ┆ [] │
/// ├╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┤
/// │ {167967218, 54449486} ┆ [{frame_nr, 1, 2}, {clock, 1, 1}] ┆ c ┆ 1 ┆ [hey] ┆ - ┆ [4294967295] │
/// └──────────────────────────────────────────────────────────┴────────────────────┴─────────────────────┴─────────────┴──────────────────────────────────┴─────────────────┘
/// ┌───────────────────────────────────────────────────────────────────────────┬───────────────────┬─────────────────────┬─────────────┬──────────────────────────────────┬─────────────────┐
/// │ frame_nr ┆ log_time ┆ rerun.row_id ┆ rerun.entity_path ┆ rerun.num_instances ┆ rerun.label ┆ rerun.point2d ┆ rerun.colorrgba │
/// ╞═══════════════════════════════════════════════════════════════════════════╪═══════════════════╪═════════════════════╪═════════════╪══════════════════════════════════╪═════════════════╡
/// │ 1 ┆ 2023-04-05 09:36:47.188796402 ┆ 1753004ACBF5D6E651F2983C3DAF260C ┆ a ┆ 2 ┆ [] ┆ [{x: 10, y: 10}, {x: 20, y: 20}] ┆ [2155905279] │
/// ├╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┤
/// │ 1 ┆ 2023-04-05 09:36:47.188852222 ┆ 1753004ACBF5D6E651F2983C3DAF260C ┆ b ┆ 0 ┆ - ┆ - ┆ [] │
/// ├╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌╌┤
/// │ 2 ┆ 2023-04-05 09:36:47.188855872 ┆ 1753004ACBF5D6E651F2983C3DAF260C ┆ c ┆ 1 ┆ [hey] ┆ - ┆ [4294967295] │
/// └───────────────────────────────────────────────────────────────────────────┴───────────────────┴─────────────────────┴─────────────┴──────────────────────────────────┴─────────────────┘
/// ```
///
/// ## Example
Expand Down Expand Up @@ -533,8 +533,6 @@ impl DataTable {
[(METADATA_KIND.to_owned(), METADATA_KIND_CONTROL.to_owned())].into(),
);

// TODO(cmc): why do we have to do this manually on the way out, but it's done
// automatically on our behalf on the way in...?
if let DataType::Extension(name, _, _) = data.data_type() {
field
.metadata
Expand Down Expand Up @@ -627,15 +625,20 @@ impl DataTable {
.map(|cell| cell.as_arrow_ref())
.collect_vec();

let ext_name = cell_refs.first().and_then(|cell| match cell.data_type() {
DataType::Extension(name, _, _) => Some(name),
_ => None,
});

// NOTE: Avoid paying for the cost of the concatenation machinery if there's a single
// row in the column.
let data = if cell_refs.len() == 1 {
data_to_lists(column, cell_refs[0].to_boxed())
data_to_lists(column, cell_refs[0].to_boxed(), ext_name.cloned())
} else {
// NOTE: This is a column of cells, it shouldn't ever fail to concatenate since
// they share the same underlying type.
let data = arrow2::compute::concatenate::concatenate(cell_refs.as_slice())?;
data_to_lists(column, data)
data_to_lists(column, data, ext_name.cloned())
};

let field = Field::new(name, data.data_type().clone(), false)
Expand All @@ -648,10 +651,26 @@ impl DataTable {
///
/// * Before: `[C, C, C, C, C, C, C, ...]`
/// * After: `ListArray[ [[C, C], [C, C, C], None, [C], [C], ...] ]`
fn data_to_lists(column: &[Option<DataCell>], data: Box<dyn Array>) -> Box<dyn Array> {
fn data_to_lists(
column: &[Option<DataCell>],
data: Box<dyn Array>,
ext_name: Option<String>,
) -> Box<dyn Array> {
let datatype = data.data_type().clone();

let datatype = ListArray::<i32>::default_datatype(datatype);
let field = {
let mut field = Field::new("item", datatype, true);

if let Some(name) = ext_name {
field
.metadata
.extend([("ARROW:extension:name".to_owned(), name)]);
}

field
};

let datatype = DataType::List(Box::new(field));
let offsets = Offsets::try_from_lengths(column.iter().map(|cell| {
cell.as_ref()
.map_or(0, |cell| cell.num_instances() as usize)
Expand Down
28 changes: 24 additions & 4 deletions crates/re_tuid/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,10 @@
#![doc = document_features::document_features!()]
//!
use arrow2_convert::{ArrowDeserialize, ArrowField, ArrowSerialize};
use arrow2::datatypes::DataType;
use arrow2_convert::{ArrowDeserialize, ArrowSerialize};

#[derive(
Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, ArrowField, ArrowSerialize, ArrowDeserialize,
)]
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, ArrowSerialize, ArrowDeserialize)]
#[cfg_attr(feature = "serde", derive(serde::Deserialize, serde::Serialize))]
pub struct Tuid {
/// Approximate nanoseconds since epoch.
Expand All @@ -21,6 +20,27 @@ pub struct Tuid {
inc: u64,
}

arrow2_convert::arrow_enable_vec_for_type!(Tuid);

// TODO(#1774): shouldn't have to write this manually
impl arrow2_convert::field::ArrowField for Tuid {
type Type = Self;

fn data_type() -> arrow2::datatypes::DataType {
let datatype = arrow2::datatypes::DataType::Struct(<[_]>::into_vec(Box::new([
<u64 as arrow2_convert::field::ArrowField>::field("time_ns"),
<u64 as arrow2_convert::field::ArrowField>::field("inc"),
])));
DataType::Extension("rerun.tuid".into(), Box::new(datatype), None)
}
}

impl std::fmt::Display for Tuid {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "{:032X}", self.as_u128())
}
}

impl std::fmt::Debug for Tuid {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "{:032X}", self.as_u128())
Expand Down

1 comment on commit 3be747c

@github-actions
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Rust Benchmark

Benchmark suite Current: 3be747c Previous: d6cce1c Ratio
datastore/num_rows=1000/num_instances=1000/packed=false/insert/default 11306682 ns/iter (± 440609) 11194874 ns/iter (± 504802) 1.01
datastore/num_rows=1000/num_instances=1000/packed=false/insert/bucketsz=0 14126657 ns/iter (± 757077) 13186615 ns/iter (± 644932) 1.07
datastore/num_rows=1000/num_instances=1000/packed=false/insert/bucketsz=2 12912141 ns/iter (± 576516) 12735561 ns/iter (± 551566) 1.01
datastore/num_rows=1000/num_instances=1000/packed=false/insert/bucketsz=32 11403049 ns/iter (± 516850) 11321877 ns/iter (± 408025) 1.01
datastore/num_rows=1000/num_instances=1000/packed=false/insert/bucketsz=2048 11443930 ns/iter (± 698372) 11060150 ns/iter (± 592723) 1.03
datastore/num_rows=1000/num_instances=1000/packed=true/insert/default 11023654 ns/iter (± 579959) 10762049 ns/iter (± 518526) 1.02
datastore/num_rows=1000/num_instances=1000/packed=true/insert/bucketsz=0 13756804 ns/iter (± 638643) 12725376 ns/iter (± 640087) 1.08
datastore/num_rows=1000/num_instances=1000/packed=true/insert/bucketsz=2 12641013 ns/iter (± 665367) 12130226 ns/iter (± 659042) 1.04
datastore/num_rows=1000/num_instances=1000/packed=true/insert/bucketsz=32 11187066 ns/iter (± 541598) 10835012 ns/iter (± 486329) 1.03
datastore/num_rows=1000/num_instances=1000/packed=true/insert/bucketsz=2048 10790959 ns/iter (± 427863) 10813121 ns/iter (± 468546) 1.00
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at/default 1851 ns/iter (± 18) 1828 ns/iter (± 20) 1.01
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at/bucketsz=0 1858 ns/iter (± 8) 1854 ns/iter (± 9) 1.00
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at/bucketsz=2 1854 ns/iter (± 11) 1852 ns/iter (± 13) 1.00
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at/bucketsz=32 1879 ns/iter (± 10) 1823 ns/iter (± 99) 1.03
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at/bucketsz=2048 1850 ns/iter (± 9) 1814 ns/iter (± 10) 1.02
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at/default 1855 ns/iter (± 21) 1819 ns/iter (± 26) 1.02
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at/bucketsz=0 1859 ns/iter (± 10) 1840 ns/iter (± 8) 1.01
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at/bucketsz=2 1860 ns/iter (± 12) 1976 ns/iter (± 10) 0.94
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at/bucketsz=32 1838 ns/iter (± 11) 1801 ns/iter (± 7) 1.02
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at/bucketsz=2048 1832 ns/iter (± 10) 1783 ns/iter (± 4) 1.03
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/primary/default 283 ns/iter (± 0) 284 ns/iter (± 0) 1.00
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/secondaries/default 435 ns/iter (± 0) 440 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/primary/bucketsz=0 281 ns/iter (± 0) 283 ns/iter (± 0) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/secondaries/bucketsz=0 443 ns/iter (± 1) 446 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/primary/bucketsz=2 281 ns/iter (± 0) 283 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/secondaries/bucketsz=2 443 ns/iter (± 0) 446 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/primary/bucketsz=32 283 ns/iter (± 0) 284 ns/iter (± 1) 1.00
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/secondaries/bucketsz=32 440 ns/iter (± 0) 444 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/primary/bucketsz=2048 283 ns/iter (± 0) 285 ns/iter (± 0) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/latest_at_missing/secondaries/bucketsz=2048 439 ns/iter (± 2) 439 ns/iter (± 1) 1
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/primary/default 283 ns/iter (± 0) 285 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/secondaries/default 435 ns/iter (± 1) 441 ns/iter (± 4) 0.99
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/primary/bucketsz=0 281 ns/iter (± 0) 282 ns/iter (± 1) 1.00
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/secondaries/bucketsz=0 443 ns/iter (± 0) 446 ns/iter (± 2) 0.99
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/primary/bucketsz=2 281 ns/iter (± 0) 282 ns/iter (± 1) 1.00
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/secondaries/bucketsz=2 442 ns/iter (± 0) 446 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/primary/bucketsz=32 283 ns/iter (± 0) 284 ns/iter (± 0) 1.00
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/secondaries/bucketsz=32 440 ns/iter (± 0) 443 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/primary/bucketsz=2048 283 ns/iter (± 0) 284 ns/iter (± 0) 1.00
datastore/num_rows=1000/num_instances=1000/packed=true/latest_at_missing/secondaries/bucketsz=2048 436 ns/iter (± 0) 442 ns/iter (± 1) 0.99
datastore/num_rows=1000/num_instances=1000/packed=false/range/default 15200439 ns/iter (± 438260) 11623590 ns/iter (± 417887) 1.31
datastore/num_rows=1000/num_instances=1000/packed=false/range/bucketsz=0 2334572 ns/iter (± 55634) 2498076 ns/iter (± 9066) 0.93
datastore/num_rows=1000/num_instances=1000/packed=false/range/bucketsz=2 2216958 ns/iter (± 17591) 2386056 ns/iter (± 39658) 0.93
datastore/num_rows=1000/num_instances=1000/packed=false/range/bucketsz=32 1914231 ns/iter (± 9892) 2149255 ns/iter (± 14986) 0.89
datastore/num_rows=1000/num_instances=1000/packed=false/range/bucketsz=2048 1871361 ns/iter (± 8271) 2060487 ns/iter (± 7330) 0.91
datastore/num_rows=1000/num_instances=1000/packed=true/range/default 11614774 ns/iter (± 623175) 11061114 ns/iter (± 697889) 1.05
datastore/num_rows=1000/num_instances=1000/packed=true/range/bucketsz=0 2131867 ns/iter (± 7752) 2412560 ns/iter (± 10671) 0.88
datastore/num_rows=1000/num_instances=1000/packed=true/range/bucketsz=2 2140570 ns/iter (± 26386) 2414467 ns/iter (± 9007) 0.89
datastore/num_rows=1000/num_instances=1000/packed=true/range/bucketsz=32 1844897 ns/iter (± 17501) 2028556 ns/iter (± 9078) 0.91
datastore/num_rows=1000/num_instances=1000/packed=true/range/bucketsz=2048 1829034 ns/iter (± 7480) 1923699 ns/iter (± 11025) 0.95
mono_points_arrow/generate_message_bundles 47289809 ns/iter (± 542415) 47341690 ns/iter (± 901351) 1.00
mono_points_arrow/generate_messages 152778242 ns/iter (± 1095428) 153377797 ns/iter (± 1274146) 1.00
mono_points_arrow/encode_log_msg 183527207 ns/iter (± 992678) 191111995 ns/iter (± 822229) 0.96
mono_points_arrow/encode_total 382694293 ns/iter (± 1594018) 389712932 ns/iter (± 1506223) 0.98
mono_points_arrow/decode_log_msg 232177493 ns/iter (± 825811) 228082634 ns/iter (± 908490) 1.02
mono_points_arrow/decode_message_bundles 72181790 ns/iter (± 601140) 85993581 ns/iter (± 824742) 0.84
mono_points_arrow/decode_total 309659930 ns/iter (± 1525146) 314835861 ns/iter (± 1575306) 0.98
mono_points_arrow_batched/generate_message_bundles 40495454 ns/iter (± 1242825) 38717973 ns/iter (± 1596673) 1.05
mono_points_arrow_batched/generate_messages 8347288 ns/iter (± 532005) 7571198 ns/iter (± 496410) 1.10
mono_points_arrow_batched/encode_log_msg 1489499 ns/iter (± 10777) 1721235 ns/iter (± 15697) 0.87
mono_points_arrow_batched/encode_total 52148625 ns/iter (± 1713979) 49169199 ns/iter (± 2285050) 1.06
mono_points_arrow_batched/decode_log_msg 860449 ns/iter (± 3058) 966155 ns/iter (± 3285) 0.89
mono_points_arrow_batched/decode_message_bundles 13220882 ns/iter (± 911097) 11781200 ns/iter (± 400892) 1.12
mono_points_arrow_batched/decode_total 13732058 ns/iter (± 777944) 13299495 ns/iter (± 708556) 1.03
batch_points_arrow/generate_message_bundles 285834 ns/iter (± 913) 307575 ns/iter (± 1365) 0.93
batch_points_arrow/generate_messages 6409 ns/iter (± 17) 5717 ns/iter (± 32) 1.12
batch_points_arrow/encode_log_msg 383397 ns/iter (± 1670) 425853 ns/iter (± 2013) 0.90
batch_points_arrow/encode_total 693670 ns/iter (± 3268) 750165 ns/iter (± 3354) 0.92
batch_points_arrow/decode_log_msg 359561 ns/iter (± 1013) 388069 ns/iter (± 1019) 0.93
batch_points_arrow/decode_message_bundles 2378 ns/iter (± 5) 2158 ns/iter (± 17) 1.10
batch_points_arrow/decode_total 366973 ns/iter (± 878) 398651 ns/iter (± 1472) 0.92
arrow_mono_points/insert 6478369758 ns/iter (± 26784240) 7177901538 ns/iter (± 20732705) 0.90
arrow_mono_points/query 1824473 ns/iter (± 17579) 1919860 ns/iter (± 9951) 0.95
arrow_batch_points/insert 3180948 ns/iter (± 16051) 3132053 ns/iter (± 9789) 1.02
arrow_batch_points/query 17197 ns/iter (± 29) 17274 ns/iter (± 47) 1.00
arrow_batch_vecs/insert 45543 ns/iter (± 322) 46606 ns/iter (± 157) 0.98
arrow_batch_vecs/query 506252 ns/iter (± 578) 524339 ns/iter (± 1849) 0.97
tuid/Tuid::random 46 ns/iter (± 5) 34 ns/iter (± 0) 1.35

This comment was automatically generated by workflow using github-action-benchmark.

Please sign in to comment.