use itertools::Itertools;
use vortex_error::VortexResult;
use crate::ArrayRef;
use crate::IntoArray;
use crate::arrays::ConstantArray;
use crate::arrays::ScalarFnArray;
use crate::expr::Expression;
use crate::optimizer::ArrayOptimizer;
use crate::scalar_fn::fns::literal::Literal;
use crate::scalar_fn::fns::root::Root;
impl ArrayRef {
pub fn apply(self, expr: &Expression) -> VortexResult<ArrayRef> {
if expr.is::<Root>() {
return Ok(self);
}
if let Some(scalar) = expr.as_opt::<Literal>() {
return Ok(ConstantArray::new(scalar.clone(), self.len()).into_array());
}
let children: Vec<_> = expr
.children()
.iter()
.map(|e| self.clone().apply(e))
.try_collect()?;
let array =
ScalarFnArray::try_new(expr.scalar_fn().clone(), children, self.len())?.into_array();
array.optimize()
}
}