From 0bcb19bff9ae9037615a845affe682e14f86a7dd Mon Sep 17 00:00:00 2001 From: psvri Date: Thu, 15 Feb 2024 22:16:58 +0530 Subject: [PATCH 1/2] Add cast f64 to string to benchmark --- arrow/benches/cast_kernels.rs | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/arrow/benches/cast_kernels.rs b/arrow/benches/cast_kernels.rs index 933ddd4a06b..6632dbc57c5 100644 --- a/arrow/benches/cast_kernels.rs +++ b/arrow/benches/cast_kernels.rs @@ -207,7 +207,9 @@ fn add_benchmark(c: &mut Criterion) { c.bench_function("cast f32 to string 512", |b| { b.iter(|| cast_array(&f32_array, DataType::Utf8)) }); - + c.bench_function("cast f64 to string 512", |b| { + b.iter(|| cast_array(&f64_array, DataType::Utf8)) + }); c.bench_function("cast timestamp_ms to i64 512", |b| { b.iter(|| cast_array(&time_ms_array, DataType::Int64)) }); From 428a7b44c69313063a483384c224cfd397591a30 Mon Sep 17 00:00:00 2001 From: psvri Date: Thu, 15 Feb 2024 22:21:40 +0530 Subject: [PATCH 2/2] Improve float to string performance using ryu --- arrow-cast/Cargo.toml | 1 + arrow-cast/src/display.rs | 16 +++++++++++++++- 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/arrow-cast/Cargo.toml b/arrow-cast/Cargo.toml index 81dd0ebd415..2d8a57aba5f 100644 --- a/arrow-cast/Cargo.toml +++ b/arrow-cast/Cargo.toml @@ -52,6 +52,7 @@ lexical-core = { version = "^0.8", default-features = false, features = ["write- atoi = "2.0.0" comfy-table = { version = "7.0", optional = true, default-features = false } base64 = "0.21" +ryu = "1.0.16" [dev-dependencies] criterion = { version = "0.5", default-features = false } diff --git a/arrow-cast/src/display.rs b/arrow-cast/src/display.rs index d74128a20ba..9ec12f6e63d 100644 --- a/arrow-cast/src/display.rs +++ b/arrow-cast/src/display.rs @@ -427,9 +427,23 @@ macro_rules! primitive_display { }; } +macro_rules! primitive_display_float { + ($($t:ty),+) => { + $(impl<'a> DisplayIndex for &'a PrimitiveArray<$t> + { + fn write(&self, idx: usize, f: &mut dyn Write) -> FormatResult { + let value = self.value(idx); + let mut buffer = ryu::Buffer::new(); + f.write_str(buffer.format(value))?; + Ok(()) + } + })+ + }; +} + primitive_display!(Int8Type, Int16Type, Int32Type, Int64Type); primitive_display!(UInt8Type, UInt16Type, UInt32Type, UInt64Type); -primitive_display!(Float32Type, Float64Type); +primitive_display_float!(Float32Type, Float64Type); impl<'a> DisplayIndex for &'a PrimitiveArray { fn write(&self, idx: usize, f: &mut dyn Write) -> FormatResult {