🛰️航天仿真算法库 SpaceAST 0.0.1
载入中...
搜索中...
未找到
ODEIntegrator.hpp
浏览该文件的文档.
1
20
21#pragma once
22
23#include "AstGlobal.h"
24#include "AstMath/ODEEventDetectorList.hpp"
25#include "AstMath/ODEStateObserverList.hpp"
26#include "AstMath/ODEInnerStateObserver.hpp"
27#include "AstMath/OrdinaryDifferentialEquation.hpp"
28#include "AstUtil/Object.hpp"
29#include "AstUtil/ObjectNamed.hpp"
30#include <vector>
31#include <type_traits>
32
33AST_NAMESPACE_BEGIN
34
35class ODEEventDetector;
36
40class AST_MATH_API IODEIntegrator: public ObjectNamed
42public:
43 virtual ~IODEIntegrator() {};
44
48 virtual errc_t initialize(ODE& ode) = 0;
49
50
57 virtual errc_t integrate(ODE& ode, double* y,double& t, double tf) = 0;
58
59
68 virtual errc_t integrateStep(ODE& ode, double* y, double& t, double tf) = 0;
69
75 virtual errc_t singleStep(ODE& ode, double* y, double t0, double step) = 0;
76};
77
78
82class AST_MATH_API ODEIntegrator : public IODEIntegrator
83{
84public:
85 ODEIntegrator() = default;
86 ~ODEIntegrator() override;
87
88 using IODEIntegrator::integrate;
89
90 errc_t initialize(ODE& ode) override;
91
92
102 errc_t integrate(
103 ODE& ode, double* y, double& t, double tf,
104 std::vector<double>& xlist, std::vector<std::vector<double>>& ylist
105 );
106
114 template<typename Func>
115 errc_t integrate(int ndim, Func func, double* y, double& t, double tf)
116 {
117 auto ode = make_ode(ndim, func);
118 return integrate(ode, y, t, tf);
119 }
120
125 void addEventDetector(ODEEventDetector* detector);
126
130 template<typename Func>
131 typename std::enable_if<!std::is_base_of<ODEEventDetector, typename std::remove_pointer<Func>::type>::value, ODEEventDetector*>::type
132 addEventDetector(Func func) {
133 ODEEventDetector* detector = new ODEEventDetectorGeneric<Func>(std::move(func));
134 addEventDetector(detector);
135 return detector;
136 }
137
141 void removeEventDetector(ODEEventDetector* detector);
142
145 void clearEventDetectors();
146
151 void addStateObserver(ODEStateObserver* observer);
152
153
157 template<typename Func>
158 typename std::enable_if<!std::is_base_of<ODEStateObserver, typename std::remove_pointer<Func>::type>::value, ODEStateObserver*>::type
159 addStateObserver(Func func) {
160 auto observer = new ODEStateObserverGeneric<Func>(func);
161 addStateObserver(observer);
162 return observer;
163 }
164
168 void removeStateObserver(ODEStateObserver* observer);
169
173 ODE* getODE() { return ode_; }
174
178 double* stateAtStepStart() { return stateAtStepStart_; }
179
183 double* stateAtStepEnd() { return stateAtStepEnd_; }
184
188 double& timeAtStepStart() { return timeAtStepStart_; }
189
193 double& timeAtStepEnd() { return timeAtStepEnd_; }
194
198 double* stateTemp() { return stateTemp_; }
199protected:
200 friend class ODEInnerStateObserver;
201 void initWorkStateObserver();
202 A_DISABLE_COPY(ODEIntegrator);
203protected:
204 ODE* ode_{nullptr};
205 ODEStateObserver* workStateObserver_{nullptr};
208 ODEInnerStateObserver* innerStateObserver_{nullptr};
209 double* stateAtStepStart_{nullptr};
210 double* stateAtStepEnd_{nullptr};
211 double* stateTemp_{nullptr};
212 double timeAtStepStart_{0.0};
213 double timeAtStepEnd_{0.0};
214};
215
216
217AST_NAMESPACE_END
ODE 积分器接口类
定义 ODEIntegrator.hpp:41
virtual errc_t singleStep(ODE &ode, double *y, double t0, double step)=0
执行一步积分
virtual errc_t integrateStep(ODE &ode, double *y, double &t, double tf)=0
积分ODE一步
virtual errc_t integrate(ODE &ode, double *y, double &t, double tf)=0
积分ODE
virtual errc_t initialize(ODE &ode)=0
初始化积分器
泛型ODE积分的事件检测器
定义 ODEEventDetector.hpp:98
定义 ODEEventDetectorList.hpp:32
ODE积分的事件检测器
定义 ODEEventDetector.hpp:36
定义 ODEInnerStateObserver.hpp:31
ODE 积分器
定义 ODEIntegrator.hpp:83
double * stateTemp()
获取临时状态向量
定义 ODEIntegrator.hpp:198
errc_t integrate(int ndim, Func func, double *y, double &t, double tf)
积分ODE
定义 ODEIntegrator.hpp:115
double & timeAtStepEnd()
获取当前积分步的结束时间
定义 ODEIntegrator.hpp:193
std::enable_if<!std::is_base_of< ODEStateObserver, typenamestd::remove_pointer< Func >::type >::value, ODEStateObserver * >::type addStateObserver(Func func)
添加状态观察者(泛型模板)
定义 ODEIntegrator.hpp:159
double * stateAtStepEnd()
获取当前积分步的结束状态
定义 ODEIntegrator.hpp:183
std::enable_if<!std::is_base_of< ODEEventDetector, typenamestd::remove_pointer< Func >::type >::value, ODEEventDetector * >::type addEventDetector(Func func)
添加事件检测器(泛型模板)
定义 ODEIntegrator.hpp:132
ODE * getODE()
获取ODE方程
定义 ODEIntegrator.hpp:173
ODEEventDetectorList eventDetectorList_
事件检测器列表
定义 ODEIntegrator.hpp:206
ODEStateObserverList stateObserverList_
状态观察者列表
定义 ODEIntegrator.hpp:207
double & timeAtStepStart()
获取当前积分步的开始时间
定义 ODEIntegrator.hpp:188
double * stateAtStepStart()
获取当前积分步的开始状态
定义 ODEIntegrator.hpp:178
泛型ODE状态量观察者
定义 ODEStateObserver.hpp:84
定义 ODEStateObserverList.hpp:30
ODE状态量观察者
定义 ODEStateObserver.hpp:39
命名对象
定义 ObjectNamed.hpp:36
常微分方程基接口
定义 OrdinaryDifferentialEquation.hpp:33
ODEGeneric< Func > make_ode(Func func, int dim)
创建一个常微分方程
定义 OrdinaryDifferentialEquation.hpp:89