All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hazelcast.org.apache.calcite.plan.RelOptRules Maven / Gradle / Ivy

There is a newer version: 5.5.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to you under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.hazelcast.org.apache.calcite.plan;

import com.hazelcast.org.apache.calcite.adapter.enumerable.EnumerableRules;
import com.hazelcast.org.apache.calcite.config.CalciteSystemProperty;
import com.hazelcast.org.apache.calcite.interpreter.Bindables;
import com.hazelcast.org.apache.calcite.linq4j.function.Experimental;
import com.hazelcast.org.apache.calcite.plan.volcano.AbstractConverter;
import com.hazelcast.org.apache.calcite.rel.rules.CoreRules;
import com.hazelcast.org.apache.calcite.rel.rules.DateRangeRules;
import com.hazelcast.org.apache.calcite.rel.rules.JoinPushThroughJoinRule;
import com.hazelcast.org.apache.calcite.rel.rules.PruneEmptyRules;
import com.hazelcast.org.apache.calcite.rel.rules.materialize.MaterializedViewRules;

import com.hazelcast.com.google.common.collect.ImmutableList;

import java.util.List;

/**
 * A utility class for organizing built-in rules and rule related
 * methods. Currently some rule sets are package private for serving core Calcite.
 *
 * @see RelOptRule
 * @see RelOptUtil
 */
@Experimental
public class RelOptRules {

  private RelOptRules() {
  }

  /** Calc rule set; public so that {@link com.hazelcast.org.apache.calcite.tools.Programs} can
   * use it. */
  public static final ImmutableList CALC_RULES =
      ImmutableList.of(
          Bindables.FROM_NONE_RULE,
          EnumerableRules.ENUMERABLE_CALC_RULE,
          EnumerableRules.ENUMERABLE_FILTER_TO_CALC_RULE,
          EnumerableRules.ENUMERABLE_PROJECT_TO_CALC_RULE,
          CoreRules.FILTER_TO_CALC,
          CoreRules.PROJECT_TO_CALC,
          CoreRules.CALC_MERGE,

          // REVIEW jvs 9-Apr-2006: Do we still need these two?  Doesn't the
          // combination of CalcMergeRule, FilterToCalcRule, and
          // ProjectToCalcRule have the same effect?
          CoreRules.FILTER_CALC_MERGE,
          CoreRules.PROJECT_CALC_MERGE);

  static final List BASE_RULES = ImmutableList.of(
      CoreRules.AGGREGATE_STAR_TABLE,
      CoreRules.AGGREGATE_PROJECT_STAR_TABLE,
      CalciteSystemProperty.COMMUTE.value()
          ? CoreRules.JOIN_ASSOCIATE
          : CoreRules.PROJECT_MERGE,
      CoreRules.FILTER_SCAN,
      CoreRules.PROJECT_FILTER_TRANSPOSE,
      CoreRules.FILTER_PROJECT_TRANSPOSE,
      CoreRules.FILTER_INTO_JOIN,
      CoreRules.JOIN_PUSH_EXPRESSIONS,
      CoreRules.AGGREGATE_EXPAND_DISTINCT_AGGREGATES,
      CoreRules.AGGREGATE_EXPAND_WITHIN_DISTINCT,
      CoreRules.AGGREGATE_CASE_TO_FILTER,
      CoreRules.AGGREGATE_REDUCE_FUNCTIONS,
      CoreRules.FILTER_AGGREGATE_TRANSPOSE,
      CoreRules.PROJECT_WINDOW_TRANSPOSE,
      CoreRules.MATCH,
      CoreRules.JOIN_COMMUTE,
      JoinPushThroughJoinRule.RIGHT,
      JoinPushThroughJoinRule.LEFT,
      CoreRules.SORT_PROJECT_TRANSPOSE,
      CoreRules.SORT_JOIN_TRANSPOSE,
      CoreRules.SORT_REMOVE_CONSTANT_KEYS,
      CoreRules.SORT_UNION_TRANSPOSE,
      CoreRules.EXCHANGE_REMOVE_CONSTANT_KEYS,
      CoreRules.SORT_EXCHANGE_REMOVE_CONSTANT_KEYS);

  static final List ABSTRACT_RULES = ImmutableList.of(
      CoreRules.AGGREGATE_ANY_PULL_UP_CONSTANTS,
      CoreRules.UNION_PULL_UP_CONSTANTS,
      PruneEmptyRules.UNION_INSTANCE,
      PruneEmptyRules.INTERSECT_INSTANCE,
      PruneEmptyRules.MINUS_INSTANCE,
      PruneEmptyRules.PROJECT_INSTANCE,
      PruneEmptyRules.FILTER_INSTANCE,
      PruneEmptyRules.SORT_INSTANCE,
      PruneEmptyRules.AGGREGATE_INSTANCE,
      PruneEmptyRules.JOIN_LEFT_INSTANCE,
      PruneEmptyRules.JOIN_RIGHT_INSTANCE,
      PruneEmptyRules.SORT_FETCH_ZERO_INSTANCE,
      CoreRules.UNION_MERGE,
      CoreRules.INTERSECT_MERGE,
      CoreRules.MINUS_MERGE,
      CoreRules.PROJECT_TO_LOGICAL_PROJECT_AND_WINDOW,
      CoreRules.FILTER_MERGE,
      DateRangeRules.FILTER_INSTANCE,
      CoreRules.INTERSECT_TO_DISTINCT);

  static final List ABSTRACT_RELATIONAL_RULES = ImmutableList.of(
      CoreRules.FILTER_INTO_JOIN,
      CoreRules.JOIN_CONDITION_PUSH,
      AbstractConverter.ExpandConversionRule.INSTANCE,
      CoreRules.JOIN_COMMUTE,
      CoreRules.PROJECT_TO_SEMI_JOIN,
      CoreRules.JOIN_TO_SEMI_JOIN,
      CoreRules.AGGREGATE_REMOVE,
      CoreRules.UNION_TO_DISTINCT,
      CoreRules.PROJECT_REMOVE,
      CoreRules.PROJECT_AGGREGATE_MERGE,
      CoreRules.AGGREGATE_JOIN_TRANSPOSE,
      CoreRules.AGGREGATE_MERGE,
      CoreRules.AGGREGATE_PROJECT_MERGE,
      CoreRules.CALC_REMOVE,
      CoreRules.SORT_REMOVE);

  static final List CONSTANT_REDUCTION_RULES = ImmutableList.of(
      CoreRules.PROJECT_REDUCE_EXPRESSIONS,
      CoreRules.FILTER_REDUCE_EXPRESSIONS,
      CoreRules.CALC_REDUCE_EXPRESSIONS,
      CoreRules.WINDOW_REDUCE_EXPRESSIONS,
      CoreRules.JOIN_REDUCE_EXPRESSIONS,
      CoreRules.FILTER_VALUES_MERGE,
      CoreRules.PROJECT_FILTER_VALUES_MERGE,
      CoreRules.PROJECT_VALUES_MERGE,
      CoreRules.AGGREGATE_VALUES);

  public static final List MATERIALIZATION_RULES = ImmutableList.of(
      MaterializedViewRules.FILTER_SCAN,
      MaterializedViewRules.PROJECT_FILTER,
      MaterializedViewRules.FILTER,
      MaterializedViewRules.PROJECT_JOIN,
      MaterializedViewRules.JOIN,
      MaterializedViewRules.PROJECT_AGGREGATE,
      MaterializedViewRules.AGGREGATE);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy