24#include "AstCore/Vector.hpp"
25#include "AstCore/OrbitParam.hpp"
26#include "AstCore/TimePoint.hpp"
27#include "AstUtil/Constants.h"
55 A_DEF_POD_ITERABLE(
double)
59 const Vector3d& pos()
const {
return pos_;}
60 Vector3d& pos() {
return pos_;}
64 const Vector3d&
vel()
const {
return vel_;}
65 Vector3d& vel() {
return vel_;}
67 double& x() {
return pos_.x();}
68 double& y() {
return pos_.y();}
69 double& z() {
return pos_.z();}
70 double& vx() {
return vel_.x();}
71 double& vy() {
return vel_.y();}
72 double& vz() {
return vel_.z();}
74 double x()
const {
return pos_.x();}
75 double y()
const {
return pos_.y();}
76 double z()
const {
return pos_.z();}
77 double vx()
const {
return vel_.x();}
78 double vy()
const {
return vel_.y();}
79 double vz()
const {
return vel_.z();}
97 double getSMA()
const {
return a_;}
99 double getA()
const {
return a_;}
101 double getE()
const {
return e_;}
103 double getI()
const {
return i_;}
105 double getRAAN()
const {
return raan_;}
107 double getArgPer()
const {
return argper_;}
109 double getTrueA()
const {
return trueA_;}
113 std::string toString()
const;
115 A_DEF_POD_ITERABLE(
double)
116 AST_DEF_ACCESS_METHOD(
double, a)
117 AST_DEF_ACCESS_METHOD(
double, e)
118 AST_DEF_ACCESS_METHOD(
double, i)
119 AST_DEF_ACCESS_METHOD(
double, raan)
120 AST_DEF_ACCESS_METHOD(
double, argper)
121 AST_DEF_ACCESS_METHOD(
double, trueA)
137 double getSMA()
const {
return rp_ / (1 - e_);}
155 double getPeriAlt(
double bodyRadius)
const{
return getPeriRad() - bodyRadius;}
190 return stateEpoch - getTimePastAscNode(gm);
196 return aRAANToLAN(getRAAN(), inertialAxes, timeOfAscNodePassage, bodyFixedAxes);
201 double getA()
const {
return getSMA();}
204 double getP()
const {
return rp_ * (1 + e_);}
206 double getE()
const {
return getEcc();}
208 double getI()
const {
return getInc();}
210 double getArgPer()
const {
return getArgPeri();}
212 double getTrueA()
const {
return getTrueAnomaly();}
216 std::string toString()
const;
218 A_DEF_POD_ITERABLE(
double)
219 AST_DEF_ACCESS_METHOD(
double, rp)
220 AST_DEF_ACCESS_METHOD(
double, e)
221 AST_DEF_ACCESS_METHOD(
double, i)
222 AST_DEF_ACCESS_METHOD(
double, raan)
223 AST_DEF_ACCESS_METHOD(
double, argper)
224 AST_DEF_ACCESS_METHOD(
double, trueA)
239 A_DEF_POD_ITERABLE(
double)
240 AST_DEF_ACCESS_METHOD(
double, a)
241 AST_DEF_ACCESS_METHOD(
double, h)
242 AST_DEF_ACCESS_METHOD(
double, k)
243 AST_DEF_ACCESS_METHOD(
double, p)
244 AST_DEF_ACCESS_METHOD(
double, q)
245 AST_DEF_ACCESS_METHOD(
double, lambda)
259 A_DEF_POD_ITERABLE(
double)
260 AST_DEF_ACCESS_METHOD(
double, p)
261 AST_DEF_ACCESS_METHOD(
double, f)
262 AST_DEF_ACCESS_METHOD(
double, g)
263 AST_DEF_ACCESS_METHOD(
double, h)
264 AST_DEF_ACCESS_METHOD(
double, k)
265 AST_DEF_ACCESS_METHOD(
double, L)
289 A_DEF_POD_ITERABLE(
double)
290 AST_DEF_ACCESS_METHOD(
double,
L)
291 AST_DEF_ACCESS_METHOD(
double, G)
292 AST_DEF_ACCESS_METHOD(
double, H)
293 AST_DEF_ACCESS_METHOD(
double, l)
294 AST_DEF_ACCESS_METHOD(
double,
g)
295 AST_DEF_ACCESS_METHOD(
double,
h)
305AST_CORE_CAPI errc_t
coe2rv(
const double* coe,
double gm,
double* pos,
double* vel);
311AST_CORE_CAPI errc_t
coe2mee(
const double* coe,
double* mee);
318AST_CORE_CAPI
void ee2rv(
const double* ee,
double gm,
double* pos,
double* vel);
325AST_CORE_CAPI
void mee2rv(
const double* mee,
double gm,
double* pos,
double* vel);
333AST_CORE_CAPI errc_t
rv2mee(
const double* pos,
const double* vel,
double gm,
double* mee);
339AST_CORE_CAPI errc_t
mee2coe(
const double* mee,
double* coe);
346AST_CORE_CAPI
void rv2ee(
const double* pos,
const double* vel,
double gm,
double* ee);
354AST_CORE_CAPI errc_t
rv2moe(
const double* pos,
const double* vel,
double gm,
double* moe);
362AST_CORE_CAPI errc_t
rv2coe(
const double* pos,
const double* vel,
double gm,
double* coe);
368AST_CORE_CAPI errc_t
ee2moe(
const double* ee,
double* moe);
374AST_CORE_CAPI errc_t
moe2ee(
const double* moe,
double* ee);
379AST_CORE_CAPI errc_t
moe2coe(
const double* moe,
double* coe);
384AST_CORE_CAPI
void coe2moe(
const double* coe,
double* moe);
391AST_CORE_CAPI errc_t
moe2rv(
const double* moe,
double gm,
double* pos,
double* vel);
396AST_CORE_CAPI
void moe2mee(
const double* moe,
double* mee);
401AST_CORE_CAPI
void coe2ee(
const double* coe,
double* ee);
406AST_CORE_CAPI
void ee2coe(
const double* ee,
double* coe);
411AST_CORE_CAPI
void ee2mee(
const double* ee,
double* mee);
416AST_CORE_CAPI
void mee2ee(
const double* mee,
double* ee);
421AST_CORE_CAPI
void mee2moe(
const double* mee,
double* moe);
428AST_CORE_CAPI errc_t
coe2dela(
const double* coe,
double gm,
double* dela);
434AST_CORE_CAPI errc_t
dela2coe(
const double* dela,
double gm,
double* coe);
614AST_DECL_TYPE_ALIAS(CartState)
直角坐标
定义 OrbitElement.hpp:46
Vector3d vel_
速度
定义 OrbitElement.hpp:49
Vector3d pos_
位置
定义 OrbitElement.hpp:48
const Vector3d & vel() const
获取速度
定义 OrbitElement.hpp:64
static CartState Zero()
获取零状态
定义 OrbitElement.hpp:53
德洛奈根数
定义 OrbitElement.hpp:279
春分点根数
定义 OrbitElement.hpp:230
double lambda_
mean longitude = M + raan + argper
定义 OrbitElement.hpp:237
double k_
e*cos(argper + raan)
定义 OrbitElement.hpp:234
double q_
tan(i/2)*cos(raan)
定义 OrbitElement.hpp:236
double a_
semimajor axis length
定义 OrbitElement.hpp:232
double p_
tan(i/2)*sin(raan)
定义 OrbitElement.hpp:235
double h_
e*sin(argper + raan) omegabar=argper + raan
定义 OrbitElement.hpp:233
改进春分点轨道根数, 180度奇异
定义 OrbitElement.hpp:250
double h_
h = tan(i/2)cos(RAAN)
定义 OrbitElement.hpp:255
double k_
k = tan(i/2)sin(RAAN)
定义 OrbitElement.hpp:256
double L_
L = RAAN + argper + trueA
定义 OrbitElement.hpp:257
double g_
g = e*sin(argper+RAAN)
定义 OrbitElement.hpp:254
double f_
f = e*cos(argper+RAAN)
定义 OrbitElement.hpp:253
double p_
p = a(1-e^2) 半通径
定义 OrbitElement.hpp:252
修正轨道根数
定义 OrbitElement.hpp:127
double rp_
近拱点半径
定义 OrbitElement.hpp:129
double getMeanMotion(double gm) const
计算平均角速度
定义 OrbitElement.hpp:140
double getA() const
计算半长轴
定义 OrbitElement.hpp:201
double getLAN(Axes *inertialAxes, const TimePoint &timeOfAscNodePassage, Axes *bodyFixedAxes) const
计算升交点经度
定义 OrbitElement.hpp:194
double trueA_
真近点角
定义 OrbitElement.hpp:134
double getSMA() const
计算半长轴
定义 OrbitElement.hpp:137
double getArgLat() const
计算纬度幅角
定义 OrbitElement.hpp:179
double getEccAnomaly() const
计算偏近点角
定义 OrbitElement.hpp:176
double getRAAN() const
计算升交点赤经
定义 OrbitElement.hpp:164
double getTimePastAscNode(double gm) const
计算过升交点后经过的时间
定义 OrbitElement.hpp:185
double getPeriAlt(double bodyRadius) const
计算近拱点高度
定义 OrbitElement.hpp:155
double getP() const
计算半通径
定义 OrbitElement.hpp:204
double getPeriod(double gm) const
计算周期
定义 OrbitElement.hpp:143
double e_
偏心率
定义 OrbitElement.hpp:130
double getApoRad() const
计算远拱点半径
定义 OrbitElement.hpp:146
double argper_
近拱点角
定义 OrbitElement.hpp:133
double getTimePastPeri(double gm) const
计算过近地点后经过的时间
定义 OrbitElement.hpp:182
double getMeanAnomaly() const
计算平近点角
定义 OrbitElement.hpp:173
double getPeriRad() const
计算近拱点半径
定义 OrbitElement.hpp:152
double getApoAlt(double bodyRadius) const
计算远拱点高度
定义 OrbitElement.hpp:149
double raan_
升交点赤经
定义 OrbitElement.hpp:132
double getEcc() const
计算偏心率
定义 OrbitElement.hpp:158
double getArgPeri() const
计算近拱点幅角
定义 OrbitElement.hpp:167
double getInc() const
计算轨道倾角
定义 OrbitElement.hpp:161
double i_
轨道倾角
定义 OrbitElement.hpp:131
TimePoint getTimeOfAscNodePassage(const TimePoint &stateEpoch, double gm) const
计算过升交点时刻
定义 OrbitElement.hpp:188
double getTrueAnomaly() const
计算真近点角
定义 OrbitElement.hpp:170
经典轨道根数
定义 OrbitElement.hpp:85
double a_
长半轴
定义 OrbitElement.hpp:87
double argper_
近拱点角
定义 OrbitElement.hpp:91
double trueA_
真近点角
定义 OrbitElement.hpp:92
double raan_
升交点赤经
定义 OrbitElement.hpp:90
double i_
轨道倾角
定义 OrbitElement.hpp:89
double getMeanMotion(double gm) const
计算平均角速度变化率
定义 OrbitElement.hpp:95
double e_
偏心率
定义 OrbitElement.hpp:88
绝对时间点
定义 TimePoint.hpp:106
errc_t aCartToModEquinElem(const Vector3d &pos, const Vector3d &vel, double gm, ModEquinElem &mee)
直角坐标转换为改进春分点轨道根数(类引用版本)
定义 OrbitElement.cpp:1028
errc_t moe2rv(const double *moe, double gm, double *pos, double *vel)
修正轨道根数转换为直角坐标
定义 OrbitElement.cpp:672
double aPeriRadToApoRad(double perigeeRad, double eccentricity)
近地点半径转换为远地点半径
定义 OrbitParam.cpp:316
double aPeriRadToMeanMotion(double perigeeRad, double eccentricity, double gm)
近地点半径转换为平均角速度
定义 OrbitParam.cpp:321
void mee2ee(const double *mee, double *ee)
改进春分点轨道根数转换为春分点根数
定义 OrbitElement.cpp:849
double aRAANToLAN(double raan, Axes *inertialAxes, const TimePoint &timeOfAscNodePassage, Axes *bodyFixedAxes)
升交点赤经转换为升交点经度
定义 OrbitParam.cpp:511
errc_t aModOrbToEquinElem(const ModOrbElem &modOrb, EquinElem &equinElem)
修正轨道根数转换为春分点根数(类引用版本)
定义 OrbitElement.cpp:1090
errc_t mee2coe(const double *mee, double *coe)
改进春分点轨道根数转换为经典轨道根数
定义 OrbitElement.cpp:259
void rv2ee(const double *pos, const double *vel, double gm, double *ee)
直角坐标转换为春分点根数
定义 OrbitElement.cpp:321
void coe2moe(const double *coe_, double *moe_)
经典轨道根数转换为修正轨道根数
定义 OrbitElement.cpp:661
double aSMAToMeanMotion(double semiMajorAxis, double gm)
长半轴转换为平均角速度
定义 OrbitParam.cpp:384
errc_t coe2rv(const double *coe, double gm, double *pos, double *vel)
经典轨道根数转换为直角坐标
定义 OrbitElement.cpp:61
errc_t ee2moe(const double *ee, double *moe)
春分点根数转换为修正轨道根数
定义 OrbitElement.cpp:537
errc_t moe2ee(const double *moe, double *ee)
修正轨道根数转换为春分点根数
定义 OrbitElement.cpp:614
double aTrueToMean(double trueAnomaly, double eccentricity)
真近点角转换为平近点角
定义 OrbitParam.cpp:484
errc_t rv2moe(const double *pos, const double *vel, double gm, double *moe)
直角坐标转换为修正轨道根数
定义 OrbitElement.cpp:389
void aModEquinElemToCart(const ModEquinElem &mee, double gm, Vector3d &pos, Vector3d &vel)
改进春分点轨道根数转换为直角坐标(类引用版本)
定义 OrbitElement.cpp:1016
errc_t coe2mee(const double *coe, double *mee)
经典轨道根数转换为改进春分点轨道根数
定义 OrbitElement.cpp:96
errc_t aDelaunayToOrbElem(const DelaunayElem &delaunay, double gm, OrbElem &elem)
修正轨道根数转换为经典轨道根数(类引用版本)
定义 OrbitElement.cpp:1145
errc_t moe2coe(const double *moe_, double *coe_)
修正轨道根数转换为经典轨道根数
定义 OrbitElement.cpp:648
double aTrueToTimePastAscNode(double trueAnomaly, double argPeri, double semiMajorAxis, double eccentricity, double gm)
真近点角转换为过升交点后时间
定义 OrbitParam.cpp:489
errc_t aOrbElemToDelaunay(const OrbElem &elem, double gm, DelaunayElem &delaunay)
经典轨道根数转换为修正轨道根数(类引用版本)
定义 OrbitElement.cpp:1140
void ee2rv(const double *ee, double gm, double *pos, double *vel)
春分点根数转换为直角坐标
定义 OrbitElement.cpp:119
void mee2rv(const double *mee, double gm, double *pos, double *vel)
改进春分点轨道根数转换为直角坐标
定义 OrbitElement.cpp:173
errc_t rv2coe(const double *pos, const double *vel, double gm, double *coe)
直角坐标转换为经典轨道根数
定义 OrbitElement.cpp:453
void aCartToEquinElem(const Vector3d &pos, const Vector3d &vel, double gm, EquinElem &equinElem)
直角坐标转换为春分点根数(类引用版本)
定义 OrbitElement.cpp:1121
void aEquinElemToCart(const EquinElem &equinElem, double gm, Vector3d &pos, Vector3d &vel)
春分点根数转换为直角坐标(类引用版本)
定义 OrbitElement.cpp:1131
void ee2mee(const double *ee, double *mee)
春分点根数转换为改进春分点轨道根数
定义 OrbitElement.cpp:813
errc_t aCartToModOrbElem(const Vector3d &pos, const Vector3d &vel, double gm, ModOrbElem &modOrb)
直角坐标转换为修正轨道根数(类引用版本)
定义 OrbitElement.cpp:1058
errc_t aModEquinElemToOrbElem(const ModEquinElem &mee, OrbElem &elem)
改进春分点轨道根数转换为经典轨道根数(类引用版本)
定义 OrbitElement.cpp:1049
void mee2moe(const double *mee, double *moe)
改进春分点轨道根数转换为修正轨道根数
定义 OrbitElement.cpp:868
errc_t aOrbElemToModEquinElem(const OrbElem &elem, ModEquinElem &mee)
经典轨道根数转换为改进春分点轨道根数(类引用版本)
定义 OrbitElement.cpp:1040
double aTrueToEcc(double f, double e)
真近点角转换为偏近点角
定义 OrbitParam.cpp:457
double aTrueToArgLat(double trueAnomaly, double argPeri)
真近点角转换为纬度幅角
定义 OrbitParam.hpp:653
errc_t aOrbElemToCart(const OrbElem &elem, double gm, Vector3d &pos, Vector3d &vel)
经典轨道根数转换为直角坐标(类引用版本)
定义 OrbitElement.cpp:1110
errc_t aEquinElemToModOrb(const EquinElem &equinElem, ModOrbElem &modOrb)
春分点根数转换为修正轨道根数(类引用版本)
定义 OrbitElement.cpp:1081
errc_t rv2mee(const double *pos_, const double *vel_, double gm, double *mee)
直角坐标转换为改进春分点轨道根数
定义 OrbitElement.cpp:196
errc_t aModOrbElemToCart(const ModOrbElem &modOrb, double gm, Vector3d &pos, Vector3d &vel)
修正轨道根数转换为直角坐标(类引用版本)
定义 OrbitElement.cpp:1099
void coe2ee(const double *coe, double *ee)
经典轨道根数转换为春分点根数
定义 OrbitElement.cpp:722
errc_t aCartToOrbElem(const Vector3d &pos, const Vector3d &vel, double gm, OrbElem &elem)
直角坐标转换为经典轨道根数(类引用版本)
定义 OrbitElement.cpp:1069
void ee2coe(const double *ee, double *coe)
春分点根数转换为经典轨道根数
定义 OrbitElement.cpp:740
double aTrueToTimePastPeri(double trueAnomaly, double semiMajorAxis, double eccentricity, double gm)
真近点角转换为过近心点后时间
定义 OrbitParam.cpp:494
errc_t coe2dela(const double *coeIn, double gm, double *delaOut)
经典轨道根数转换为德洛奈根数
定义 OrbitElement.cpp:923
void moe2mee(const double *moe, double *mee)
修正轨道根数转换为改进春分点轨道根数
定义 OrbitElement.cpp:705
double aPeriRadToApoAlt(double perigeeRad, double eccentricity, double bodyRadius)
近地点半径转换为远地点高度
定义 OrbitParam.cpp:312
errc_t dela2coe(const double *delaIn, double gm, double *coeOut)
德洛奈根数转换为经典轨道根数
定义 OrbitElement.cpp:977
constexpr double kTwoPI
2*PI
定义 Constants.h:54