polars_arrow/compute/take/
boolean.rsuse polars_utils::IdxSize;
use super::bitmap::{take_bitmap_nulls_unchecked, take_bitmap_unchecked};
use crate::array::{Array, BooleanArray, PrimitiveArray};
use crate::bitmap::{Bitmap, MutableBitmap};
unsafe fn take_no_validity(values: &Bitmap, indices: &[IdxSize]) -> (Bitmap, Option<Bitmap>) {
(take_bitmap_unchecked(values, indices), None)
}
unsafe fn take_values_validity(
values: &BooleanArray,
indices: &[IdxSize],
) -> (Bitmap, Option<Bitmap>) {
let validity_values = values.validity().unwrap();
let validity = take_bitmap_unchecked(validity_values, indices);
let values_values = values.values();
let buffer = take_bitmap_unchecked(values_values, indices);
(buffer, validity.into())
}
unsafe fn take_indices_validity(
values: &Bitmap,
indices: &PrimitiveArray<IdxSize>,
) -> (Bitmap, Option<Bitmap>) {
let buffer = take_bitmap_nulls_unchecked(values, indices);
(buffer, indices.validity().cloned())
}
unsafe fn take_values_indices_validity(
values: &BooleanArray,
indices: &PrimitiveArray<IdxSize>,
) -> (Bitmap, Option<Bitmap>) {
let mut validity = MutableBitmap::with_capacity(indices.len());
let values_validity = values.validity().unwrap();
let values_values = values.values();
let values = indices.iter().map(|index| match index {
Some(&index) => {
let index = index as usize;
debug_assert!(index < values.len());
validity.push(values_validity.get_bit_unchecked(index));
values_values.get_bit_unchecked(index)
},
None => {
validity.push(false);
false
},
});
let values = Bitmap::from_trusted_len_iter(values);
(values, validity.into())
}
pub unsafe fn take_unchecked(
values: &BooleanArray,
indices: &PrimitiveArray<IdxSize>,
) -> BooleanArray {
let dtype = values.dtype().clone();
let indices_has_validity = indices.null_count() > 0;
let values_has_validity = values.null_count() > 0;
let (values, validity) = match (values_has_validity, indices_has_validity) {
(false, false) => take_no_validity(values.values(), indices.values()),
(true, false) => take_values_validity(values, indices.values()),
(false, true) => take_indices_validity(values.values(), indices),
(true, true) => take_values_indices_validity(values, indices),
};
BooleanArray::new(dtype, values, validity)
}