Skip to content

Commit

Permalink
Move PType into vortex-dtype
Browse files Browse the repository at this point in the history
  • Loading branch information
gatesn committed Apr 29, 2024
1 parent e845b4c commit 8feb313
Show file tree
Hide file tree
Showing 61 changed files with 185 additions and 195 deletions.
4 changes: 3 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions vortex-alp/src/compress.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@ use itertools::Itertools;
use vortex::array::primitive::PrimitiveArray;
use vortex::array::sparse::{Sparse, SparseArray};
use vortex::compress::{CompressConfig, CompressCtx, EncodingCompression};
use vortex::ptype::{NativePType, PType};
use vortex::scalar::Scalar;
use vortex::validity::Validity;
use vortex::{Array, ArrayDType, ArrayDef, AsArray, IntoArray, OwnedArray};
use vortex_dtype::{NativePType, PType};
use vortex_error::{vortex_bail, vortex_err, VortexResult};

use crate::alp::ALPFloat;
Expand All @@ -16,8 +16,8 @@ use crate::{Exponents, OwnedALPArray};
macro_rules! match_each_alp_float_ptype {
($self:expr, | $_:tt $enc:ident | $($body:tt)*) => ({
macro_rules! __with__ {( $_ $enc:ident ) => ( $($body)* )}
use vortex_dtype::PType;
use vortex_error::vortex_err;
use vortex::ptype::PType;
let ptype = $self;
match ptype {
PType::F32 => Ok(__with__! { f32 }),
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/bool/compute/take.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
use arrow_buffer::BooleanBuffer;
use num_traits::AsPrimitive;
use vortex_dtype::match_each_integer_ptype;
use vortex_error::VortexResult;

use crate::array::bool::BoolArray;
use crate::compute::take::TakeFn;
use crate::match_each_integer_ptype;
use crate::AsArray;
use crate::IntoArray;
use crate::{Array, OwnedArray};
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/chunked/compute/take.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
use vortex_dtype::PType;
use vortex_error::VortexResult;

use crate::array::chunked::ChunkedArray;
use crate::compute::cast::cast;
use crate::compute::take::{take, TakeFn};
use crate::ptype::PType;
use crate::{Array, IntoArray, OwnedArray, ToArray, ToStatic};
use crate::{ArrayDType, ArrayTrait};

Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/chunked/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -145,10 +145,10 @@ impl EncodingCompression for ChunkedEncoding {}

#[cfg(test)]
mod test {
use vortex_dtype::NativePType;
use vortex_dtype::{DType, IntWidth, Nullability, Signedness};

use crate::array::chunked::{ChunkedArray, OwnedChunkedArray};
use crate::ptype::NativePType;
use crate::{Array, IntoArray};

#[allow(dead_code)]
Expand Down
3 changes: 1 addition & 2 deletions vortex-array/src/array/composite/array.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ use vortex_flatbuffers::{FlatBufferToBytes, ReadFlatBuffer};

use crate::array::composite::{find_extension, CompositeExtensionRef, TypedCompositeArray};
use crate::compute::ArrayCompute;
use crate::scalar::AsBytes;
use crate::stats::ArrayStatisticsCompute;
use crate::validity::{ArrayValidity, LogicalValidity};
use crate::visitor::{AcceptArrayVisitor, ArrayVisitor};
Expand Down Expand Up @@ -141,7 +140,7 @@ impl CompositeArray<'_> {
impl<'a> CompositeArray<'a> {
pub fn as_typed<M: UnderlyingMetadata>(&'a self) -> VortexResult<TypedCompositeArray<'a, M>> {
Ok(TypedCompositeArray::new(
M::try_deserialize_metadata(Some(self.underlying_metadata().as_bytes()))?,
M::try_deserialize_metadata(Some(self.underlying_metadata()))?,
self.underlying().clone(),
))
}
Expand Down
4 changes: 2 additions & 2 deletions vortex-array/src/array/constant/flatten.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
use vortex_dtype::Nullability;
use vortex_dtype::{match_each_native_ptype, Nullability};
use vortex_error::VortexResult;

use crate::array::bool::BoolArray;
use crate::array::constant::ConstantArray;
use crate::array::primitive::PrimitiveArray;
use crate::scalar::Scalar;
use crate::validity::Validity;
use crate::{match_each_native_ptype, ArrayDType, ArrayTrait};
use crate::{ArrayDType, ArrayTrait};
use crate::{ArrayFlatten, Flattened};

impl ArrayFlatten for ConstantArray<'_> {
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/datetime/localdatetime.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,13 @@ use arrow_array::{
TimestampNanosecondArray, TimestampSecondArray,
};
use serde::{Deserialize, Serialize};
use vortex_dtype::PType;
use vortex_error::VortexResult;

use crate::array::datetime::TimeUnit;
use crate::compute::as_arrow::AsArrowArray;
use crate::compute::cast::cast;
use crate::impl_composite;
use crate::ptype::PType;
use crate::validity::ArrayValidity;

impl_composite!("vortex.localdatetime", LocalDateTime);
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/primitive/accessor.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
use vortex_dtype::NativePType;
use vortex_error::VortexResult;

use crate::accessor::ArrayAccessor;
use crate::array::primitive::PrimitiveArray;
use crate::ptype::NativePType;
use crate::validity::ArrayValidity;

impl<T: NativePType> ArrayAccessor<T> for PrimitiveArray<'_> {
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/primitive/compute/as_arrow.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@ use arrow_array::{
ArrayRef as ArrowArrayRef, ArrowPrimitiveType, PrimitiveArray as ArrowPrimitiveArray,
};
use arrow_buffer::ScalarBuffer;
use vortex_dtype::PType;
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::compute::as_arrow::AsArrowArray;
use crate::ptype::PType;
use crate::validity::ArrayValidity;
use crate::ArrayTrait;

Expand Down
3 changes: 2 additions & 1 deletion vortex-array/src/array/primitive/compute/as_contiguous.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
use arrow_buffer::{MutableBuffer, ScalarBuffer};
use vortex_dtype::match_each_native_ptype;
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::compute::as_contiguous::AsContiguousFn;
use crate::validity::Validity;
use crate::{match_each_native_ptype, ArrayDType};
use crate::ArrayDType;
use crate::{Array, IntoArray, OwnedArray};

impl AsContiguousFn for PrimitiveArray<'_> {
Expand Down
8 changes: 4 additions & 4 deletions vortex-array/src/array/primitive/compute/cast.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
use vortex_dtype::DType;
use vortex_dtype::{match_each_native_ptype, DType};
use vortex_dtype::{NativePType, PType};
use vortex_error::{vortex_err, VortexResult};

use crate::array::primitive::PrimitiveArray;
use crate::compute::cast::CastFn;
use crate::ptype::{NativePType, PType};
use crate::validity::Validity;
use crate::{match_each_native_ptype, ArrayDType};
use crate::ArrayDType;
use crate::{IntoArray, OwnedArray};

impl CastFn for PrimitiveArray<'_> {
Expand Down Expand Up @@ -49,9 +49,9 @@ fn cast<T: NativePType>(array: &PrimitiveArray) -> VortexResult<Vec<T>> {

#[cfg(test)]
mod test {
use vortex_dtype::PType;
use vortex_error::VortexError;

use crate::ptype::PType;
use crate::{compute, IntoArray};

#[test]
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/primitive/compute/fill.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
use vortex_dtype::match_each_native_ptype;
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::compute::fill::FillForwardFn;
use crate::match_each_native_ptype;
use crate::validity::ArrayValidity;
use crate::{IntoArray, OwnedArray, ToArrayData};

Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/primitive/compute/scalar_at.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
use vortex_dtype::match_each_native_ptype;
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::compute::scalar_at::ScalarAtFn;
use crate::match_each_native_ptype;
use crate::scalar::PrimitiveScalar;
use crate::scalar::Scalar;
use crate::validity::ArrayValidity;
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/primitive/compute/search_sorted.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
use vortex_dtype::match_each_native_ptype;
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::compute::search_sorted::{SearchResult, SearchSorted};
use crate::compute::search_sorted::{SearchSortedFn, SearchSortedSide};
use crate::match_each_native_ptype;
use crate::scalar::Scalar;

impl SearchSortedFn for PrimitiveArray<'_> {
Expand Down
2 changes: 1 addition & 1 deletion vortex-array/src/array/primitive/compute/slice.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
use vortex_dtype::match_each_native_ptype;
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::compute::slice::SliceFn;
use crate::match_each_native_ptype;
use crate::IntoArray;
use crate::OwnedArray;

Expand Down
4 changes: 2 additions & 2 deletions vortex-array/src/array/primitive/compute/take.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
use num_traits::PrimInt;
use vortex_dtype::NativePType;
use vortex_dtype::{match_each_integer_ptype, match_each_native_ptype};
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::compute::take::TakeFn;
use crate::ptype::NativePType;
use crate::IntoArray;
use crate::{match_each_integer_ptype, match_each_native_ptype};
use crate::{Array, OwnedArray};

impl TakeFn for PrimitiveArray<'_> {
Expand Down
20 changes: 13 additions & 7 deletions vortex-array/src/array/primitive/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,14 @@ use arrow_buffer::{ArrowNativeType, ScalarBuffer};
use itertools::Itertools;
use num_traits::AsPrimitive;
use serde::{Deserialize, Serialize};
use vortex_dtype::{match_each_native_ptype, NativePType, PType};
use vortex_error::{vortex_bail, VortexResult};

use crate::buffer::Buffer;
use crate::ptype::{NativePType, PType};
use crate::validity::{ArrayValidity, LogicalValidity, Validity, ValidityMetadata};
use crate::visitor::{AcceptArrayVisitor, ArrayVisitor};
use crate::ArrayFlatten;
use crate::{impl_encoding, ArrayDType, OwnedArray};
use crate::{match_each_native_ptype, ArrayFlatten};

mod accessor;
mod compute;
Expand All @@ -23,6 +23,7 @@ pub struct PrimitiveMetadata {
}

impl PrimitiveArray<'_> {
// TODO(ngates): remove the Arrow types from this API.
pub fn try_new<T: NativePType + ArrowNativeType>(
buffer: ScalarBuffer<T>,
validity: Validity,
Expand All @@ -40,11 +41,15 @@ impl PrimitiveArray<'_> {
})
}

pub fn from_vec<T: NativePType + ArrowNativeType>(values: Vec<T>, validity: Validity) -> Self {
Self::try_new(ScalarBuffer::from(values), validity).unwrap()
pub fn from_vec<T: NativePType>(values: Vec<T>, validity: Validity) -> Self {
match_each_native_ptype!(T::PTYPE, |$P| {
Self::try_new(ScalarBuffer::<$P>::from(
unsafe { std::mem::transmute::<Vec<T>, Vec<$P>>(values) }
), validity).unwrap()
})
}

pub fn from_nullable_vec<T: NativePType + ArrowNativeType>(values: Vec<Option<T>>) -> Self {
pub fn from_nullable_vec<T: NativePType>(values: Vec<Option<T>>) -> Self {
let elems: Vec<T> = values.iter().map(|v| v.unwrap_or_default()).collect();
let validity = Validity::from(values.iter().map(|v| v.is_some()).collect::<Vec<_>>());
Self::from_vec(elems, validity)
Expand All @@ -65,7 +70,8 @@ impl PrimitiveArray<'_> {
self.array().buffer().expect("missing buffer")
}

pub fn scalar_buffer<T: NativePType>(&self) -> ScalarBuffer<T> {
// TODO(ngates): deprecated, remove this.
pub fn scalar_buffer<T: NativePType + ArrowNativeType>(&self) -> ScalarBuffer<T> {
assert_eq!(
T::PTYPE,
self.ptype(),
Expand Down Expand Up @@ -126,7 +132,7 @@ impl PrimitiveArray<'_> {
for (idx, value) in positions.iter().zip_eq(values.iter()) {
own_values[(*idx).as_()] = *value;
}
Self::try_new(ScalarBuffer::from(own_values), validity)
Ok(Self::from_vec(own_values, validity))
}
}

Expand Down
22 changes: 12 additions & 10 deletions vortex-array/src/array/primitive/stats.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,18 +2,20 @@ use std::collections::HashMap;
use std::mem::size_of;

use arrow_buffer::buffer::BooleanBuffer;
use vortex_dtype::match_each_native_ptype;
use vortex_error::VortexResult;

use crate::array::primitive::PrimitiveArray;
use crate::match_each_native_ptype;
use crate::ptype::NativePType;
use crate::scalar::Scalar;
use crate::scalar::{ListScalarVec, PScalar};
use crate::scalar::{PScalarType, Scalar};
use crate::stats::{ArrayStatisticsCompute, Stat};
use crate::validity::ArrayValidity;
use crate::validity::LogicalValidity;
use crate::IntoArray;

trait PStatsType: PScalarType + Into<Scalar> {}
impl<T: PScalarType + Into<Scalar>> PStatsType for T {}

impl ArrayStatisticsCompute for PrimitiveArray<'_> {
fn compute_statistics(&self, stat: Stat) -> VortexResult<HashMap<Stat, Scalar>> {
match_each_native_ptype!(self.ptype(), |$P| {
Expand All @@ -30,7 +32,7 @@ impl ArrayStatisticsCompute for PrimitiveArray<'_> {
}
}

impl<T: NativePType> ArrayStatisticsCompute for &[T] {
impl<T: PStatsType> ArrayStatisticsCompute for &[T] {
fn compute_statistics(&self, _stat: Stat) -> VortexResult<HashMap<Stat, Scalar>> {
if self.is_empty() {
return Ok(HashMap::default());
Expand All @@ -41,7 +43,7 @@ impl<T: NativePType> ArrayStatisticsCompute for &[T] {
}
}

fn all_null_stats<T: NativePType>(len: usize) -> VortexResult<HashMap<Stat, Scalar>> {
fn all_null_stats<T: PStatsType>(len: usize) -> VortexResult<HashMap<Stat, Scalar>> {
Ok(HashMap::from([
(Stat::Min, Option::<T>::None.into()),
(Stat::Max, Option::<T>::None.into()),
Expand All @@ -61,9 +63,9 @@ fn all_null_stats<T: NativePType>(len: usize) -> VortexResult<HashMap<Stat, Scal
]))
}

struct NullableValues<'a, T: NativePType>(&'a [T], &'a BooleanBuffer);
struct NullableValues<'a, T: PStatsType>(&'a [T], &'a BooleanBuffer);

impl<'a, T: NativePType> ArrayStatisticsCompute for NullableValues<'a, T> {
impl<'a, T: PStatsType> ArrayStatisticsCompute for NullableValues<'a, T> {
fn compute_statistics(&self, _stat: Stat) -> VortexResult<HashMap<Stat, Scalar>> {
let values = self.0;
if values.is_empty() {
Expand Down Expand Up @@ -98,7 +100,7 @@ trait BitWidth {
fn trailing_zeros(self) -> usize;
}

impl<T: NativePType + Into<PScalar>> BitWidth for T {
impl<T: PStatsType> BitWidth for T {
fn bit_width(self) -> usize {
let bit_width = size_of::<T>() * 8;
let scalar: PScalar = self.into();
Expand Down Expand Up @@ -135,7 +137,7 @@ impl<T: NativePType + Into<PScalar>> BitWidth for T {
}
}

struct StatsAccumulator<T: NativePType> {
struct StatsAccumulator<T: PStatsType> {
prev: T,
min: T,
max: T,
Expand All @@ -147,7 +149,7 @@ struct StatsAccumulator<T: NativePType> {
trailing_zeros: Vec<usize>,
}

impl<T: NativePType> StatsAccumulator<T> {
impl<T: PStatsType> StatsAccumulator<T> {
fn new(first_value: T) -> Self {
let mut stats = Self {
prev: first_value,
Expand Down
Loading

0 comments on commit 8feb313

Please sign in to comment.