From a65483316357ad74654fbe80e00c4c5d4163d8cf Mon Sep 17 00:00:00 2001 From: Dan King Date: Mon, 21 Oct 2024 10:08:44 -0400 Subject: [PATCH] feat: teach PyArray filter (#1091) --- pyvortex/src/array.rs | 32 +++++++++++++++++++++++++++++--- 1 file changed, 29 insertions(+), 3 deletions(-) diff --git a/pyvortex/src/array.rs b/pyvortex/src/array.rs index 10b8043fe4..c74fe746fd 100644 --- a/pyvortex/src/array.rs +++ b/pyvortex/src/array.rs @@ -139,10 +139,12 @@ impl PyArray { PyDType::wrap(self_.py(), self_.inner.dtype().clone()) } - /// Fill forward non-null values over runs of nulls. + /// Filter an Array by another Boolean array. /// - /// Leading nulls are replaced with the "zero" for that type. For integral and floating-point - /// types, this is zero. For the Boolean type, this is `:obj:`False`. + /// Parameters + /// ---------- + /// filter : :class:`vortex.encoding.Array` + /// Keep all the rows in ``self`` for which the correspondingly indexed row in `filter` is True. /// /// Returns /// ------- @@ -151,6 +153,30 @@ impl PyArray { /// Examples /// -------- /// + /// Keep only the single digit positive integers. + /// + /// >>> a = vortex.encoding.array([0, 42, 1_000, -23, 10, 9, 5]) + /// >>> filter = vortex.array([True, False, False, False, False, True, True]) + /// >>> a.filter(filter).to_arrow_array() + /// + /// [ + /// 0, + /// 9, + /// 5 + /// ] + fn filter(&self, filter: &Bound) -> PyResult { + let filter = filter.borrow(); + + vortex::compute::filter(&self.inner, &filter.inner) + .map_err(PyVortexError::map_err) + .map(|arr| PyArray { inner: arr }) + } + + /// Fill forward non-null values over runs of nulls. + /// + /// Leading nulls are replaced with the "zero" for that type. For integral and floating-point + /// types, this is zero. For the Boolean type, this is `:obj:`False`. + /// /// Fill forward sensor values over intermediate missing values. Note that leading nulls are /// replaced with 0.0: ///