polars_compute/comparisons/
mod.rsuse arrow::array::Array;
use arrow::bitmap::{self, Bitmap};
pub trait TotalEqKernel: Sized + Array {
type Scalar: ?Sized;
fn tot_eq_kernel(&self, other: &Self) -> Bitmap;
fn tot_ne_kernel(&self, other: &Self) -> Bitmap;
fn tot_eq_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap;
fn tot_ne_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap;
fn tot_eq_missing_kernel(&self, other: &Self) -> Bitmap {
let q = self.tot_eq_kernel(other);
let combined = match (self.validity(), other.validity()) {
(None, None) => q,
(None, Some(r)) => &q & r,
(Some(l), None) => &q & l,
(Some(l), Some(r)) => bitmap::ternary(&q, l, r, |q, l, r| (q & l & r) | !(l | r)),
};
combined
}
fn tot_ne_missing_kernel(&self, other: &Self) -> Bitmap {
let q = self.tot_ne_kernel(other);
let combined = match (self.validity(), other.validity()) {
(None, None) => q,
(None, Some(r)) => &q | &!r,
(Some(l), None) => &q | &!l,
(Some(l), Some(r)) => bitmap::ternary(&q, l, r, |q, l, r| (q & l & r) | (l ^ r)),
};
combined
}
fn tot_eq_missing_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap {
let q = self.tot_eq_kernel_broadcast(other);
if let Some(valid) = self.validity() {
bitmap::binary(&q, valid, |q, v| q & v)
} else {
q
}
}
fn tot_ne_missing_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap {
let q = self.tot_ne_kernel_broadcast(other);
if let Some(valid) = self.validity() {
bitmap::binary(&q, valid, |q, v| q | !v)
} else {
q
}
}
}
pub trait TotalOrdKernel: Sized + Array {
type Scalar: ?Sized;
fn tot_lt_kernel(&self, other: &Self) -> Bitmap;
fn tot_le_kernel(&self, other: &Self) -> Bitmap;
fn tot_gt_kernel(&self, other: &Self) -> Bitmap {
other.tot_lt_kernel(self)
}
fn tot_ge_kernel(&self, other: &Self) -> Bitmap {
other.tot_le_kernel(self)
}
fn tot_lt_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap;
fn tot_le_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap;
fn tot_gt_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap;
fn tot_ge_kernel_broadcast(&self, other: &Self::Scalar) -> Bitmap;
}
mod binary;
mod boolean;
mod dictionary;
mod dyn_array;
mod list;
mod null;
mod scalar;
mod struct_;
mod utf8;
mod view;
#[cfg(feature = "simd")]
mod _simd_dtypes {
use arrow::types::{days_ms, f16, i256, months_days_ns};
use crate::NotSimdPrimitive;
impl NotSimdPrimitive for f16 {}
impl NotSimdPrimitive for i256 {}
impl NotSimdPrimitive for days_ms {}
impl NotSimdPrimitive for months_days_ns {}
}
#[cfg(feature = "simd")]
mod simd;
#[cfg(feature = "dtype-array")]
mod array;