mz_expr::relation::canonicalize

Function rank_complexity

Source
fn rank_complexity(expr: &MirScalarExpr) -> usize
Expand description

Gives a relative complexity ranking for an expression. Higher numbers mean greater complexity.

Currently, this method weighs literals as the least complex and weighs all other expressions by the number of non-literals. In the future, we can change how complexity is ranked so that repeated substitutions would result in arriving at “better” fixed points. For example, we could try to improve performance by ranking expressions by their estimated computation time.

To ensure we arrive at a fixed point after repeated substitutions, valid complexity rankings must fulfill the following property: For any expression e, there does not exist a SQL function f such that complexity(e) >= complexity(f(e)).

For ease of intuiting the fixed point that we will arrive at after repeated substitutions, it is nice but not required that complexity rankings additionally fulfill the following property: If expressions e1 and e2 are such that complexity(e1) < complexity(e2) then for all SQL functions f, complexity(f(e1)) < complexity(f(e2)).