pub struct PhysicalExprSimplifier<'a> { /* private fields */ }Expand description
Simplifies physical expressions by applying various optimizations
This can be useful after adapting expressions from a table schema to a file schema. For example, casts added to match the types may potentially be unwrapped.
Implementations§
Source§impl<'a> PhysicalExprSimplifier<'a>
impl<'a> PhysicalExprSimplifier<'a>
Sourcepub fn simplify(
&mut self,
expr: Arc<dyn PhysicalExpr>,
) -> Result<Arc<dyn PhysicalExpr>>
pub fn simplify( &mut self, expr: Arc<dyn PhysicalExpr>, ) -> Result<Arc<dyn PhysicalExpr>>
Simplify a physical expression
Trait Implementations§
Source§impl<'a> TreeNodeRewriter for PhysicalExprSimplifier<'a>
impl<'a> TreeNodeRewriter for PhysicalExprSimplifier<'a>
Source§type Node = Arc<dyn PhysicalExpr>
type Node = Arc<dyn PhysicalExpr>
The node type which is rewritable.
Source§fn f_up(&mut self, node: Self::Node) -> Result<Transformed<Self::Node>>
fn f_up(&mut self, node: Self::Node) -> Result<Transformed<Self::Node>>
Invoked while traversing up the tree after all children have been rewritten.
Default implementation returns the node as is and continues recursion.
Source§fn f_down(
&mut self,
node: Self::Node,
) -> Result<Transformed<Self::Node>, DataFusionError>
fn f_down( &mut self, node: Self::Node, ) -> Result<Transformed<Self::Node>, DataFusionError>
Invoked while traversing down the tree before any children are rewritten.
Default implementation returns the node as is and continues recursion.
Auto Trait Implementations§
impl<'a> Freeze for PhysicalExprSimplifier<'a>
impl<'a> RefUnwindSafe for PhysicalExprSimplifier<'a>
impl<'a> Send for PhysicalExprSimplifier<'a>
impl<'a> Sync for PhysicalExprSimplifier<'a>
impl<'a> Unpin for PhysicalExprSimplifier<'a>
impl<'a> UnwindSafe for PhysicalExprSimplifier<'a>
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
Mutably borrows from an owned value. Read more
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>
Converts
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>
Converts
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 more