Module mz_compute_types::plan

source ·
Expand description

An explicit representation of a rendering plan for provided dataflows.

Modules§

  • FlatPlan, a flat representation of LIR plans used in the compute protocol and rendering, and support for for flatting Plans into this representation.
  • Utilities and implementations for abstract interpretation of crate::plan::Plan structures.
  • Planning of Plan::Join operators, and supporting types.
  • lowering 🔒
    Lowering DataflowDescriptions from MIR (MirRelationExpr) to LIR (Plan).
  • Nested message and enum types in ProtoAvailableCollections.
  • Nested message and enum types in ProtoGetPlan.
  • Reduction execution planning and dataflow construction. We build ReducePlans to manage the complexity of planning the generated dataflow for a given reduce expression. The intent here is that each creating a ReducePlan should capture all of the decision making about what kind of dataflow do we need to render and what each operator needs to do, and then actually rendering the plan can be a relatively simple application of (as much as possible) straight line code.
  • Threshold planning logic.
  • TopK planning logic.
  • Utilities and implementations for transformation of crate::plan::Plan structures.

Structs§

Enums§

  • How a Get stage will be rendered.
  • A rendering plan with as much conditional logic as possible removed.

Constants§

Functions§

  • A strategy that produces arrangements that are thinner than the default. That is the number of direct children is limited to a maximum of 3.
  • Returns bucket sizes, descending, suitable for hierarchical decomposition of an operator, based on the expected number of rows that will have the same group key.

Type Aliases§

  • An identifier for an LIR node.