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

org.apache.hadoop.hive.ql.exec.UDAF Maven / Gradle / Ivy

/**
 * 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 org.apache.hadoop.hive.ql.exec;

/**
 * Base class for all User-defined Aggregation Function (UDAF) classes.
 * 
 * UDAF classes are REQUIRED to inherit from this class.
 * 
 * Required for a UDAF class: 1. Implement the init() method, which reset the
 * status of the aggregation function. 2. Implement a single method called
 * "aggregate" that returns boolean. The method should always return "true" on
 * valid inputs, or the framework will throw an Exception. Following are some
 * examples: public boolean aggregate(double a); public boolean aggregate(int
 * b); public boolean aggregate(double c, double d); 3. Implement a single
 * method called "evaluate" that returns the FINAL aggregation result.
 * "evaluate" should never return "null" or an Exception will be thrown.
 * Following are some examples. public int evaluate(); public long evaluate();
 * public double evaluate(); public Double evaluate(); public String evaluate();
 * 
 * Optional for a UDAF class (by implementing these 2 methods, the user declares
 * that the UDAF support partial aggregations): 1. Implement a single method
 * called "evaluatePartial" that returns the PARTIAL aggregation result.
 * "evaluatePartial" should never return "null" or an Exception will be thrown.
 * 2. Implement a single method called "aggregatePartial" that takes a PARTIAL
 * aggregation result and returns a boolean. The method should always return
 * "true" on valid inputs, or the framework will throw an Exception.
 * 
 * Following are some examples: public int evaluatePartial(); public boolean
 * aggregatePartial(int partial);
 * 
 * public String evaluatePartial(); public boolean aggregatePartial(String
 * partial);
 * 
 */
public class UDAF {

  /**
   * The resolver used for method resolution.
   */
  UDAFEvaluatorResolver rslv;

  /**
   * The default constructor.
   */
  public UDAF() {
    rslv = new DefaultUDAFEvaluatorResolver(this.getClass());
  }

  /**
   * The constructor with a particular type of resolver.
   */
  public UDAF(UDAFEvaluatorResolver rslv) {
    this.rslv = rslv;
  }

  /**
   * Sets the resolver.
   * 
   * @param rslv
   *          The method resolver to use for method resolution.
   */
  public void setResolver(UDAFEvaluatorResolver rslv) {
    this.rslv = rslv;
  }

  /**
   * Gets the resolver.
   */
  public UDAFEvaluatorResolver getResolver() {
    return rslv;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy