vortex_sequence/compute/
is_sorted.rs

1// SPDX-License-Identifier: Apache-2.0
2// SPDX-FileCopyrightText: Copyright the Vortex contributors
3
4use num_traits::zero;
5use vortex_array::compute::IsSortedKernel;
6use vortex_array::compute::IsSortedKernelAdapter;
7use vortex_array::register_kernel;
8use vortex_dtype::match_each_native_ptype;
9use vortex_error::VortexResult;
10
11use crate::SequenceArray;
12use crate::SequenceVTable;
13
14impl IsSortedKernel for SequenceVTable {
15    fn is_sorted(&self, array: &SequenceArray) -> VortexResult<Option<bool>> {
16        let m = array.multiplier();
17        match_each_native_ptype!(m.ptype(), |P| { Ok(Some(m.cast::<P>() >= zero::<P>())) })
18    }
19
20    fn is_strict_sorted(&self, array: &SequenceArray) -> VortexResult<Option<bool>> {
21        let m = array.multiplier();
22        match_each_native_ptype!(m.ptype(), |P| { Ok(Some(m.cast::<P>() > zero::<P>())) })
23    }
24}
25
26register_kernel!(IsSortedKernelAdapter(SequenceVTable).lift());