本文整理匯總了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];
}
示例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);
}
示例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;
}
示例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;
}
示例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>();
}
示例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);
}
}
示例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);
}
}
示例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);
}
}
示例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);
}
}
示例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>();
}
示例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);
}
}
示例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);
}
}
示例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);
}
}
示例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);
}
}
示例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<>();
}