All Downloads are FREE. Search and download functionalities are using the official Maven repository.

dk.alexandra.fresco.suite.ProtocolSuite Maven / Gradle / Ivy

package dk.alexandra.fresco.suite;

import dk.alexandra.fresco.framework.BuilderFactory;
import dk.alexandra.fresco.framework.ProtocolCollection;
import dk.alexandra.fresco.framework.builder.ProtocolBuilder;
import dk.alexandra.fresco.framework.network.Network;
import dk.alexandra.fresco.framework.sce.resources.ResourcePool;

public interface ProtocolSuite {

  /**
   * Initializes the protocol suite by supplying any needed resources to the protocol suite. The
   * protocol invocation implementation is then in charge of supplying the needed resources to it's
   * internal protocols when needed.
   *
   * @param resourcePool the resources used in the init
   */
  BuilderFactory init(ResourcePoolT resourcePool);

  /**
   * Get a RoundSynchronization used by evaluators to signal progress and allow protocols to do
   * additional work during evaluation. Only RoundSynchronization.finishedBatch is guaranteed to be
   * called by the evaluator.
   *
   * @return a RoundSynchronization that can be used by current evaluation.
   */
  RoundSynchronization createRoundSynchronization();

  interface RoundSynchronization {

    /**
     * Before batch is called before the evaluator has started the evaluation of the given batch of
     * protocols. This method is available because some protocol suites will need to know in advance
     * the type of native protocols that will appear.
     *
     * @param protocols The protocols about to be evaluated right after this method finishes.
     * @param resourcePool The resource pool used.
     * @param network network to use for the synchronization
     */
    void beforeBatch(ProtocolCollection protocols, ResourcePoolT resourcePool,
        Network network)
    ;

    /**
     * Let's the protocol suite know that now is a possible point of synchronization. The invariant
     * is that all threads are done executing. This means that no network connections are busy any
     * more as all gates up until now has been evaluated.
     *
     * @param gatesEvaluated Indicates how many gates was evaluated since last call to
     *     synchronize.
     *     It is therefore _not_ indicative of a total amount.
     * @param resourcePool The resource pool used
     * @param network network to use for the synchronization
     */
    void finishedBatch(int gatesEvaluated, ResourcePoolT resourcePool, Network network);

    /**
     * Let the protocol suite know that the evaluation has reached it's end. Runtime can then do
     * cleanup or resume background activities if needed.
     *
     * @param resourcePool The resource pool used
     * @param network network to use for the synchronization
     */
    void finishedEval(ResourcePoolT resourcePool, Network network);
  }

  /**
   * Dummy round synchronization that does nothing.
   */
  class DummyRoundSynchronization
      implements RoundSynchronization {

    @Override
    public void beforeBatch(ProtocolCollection protocols,
        ResourcePoolT resourcePool, Network network) {

    }

    @Override
    public void finishedBatch(int gatesEvaluated, ResourcePoolT resourcePool, Network network) {

    }

    @Override
    public void finishedEval(ResourcePoolT resourcePool, Network network) {

    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy