TA的每日心情 | 开心 19 小时前 |
---|
签到天数: 2801 天 [LV.Master]无
|
本帖最后由 heinsect 于 2015-2-1 18:13 编辑 # q, h2 n1 B& t$ u+ W4 `0 _' R+ \
/ U4 q; r- c% d
程序员计算日期是用儒略日的。
$ u; M6 v% i! s& e+ d
% n, ?& }' h$ {7 f7 a1 H9 v儒略日中的儒略和儒略历中的儒略的关系嘛,只是因为儒略日的发明人的爷爷葱白凯撒,给儿子用了大帝的名字。刚好儒略历也用了大帝的名字。
3 _- d4 h8 Z! y& |& p, r; k. k. I' K& @5 a6 a1 Q/ i
单用日期的话,儒略日是从某天开始的一个日的整数。两个儒略日的差值就是相差的天数。这样想计算两个日期间的差值,计算星期几就很简单了。至于那个开始日期,儒略日的零点,用起来的时候谁也不关心,我就不讲了。
& {8 F- K+ A+ y+ R. k
& |0 [$ X2 {9 M从格里高利历日期算儒略日(JDN)的公式是这个样子的:
! y* a4 E* l) y4 m( w' a: L
3 z7 V9 d; t" I) R4 {先要改一下年月:
0 f, y+ u6 U! {/ c' Y % ]- m( h" u: Q' n$ f# \
9 p, V4 X; l/ }% s; T' ?上面这组公式的结果呢,差不多是这个意思:
( g2 T9 C5 q7 R* K( r4 ]三月 m = 0, y=y
# W2 f( y! c# }# s! z...
8 t1 L2 G8 z' e7 A; W十二月 m=9, y=y I: u8 H5 F3 X: V! Y
一月 m = 10, y=y-1
) o! }7 P% @1 j0 b' E/ x' s. D二月 m = 11, y=y-1% _% q" I, H6 d
9 F+ i& _( V9 F- Q
那个4800,是个计算零点,大概在公元前4801年,是和前面所说的那个零点相关的。
0 F* o" r# M7 v, ?9 a. c1 n, d% J然后计算儒略日的公式长是这个样子的:
! @- V, l4 Y" y' R% [3 g/ b3 q
# L, R. q6 x0 q % _7 h* [$ s+ V3 ~# e3 ^& [
! `5 `6 u9 K5 g& X这个公式中最巧的部分是 floor((153m+2)/5), 做出的效果嘛,看这个表:4 V7 H& D2 c* r* g9 V
Mar–Jul:31 30 31 30 31Aug–Dec:31 30 31 30 31Jan–Feb:31 28
. \2 r& z o6 R8 v8 | u# u& R+ A% ~最后面的那个系数,是相对于原点的修正值。原公式算出来的值一般太大,计算中用起来会超过32/64位字长。现在天文计算中一般会选择2000年1月1日为零点,之前有用1900年和1950年的。$ c: {/ _' _9 i4 k k
% S3 L: T2 T& v m0 ~' Q7 O从儒略日计算星期几,(JDN+1) mod 7 就好了。9 D- J, u- F- j& n' q1 O
3 U' b, } E/ F
这个公式是怎么来的呢? 1582年,教皇格里高利十三(XIII)发现,那一年的春分是3月11日,和儒略历里规定的日期3月21日差了十天。原因嘛,就是回归年的长度是365.2422,儒略历用的365.25。格十三用上了全部的指头,哦,应该是找了很多XX家之后,下令当年10月4日的后一天是10月15日,同时规定在原先四年一闰的基础上,100的整数倍年不是闰年,但400的整数倍年又是闰年。新的历法改名为格里高利历。) |3 m. L6 ]3 R& R
8 ~' E3 r; g5 _* _& {为了计算转换儒略历和格里高利历,一个法国的教会学者Joseph Justus Scaliger给出了这个公式。“儒略日”中的儒略,是他老爸的名字。7 ~4 M0 t/ p) M; `) h
% O3 @9 {) |+ B: ~
哦,原来的文献中用的是儒略历日期,要算儒略日是这样的:
3 s! _% s" F1 N i" f
- Q' t0 e" O) y% x6 j![]()
; X. t* ^+ g6 Z+ C% P
2 B* Y! k9 k: C. b2 X) ]6 h从儒略日转格里高利历,也有一组公式,这里有:# E6 V8 U. e8 x- g
) |4 F% T9 d3 W1 Q) I* T其实这些偏差,在儒略历启用之前是有人知道的。但是,始皇三十五年的某一天,一个罗马士兵在西西里岛上,拔出刀来,朝一个老人身上刺下去。这一刺,西方的科技文明停滞了一千多年。来自群组: 软件人家 |
评分
-
查看全部评分
|