Пример #1
0
  @Override
  public Void doInBackground() {
    try {
      for (DataStructure solutiondomds : ssm1clone.getSolutionDomains())
        removeDomainBounds(solutiondomds.getName());

      HashMap<String, String> oldnewdsnamemap = resolveSyntacticOverlap();
      Merger merger =
          new Merger(
              ssm1clone, ssm2clone, overlapmap, oldnewdsnamemap, choicelist, conversionfactors);

      mergedmodel = merger.merge();

    } catch (Exception e) {
      e.printStackTrace();
    }
    return null;
  }
Пример #2
0
 private void setModelComponents() {
   semsimmodel.setPhysicalEntities(ents);
   semsimmodel.setPhysicalProcesses(procs);
 }
Пример #3
0
  private HashMap<String, String> resolveSyntacticOverlap() {

    // First resolve the syntactic overlap between submodels
    HashMap<String, String> oldnewdsnamemap = new HashMap<String, String>();

    for (String oldsmname : submodnamemap.keySet()) {
      String newsmname = new String(submodnamemap.get(oldsmname));
      Submodel renamedsm = ssm1clone.getSubmodel(oldsmname);
      renamedsm.setName(newsmname);
      renamedsm.setLocalName(newsmname);

      for (DataStructure ds : renamedsm.getAssociatedDataStructures()) {
        String olddsname = ds.getName();
        String newdsname = ds.getName().replace(oldsmname, newsmname);
        oldnewdsnamemap.put(olddsname, newdsname);
        ds.setName(newdsname);
        cwnamemap.remove(olddsname); // Remove duplicate codeword mapping if present in cwnamemap
      }
    }

    // Then resolve for data structures
    for (String dsname : cwnamemap.keySet()) {
      String newdsname = new String(cwnamemap.get(dsname));
      ssm1clone.getAssociatedDataStructure(dsname).setName(newdsname);
      Boolean derivreplace = false;
      String derivname = null;

      // If there is a derivative of the data structure that we're renaming, rename it, too
      if (ssm1clone.getAssociatedDataStructure(newdsname).hasSolutionDomain()) {
        derivname =
            dsname
                + ":"
                + ssm1clone.getAssociatedDataStructure(newdsname).getSolutionDomain().getName();

        if (ssm1clone.containsDataStructure(derivname)) {
          ssm1clone
              .getAssociatedDataStructure(derivname)
              .setName(derivname.replace(dsname, newdsname));
          derivreplace = true;
        }
      }
      // Use the new name in all the equations
      SemSimUtil.replaceCodewordInAllEquations(
          ssm1clone.getAssociatedDataStructure(newdsname),
          ssm1clone.getAssociatedDataStructure(newdsname),
          ssm1clone,
          dsname,
          newdsname,
          Pair.of(1.0, "*"));

      // IS THERE AN ISSUE WITH SELF_REF_ODEs HERE?
      if (derivreplace) {
        SemSimUtil.replaceCodewordInAllEquations(
            ssm1clone.getAssociatedDataStructure(derivname.replace(dsname, newdsname)),
            ssm1clone.getAssociatedDataStructure(derivname.replace(dsname, newdsname)),
            ssm1clone,
            derivname,
            derivname.replace(dsname, newdsname),
            Pair.of(1.0, "*"));
      }
    }
    return oldnewdsnamemap;
  }
Пример #4
0
 private void removeDomainBounds(String name) {
   // Remove .min, .max, .delta solution domain DataStructures
   ssm2clone.removeDataStructure(name + ".min");
   ssm2clone.removeDataStructure(name + ".max");
   ssm2clone.removeDataStructure(name + ".delta");
 }