org.elasticsearch.compute.aggregation.PercentileLongAggregator Maven / Gradle / Ivy
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0; you may not use this file except in compliance with the Elastic License
* 2.0.
*/
package org.elasticsearch.compute.aggregation;
import org.apache.lucene.util.BytesRef;
import org.elasticsearch.common.util.BigArrays;
import org.elasticsearch.compute.ann.Aggregator;
import org.elasticsearch.compute.ann.GroupingAggregator;
import org.elasticsearch.compute.ann.IntermediateState;
import org.elasticsearch.compute.data.Block;
import org.elasticsearch.compute.data.IntVector;
import org.elasticsearch.compute.operator.DriverContext;
@Aggregator({ @IntermediateState(name = "quart", type = "BYTES_REF") })
@GroupingAggregator
class PercentileLongAggregator {
public static QuantileStates.SingleState initSingle(double percentile) {
return new QuantileStates.SingleState(percentile);
}
public static void combine(QuantileStates.SingleState current, long v) {
current.add(v);
}
public static void combineIntermediate(QuantileStates.SingleState state, BytesRef inValue) {
state.add(inValue);
}
public static Block evaluateFinal(QuantileStates.SingleState state, DriverContext driverContext) {
return state.evaluatePercentile(driverContext);
}
public static QuantileStates.GroupingState initGrouping(BigArrays bigArrays, double percentile) {
return new QuantileStates.GroupingState(bigArrays, percentile);
}
public static void combine(QuantileStates.GroupingState state, int groupId, long v) {
state.add(groupId, v);
}
public static void combineIntermediate(QuantileStates.GroupingState state, int groupId, BytesRef inValue) {
state.add(groupId, inValue);
}
public static void combineStates(
QuantileStates.GroupingState current,
int currentGroupId,
QuantileStates.GroupingState state,
int statePosition
) {
current.add(currentGroupId, state.getOrNull(statePosition));
}
public static Block evaluateFinal(QuantileStates.GroupingState state, IntVector selectedGroups, DriverContext driverContext) {
return state.evaluatePercentile(selectedGroups, driverContext);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy