Search in sources :

Example 1 with InputFunction

use of io.trino.spi.function.InputFunction in project trino by trinodb.

the class MergeHyperLogLogAggregation method input.

@InputFunction
public static void input(@AggregationState HyperLogLogState state, @SqlType(StandardTypes.HYPER_LOG_LOG) Slice value) {
    HyperLogLog input = HyperLogLog.newInstance(value);
    merge(state, input);
}
Also used : HyperLogLog(io.airlift.stats.cardinality.HyperLogLog) InputFunction(io.trino.spi.function.InputFunction)

Example 2 with InputFunction

use of io.trino.spi.function.InputFunction in project trino by trinodb.

the class TDigestAggregationFunction method input.

@InputFunction
public static void input(@AggregationState TDigestState state, @SqlType(StandardTypes.DOUBLE) double value) {
    TDigest tdigest = state.getTDigest();
    if (tdigest == null) {
        tdigest = new TDigest();
        state.setTDigest(tdigest);
        state.addMemoryUsage(tdigest.estimatedInMemorySizeInBytes());
    }
    state.addMemoryUsage(-tdigest.estimatedInMemorySizeInBytes());
    tdigest.add(value);
    state.addMemoryUsage(tdigest.estimatedInMemorySizeInBytes());
}
Also used : TDigest(io.airlift.stats.TDigest) InputFunction(io.trino.spi.function.InputFunction)

Example 3 with InputFunction

use of io.trino.spi.function.InputFunction in project trino by trinodb.

the class TDigestAggregationFunction method weightedInput.

@InputFunction
public static void weightedInput(@AggregationState TDigestState state, @SqlType(StandardTypes.DOUBLE) double value, @SqlType(StandardTypes.DOUBLE) double weight) {
    TDigest tdigest = state.getTDigest();
    if (tdigest == null) {
        tdigest = new TDigest();
        state.setTDigest(tdigest);
        state.addMemoryUsage(tdigest.estimatedInMemorySizeInBytes());
    }
    state.addMemoryUsage(-tdigest.estimatedInMemorySizeInBytes());
    tdigest.add(value, verifyWeight(weight));
    state.addMemoryUsage(tdigest.estimatedInMemorySizeInBytes());
}
Also used : TDigest(io.airlift.stats.TDigest) InputFunction(io.trino.spi.function.InputFunction)

Example 4 with InputFunction

use of io.trino.spi.function.InputFunction in project trino by trinodb.

the class SpatialPartitioningInternalAggregateFunction method input.

@InputFunction
public static void input(SpatialPartitioningState state, @SqlType(GEOMETRY_TYPE_NAME) Slice slice, @SqlType(INTEGER) long partitionCount) {
    Envelope envelope = deserializeEnvelope(slice);
    if (envelope.isEmpty()) {
        return;
    }
    Rectangle extent = new Rectangle(envelope.getXMin(), envelope.getYMin(), envelope.getXMax(), envelope.getYMax());
    if (state.getCount() == 0) {
        state.setPartitionCount(toIntExact(partitionCount));
        state.setExtent(extent);
        state.setSamples(new ArrayList<>());
    } else {
        state.setExtent(state.getExtent().merge(extent));
    }
    // use reservoir sampling
    List<Rectangle> samples = state.getSamples();
    if (samples.size() <= MAX_SAMPLE_COUNT) {
        samples.add(extent);
    } else {
        long sampleIndex = ThreadLocalRandom.current().nextLong(state.getCount());
        if (sampleIndex < MAX_SAMPLE_COUNT) {
            samples.set(toIntExact(sampleIndex), extent);
        }
    }
    state.setCount(state.getCount() + 1);
}
Also used : Rectangle(io.trino.geospatial.Rectangle) Envelope(com.esri.core.geometry.Envelope) GeometrySerde.deserializeEnvelope(io.trino.geospatial.serde.GeometrySerde.deserializeEnvelope) InputFunction(io.trino.spi.function.InputFunction)

Example 5 with InputFunction

use of io.trino.spi.function.InputFunction in project trino by trinodb.

the class AggregationFromAnnotationsParser method parseFunctionDefinitions.

public static List<ParametricAggregation> parseFunctionDefinitions(Class<?> aggregationDefinition) {
    AggregationFunction aggregationAnnotation = aggregationDefinition.getAnnotation(AggregationFunction.class);
    requireNonNull(aggregationAnnotation, "aggregationAnnotation is null");
    ImmutableList.Builder<ParametricAggregation> functions = ImmutableList.builder();
    // There must be a single state class and combine function
    Class<? extends AccumulatorState> stateClass = getStateClass(aggregationDefinition);
    Optional<Method> combineFunction = getCombineFunction(aggregationDefinition, stateClass);
    // Each output function defines a new aggregation function
    for (Method outputFunction : getOutputFunctions(aggregationDefinition, stateClass)) {
        AggregationHeader header = parseHeader(aggregationDefinition, outputFunction);
        if (header.isDecomposable()) {
            checkArgument(combineFunction.isPresent(), "Decomposable method %s does not have a combine method", header.getName());
        } else if (combineFunction.isPresent()) {
            log.warn("Aggregation function %s is not decomposable, but has combine method", header.getName());
        }
        // Input functions can have either an exact signature, or generic/calculate signature
        List<AggregationImplementation> exactImplementations = new ArrayList<>();
        List<AggregationImplementation> nonExactImplementations = new ArrayList<>();
        for (Method inputFunction : getInputFunctions(aggregationDefinition, stateClass)) {
            Optional<Method> removeInputFunction = getRemoveInputFunction(aggregationDefinition, inputFunction);
            AggregationImplementation implementation = parseImplementation(aggregationDefinition, header.getName(), inputFunction, removeInputFunction, outputFunction, combineFunction.filter(function -> header.isDecomposable()));
            if (isGenericOrCalculated(implementation.getSignature())) {
                exactImplementations.add(implementation);
            } else {
                nonExactImplementations.add(implementation);
            }
        }
        // register a set functions for the canonical name, and each alias
        functions.addAll(buildFunctions(header.getName(), header, stateClass, exactImplementations, nonExactImplementations));
        for (String alias : getAliases(aggregationDefinition.getAnnotation(AggregationFunction.class), outputFunction)) {
            functions.addAll(buildFunctions(alias, header, stateClass, exactImplementations, nonExactImplementations));
        }
    }
    return functions.build();
}
Also used : Arrays(java.util.Arrays) Logger(io.airlift.log.Logger) AggregationFunction(io.trino.spi.function.AggregationFunction) OutputFunction(io.trino.spi.function.OutputFunction) ArrayList(java.util.ArrayList) Preconditions.checkArgument(com.google.common.base.Preconditions.checkArgument) ImmutableList(com.google.common.collect.ImmutableList) RemoveInputFunction(io.trino.spi.function.RemoveInputFunction) CombineFunction(io.trino.spi.function.CombineFunction) Objects.requireNonNull(java.util.Objects.requireNonNull) Parser.parseImplementation(io.trino.operator.aggregation.AggregationImplementation.Parser.parseImplementation) Signature(io.trino.metadata.Signature) Method(java.lang.reflect.Method) TypeSignature(io.trino.spi.type.TypeSignature) ImmutableSet(com.google.common.collect.ImmutableSet) ParametricFunctionHelpers.signatureWithName(io.trino.operator.ParametricFunctionHelpers.signatureWithName) ParametricImplementationsGroup(io.trino.operator.ParametricImplementationsGroup) MoreCollectors(com.google.common.collect.MoreCollectors) ImmutableList.toImmutableList(com.google.common.collect.ImmutableList.toImmutableList) Iterables.getOnlyElement(com.google.common.collect.Iterables.getOnlyElement) AccumulatorState(io.trino.spi.function.AccumulatorState) List(java.util.List) Strings.emptyToNull(com.google.common.base.Strings.emptyToNull) FunctionsParserHelper(io.trino.operator.annotations.FunctionsParserHelper) Optional(java.util.Optional) InputFunction(io.trino.spi.function.InputFunction) FunctionsParserHelper.parseDescription(io.trino.operator.annotations.FunctionsParserHelper.parseDescription) AnnotatedElement(java.lang.reflect.AnnotatedElement) ImmutableList(com.google.common.collect.ImmutableList) ImmutableList.toImmutableList(com.google.common.collect.ImmutableList.toImmutableList) ArrayList(java.util.ArrayList) Method(java.lang.reflect.Method) AggregationFunction(io.trino.spi.function.AggregationFunction)

Aggregations

InputFunction (io.trino.spi.function.InputFunction)20 HyperLogLog (io.airlift.stats.cardinality.HyperLogLog)11 TDigest (io.airlift.stats.TDigest)6 TypeParameter (io.trino.spi.function.TypeParameter)6 Envelope (com.esri.core.geometry.Envelope)1 Preconditions.checkArgument (com.google.common.base.Preconditions.checkArgument)1 Strings.emptyToNull (com.google.common.base.Strings.emptyToNull)1 ImmutableList (com.google.common.collect.ImmutableList)1 ImmutableList.toImmutableList (com.google.common.collect.ImmutableList.toImmutableList)1 ImmutableSet (com.google.common.collect.ImmutableSet)1 Iterables.getOnlyElement (com.google.common.collect.Iterables.getOnlyElement)1 MoreCollectors (com.google.common.collect.MoreCollectors)1 Logger (io.airlift.log.Logger)1 QuantileDigest (io.airlift.stats.QuantileDigest)1 Rectangle (io.trino.geospatial.Rectangle)1 GeometrySerde.deserializeEnvelope (io.trino.geospatial.serde.GeometrySerde.deserializeEnvelope)1 Signature (io.trino.metadata.Signature)1 ParametricFunctionHelpers.signatureWithName (io.trino.operator.ParametricFunctionHelpers.signatureWithName)1 ParametricImplementationsGroup (io.trino.operator.ParametricImplementationsGroup)1 Parser.parseImplementation (io.trino.operator.aggregation.AggregationImplementation.Parser.parseImplementation)1