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


Java TupleFactory類代碼示例

本文整理匯總了Java中nl.vu.cs.ajira.data.types.TupleFactory的典型用法代碼示例。如果您正苦於以下問題:Java TupleFactory類的具體用法?Java TupleFactory怎麽用?Java TupleFactory使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: applyTo

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public static final void applyTo(RDFTerm v1, RDFTerm v2, RDFTerm v3,
		ActionSequence actions) throws ActionNotConfiguredException {
	ActionConf c = ActionFactory.getActionConf(QueryInputLayer.class);
	c.setParamString(QueryInputLayer.S_INPUTLAYER,
			DummyLayer.class.getName());
	c.setParamWritable(
			QueryInputLayer.W_QUERY,
			new nl.vu.cs.ajira.actions.support.Query(TupleFactory.newTuple(
					v1, v2, v3, new TInt(0))));
	actions.add(c);

	c = ActionFactory.getActionConf(QSQBCAlgo.class);
	actions.add(c);

	actions.add(ActionFactory.getActionConf(QSQRemoveLastTerm.class));
	
	c = ActionFactory.getActionConf(CollectToNode.class);
	c.setParamStringArray(CollectToNode.SA_TUPLE_FIELDS,
			RDFTerm.class.getName(), RDFTerm.class.getName(),
			RDFTerm.class.getName());
	actions.add(c);
}
 
開發者ID:jrbn,項目名稱:querypie,代碼行數:23,代碼來源:QSQBCAlgo.java

示例2: generateTuples

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
private List<Tuple> generateTuples(int numTuples, int minValue,
		int maxValue, Random r, List<String> attributes) {
	List<Tuple> result = new ArrayList<Tuple>();
	int tupleSize = attributes.size() * 2;
	for (int i = 0; i < numTuples; i++) {
		SimpleData[] data = new SimpleData[tupleSize];
		int pos = 0;
		for (String attr : attributes) {
			data[pos++] = new TString(attr);
			data[pos++] = new TInt(minValue
					+ r.nextInt(maxValue - minValue));
		}
		result.add(TupleFactory.newTuple(data));
	}
	return result;
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:17,代碼來源:RandomGeneratorInputLayer.java

示例3: GroupIterator

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public GroupIterator(TupleIterator itr, Tuple inputTuple,
		SimpleData[] key, int sizeKey, ActionContext context)
		throws Exception {
	this.itr = itr;
	this.key = key;
	this.sizeKey = sizeKey;
	this.inputTuple = inputTuple;
	this.context = context;

	// The values are a copy of the current tuple
	this.sValues = new SimpleData[inputTuple.getNElements() - sizeKey];
	for (int i = 0; i < sValues.length; ++i) {
		sValues[i] = DataProvider.get().get(
				inputTuple.get(sizeKey + i).getIdDatatype());
	}
	this.outputTuple = TupleFactory.newTuple(sValues);

	this.moreGroups = true;

	for (int i = 0; i < sizeKey; ++i) {
		key[i] = DataProvider.get().get(
				inputTuple.get(i).getIdDatatype());
	}
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:25,代碼來源:GroupBy.java

示例4: startProcess

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
@Override
public void startProcess(ActionContext context) throws Exception {
	tl1 = new TLong();
	tl2 = new TLong();
	tl3 = new TLong();
	step = new TInt();
	count = new TInt();
	previousTuple = TupleFactory.newTuple(tl1, tl2, tl3);
	outputTuple = new SimpleData[5];
	for (int i = 0; i < 3; ++i) {
		outputTuple[i] = previousTuple.get(i);
	}
	outputTuple[3] = step;
	outputTuple[4] = count;
	currentCount = 0;
	minStep = Integer.MAX_VALUE;
	stepToCount = getParamInt(I_MIN_STEP);
}
 
開發者ID:jrbn,項目名稱:dynamite,代碼行數:19,代碼來源:AddDerivationCount.java

示例5: Tuples

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public Tuples(List<Tuple> tuples, int tuplesLength, List<Integer> steps) {
	this.tuplesLength = tuplesLength;
	rows = new ArrayList<Row>();
	for (int i = 0; i < tuples.size(); ++i) {
		Tuple t = tuples.get(i);
		TLong[] signature = new TLong[tuplesLength];
		for (int j = 0; j < tuplesLength; ++j) {
			signature[j] = new TLong();
		}
		Tuple resultTuple = TupleFactory.newTuple(signature);
		for (int j = 0; j < tuplesLength; j++) {
			SimpleData data = t.get(j);
			resultTuple.set(data, j);
		}
		int step = steps.get(i);
		rows.add(new Row(step, resultTuple));
	}
}
 
開發者ID:jrbn,項目名稱:dynamite,代碼行數:19,代碼來源:Tuples.java

示例6: applyTo

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public static void applyTo(RDFTerm v1, RDFTerm v2, RDFTerm v3,
		boolean explicit, int typeRules, long iteration,
		ActionSequence actions) throws ActionNotConfiguredException {

	ActionConf c = ActionFactory.getActionConf(QueryInputLayer.class);
	c.setParamString(QueryInputLayer.S_INPUTLAYER,
			DummyLayer.class.getName());
	c.setParamWritable(
			QueryInputLayer.W_QUERY,
			new nl.vu.cs.ajira.actions.support.Query(TupleFactory.newTuple(
					v1, v2, v3, new TInt(0))));
	actions.add(c);

	c = ActionFactory.getActionConf(ExpandQuery.class);
	c.setParamBoolean(ExpandQuery.B_EXPLICIT, explicit);
	c.setParamInt(ExpandQuery.I_TYPE_RULES, typeRules);
	actions.add(c);

	c = ActionFactory.getActionConf(CollectToNode.class);
	c.setParamStringArray(CollectToNode.SA_TUPLE_FIELDS,
			RDFTerm.class.getName(), RDFTerm.class.getName(),
			RDFTerm.class.getName(), TBoolean.class.getName());
	c.setParamBoolean(CollectToNode.B_SORT, true);
	actions.add(c);

	actions.add(ActionFactory.getActionConf(RemoveDuplicates.class));

	c = ActionFactory.getActionConf(OptimalBCAlgo.class);
	c.setParamLong(OptimalBCAlgo.L_FIELD1, v1.getValue());
	c.setParamLong(OptimalBCAlgo.L_FIELD2, v2.getValue());
	c.setParamLong(OptimalBCAlgo.L_FIELD3, v3.getValue());
	c.setParamBoolean(OptimalBCAlgo.B_EXPLICIT, explicit);
	c.setParamLong(OptimalBCAlgo.L_ITERATION, iteration);
	actions.add(c);
}
 
開發者ID:jrbn,項目名稱:querypie,代碼行數:36,代碼來源:OptimalBCAlgo.java

示例7: reloadRulesOnOtherNodes

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
private void reloadRulesOnOtherNodes(ActionOutput output, String newList)
		throws Exception {

	if (log.isDebugEnabled()) {
		log.debug("reloadRulesOnOtherNodes");
	}
	ActionSequence sequence = new ActionSequence();

	ActionConf c = ActionFactory.getActionConf(QueryInputLayer.class);
	c.setParamString(QueryInputLayer.S_INPUTLAYER,
			RDFStorage.class.getName());
	c.setParamWritable(
			QueryInputLayer.W_QUERY,
			new nl.vu.cs.ajira.actions.support.Query(TupleFactory.newTuple(
					new RDFTerm(Schema.CLOSURE_BROADCASTFLAG), new RDFTerm(
							0), new RDFTerm(0), new TInt(0))));
	sequence.add(c);

	// Action which reloads the rules and sends nothing
	c = ActionFactory.getActionConf(ReloadRules.class);
	c.setParamString(ReloadRules.S_FILE, newList);
	sequence.add(c);

	// CollectToNode
	c = ActionFactory.getActionConf(CollectToNode.class);
	c.setParamStringArray(CollectToNode.SA_TUPLE_FIELDS,
			TLong.class.getName());
	sequence.add(c);

	// Action that increase the lock in the stopProcess
	sequence.add(ActionFactory.getActionConf(IncreaseLock.class));

	output.branch(sequence);
}
 
開發者ID:jrbn,項目名稱:querypie,代碼行數:35,代碼來源:CalculateClosure.java

示例8: applyTo

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public static void applyTo(RDFTerm v1, RDFTerm v2, RDFTerm v3,
		boolean explicit, ActionSequence actions)
				throws ActionNotConfiguredException {

	ActionConf c = ActionFactory.getActionConf(QueryInputLayer.class);
	c.setParamString(QueryInputLayer.S_INPUTLAYER,
			DummyLayer.class.getName());
	c.setParamWritable(
			QueryInputLayer.W_QUERY,
			new nl.vu.cs.ajira.actions.support.Query(TupleFactory.newTuple(
					v1, v2, v3, new TInt(0))));
	actions.add(c);

	c = ActionFactory.getActionConf(ExpandQuery.class);
	c.setParamBoolean(ExpandQuery.B_EXPLICIT, explicit);
	c.setParamBoolean(ExpandQuery.B_FORCERESTART, true);
	actions.add(c);

	c = ActionFactory.getActionConf(CollectToNode.class);
	c.setParamStringArray(CollectToNode.SA_TUPLE_FIELDS,
			RDFTerm.class.getName(), RDFTerm.class.getName(),
			RDFTerm.class.getName(), TBoolean.class.getName());
	actions.add(c);

	// AddIntermediateTriples.applyTo(v1.getValue(), v2.getValue(),
	// v3.getValue(), actions);

	c = ActionFactory.getActionConf(RuleBCAlgo.class);
	c.setParamLong(L_FIELD1, v1.getValue());
	c.setParamLong(L_FIELD2, v2.getValue());
	c.setParamLong(L_FIELD3, v3.getValue());
	c.setParamBoolean(B_EXPLICIT, explicit);
	actions.add(c);
}
 
開發者ID:jrbn,項目名稱:querypie,代碼行數:35,代碼來源:RuleBCAlgo.java

示例9: applyTo

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public static final void applyTo(RDFTerm v1, RDFTerm v2, RDFTerm v3,
		int posSet, long nameSet, ActionSequence actions)
				throws ActionNotConfiguredException {

	// Get the query
	ActionConf c = ActionFactory.getActionConf(QueryInputLayer.class);
	c.setParamString(QueryInputLayer.S_INPUTLAYER,
			DummyLayer.class.getName());
	c.setParamWritable(
			QueryInputLayer.W_QUERY,
			new nl.vu.cs.ajira.actions.support.Query(TupleFactory.newTuple(
					v1, v2, v3, new TInt(0))));
	actions.add(c);

	// Expand it in incremental fashion
	c = ActionFactory.getActionConf(ExpandQuery.class);
	c.setParamBoolean(ExpandQuery.B_EXPLICIT, true);
	c.setParamInt(ExpandQuery.I_TYPE_RULES, TreeExpander.ONLY_FIRST_SECOND);
	c.setParamBoolean(ExpandQuery.B_ALLOWRECURSION, false);
	actions.add(c);

	// Collect to node
	c = ActionFactory.getActionConf(CollectToNode.class);
	c.setParamStringArray(CollectToNode.SA_TUPLE_FIELDS,
			RDFTerm.class.getName(), RDFTerm.class.getName(),
			RDFTerm.class.getName(), TBoolean.class.getName());
	actions.add(c);

	// Check whether we should repeat the process
	c = ActionFactory.getActionConf(IncrRuleBCAlgo.class);
	c.setParamLong(L_NAMESET, nameSet);
	c.setParamInt(I_POSSET, posSet);
	c.setParamLong(L_FIELD1, v1.getValue());
	c.setParamLong(L_FIELD2, v2.getValue());
	c.setParamLong(L_FIELD3, v3.getValue());
	actions.add(c);
}
 
開發者ID:jrbn,項目名稱:querypie,代碼行數:38,代碼來源:IncrRuleBCAlgo.java

示例10: WritableTuple

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
/**
 * Copying constructor.
 */
public WritableTuple(WritableTuple w) {
	shouldSort = w.shouldSort;
	fieldsToSort = w.fieldsToSort;
	otherFields = w.otherFields;
	nFields = w.nFields;
	tuple = TupleFactory.newTuple();
	if (w.lengths != null) {
		lengths = new int[w.lengths.length];
	}
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:14,代碼來源:WritableTuple.java

示例11: getSpot

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
private synchronized void getSpot() {
	while (bufferFull()) {
		try {
			wait();
		} catch (InterruptedException e) {
			// ignore
		}
	}
	if (head == tail) {
		notify();
	}
	if (data[tail] == null) {
		data[tail] = TupleFactory.newTuple();
	}
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:16,代碼來源:ChainSplitLayer.java

示例12: emitCurrentWindowCounts

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
private final void emitCurrentWindowCounts(ActionOutput output)
		throws Exception {
	lastModifiedTracker.markAsModified();
	Map<String, Long> counts = counter.getCountsThenAdvanceWindow();
	for (Entry<String, Long> entry : counts.entrySet()) {
		String str = entry.getKey();
		Long count = entry.getValue();
		Tuple tuple = TupleFactory.newTuple(new TString(str), new TLong(
				count));
		output.output(tuple);
	}
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:13,代碼來源:RollingCountAction.java

示例13: project

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public Tuple project(Tuple tuple) throws AttributeNotFoundException {
  if (first) {
    determineAttributesPositions(tuple);
    first = false;
  }
  int pos = 0;
  for (Integer i : attributesPositions) {
    data[pos++] = tuple.get(i);
    data[pos++] = tuple.get(i + 1);
  }
  return TupleFactory.newTuple(data);
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:13,代碼來源:Projector.java

示例14: StreamTuple

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public StreamTuple(LinkedHashMap<String, SimpleData> attributes) {
  int numElements = attributes.size() * 2;
  SimpleData[] data = new SimpleData[numElements];
  int pos = 0;
  for (String name : attributes.keySet()) {
    data[pos++] = new TString(name);
    data[pos++] = attributes.get(name);
  }
  tuple = TupleFactory.newTuple(data);
  this.attributes = attributes;
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:12,代碼來源:StreamTuple.java

示例15: getTuple

import nl.vu.cs.ajira.data.types.TupleFactory; //導入依賴的package包/類
public static final Tuple getTuple(byte[] bytes) {
  int pos = 0;
  int numElements = bytes[pos++];
  SimpleData[] data = new SimpleData[numElements];
  for (int i = 0; i < numElements; i++) {
    byte type = bytes[pos++];
    switch (type) {
    case INT:
      data[i] = getInt(bytes, pos);
      pos += 4;
      break;
    case LONG:
      data[i] = getLong(bytes, pos);
      pos += 8;
      break;
    case STRING:
      int stringLen = bytes[pos++];
      data[i] = getString(bytes, pos, stringLen);
      pos += stringLen;
      break;
    case BOOLEAN:
      data[i] = getBoolean(bytes, pos);
      pos++;
      break;
    }
  }
  return TupleFactory.newTuple(data);
}
 
開發者ID:jrbn,項目名稱:ajira,代碼行數:29,代碼來源:TupleSerializer.java


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