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

us.ihmc.simulationconstructionset.util.simulationRunner.VariablesThatShouldMatchList Maven / Gradle / Ivy

package us.ihmc.simulationconstructionset.util.simulationRunner;

import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;

import us.ihmc.yoVariables.registry.YoRegistry;
import us.ihmc.yoVariables.registry.YoVariableList;
import us.ihmc.yoVariables.variable.YoVariable;

public class VariablesThatShouldMatchList
{
   private LinkedHashMap variableHashMapOne = new LinkedHashMap<>(); // From full name to the variable with that name.
   private LinkedHashMap variableHashMapTwo = new LinkedHashMap<>(); // From full name to the variable with that name.

   private final List variablesThatShouldMatch = new ArrayList<>();
   private final List variablesInOneButNotInTwo = new ArrayList<>();
   private final List variablesInTwoButNotInOne = new ArrayList<>();

   public VariablesThatShouldMatchList(YoRegistry registryOne, YoRegistry registryTwo, List exceptions)
   {
      this(registryOne.collectSubtreeVariables(), registryTwo.collectSubtreeVariables(), exceptions);
   }

   public VariablesThatShouldMatchList(YoVariableList varListOne, YoVariableList varListTwo, List exceptions)
   {
      this(varListOne.getVariables(), varListTwo.getVariables(), exceptions);
   }

   public VariablesThatShouldMatchList(List variablesOne, List variablesTwo, List exceptions)
   {
      variablesOne = copyListButRemoveExceptions(variablesOne, exceptions);
      variablesTwo = copyListButRemoveExceptions(variablesTwo, exceptions);
      copyListAndReorder(variablesOne, variablesTwo, variablesInOneButNotInTwo, variablesInTwoButNotInOne);

      // Check to make sure there are no variables in VarListTwo that aren't in VarListOne
      if (variablesOne.size() != variablesTwo.size())
      {
         throw new RuntimeException("Variable lists don't have same length!");
      }

      for (int i = 0; i < variablesOne.size(); i++)
      {
         YoVariable variableOne = variablesOne.get(i);
         YoVariable variableTwo = variablesTwo.get(i);

         String nameOne = variableOne.getFullNameString();
         String nameTwo = variableTwo.getFullNameString();

         if (!nameOne.equals(nameTwo))
         {
            throw new RuntimeException(nameOne + " doesn't equal " + nameTwo);
         }

         variablesThatShouldMatch.add(new YoVariable[] {variableOne, variableTwo});

         variableHashMapOne.put(nameOne, variableOne);
         variableHashMapTwo.put(nameTwo, variableTwo);
      }
   }

   public List getVariablesThatShouldMatch()
   {
      return variablesThatShouldMatch;
   }

   public YoVariable getYoVariableInListOne(String fullName)
   {
      return variableHashMapOne.get(fullName);
   }

   public YoVariable getYoVariableInListTwo(String fullName)
   {
      return variableHashMapTwo.get(fullName);
   }

   private List copyListButRemoveExceptions(List variables, List exceptions)
   {
      List ret = new ArrayList<>();

      for (YoVariable variable : variables)
      {
         if (!isException(exceptions, variable))
         {
            ret.add(variable);
         }
      }

      return ret;
   }

   private static void copyListAndReorder(List variablesOne, List variablesTwo,
                                          List variablesInOneButNotInTwoToPack, List variablesInTwoButNotInOneToPack)
   {
      variablesInOneButNotInTwoToPack.clear();
      variablesInTwoButNotInOneToPack.clear();

      LinkedHashMap variablesTwoHashMap = new LinkedHashMap<>();
      for (YoVariable variableInTwo : variablesTwo)
      {
         variablesTwoHashMap.put(variableInTwo.getFullNameString(), variableInTwo);
      }

      ArrayList newVariablesTwo = new ArrayList<>();

      for (YoVariable variableInOne : variablesOne)
      {
         YoVariable variableInTwo = variablesTwoHashMap.get(variableInOne.getFullNameString());

         if (variableInTwo == null)
         {
            variablesInOneButNotInTwoToPack.add(variableInOne);
         }

         else
         {
            newVariablesTwo.add(variableInTwo);
         }
      }

      for (YoVariable variableToRemoveFromOne : variablesInOneButNotInTwoToPack)
      {
         variablesOne.remove(variableToRemoveFromOne);
      }

      for (YoVariable newVariableTwo : newVariablesTwo)
      {
         variablesTwo.remove(newVariableTwo);
      }

      for (YoVariable extraVariablesInTwo : variablesTwo)
      {
         variablesInTwoButNotInOneToPack.add(extraVariablesInTwo);
      }

      variablesTwo.clear();
      variablesTwo.addAll(newVariablesTwo);
   }

   private static boolean isException(List exceptions, YoVariable variable)
   {
      boolean isException = false;

      if (exceptions != null)
      {
         for (String exceptionName : exceptions)
         {
            String lowerCaseVariableName = variable.getName().toLowerCase();
            String lowerCaseExceptionString = exceptionName.toLowerCase();
            isException = (lowerCaseVariableName.contains(lowerCaseExceptionString));

            if (isException)
            {
               return isException;
            }
         }
      }

      return isException;
   }

   public boolean doVariableValuesMatch(List variableDifferences, double time, double maxDifferenceAllowed,
                                        boolean checkForPercentDifference)
   {
      boolean ret = true;

      for (YoVariable[] twoVariablesThatShouldMatch : variablesThatShouldMatch)
      {
         YoVariable variableOne = twoVariablesThatShouldMatch[0];
         YoVariable variableTwo = twoVariablesThatShouldMatch[1];

         double valueOne = variableOne.getValueAsDouble();
         double valueTwo = variableTwo.getValueAsDouble();

         double absoluteDifference = Math.abs(valueTwo - valueOne);

         boolean variablesAreDifferent;

         if (checkForPercentDifference)
         {
            double max = Math.max(Math.abs(valueOne), Math.abs(valueTwo));
            double percentDiff = absoluteDifference / max;

            variablesAreDifferent = (percentDiff > maxDifferenceAllowed);
         }
         else
         {
            variablesAreDifferent = (absoluteDifference > maxDifferenceAllowed);
         }

         if (variablesAreDifferent)
         {
            //          System.out.println("absoluteDifference = " + absoluteDifference + ", maxDifferenceAllowed = " + maxDifferenceAllowed);
            variableDifferences.add(new VariableDifference(time, variableOne, variableTwo));
            ret = false;
         }
      }

      for (YoVariable variable : variablesInOneButNotInTwo)
      {
         variableDifferences.add(new VariableDifference(time, variable, null));
         ret = false;
      }

      for (YoVariable variable : variablesInTwoButNotInOne)
      {
         variableDifferences.add(new VariableDifference(time, null, variable));
         ret = false;
      }

      return ret;
   }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy