Traditional Culture Encyclopedia - The 24 Solar Terms - Who has the C language program code to convert the solar calendar into the lunar calendar?
Who has the C language program code to convert the solar calendar into the lunar calendar?
Header file generated by lunar calendar information extractor (limited to the space here, the span is only 10 year)
/*****************************************************
*? Lunar calendar information (look-up table) *
*? Generation time: 20 14/ 12/25? *
*****************************************************/
#ifndef? _LUNARDATA_H
# Definition? _LUNARDATA_H
# Definition? Start year? 1600? //Define the data start year (Gregorian calendar)
# Definition? The end of the year? 16 10? //Define the year when the data ends (excluding this year)
Short? iPreLeapIndex =- 1; //The lunar leap month index before the start year corresponds to the serial number in iPreMonth. If it is-1, there is no leap month.
//Starting from October of the lunar calendar one year before the start year, the first day of each month corresponds to the ordinal number of the year in the start year.
//Ordinal numbers less than zero mean before the start year.
Short? ipremont[3]= {-44,- 15, 15 };
//The ordinal number of the first day of the first lunar month in the Gregorian calendar year (the ordinal number of the year specifies New Year's Day as 0).
Not signed? Charles? uLunarNewYearOrdinal[ 10]= {
44,33,22,4 1,30,48,37,27,46,34? // 1600- 1609
};
//Month size array, from the first month of "START_YEAR" to (leap)1February of the year before "END_YEAR".
//Twelve or thirteen months of each year are represented by two bytes, with the highest two digits set to 10, followed by leap months, from 1 month to1February. The youngest month comes first,
// 1? 00 or 1? x? x? x? x? x? x? x? x? x? x? x? x? x
// 1? 0 1 February is 0,1March is1. From 1 month to 1 February, the number of days in a month is 0, and the number of days in a month is1.
//Note that if there is no leap month, the month position is 12 and the total length is 15. If there is a leap month, the month position is 13, and the total length is 16.
Not signed? Short? LunarMonthDX[ 10]={
0x4A5D,0x492D,0xB92B,0x4A95,0xB695,0x46AA,0x4AD5,0xAAB5,0x44BA,0x4A5B? // 1600- 1609
};
//leap month array, with 4 bits representing leap month information of a lunar year, and 1 byte representing two adjacent years.
//? x? x? x? xx? x? x? x
//? The first year, the second year.
Not signed? Charles? LeapMonth[5]={
0x00,0x20,0x90,0x06,0x00? // 1600- 1609
};
//24 solar terms array, represented by one year 12 bytes, that is, one byte per month (note: this compression algorithm is suitable for data after 1600).
//For example, the solar terms of 190 1 year are:
// 1 month? February, March, April, May, June? July August September 65438+ October? 1 1 month? 65438+ February
//? 6,? 2 1,? 4,? 19,6,? 2 1,5,? 2 1,6,? 22,6,? 22,8,? 23,8,? 24,8,? 24,8,? 24,8,? 23,8,? 22
//? 9,? 6, 1 1,? 4,9,6, 10,? 6,9,? 7,9,? 7,7,? 8,7,? 9,7,? 9,7,? 9,7,? 8,7,? 15
//slight cold? Great cold? The beginning of spring? Rain? Scared? Equinox? Qingming? Grain Rain? Long summer? Little man? Mangzhong? Summer Solstice? A little hot? Summer heat? Beginning of autumn? Summer? White deer? Autumn equinox? Cold dew? First frost? Beginning of winter? Xiaoxue? Heavy snow? Winter solstice
//In this way, the data corresponding to two solar terms per month is less than 16. The following table can be obtained by storing the data of the first solar term in the high position and the data of the second solar term in the low position with one byte:
Not signed? Charles? SolarTerms[ 120]={
0x96,0x96,0x87,0x97,0x87,0x97,0x87,0x96,0x96,0x96,0x96,0x96,// 1600
0xA6,0xA5,0x87,0x87,0x87,0x87,0x87,0x97,0x96,0x97,0x96,0x96,? // 160 1
0x96,0xA5,0x88,0x87,0x88,0x87,0x87,0x87,0x96,0x87,0x96,0x97,? // 1602
0x96,0xA6,0x78,0x87,0x78,0x87,0x88,0x87,0x97,0x87,0x96,0x87,? // 1603
0x96,0x96,0x87,0x97,0x87,0x97,0x87,0x96,0x96,0x96,0xA6,0x96,? // 1604
0xA6,0xA5,0x87,0x87,0x87,0x87,0x87,0x97,0x96,0x96,0x96,0x96,? // 1605
0x96,0xA5,0x88,0x87,0x88,0x87,0x87,0x87,0x96,0x87,0x96,0x97,? // 1606
0x96,0xA5,0x78,0x87,0x78,0x87,0x88,0x87,0x97,0x87,0x96,0x87,? // 1607
0x96,0x96,0x87,0x97,0x87,0x96,0x87,0x96,0x96,0x96,0xA6,0x96,? // 1608
0xA6,0xA5,0x87,0x87,0x87,0x87,0x87,0x97,0x96,0x96,0x96,0x96? // 1609
};
//Count nine, plum blossom, plum blossom and dog days every year (based on New Year's Day of that year).
//The first calendar year is 39 years (applicable after 1600).
//In the array, each row represents one year, with four years, nine years, five years, nine years ... omitted, and the difference between every nine is 9 days. Similarly, two or nine are omitted, and the medium amount is 10 days after the initial stage. Correspondence is as follows (omitted in parentheses):
//Sanjiu? (49? Five or nine? Sixty-nine Seven or nine? Eight or nine? 99)? Become a plum? No plums? First squat? (alto)? Last autumn? Nineteen? (29) Note: September 19 is the winter solstice.
Not signed? Short? extreme season[60]= {
8, 165, 190, 199,2 19,355,7, 159, 196, 193,223,355,? // 1600- 160 1
7, 164, 19 1, 198,2 18,355,8, 159, 198, 193,223,355,? // 1602- 1603
8, 164, 193, 198,2 18,355,7, 158, 199,202,222,355,? // 1604- 1605
7, 163, 194, 197,227,355,8, 158, 189,202,222,355,? // 1606- 1607
8, 163, 196, 197,227,355,7, 167, 190,20 1,22 1,354? // 1608- 1609
};
#endif? //_LUNARDATA_H
- Previous article:When is 2020? According to the solar terms, how to calculate in a year?
- Next article:Judging people's fate from birth solar terms
- Related articles
- How to adjust the four-wheel pedal throttle of Jiefang brand?
- Cold dew poetry
- Why are the vernal equinox, autumnal equinox and winter solstice determined by crops?
- What does the po420 fault code of Great Wall Jiayu Automobile stand for?
- Ancient classical poems describing the solar terms of heavy snow.
- What time are the third and fourth bases?
- Solar terms for health, beginning of autumn, a phoenix tree, a report of autumn, Yang disappear Yin long to raise income.
- A kind word from Goddess's Day birthday.
- Why is it called rain?
- What to eat in heavy snow solar terms: how to keep healthy in heavy snow solar terms