00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026 #ifndef VariableTimeStepDirectIntegrationAnalysis_h
00027 #define VariableTimeStepDirectIntegrationAnalysis_h
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042 #include <DirectIntegrationAnalysis.h>
00043
00044 #include <ConstraintHandler.h>
00045 #include <DOF_Numberer.h>
00046 #include <AnalysisModel.h>
00047 #include <TransientIntegrator.h>
00048 #include <LinearSOE.h>
00049 #include <EquiSolnAlgo.h>
00050 #include <ConvergenceTest.h>
00051
00053 class VariableTimeStepDirectIntegrationAnalysis: public DirectIntegrationAnalysis
00054 {
00055 public:
00057 VariableTimeStepDirectIntegrationAnalysis(Domain &theDomain,
00058 ConstraintHandler &theHandler,
00059 DOF_Numberer &theNumberer,
00060 AnalysisModel &theModel,
00061 EquiSolnAlgo &theSolnAlgo,
00062 LinearSOE &theSOE,
00063 TransientIntegrator &theIntegrator);
00065 virtual ~VariableTimeStepDirectIntegrationAnalysis();
00066
00068 int analyze(int numSteps, double dT, double dtMin, double dtMax, double perCent);
00069
00070 protected:
00072 virtual double determineDt(double dT, double dtMin, double dtMax, double perCent,
00073 ConvergenceTest *theTest);
00074
00075 private:
00076 };
00077
00078 #endif
00079
00080 ÿ