eu.stratosphere.api.java.aggregation.SumAggregationFunction Maven / Gradle / Ivy
/***********************************************************************************************************************
*
* Copyright (C) 2010-2013 by the Stratosphere project (http://stratosphere.eu)
*
* Licensed 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 eu.stratosphere.api.java.aggregation;
public abstract class SumAggregationFunction extends AggregationFunction {
private static final long serialVersionUID = 1L;
@Override
public String toString() {
return "SUM";
}
// --------------------------------------------------------------------------------------------
public static final class ByteSumAgg extends SumAggregationFunction {
private static final long serialVersionUID = 1L;
private long agg;
@Override
public void initializeAggregate() {
agg = 0;
}
@Override
public void aggregate(Byte value) {
agg += value.byteValue();
}
@Override
public Byte getAggregate() {
return (byte) agg;
}
}
public static final class ShortSumAgg extends SumAggregationFunction {
private static final long serialVersionUID = 1L;
private long agg;
@Override
public void initializeAggregate() {
agg = 0;
}
@Override
public void aggregate(Short value) {
agg += value.shortValue();
}
@Override
public Short getAggregate() {
return (short) agg;
}
}
public static final class IntSumAgg extends SumAggregationFunction {
private static final long serialVersionUID = 1L;
private long agg;
@Override
public void initializeAggregate() {
agg = 0;
}
@Override
public void aggregate(Integer value) {
agg += value.intValue();
}
@Override
public Integer getAggregate() {
return (int) agg;
}
}
public static final class LongSumAgg extends SumAggregationFunction {
private static final long serialVersionUID = 1L;
private long agg;
@Override
public void initializeAggregate() {
agg = 0L;
}
@Override
public void aggregate(Long value) {
agg += value.longValue();
}
@Override
public Long getAggregate() {
return agg;
}
}
public static final class FloatSumAgg extends SumAggregationFunction {
private static final long serialVersionUID = 1L;
private float agg;
@Override
public void initializeAggregate() {
agg = 0.0f;
}
@Override
public void aggregate(Float value) {
agg += value.floatValue();
}
@Override
public Float getAggregate() {
return agg;
}
}
public static final class DoubleSumAgg extends SumAggregationFunction {
private static final long serialVersionUID = 1L;
private double agg;
@Override
public void initializeAggregate() {
agg = 0.0;
}
@Override
public void aggregate(Double value) {
agg += value.doubleValue();
}
@Override
public Double getAggregate() {
return agg;
}
}
// --------------------------------------------------------------------------------------------
public static final class SumAggregationFunctionFactory implements AggregationFunctionFactory {
private static final long serialVersionUID = 1L;
@SuppressWarnings("unchecked")
@Override
public AggregationFunction createAggregationFunction(Class type) {
if (type == Long.class) {
return (AggregationFunction) new LongSumAgg();
}
else if (type == Integer.class) {
return (AggregationFunction) new IntSumAgg();
}
else if (type == Double.class) {
return (AggregationFunction) new DoubleSumAgg();
}
else if (type == Float.class) {
return (AggregationFunction) new FloatSumAgg();
}
else if (type == Byte.class) {
return (AggregationFunction) new ByteSumAgg();
}
else if (type == Short.class) {
return (AggregationFunction) new ShortSumAgg();
}
else {
throw new UnsupportedAggregationTypeException("The type " + type.getName() +
" has currently not supported for built-in sum aggregations.");
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy