Example #1
0
  /**
   * @see ca.nengo.model.Network#addProjection(ca.nengo.model.Origin, ca.nengo.model.Termination)
   */
  public Projection addProjection(Origin origin, Termination termination)
      throws StructuralException {
    if (myProjectionMap.containsKey(termination)) {
      throw new StructuralException(
          "There is already an Origin connected to the specified Termination");
    }

    if (origin.getDimensions() != termination.getDimensions()) {
      throw new StructuralException(
          "Can't connect Origin of dimension "
              + origin.getDimensions()
              + " to Termination of dimension "
              + termination.getDimensions());
    }

    Projection result = new ProjectionImpl(origin, termination, this);
    myProjectionMap.put(termination, result);
    getSimulator().initialize(this);
    fireVisibleChangeEvent();

    return result;
  }
Example #2
0
  @Override
  public Network clone() throws CloneNotSupportedException {
    NetworkImpl result = (NetworkImpl) super.clone();

    result.myNodeMap = new HashMap<String, Node>(10);
    for (Node oldNode : myNodeMap.values()) {
      Node newNode = oldNode.clone();
      result.myNodeMap.put(newNode.getName(), newNode);
      newNode.addChangeListener(result);
    }

    // TODO: Exposed states aren't handled currently, pending redesign of Probes (it should be
    // possible
    //		to probe things that are nested deeply, in which case exposing state woulnd't be necessary)
    //		result.myProbeables
    //		result.myProbeableStates

    // TODO: this works with a single Projection impl & no params; should add
    // Projection.copy(Origin, Termination, Network)?
    result.myProjectionMap = new HashMap<Termination, Projection>(10);
    for (Projection oldProjection : getProjections()) {
      try {
        Origin newOrigin =
            result
                .getNode(oldProjection.getOrigin().getNode().getName())
                .getOrigin(oldProjection.getOrigin().getName());
        Termination newTermination =
            result
                .getNode(oldProjection.getTermination().getNode().getName())
                .getTermination(oldProjection.getTermination().getName());
        Projection newProjection = new ProjectionImpl(newOrigin, newTermination, result);
        result.myProjectionMap.put(newTermination, newProjection);
      } catch (StructuralException e) {
        throw new CloneNotSupportedException("Problem copying Projectio: " + e.getMessage());
      }
    }

    result.myExposedOrigins = new HashMap<String, Origin>(10);
    result.myExposedOriginNames = new HashMap<Origin, String>(10);
    result.OrderedExposedOrigins = new LinkedList<Origin>();
    for (Origin exposed : getOrigins()) {
      String name = exposed.getName();
      Origin wrapped = ((OriginWrapper) exposed).getWrappedOrigin();
      try {
        Origin toExpose = result.getNode(wrapped.getNode().getName()).getOrigin(wrapped.getName());
        result.exposeOrigin(toExpose, name);
      } catch (StructuralException e) {
        throw new CloneNotSupportedException("Problem exposing Origin: " + e.getMessage());
      }
    }

    result.myExposedTerminations = new HashMap<String, Termination>(10);
    result.myExposedTerminationNames = new HashMap<Termination, String>(10);
    result.OrderedExposedTerminations = new LinkedList<Termination>();
    for (Termination exposed : getTerminations()) {
      String name = exposed.getName();
      Termination wrapped = ((TerminationWrapper) exposed).getWrappedTermination();
      try {
        Termination toExpose =
            result.getNode(wrapped.getNode().getName()).getTermination(wrapped.getName());
        result.exposeTermination(toExpose, name);
      } catch (StructuralException e) {
        throw new CloneNotSupportedException("Problem exposing Termination: " + e.getMessage());
      }
    }

    result.myListeners = new ArrayList<Listener>(5);

    result.myMetaData = new HashMap<String, Object>(10);
    for (String key : myMetaData.keySet()) {
      Object o = myMetaData.get(key);
      if (o instanceof Cloneable) {
        Object copy = tryToClone((Cloneable) o);
        result.myMetaData.put(key, copy);
      } else {
        result.myMetaData.put(key, o);
      }
    }

    // TODO: take another look at Probe design (maybe Probeables reference Probes?)
    result.mySimulator = mySimulator.clone();
    result.mySimulator.initialize(result);
    Probe[] oldProbes = mySimulator.getProbes();
    for (Probe oldProbe : oldProbes) {
      Probeable target = oldProbe.getTarget();
      if (target instanceof Node) {
        Node oldNode = (Node) target;
        if (oldProbe.isInEnsemble()) {
          try {
            Ensemble oldEnsemble = (Ensemble) getNode(oldProbe.getEnsembleName());
            int neuronIndex = -1;
            for (int j = 0; j < oldEnsemble.getNodes().length && neuronIndex < 0; j++) {
              if (oldNode == oldEnsemble.getNodes()[j]) {
                neuronIndex = j;
              }
            }
            result.mySimulator.addProbe(
                oldProbe.getEnsembleName(), neuronIndex, oldProbe.getStateName(), true);
          } catch (SimulationException e) {
            ourLogger.warn("Problem copying Probe", e);
          } catch (StructuralException e) {
            ourLogger.warn("Problem copying Probe", e);
          }
        } else {
          try {
            result.mySimulator.addProbe(oldNode.getName(), oldProbe.getStateName(), true);
          } catch (SimulationException e) {
            ourLogger.warn("Problem copying Probe", e);
          }
        }
      } else {
        ourLogger.warn(
            "Can't copy Probe on type "
                + target.getClass().getName()
                + " (to be addressed in a future release)");
      }
    }

    return result;
  }
Example #3
0
 /** @see ca.nengo.model.Resettable#reset(boolean) */
 public void reset(boolean randomize) {
   myWrapped.reset(randomize);
 }
Example #4
0
 /** @return Extract the input to the termination. */
 public InstantaneousOutput getInput() {
   return myWrapped.getInput();
 }
Example #5
0
 public void setTau(float tau) throws StructuralException {
   myWrapped.setTau(tau);
 }
Example #6
0
 public void setModulatory(boolean modulatory) {
   myWrapped.setModulatory(modulatory);
 }
Example #7
0
 public float getTau() {
   return myWrapped.getTau();
 }
Example #8
0
 public boolean getModulatory() {
   return myWrapped.getModulatory();
 }
Example #9
0
 public void setValues(InstantaneousOutput values) throws SimulationException {
   myWrapped.setValues(values);
 }
Example #10
0
 public int getDimensions() {
   return myWrapped.getDimensions();
 }