use arrow::array::{BooleanArray, FixedSizeListArray};
use arrow::bitmap::Bitmap;
use arrow::legacy::utils::CustomIterTools;
use super::*;
fn array_all_any<F>(arr: &FixedSizeListArray, op: F, is_all: bool) -> PolarsResult<BooleanArray>
where
F: Fn(&BooleanArray) -> bool,
{
let values = arr.values();
polars_ensure!(values.dtype() == &ArrowDataType::Boolean, ComputeError: "expected boolean elements in array");
let values = values.as_any().downcast_ref::<BooleanArray>().unwrap();
let validity = arr.validity().cloned();
if is_all {
let all_set = arrow::compute::boolean::all(values);
if all_set {
let bits = Bitmap::new_with_value(true, arr.len());
return Ok(BooleanArray::from_data_default(bits, None).with_validity(validity));
}
}
let len = arr.size();
let iter = (0..values.len()).step_by(len).map(|start| {
let val = unsafe { values.clone().sliced_unchecked(start, len) };
op(&val)
});
Ok(BooleanArray::from_trusted_len_values_iter(
unsafe { iter.trust_my_length(arr.len()) },
)
.with_validity(validity))
}
pub(super) fn array_all(ca: &ArrayChunked) -> PolarsResult<Series> {
let chunks = ca
.downcast_iter()
.map(|arr| array_all_any(arr, arrow::compute::boolean::all, true));
Ok(BooleanChunked::try_from_chunk_iter(ca.name().clone(), chunks)?.into_series())
}
pub(super) fn array_any(ca: &ArrayChunked) -> PolarsResult<Series> {
let chunks = ca
.downcast_iter()
.map(|arr| array_all_any(arr, arrow::compute::boolean::any, false));
Ok(BooleanChunked::try_from_chunk_iter(ca.name().clone(), chunks)?.into_series())
}