天文学有一种连续纪日的儒略日(JD),它以儒略历公元前4713年1月1日的GMT正午为第0日的开始。还有一种简化儒略日(MJD): MJD=JD-2400000.5 MJD的第0日是从公历1858年11月17日的GMT零时开始的。
需要注意:儒略历公元前4713年1月1日相当于公历公元前4713年11月24日。 儒略日(Julian day)是指由公元前4713年1月1日,协调世界时中午12时开始所经过的天数,多为天文学家采用,用以作为天文学的单一历法,把不同历法的年表统一起来。 儒略日是一种不用年月的长期纪日法,简写为JD。是由法国学者Joseph Justus Scliger(1540-1609)在1583年所创,这名称是为了纪念他的父亲意大利学者Julius Caesar Scaliger(1484-1558)。
儒略日的起点订在公元前4713年(天文学上记为 -4712 年)1月1日格林威治时间平午(世界时12:00),即JD 0 指定为 4713 B.C. 1月1日12:00 UT到4713 B.C. 1月2日12:00 UT的24小时。每一天赋予了一个唯一的数字,顺数而下,如:1996年1月1日12:00:00的儒略日是2450084。这个日期是考虑了太阳、月亮的运行周期,以及当时收税的间隔而订出来的。Joseph Scliger定义儒略周期为7980年,是因28、19、15的最小公倍数为281915=7980。其中: 28年为一太阳周期(solar cycle),经过一太阳周期,则星期的日序与月的日序会重复。 19年为一太阴周期,或称默冬章(Metonic cycle),因235朔望月=19回归年,经过一太阴周期则阴历月年的日序重复。 15年为一小纪(indiction cycle),此为罗马皇帝君士坦丁(Constantine)所颁,每15年评定财产价值以供课税,成为古罗马用的一个纪元单位, 故以7980年为一儒略周期,而所选的起点公元前4713年,则是这三个循环周期同时开始的最近年份。 以儒略日计日是为方便计算年代相隔久远或不同历法的两事件所间隔的日数。 由于儒略日数字位数太多,国际天文学联合会于1973年采用简化儒略日(MJD),其定义为 MJD = JD - 2400000.5。MJD相应的起点是1858年11月17日世界时0时。
儒略日的计算 儒略日= K - 32075 + 1461 * (I + 4800 + (J-14)/12)/4+367*(J-2-(J-14)/12*12)/12-3*((I+4900+(J-14)/12)/100)/4
现把此计算公式整理如下。
比如:2009/1/1转换为 Julian day 应为 2454833 (共7码
)
Code
///summary
///產生日期的Julianday
summary
///paramname="year"年/param
///paramname="month"月/param
///paramname="day"日/param
///returnsJulianday/returns
privatelongjulian(intyear,intmonth,intday)
{
longjy=year,jm=month,jd=day;
if(jy0)
{
jy=jy+1;
}
if(month2)
{
jm=jm+1;
}
else
{
jm=jm+13;
jy=jy-1;
}
longjul=Convert.ToInt64(Math.Floor(365.25*jy)+Math.Floor(30.6001*jm)+jd+1720995.0);
if(jy1582jm10jd15)
{
returnjul;
}
else
{
longja=Convert.ToInt64(0.01*jy);
jul=Convert.ToInt64(jul+2-ja+0.25*ja);
returnjul;
}
本文主要是介绍c# Julian day 儒略日计算公式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
转载于:https://www.cnblogs.com/gnhao/archive/2013/01/20/2868725.html
这篇关于c# Julian day 儒略日计算公式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!