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

us.ihmc.simulationconstructionset.FunctionIntegrators Maven / Gradle / Ivy

There is a newer version: 0.25.3
Show newest version
package us.ihmc.simulationconstructionset;

import java.util.ArrayList;

public class FunctionIntegrators
{
   private FunctionIntegrator[] integrators;

   public FunctionIntegrators()
   {
   }

   public void addFunctionIntegrator(FunctionIntegrator integrator)
   {
      if (integrators == null)
      {
         integrators = new FunctionIntegrator[] {integrator};

         return;
      }

      ArrayList tempIntegrators = new ArrayList<>();

      for (int i = 0; i < integrators.length; i++)
      {
         tempIntegrators.add(integrators[i]);
      }

      tempIntegrators.add(integrator);

      integrators = new FunctionIntegrator[tempIntegrators.size()];
      tempIntegrators.toArray(integrators);
   }

   public void saveTempState()
   {
      for (int i = 0; i < integrators.length; i++)
      {
         integrators[i].saveTempState();
      }
   }

   public void doDynamics(int step)
   {
      for (int i = 0; i < integrators.length; i++)
      {
         integrators[i].doDynamics(step);
      }
   }

   public void eulerIntegrate(double dt)
   {
      for (int i = 0; i < integrators.length; i++)
      {
         integrators[i].eulerIntegrate(dt);
      }
   }

   public void restoreTempState()
   {
      for (int i = 0; i < integrators.length; i++)
      {
         integrators[i].restoreTempState();
      }
   }

   public void rungeKuttaSum(double DT)
   {
      for (int i = 0; i < integrators.length; i++)
      {
         integrators[i].rungeKuttaSum(DT);
      }
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy