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


Java ProgramPhase類代碼示例

本文整理匯總了Java中org.apache.tinkerpop.gremlin.process.computer.ProgramPhase的典型用法代碼示例。如果您正苦於以下問題:Java ProgramPhase類的具體用法?Java ProgramPhase怎麽用?Java ProgramPhase使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ProgramPhase類屬於org.apache.tinkerpop.gremlin.process.computer包,在下文中一共展示了ProgramPhase類的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: terminate

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
@Override
public boolean terminate(final Memory memory) {
    final TraverserGenerator generator = this.traversal.get().getTraverserGenerator();
    MemoryTraversalSideEffects.setMemorySideEffects(this.traversal.get(), memory, ProgramPhase.TERMINATE);
    checkSideEffects();
    if (memory.isInitialIteration()) {
        assertFalse(memory.exists(TraversalVertexProgram.HALTED_TRAVERSERS));
        return false;
    } else {
        ///
        assertTrue(memory.exists(TraversalVertexProgram.HALTED_TRAVERSERS));
        final TraverserSet<String> haltedTraversers = memory.get(TraversalVertexProgram.HALTED_TRAVERSERS);
        haltedTraversers.add(generator.generate("hello", this.programStep, 1l));
        haltedTraversers.add(generator.generate("gremlin", this.programStep, 1l));
        memory.set(TraversalVertexProgram.HALTED_TRAVERSERS, haltedTraversers);
        return true;
    }
}
 
開發者ID:PKUSilvester,項目名稱:LiteGraph,代碼行數:19,代碼來源:ProgramTest.java

示例2: setMemorySideEffects

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
public static void setMemorySideEffects(final Traversal.Admin<?, ?> traversal, final Memory memory, final ProgramPhase phase) {
    final TraversalSideEffects sideEffects = traversal.getSideEffects();
    if (!(sideEffects instanceof MemoryTraversalSideEffects)) {
        traversal.setSideEffects(new MemoryTraversalSideEffects(sideEffects));
    }
    final MemoryTraversalSideEffects memoryTraversalSideEffects = ((MemoryTraversalSideEffects) traversal.getSideEffects());
    memoryTraversalSideEffects.memory = memory;
    memoryTraversalSideEffects.phase = phase;
}
 
開發者ID:PKUSilvester,項目名稱:LiteGraph,代碼行數:10,代碼來源:MemoryTraversalSideEffects.java

示例3: setup

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
@Override
public void setup(final Memory memory) {
    MemoryTraversalSideEffects.setMemorySideEffects(this.traversal.get(), memory, ProgramPhase.SETUP);
    final Map<Vertex, Long> map = (Map<Vertex, Long>) this.haltedTraversers.iterator().next().get();
    assertEquals(2, map.size());
    assertTrue(map.values().contains(3l));
    assertTrue(map.values().contains(1l));
    final TraverserSet<Object> activeTraversers = new TraverserSet<>();
    map.keySet().forEach(vertex -> activeTraversers.add(this.haltedTraversers.peek().split(vertex, EmptyStep.instance())));
    this.haltedTraversers.clear();
    this.checkSideEffects();
    memory.set(TraversalVertexProgram.ACTIVE_TRAVERSERS, activeTraversers);


}
 
開發者ID:PKUSilvester,項目名稱:LiteGraph,代碼行數:16,代碼來源:ProgramTest.java

示例4: execute

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
@Override
public void execute(final Vertex vertex, final Messenger messenger, final Memory memory) {
    assertFalse(memory.exists(TraversalVertexProgram.HALTED_TRAVERSERS));
    final TraverserGenerator generator = this.traversal.get().getTraverserGenerator();
    MemoryTraversalSideEffects.setMemorySideEffects(this.traversal.get(), memory, ProgramPhase.EXECUTE);
    this.checkSideEffects();
    final TraverserSet<Vertex> activeTraversers = memory.get(TraversalVertexProgram.ACTIVE_TRAVERSERS);
    if (vertex.label().equals("software")) {
        assertEquals(1, activeTraversers.stream().filter(v -> v.get().equals(vertex)).count());
        if (memory.isInitialIteration()) {
            assertFalse(vertex.property(TraversalVertexProgram.HALTED_TRAVERSERS).isPresent());
            vertex.property(
                    TraversalVertexProgram.HALTED_TRAVERSERS,
                    new TraverserSet<>(generator.generate(vertex.value("name"), this.programStep, 1l)));
        } else {
            assertTrue(vertex.property(TraversalVertexProgram.HALTED_TRAVERSERS).isPresent());
        }
    } else {
        assertFalse(vertex.property(TraversalVertexProgram.HALTED_TRAVERSERS).isPresent());
        assertEquals(0, activeTraversers.stream().filter(v -> v.get().equals(vertex)).count());
        if (!memory.isInitialIteration()) {
            if (vertex.value("name").equals("marko"))
                memory.add(TraversalVertexProgram.HALTED_TRAVERSERS, new TraverserSet<>(generator.generate("marko-is-my-name", this.programStep, 1l)));
            else if (vertex.value("name").equals("vadas"))
                this.traversal.get().getSideEffects().add(TraversalVertexProgram.HALTED_TRAVERSERS, new TraverserSet<>(generator.generate("the-v-o-double-g", this.programStep, 1l)));
        }
    }
}
 
開發者ID:PKUSilvester,項目名稱:LiteGraph,代碼行數:29,代碼來源:ProgramTest.java

示例5: workerIterationStart

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
@Override
public void workerIterationStart(final Memory memory) {
    assertNotNull(this.haltedTraversers);
    this.haltedTraversers.clear();
    assertFalse(memory.exists(TraversalVertexProgram.HALTED_TRAVERSERS));
    MemoryTraversalSideEffects.setMemorySideEffects(this.traversal.get(), memory, ProgramPhase.WORKER_ITERATION_START);
    checkSideEffects();
}
 
開發者ID:PKUSilvester,項目名稱:LiteGraph,代碼行數:9,代碼來源:ProgramTest.java

示例6: terminate

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
@Override
public boolean terminate(final Memory memory) {
    // memory is local
    MemoryTraversalSideEffects.setMemorySideEffects(this.traversal.get(), memory, ProgramPhase.TERMINATE);
    final boolean voteToHalt = memory.<Boolean>get(VOTE_TO_HALT);
    memory.set(VOTE_TO_HALT, true);
    memory.set(ACTIVE_TRAVERSERS, new TraverserSet<>());
    if (voteToHalt) {
        // local traverser sets to process
        final TraverserSet<Object> toProcessTraversers = new TraverserSet<>();
        // traversers that need to be sent back to the workers (no longer can be processed locally by the master traversal)
        final TraverserSet<Object> remoteActiveTraversers = new TraverserSet<>();
        // halted traversers that have completed their journey
        final TraverserSet<Object> haltedTraversers = memory.get(HALTED_TRAVERSERS);
        // get all barrier traversers
        final Set<String> completedBarriers = new HashSet<>();
        MasterExecutor.processMemory(this.traversalMatrix, memory, toProcessTraversers, completedBarriers);
        // process all results from barriers locally and when elements are touched, put them in remoteActiveTraversers
        MasterExecutor.processTraversers(this.traversal, this.traversalMatrix, toProcessTraversers, remoteActiveTraversers, haltedTraversers, this.haltedTraverserStrategy);
        // tell parallel barriers that might not have been active in the last round that they are no longer active
        memory.set(COMPLETED_BARRIERS, completedBarriers);
        if (!remoteActiveTraversers.isEmpty() ||
                completedBarriers.stream().map(this.traversalMatrix::getStepById).filter(step -> step instanceof LocalBarrier).findAny().isPresent()) {
            // send active traversers back to workers
            memory.set(ACTIVE_TRAVERSERS, remoteActiveTraversers);
            return false;
        } else {
            // finalize locally with any last traversers dangling in the local traversal
            final Step<?, Object> endStep = (Step<?, Object>) this.traversal.get().getEndStep();
            while (endStep.hasNext()) {
                haltedTraversers.add(this.haltedTraverserStrategy.halt(endStep.next()));
            }
            // the result of a TraversalVertexProgram are the halted traversers
            memory.set(HALTED_TRAVERSERS, haltedTraversers);
            // finalize profile side-effect steps. (todo: try and hide this)
            for (final ProfileSideEffectStep profileStep : TraversalHelper.getStepsOfAssignableClassRecursively(ProfileSideEffectStep.class, this.traversal.get())) {
                this.traversal.get().getSideEffects().set(profileStep.getSideEffectKey(), profileStep.generateFinalResult(this.traversal.get().getSideEffects().get(profileStep.getSideEffectKey())));
            }
            return true;
        }
    } else {
        return false;
    }
}
 
開發者ID:PKUSilvester,項目名稱:LiteGraph,代碼行數:45,代碼來源:TraversalVertexProgram.java

示例7: workerIterationEnd

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
@Override
public void workerIterationEnd(final Memory memory) {
    assertFalse(memory.exists(TraversalVertexProgram.HALTED_TRAVERSERS));
    MemoryTraversalSideEffects.setMemorySideEffects(this.traversal.get(), memory, ProgramPhase.WORKER_ITERATION_END);
    checkSideEffects();
}
 
開發者ID:PKUSilvester,項目名稱:LiteGraph,代碼行數:7,代碼來源:ProgramTest.java

示例8: getMemorySideEffectsPhase

import org.apache.tinkerpop.gremlin.process.computer.ProgramPhase; //導入依賴的package包/類
public static ProgramPhase getMemorySideEffectsPhase(final Traversal.Admin<?, ?> traversal) {
    return traversal.getSideEffects() instanceof MemoryTraversalSideEffects ?
            ((MemoryTraversalSideEffects)traversal.getSideEffects()).phase:null;
}
 
開發者ID:apache,項目名稱:tinkerpop,代碼行數:5,代碼來源:MemoryTraversalSideEffects.java


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