當前位置: 首頁>>代碼示例>>Java>>正文


Java AggregationAccessorSlotPair類代碼示例

本文整理匯總了Java中com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair的典型用法代碼示例。如果您正苦於以下問題:Java AggregationAccessorSlotPair類的具體用法?Java AggregationAccessorSlotPair怎麽用?Java AggregationAccessorSlotPair使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


AggregationAccessorSlotPair類屬於com.espertech.esper.epl.agg.access包,在下文中一共展示了AggregationAccessorSlotPair類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: AggSvcGroupByRollupImpl

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
/**
 * Ctor.
 *
 * @param evaluators          - evaluate the sub-expression within the aggregate function (ie. sum(4*myNum))
 * @param prototypes          - collect the aggregation state that evaluators evaluate to, act as prototypes for new aggregations
 *                            aggregation states for each group
 * @param accessors           accessor definitions
 * @param accessAggregations  access aggs
 * @param isJoin              true for join, false for single-stream
 * @param rollupLevelDesc     rollup info
 * @param topGroupAggregators methodFactories for top group
 * @param topGroupStates      states for top group
 */
public AggSvcGroupByRollupImpl(ExprEvaluator[] evaluators,
                               AggregationMethodFactory[] prototypes,
                               AggregationAccessorSlotPair[] accessors,
                               AggregationStateFactory[] accessAggregations,
                               boolean isJoin,
                               AggregationGroupByRollupDesc rollupLevelDesc,
                               AggregationMethod[] topGroupAggregators,
                               AggregationState[] topGroupStates) {
    super(evaluators, prototypes);

    this.aggregatorsPerGroup = (Map<Object, AggregationMethodPairRow>[]) new Map[rollupLevelDesc.getNumLevelsAggregation()];
    this.removedKeys = (List<Object>[]) new ArrayList[rollupLevelDesc.getNumLevelsAggregation()];
    for (int i = 0; i < rollupLevelDesc.getNumLevelsAggregation(); i++) {
        this.aggregatorsPerGroup[i] = new HashMap<Object, AggregationMethodPairRow>();
        this.removedKeys[i] = new ArrayList<Object>(2);
    }
    this.accessors = accessors;
    this.accessAggregations = accessAggregations;
    this.isJoin = isJoin;
    this.rollupLevelDesc = rollupLevelDesc;
    this.aggregatorTopGroup = new AggregationMethodPairRow(0, topGroupAggregators, topGroupStates);
    this.methodParameterValues = new Object[evaluators.length];
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:37,代碼來源:AggSvcGroupByRollupImpl.java

示例2: toEvaluators

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public AggregationLocalGroupByPlan toEvaluators(StatementContext stmtContext, boolean isFireAndForget) {
    AggregationLocalGroupByColumn[] columns = new AggregationLocalGroupByColumn[columnsForges.length];
    for (int i = 0; i < columns.length; i++) {
        AggregationLocalGroupByColumnForge forge = columnsForges[i];
        ExprEvaluator[] evaluators = ExprNodeUtilityRich.getEvaluatorsMayCompile(forge.getPartitionForges(), stmtContext.getEngineImportService(), AggSvcLocalGroupByForge.class, isFireAndForget, stmtContext.getStatementName());
        AggregationAccessorSlotPair pair = forge.getPair() == null ? null : AggregatorUtil.getAccessorForForge(forge.getPair(), stmtContext.getEngineImportService(), isFireAndForget, stmtContext.getStatementName());
        columns[i] = new AggregationLocalGroupByColumn(forge.isDefaultGroupLevel(), evaluators, forge.getMethodOffset(), forge.isMethodAgg(), pair, forge.getLevelNum());
    }

    AggregationLocalGroupByLevel optionalLevelTop = optionalLevelTopForge == null ? null : makeLevel(optionalLevelTopForge, stmtContext, isFireAndForget);
    AggregationLocalGroupByLevel[] allLevels = new AggregationLocalGroupByLevel[allLevelsForges.length];
    for (int i = 0; i < allLevels.length; i++) {
        allLevels[i] = makeLevel(allLevelsForges[i], stmtContext, isFireAndForget);
    }

    return new AggregationLocalGroupByPlan(numMethods, numAccess, columns, optionalLevelTop, allLevels);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:18,代碼來源:AggregationLocalGroupByPlanForge.java

示例3: evalMap

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
protected static Map<String, Object> evalMap(ObjectArrayBackedEventBean event, AggregationRowPair row, Map<String, TableMetadataColumn> items, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext exprEvaluatorContext) {
    HashMap<String, Object> cols = new HashMap<String, Object>();
    for (Map.Entry<String, TableMetadataColumn> entry : items.entrySet()) {
        if (entry.getValue() instanceof TableMetadataColumnPlain) {
            TableMetadataColumnPlain plain = (TableMetadataColumnPlain) entry.getValue();
            cols.put(entry.getKey(), event.getProperties()[plain.getIndexPlain()]);
        } else {
            TableMetadataColumnAggregation aggcol = (TableMetadataColumnAggregation) entry.getValue();
            if (!aggcol.getFactory().isAccessAggregation()) {
                cols.put(entry.getKey(), row.getMethods()[aggcol.getMethodOffset()].getValue());
            } else {
                AggregationAccessorSlotPair pair = aggcol.getAccessAccessorSlotPair();
                Object value = pair.getAccessor().getValue(row.getStates()[pair.getSlot()], eventsPerStream, isNewData, exprEvaluatorContext);
                cols.put(entry.getKey(), value);
            }
        }
    }
    return cols;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:20,代碼來源:ExprTableEvalStrategyUtil.java

示例4: evalTypable

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
protected static Object[] evalTypable(ObjectArrayBackedEventBean event,
                                      AggregationRowPair row,
                                      Map<String, TableMetadataColumn> items,
                                      EventBean[] eventsPerStream,
                                      boolean isNewData,
                                      ExprEvaluatorContext exprEvaluatorContext) {
    Object[] values = new Object[items.size()];
    int count = 0;
    for (Map.Entry<String, TableMetadataColumn> entry : items.entrySet()) {
        if (entry.getValue() instanceof TableMetadataColumnPlain) {
            TableMetadataColumnPlain plain = (TableMetadataColumnPlain) entry.getValue();
            values[count] = event.getProperties()[plain.getIndexPlain()];
        } else {
            TableMetadataColumnAggregation aggcol = (TableMetadataColumnAggregation) entry.getValue();
            if (!aggcol.getFactory().isAccessAggregation()) {
                values[count] = row.getMethods()[aggcol.getMethodOffset()].getValue();
            } else {
                AggregationAccessorSlotPair pair = aggcol.getAccessAccessorSlotPair();
                values[count] = pair.getAccessor().getValue(row.getStates()[pair.getSlot()], eventsPerStream, isNewData, exprEvaluatorContext);
            }
        }
        count++;
    }
    return values;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:26,代碼來源:ExprTableEvalStrategyUtil.java

示例5: AggSvcGroupByRefcountedWAccessImpl

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
/**
 * Ctor.
 * @param evaluators - evaluate the sub-expression within the aggregate function (ie. sum(4*myNum))
 * @param prototypes - collect the aggregation state that evaluators evaluate to, act as prototypes for new aggregations
 * aggregation states for each group
 * @param methodResolutionService - factory for creating additional aggregation method instances per group key
 * @param accessors accessor definitions
 * @param streams streams in join
 * @param isJoin true for join, false for single-stream
 */
public AggSvcGroupByRefcountedWAccessImpl(ExprEvaluator evaluators[],
                                   AggregationMethodFactory prototypes[],
                                   MethodResolutionService methodResolutionService,
                                   AggregationAccessorSlotPair[] accessors,
                                   int[] streams,
                                   boolean isJoin)
{
    super(evaluators, prototypes);
    this.methodResolutionService = methodResolutionService;
    this.aggregatorsPerGroup = new HashMap<Object, AggregationMethodPairRow>();
    this.accessors = accessors;
    this.streams = streams;
    this.isJoin = isJoin;
    removedKeys = new ArrayList<Object>();
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:26,代碼來源:AggSvcGroupByRefcountedWAccessImpl.java

示例6: getValue

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public Object getValue(int column, int agentInstanceId, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext exprEvaluatorContext) {
    if (column < aggregators.length) {
        return aggregators[column].getValue();
    } else {
        AggregationAccessorSlotPair pair = factory.accessors[column - aggregators.length];
        return pair.getAccessor().getValue(states[pair.getSlot()], eventsPerStream, isNewData, exprEvaluatorContext);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupAllImplMixedAccess.java

示例7: getCollectionOfEvents

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public Collection<EventBean> getCollectionOfEvents(int column, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context) {
    if (column < aggregators.length) {
        return null;
    } else {
        AggregationAccessorSlotPair pair = factory.accessors[column - aggregators.length];
        return pair.getAccessor().getEnumerableEvents(states[pair.getSlot()], eventsPerStream, isNewData, context);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupAllImplMixedAccess.java

示例8: getCollectionScalar

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public Collection<Object> getCollectionScalar(int column, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context) {
    if (column < aggregators.length) {
        return null;
    } else {
        AggregationAccessorSlotPair pair = factory.accessors[column - aggregators.length];
        return pair.getAccessor().getEnumerableScalar(states[pair.getSlot()], eventsPerStream, isNewData, context);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupAllImplMixedAccess.java

示例9: getEventBean

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public EventBean getEventBean(int column, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context) {
    if (column < aggregators.length) {
        return null;
    } else {
        AggregationAccessorSlotPair pair = factory.accessors[column - aggregators.length];
        return pair.getAccessor().getEnumerableEvent(states[pair.getSlot()], eventsPerStream, isNewData, context);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupAllImplMixedAccess.java

示例10: AggSvcGroupByNoReclaimMixedAccessImpl

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
/**
 * Ctor.
 *
 * @param evaluators         - evaluate the sub-expression within the aggregate function (ie. sum(4*myNum))
 * @param prototypes         - collect the aggregation state that evaluators evaluate to, act as prototypes for new aggregations
 *                           aggregation states for each group
 * @param accessorsFactory   accessor definitions
 * @param accessAggregations access aggs
 * @param isJoin             true for join, false for single-stream
 */
public AggSvcGroupByNoReclaimMixedAccessImpl(ExprEvaluator[] evaluators,
                                             AggregationMethodFactory[] prototypes,
                                             AggregationAccessorSlotPair[] accessorsFactory,
                                             AggregationStateFactory[] accessAggregations,
                                             boolean isJoin) {
    super(evaluators, prototypes);
    this.accessorsFactory = accessorsFactory;
    this.accessAggregations = accessAggregations;
    this.isJoin = isJoin;
    this.aggregatorsPerGroup = new HashMap<Object, AggregationRowPair>();
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:22,代碼來源:AggSvcGroupByNoReclaimMixedAccessImpl.java

示例11: getValue

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public Object getValue(int column, int agentInstanceId, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext exprEvaluatorContext) {
    if (column < aggregators.length) {
        return currentAggregatorRow.getMethods()[column].getValue();
    } else {
        AggregationAccessorSlotPair pair = accessorsFactory[column - aggregators.length];
        return pair.getAccessor().getValue(currentAggregatorRow.getStates()[pair.getSlot()], eventsPerStream, isNewData, exprEvaluatorContext);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupByNoReclaimMixedAccessImpl.java

示例12: getCollectionOfEvents

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public Collection<EventBean> getCollectionOfEvents(int column, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context) {
    if (column < aggregators.length) {
        return null;
    } else {
        AggregationAccessorSlotPair pair = accessorsFactory[column - aggregators.length];
        return pair.getAccessor().getEnumerableEvents(currentAggregatorRow.getStates()[pair.getSlot()], eventsPerStream, isNewData, context);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupByNoReclaimMixedAccessImpl.java

示例13: getCollectionScalar

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public Collection<Object> getCollectionScalar(int column, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context) {
    if (column < aggregators.length) {
        return null;
    } else {
        AggregationAccessorSlotPair pair = accessorsFactory[column - aggregators.length];
        return pair.getAccessor().getEnumerableScalar(currentAggregatorRow.getStates()[pair.getSlot()], eventsPerStream, isNewData, context);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupByNoReclaimMixedAccessImpl.java

示例14: getEventBean

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
public EventBean getEventBean(int column, EventBean[] eventsPerStream, boolean isNewData, ExprEvaluatorContext context) {
    if (column < aggregators.length) {
        return null;
    } else {
        AggregationAccessorSlotPair pair = accessorsFactory[column - aggregators.length];
        return pair.getAccessor().getEnumerableEvent(currentAggregatorRow.getStates()[pair.getSlot()], eventsPerStream, isNewData, context);
    }
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:9,代碼來源:AggSvcGroupByNoReclaimMixedAccessImpl.java

示例15: AggSvcGroupByRefcountedWAccessImpl

import com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair; //導入依賴的package包/類
/**
 * Ctor.
 *
 * @param evaluators         - evaluate the sub-expression within the aggregate function (ie. sum(4*myNum))
 * @param prototypes         - collect the aggregation state that evaluators evaluate to, act as prototypes for new aggregations
 *                           aggregation states for each group
 * @param accessors          accessor definitions
 * @param accessAggregations access aggs
 * @param isJoin             true for join, false for single-stream
 */
public AggSvcGroupByRefcountedWAccessImpl(ExprEvaluator[] evaluators,
                                          AggregationMethodFactory[] prototypes,
                                          AggregationAccessorSlotPair[] accessors,
                                          AggregationStateFactory[] accessAggregations,
                                          boolean isJoin) {
    super(evaluators, prototypes);
    this.aggregatorsPerGroup = new HashMap<>();
    this.accessors = accessors;
    this.accessAggregations = accessAggregations;
    this.isJoin = isJoin;
    removedKeys = new ArrayList<>();
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:23,代碼來源:AggSvcGroupByRefcountedWAccessImpl.java


注:本文中的com.espertech.esper.epl.agg.access.AggregationAccessorSlotPair類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。