From 035ad88200be89b28cf916f8cfdd9907b10dac52 Mon Sep 17 00:00:00 2001 From: Andrew Stein Date: Fri, 20 Dec 2024 23:18:53 -0500 Subject: [PATCH] Fix filter config serialization for internal arrow types Signed-off-by: Andrew Stein --- cpp/perspective/src/cpp/server.cpp | 41 +++++++++++++++++- rust/perspective-js/test/arrow/float32.arrow | Bin 0 -> 792 bytes .../test/js/constructors.spec.js | 13 ++++++ rust/perspective-js/test/js/filters.spec.js | 32 ++++++++++++++ rust/perspective-js/test/js/test_arrows.js | 4 ++ 5 files changed, 89 insertions(+), 1 deletion(-) create mode 100644 rust/perspective-js/test/arrow/float32.arrow diff --git a/cpp/perspective/src/cpp/server.cpp b/cpp/perspective/src/cpp/server.cpp index 58f9cad558..b3dd40f3a7 100644 --- a/cpp/perspective/src/cpp/server.cpp +++ b/cpp/perspective/src/cpp/server.cpp @@ -1017,17 +1017,32 @@ coerce_to(const t_dtype dtype, const A& val) { case DTYPE_BOOL: scalar.set(val == "true"); return scalar; + case DTYPE_FLOAT32: + scalar.set(std::stof(val)); + return scalar; case DTYPE_FLOAT64: scalar.set(std::stod(val)); return scalar; + case DTYPE_UINT8: + scalar.set((std::uint8_t)std::stoul(val)); + return scalar; + case DTYPE_UINT16: + scalar.set((std::uint16_t)std::stoul(val)); + return scalar; case DTYPE_UINT32: scalar.set((std::uint32_t)std::stoul(val)); return scalar; case DTYPE_UINT64: scalar.set((std::uint64_t)std::stoull(val)); return scalar; + case DTYPE_INT8: + scalar.set((std::int8_t)std::stoi(val)); + return scalar; + case DTYPE_INT16: + scalar.set((std::int16_t)std::stoi(val)); + return scalar; case DTYPE_INT32: - scalar.set(std::stoi(val)); + scalar.set((std::int32_t)std::stoi(val)); return scalar; case DTYPE_INT64: scalar.set((std::int64_t)std::stoll(val)); @@ -1946,12 +1961,36 @@ ProtoServer::_handle_request(std::uint32_t client_id, const Request& req) { case DTYPE_BOOL: s->set_bool_(scalar.get()); break; + case DTYPE_FLOAT32: + s->set_float_(scalar.get()); + break; case DTYPE_FLOAT64: s->set_float_(scalar.get()); break; + case DTYPE_INT8: + s->set_float_((double)scalar.get()); + break; + case DTYPE_INT16: + s->set_float_((double)scalar.get()); + break; + case DTYPE_INT32: + s->set_float_((double)scalar.get()); + break; case DTYPE_INT64: s->set_float_((double)scalar.get()); break; + case DTYPE_UINT8: + s->set_float_((double)scalar.get()); + break; + case DTYPE_UINT16: + s->set_float_((double)scalar.get()); + break; + case DTYPE_UINT32: + s->set_float_((double)scalar.get()); + break; + case DTYPE_UINT64: + s->set_float_((double)scalar.get()); + break; case DTYPE_STR: s->set_string(scalar.get()); break; diff --git a/rust/perspective-js/test/arrow/float32.arrow b/rust/perspective-js/test/arrow/float32.arrow new file mode 100644 index 0000000000000000000000000000000000000000..91fdf6e557a857297ae449db06ecfe589b01adf1 GIT binary patch literal 792 zcmZ9JK~BR!3`LzLEm2jGN+3WeiyVO^Tf&9~mnfwYl>$X&!&TrAh%GBN9EMwj_h(|7 z#v_kszU^<1r)}GIo|w%|GQ}R+f#sZnBzZ8IJrkF4PSH>F7S+8`KK2Yn(voeAzAQJ} zm5?A47$+=ALXDDpVW(te+?0Qb9?MNY$2FE!ji<%qKUD@IEN96Zce5Y*07xpfIZTQv z0&^aA)#&&~;vJ#udp0Du8LC$YNh%C9R=nYxMF%T5`XMRlZ$;tY|1Oe zpM{xgbE zNo90tc7b-1sYXfr|sKe|Lz^)l{-4?caIaSn*F+t$+`^vnvwpxk2@A~ QzUue45A?g%UH>lo2WU4l`v3p{ literal 0 HcmV?d00001 diff --git a/rust/perspective-js/test/js/constructors.spec.js b/rust/perspective-js/test/js/constructors.spec.js index 278da54ae8..93a0036a4e 100644 --- a/rust/perspective-js/test/js/constructors.spec.js +++ b/rust/perspective-js/test/js/constructors.spec.js @@ -966,6 +966,19 @@ function validate_typed_array(typed_array, column_data) { table.delete(); }); + test("Arrow float32 constructor", async function () { + const table = await perspective.table(arrows.float32_arrow.slice()); + const view = await table.view(); + const result = await view.to_columns(); + expect(result).toEqual({ + id: [1, 2, 3], + name: ["Alice", "Bob", "Charlie"], + score: [92.5, 87.30000305175781, 95.80000305175781], + }); + view.delete(); + table.delete(); + }); + test("Arrow date64 constructor", async function () { const table = await perspective.table(arrows.date64_arrow.slice()); const view = await table.view(); diff --git a/rust/perspective-js/test/js/filters.spec.js b/rust/perspective-js/test/js/filters.spec.js index 36abecfd73..00ce8eba93 100644 --- a/rust/perspective-js/test/js/filters.spec.js +++ b/rust/perspective-js/test/js/filters.spec.js @@ -12,6 +12,7 @@ import { test, expect } from "@finos/perspective-test"; import perspective from "./perspective_client"; +import * as arrows from "./test_arrows.js"; var yesterday = new Date(); yesterday.setDate(yesterday.getDate() - 1); @@ -471,6 +472,37 @@ const datetime_data_local = [ }); }); + test.describe("Arrow types", function () { + // https://github.com/finos/perspective/issues/2881 + test("Arrow float32 filters", async function () { + const table = await perspective.table( + arrows.float32_arrow.slice() + ); + + const view = await table.view({ filter: [["score", "<", 93]] }); + const result = await view.to_columns(); + expect(result).toEqual({ + id: [1, 2], + name: ["Alice", "Bob"], + score: [92.5, 87.30000305175781], + }); + + const cfg = await view.get_config(); + expect(cfg).toEqual({ + aggregates: {}, + columns: ["id", "name", "score"], + expressions: {}, + filter: [["score", "<", 93]], + group_by: [], + sort: [], + split_by: [], + }); + + view.delete(); + table.delete(); + }); + }); + test.describe("multiple", function () { test("x > 1 & x < 4", async function () { var table = await perspective.table(data); diff --git a/rust/perspective-js/test/js/test_arrows.js b/rust/perspective-js/test/js/test_arrows.js index e464fdb038..ce00b3fc07 100644 --- a/rust/perspective-js/test/js/test_arrows.js +++ b/rust/perspective-js/test/js/test_arrows.js @@ -71,6 +71,10 @@ export const int_float_str_file_arrow = load_arrow( path.join(__dirname, "..", "arrow", "int_float_str_file.arrow") ); +export const float32_arrow = load_arrow( + path.join(__dirname, "..", "arrow", "float32.arrow") +); + export const date32_arrow = load_arrow( path.join(__dirname, "..", "arrow", "date32.arrow") );