🛰️航天仿真算法库 SpaceAST 0.0.1
载入中...
搜索中...
未找到
TimePoint.hpp
浏览该文件的文档.
1
20
21#pragma once
22
23#include "AstGlobal.h"
24#include "Duration.hpp" // for LongDuration
25#include "AstCore/Constants.h" // for kJ2000XXXX
26#include "AstCore/JulianDate.hpp"
27#include "AstCore/DateTime.hpp"
28#include "AstCore/RunTime.hpp"
29#include <stdint.h> // for int64_t
30
31AST_NAMESPACE_BEGIN
32
40class DateTime;
41
42class LongDuration;
43class ShortDuration;
44class DaySecDuration;
45
46class TAIScale;
47class TDBScale;
48class TTScale;
49class UTCScale;
50
51class TimePoint;
52
53constexpr static double kTimePointDefaultFormatPrecision = 6;
54
55
56// --------------------
57// 时间点与时间系统的转换
58// --------------------
59
61AST_CORE_API void aTimePointToUTC(const TimePoint& time, JulianDate& jdUTC);
62
64AST_CORE_API void aTimePointToTT(const TimePoint& time, JulianDate& jdTT);
65
67AST_CORE_API void aTimePointToTDB(const TimePoint& time, JulianDate& jdTDB);
68
70AST_CORE_API void aTimePointToTAI(const TimePoint& time, JulianDate& jdTAI);
71
73AST_CORE_API void aTimePointToUT1(const TimePoint& time, JulianDate& jdUT1);
74
76AST_CORE_API void aTimePointToUTC(const TimePoint& time, DateTime& dttmUTC);
77
79AST_CORE_API void aTimePointToTT(const TimePoint& time, DateTime& dttmTT);
80
82AST_CORE_API void aTimePointToTDB(const TimePoint& time, DateTime& dttmTDB);
83
85AST_CORE_API void aTimePointToTAI(const TimePoint& time, DateTime& dttmTAI);
86
88AST_CORE_API void aTimePointToUT1(const TimePoint& time, DateTime& dttmUT1);
89
90
91
92// ----------------
93// 时间点格式化与解析
94// ----------------
95
96
98AST_CORE_CAPI errc_t aTimePointFormat(const TimePoint& time, std::string& str, int precision = kTimePointDefaultFormatPrecision);
99
101AST_CORE_CAPI errc_t aTimePointParse(StringView str, TimePoint& time);
102
103
106{
107public:
109 AST_CORE_API
110 static TimePoint CurrentTime();
111
113 AST_CORE_API
114 static TimePoint TodayUTC();
115
117 AST_CORE_API
118 static TimePoint TomorrowUTC();
119
121 AST_CORE_API
122 static TimePoint FromUTC(const DateTime& dttmUTC);
123
125 AST_CORE_API
126 static TimePoint FromUTC(int year, int month, int day, int hour, int minute, double second);
127
129 AST_CORE_API
130 static TimePoint FromTAI(const JulianDate& jdTAI);
131
133 AST_CORE_API
134 static TimePoint FromTT(const JulianDate& jdTT);
135
137 AST_CORE_API
138 static TimePoint FromTDB(const JulianDate& jdTDB);
139
141 AST_CORE_API
142 static TimePoint FromImpreciseJDTT(double jdTT);
143
146 return {0, -kTTMinusTAI};
147 }
148
153 TimePoint time;
154 aTimePointParse(str, time);
155 return time;
156 }
157
158public:
160 int64_t integerPart() const { return duration_.integer_; }
161
163 double fractionalPart() const { return duration_.fractional_; }
164public:
166 double daysFromJ2000TT() const{
167 return ((double)integerPart() / kSecondsPerDay) + (fractionalPart() + kTTMinusTAI) / kSecondsPerDay;
168 }
169
172 return daysFromJ2000TT() / kDaysPerJulianCentury;
173 }
174
176 void toTT(JulianDate& jdTT) const{
177 aTimePointToTT(*this, jdTT);
178 }
181 JulianDate jdTT;
182 toTT(jdTT);
183 return jdTT;
184 }
186 void toTDB(JulianDate& jdTDB) const{
187 aTimePointToTDB(*this, jdTDB);
188 }
191 JulianDate jdTDB;
192 toTDB(jdTDB);
193 return jdTDB;
194 }
196 void toTAI(JulianDate& jdTAI) const{
197 aTimePointToTAI(*this, jdTAI);
198 }
201 JulianDate jdTAI;
202 toTAI(jdTAI);
203 return jdTAI;
204 }
206 double toEpochSecond() const{
207 return aTimePointToEpochSecond(*this);
208 }
209
211 double durationFrom(const TimePoint& other) const{
212 return duration_.minusInSecond(other.duration_);
213 }
214
216 double daysFrom(const TimePoint& other) const{
217 return duration_.minusInDay(other.duration_);
218 }
219
223 double operator-(const TimePoint& other) const{
224 return durationFrom(other);
225 }
229 TimePoint operator+(double second) const{
230 return {integerPart(), fractionalPart() + second};
231 }
232
236 TimePoint operator-(double second) const{
237 return {integerPart(), fractionalPart() - second};
238 }
239
243 std::string toString(int precision = kTimePointDefaultFormatPrecision) const
244 {
245 std::string str;
246 aTimePointFormat(*this, str, precision);
247 return str;
248 }
249public:
253 TimePoint shiftedBySecond(double second) const{
254 return {integerPart(), fractionalPart() + second};
255 }
256
260 AST_CORE_API TimePoint shiftedBySecondInTDB(double second) const;
261
262protected:
263 static TimePoint FromIntegerFractional(int64_t integer, double fractional);
264public:
265 LongDuration duration_;
266};
267
268
269// typedef TimePoint<TDBScale, LongDuration> TDBTime;
270// typedef TimePoint<TTScale, LongDuration> TTTime;
271// typedef TimePoint<UTCScale, LongDuration> UTCTime;
272// typedef TimePoint<TAIScale, LongDuration> TAITime;
273
274// typedef TAITime AbsTime;
275// typedef TAITime AstTime;
276
277
280AST_NAMESPACE_END
long int integer
定义 MockSnopt.c:24
Unit day
定义 Unit.cpp:430
Unit hour
小时
定义 Unit.cpp:428
日期时间
定义 DateTime.hpp:418
儒略日
定义 JulianDate.hpp:82
长时长
定义 Duration.hpp:49
绝对时间点
定义 TimePoint.hpp:106
JulianDate toTAI() const
将时间点转换为儒略日数(原子时 TAI)
定义 TimePoint.hpp:200
double julianCenturyFromJ2000TT() const
计算时间点与 J2000 epoch 的时间差(儒略世纪)
定义 TimePoint.hpp:171
TimePoint shiftedBySecond(double second) const
计算时间点偏移后的新时间点,按默认时间尺度进行时间偏移
定义 TimePoint.hpp:253
static TimePoint J2000TT()
J2000.0 TT 时间点
定义 TimePoint.hpp:145
double fractionalPart() const
时间点的小数秒数部分
定义 TimePoint.hpp:163
double durationFrom(const TimePoint &other) const
计算与另一个时间点的时间差(秒数)
定义 TimePoint.hpp:211
TimePoint operator-(double second) const
时间点减法运算符
定义 TimePoint.hpp:236
TimePoint operator+(double second) const
时间点加法运算符
定义 TimePoint.hpp:229
void toTT(JulianDate &jdTT) const
将时间点转换为儒略日数(地球时TT)
定义 TimePoint.hpp:176
void toTDB(JulianDate &jdTDB) const
将时间点转换为儒略日数(质心动力学时TDB)
定义 TimePoint.hpp:186
static TimePoint Parse(StringView str)
从字符串解析时间点
定义 TimePoint.hpp:152
double toEpochSecond() const
将时间点转换为相对于参考历元的秒数
定义 TimePoint.hpp:206
JulianDate toTT() const
将时间点转换为儒略日数(地球时TT)
定义 TimePoint.hpp:180
double daysFromJ2000TT() const
计算时间点与 J2000 epoch 的时间差(天)
定义 TimePoint.hpp:166
int64_t integerPart() const
时间点的整数秒数部分
定义 TimePoint.hpp:160
double operator-(const TimePoint &other) const
时间点减法运算符
定义 TimePoint.hpp:223
JulianDate toTDB() const
将时间点转换为儒略日数(质心动力学时TDB)
定义 TimePoint.hpp:190
std::string toString(int precision=kTimePointDefaultFormatPrecision) const
将时间点格式化为字符串
定义 TimePoint.hpp:243
double daysFrom(const TimePoint &other) const
计算与另一个时间点的时间差(天)
定义 TimePoint.hpp:216
void toTAI(JulianDate &jdTAI) const
将时间点转换为儒略日数(原子时 TAI)
定义 TimePoint.hpp:196
double aTimePointToEpochSecond(const TimePoint &tp)
将时间点转换为相对参考历元的秒数
定义 RunTimeEpoch.cpp:27
void aTimePointToTDB(const TimePoint &time, JulianDate &jdTDB)
将时间点转换为儒略日数(质心动力学时TDB)
定义 TimePoint.cpp:102
void aTimePointToTAI(const TimePoint &time, JulianDate &jdTAI)
将时间点转换为儒略日数(原子时 TAI)
定义 TimePoint.cpp:59
errc_t aTimePointFormat(const TimePoint &time, std::string &str, int precision)
将时间点格式化为字符串
定义 TimePoint.cpp:84
void aTimePointToUTC(const TimePoint &time, JulianDate &jdUTC)
将时间点转换为儒略日数(协调世界时 UTC)
定义 TimePoint.cpp:41
void aTimePointToUT1(const TimePoint &time, JulianDate &jdUT1)
将时间点转换为儒略日数(世界时 UT1)
定义 TimePoint.cpp:70
void aTimePointToTT(const TimePoint &time, JulianDate &jdTT)
将时间点转换为儒略日数(地球时TT)
定义 TimePoint.cpp:47
errc_t aTimePointParse(StringView str, TimePoint &time)
从字符串解析时间点
定义 TimePoint.cpp:93
constexpr double kSecondsPerDay
一天的秒数
定义 Constants.h:204
constexpr double kDaysPerJulianCentury
儒略世纪天数
定义 Constants.h:202
constexpr double kTTMinusTAI
地球时相对原子时的偏置[s]
定义 Constants.h:45