pub enum ScalarExpr {
Column(usize),
Literal(Value, ConcreteDataType),
CallUnmaterializable(UnmaterializableFunc),
CallUnary {
func: UnaryFunc,
expr: Box<ScalarExpr>,
},
CallBinary {
func: BinaryFunc,
expr1: Box<ScalarExpr>,
expr2: Box<ScalarExpr>,
},
CallVariadic {
func: VariadicFunc,
exprs: Vec<ScalarExpr>,
},
CallDf {
df_scalar_fn: DfScalarFunction,
exprs: Vec<ScalarExpr>,
},
If {
cond: Box<ScalarExpr>,
then: Box<ScalarExpr>,
els: Box<ScalarExpr>,
},
}
Expand description
A scalar expression, which can be evaluated to a value.
Variants§
Column(usize)
A column of the input row
Literal(Value, ConcreteDataType)
A literal value. Extra type info to know original type even when it is null
CallUnmaterializable(UnmaterializableFunc)
A call to an unmaterializable function.
These functions cannot be evaluated by ScalarExpr::eval
. They must
be transformed away by a higher layer.
CallUnary
CallBinary
CallVariadic
CallDf
Fields
df_scalar_fn: DfScalarFunction
invariant: the input args set inside this DfScalarFunction
is
always col(0) to col(n-1) where n is the length of expr
exprs: Vec<ScalarExpr>
If
Conditionally evaluated expressions.
It is important that then
and els
only be evaluated if
cond
is true or not, respectively. This is the only way
users can guard execution (other logical operator do not
short-circuit) and we need to preserve that.
Implementations§
Source§impl ScalarExpr
impl ScalarExpr
pub fn with_type(self, typ: ColumnType) -> TypedExpr
Sourcepub fn typ(&self, context: &[ColumnType]) -> Result<ColumnType, Error>
pub fn typ(&self, context: &[ColumnType]) -> Result<ColumnType, Error>
try to determine the type of the expression
Source§impl ScalarExpr
impl ScalarExpr
pub fn cast(self, typ: ConcreteDataType) -> Self
Sourcepub fn optimize(&mut self)
pub fn optimize(&mut self)
apply optimization to the expression, like flatten variadic function
Sourcefn flatten_variadic_fn(&mut self)
fn flatten_variadic_fn(&mut self)
Because Substrait’s And
/Or
function is binary, but FlowPlan’s
And
/Or
function is variadic, we need to flatten the And
function if multiple And
/Or
functions are nested.
Source§impl ScalarExpr
impl ScalarExpr
Sourcepub fn call_unary(self, func: UnaryFunc) -> Self
pub fn call_unary(self, func: UnaryFunc) -> Self
Call a unary function on this expression.
Sourcepub fn call_binary(self, other: Self, func: BinaryFunc) -> Self
pub fn call_binary(self, other: Self, func: BinaryFunc) -> Self
Call a binary function on this expression and another.
pub fn eval_batch(&self, batch: &Batch) -> Result<VectorRef, EvalError>
Sourcefn eval_if_then(
batch: &Batch,
cond: &ScalarExpr,
then: &ScalarExpr,
els: &ScalarExpr,
) -> Result<VectorRef, EvalError>
fn eval_if_then( batch: &Batch, cond: &ScalarExpr, then: &ScalarExpr, els: &ScalarExpr, ) -> Result<VectorRef, EvalError>
NOTE: this if then eval impl assume all given expr are pure, and will not change the state of the world since it will evaluate both then and else branch and filter the result
Sourcepub fn eval(&self, values: &[Value]) -> Result<Value, EvalError>
pub fn eval(&self, values: &[Value]) -> Result<Value, EvalError>
Eval this expression with the given values.
TODO(discord9): add tests to make sure eval_batch
is the same as eval
in
most cases
Sourcepub fn permute(&mut self, permutation: &[usize]) -> Result<(), Error>
pub fn permute(&mut self, permutation: &[usize]) -> Result<(), Error>
Rewrites column indices with their value in permutation
.
This method is applicable even when permutation
is not a
strict permutation, and it only needs to have entries for
each column referenced in self
.
Sourcepub fn permute_map(
&mut self,
permutation: &BTreeMap<usize, usize>,
) -> Result<(), Error>
pub fn permute_map( &mut self, permutation: &BTreeMap<usize, usize>, ) -> Result<(), Error>
Rewrites column indices with their value in permutation
.
This method is applicable even when permutation
is not a
strict permutation, and it only needs to have entries for
each column referenced in self
.
Sourcepub fn get_all_ref_columns(&self) -> BTreeSet<usize>
pub fn get_all_ref_columns(&self) -> BTreeSet<usize>
Returns the set of columns that are referenced by self
.
Sourcepub fn as_column(&self) -> Option<usize>
pub fn as_column(&self) -> Option<usize>
Cast the expression to a column reference if it is one.
Sourcepub fn as_literal(&self) -> Option<Value>
pub fn as_literal(&self) -> Option<Value>
Cast the expression to a literal if it is one.
Sourcepub fn is_literal(&self) -> bool
pub fn is_literal(&self) -> bool
Return true if the expression is a literal.
Sourcepub fn is_literal_true(&self) -> bool
pub fn is_literal_true(&self) -> bool
Return true if the expression is a literal true.
Sourcepub fn is_literal_false(&self) -> bool
pub fn is_literal_false(&self) -> bool
Return true if the expression is a literal false.
Sourcepub fn is_literal_null(&self) -> bool
pub fn is_literal_null(&self) -> bool
Return true if the expression is a literal null.
Sourcepub fn literal_null() -> Self
pub fn literal_null() -> Self
Build a literal null
Sourcepub fn literal(res: Value, typ: ConcreteDataType) -> Self
pub fn literal(res: Value, typ: ConcreteDataType) -> Self
Build a literal from value and type
Sourcepub fn literal_false() -> Self
pub fn literal_false() -> Self
Build a literal false
Sourcepub fn literal_true() -> Self
pub fn literal_true() -> Self
Build a literal true
Source§impl ScalarExpr
impl ScalarExpr
Sourcefn visit_post_nolimit<F>(&self, f: &mut F) -> Result<(), EvalError>
fn visit_post_nolimit<F>(&self, f: &mut F) -> Result<(), EvalError>
visit post-order without stack call limit, but may cause stack overflow
fn visit_children<F>(&self, f: F) -> Result<(), EvalError>
fn visit_mut_post_nolimit<F>(&mut self, f: &mut F) -> Result<(), Error>
fn visit_mut_children<F>(&mut self, f: F) -> Result<(), Error>
Source§impl ScalarExpr
impl ScalarExpr
Sourcepub fn contains_temporal(&self) -> bool
pub fn contains_temporal(&self) -> bool
if expr contains function Now
Sourcepub fn extract_bound(&self) -> Result<(Option<Self>, Option<Self>), Error>
pub fn extract_bound(&self) -> Result<(Option<Self>, Option<Self>), Error>
extract lower or upper bound of Now
for expr, where lower bound <= expr < upper bound
returned bool indicates whether the bound is upper bound:
false for lower bound, true for upper bound
TODO(discord9): allow simple transform like now() + a < b
to now() < b - a
Trait Implementations§
Source§impl Clone for ScalarExpr
impl Clone for ScalarExpr
Source§fn clone(&self) -> ScalarExpr
fn clone(&self) -> ScalarExpr
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl Debug for ScalarExpr
impl Debug for ScalarExpr
Source§impl Hash for ScalarExpr
impl Hash for ScalarExpr
Source§impl Ord for ScalarExpr
impl Ord for ScalarExpr
Source§fn cmp(&self, other: &ScalarExpr) -> Ordering
fn cmp(&self, other: &ScalarExpr) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Source§impl PartialEq for ScalarExpr
impl PartialEq for ScalarExpr
Source§impl PartialOrd for ScalarExpr
impl PartialOrd for ScalarExpr
impl Eq for ScalarExpr
impl StructuralPartialEq for ScalarExpr
Auto Trait Implementations§
impl !Freeze for ScalarExpr
impl !RefUnwindSafe for ScalarExpr
impl Send for ScalarExpr
impl Sync for ScalarExpr
impl Unpin for ScalarExpr
impl !UnwindSafe for ScalarExpr
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> CallHasher for T
impl<T> CallHasher for T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
§impl<T> Conv for T
impl<T> Conv for T
§impl<T, V> Convert<T> for Vwhere
V: Into<T>,
impl<T, V> Convert<T> for Vwhere
V: Into<T>,
fn convert(value: Self) -> T
fn convert_box(value: Box<Self>) -> Box<T>
fn convert_vec(value: Vec<Self>) -> Vec<T>
fn convert_vec_box(value: Vec<Box<Self>>) -> Vec<Box<T>>
fn convert_matrix(value: Vec<Vec<Self>>) -> Vec<Vec<T>>
fn convert_option(value: Option<Self>) -> Option<T>
fn convert_option_box(value: Option<Box<Self>>) -> Option<Box<T>>
fn convert_option_vec(value: Option<Vec<Self>>) -> Option<Vec<T>>
§impl<Choices> CoproductSubsetter<CNil, HNil> for Choices
impl<Choices> CoproductSubsetter<CNil, HNil> for Choices
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
§impl<T, U, I> LiftInto<U, I> for Twhere
U: LiftFrom<T, I>,
impl<T, U, I> LiftInto<U, I> for Twhere
U: LiftFrom<T, I>,
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<Source> Sculptor<HNil, HNil> for Source
impl<Source> Sculptor<HNil, HNil> for Source
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.