Fun_People Archive
7 Apr
Bug report... - Y2K Classics


Content-Type: text/plain
Mime-Version: 1.0 (NeXT Mail 3.3 v118.2)
From: Peter Langston <psl>
Date: Wed,  7 Apr 99 11:52:08 -0700
To: Fun_People
Precedence: bulk
Subject: Bug report... - Y2K Classics

X-Lib-of-Cong-ISSN: 1098-7649
X-http://www.langston.com/psl-bin/Fun_People.cgi
Forwarded-by: David H Elrod <dhelrod@rivendell.com>

[The following was taken from an actual bug report that I have seen myself.
 It shows an edited bug report from a customer and an edited response. I did
 the editing, to protect the customer and company involved.  - dhelrod]

CUSTOMER BUG REPORT:
  The [...]Library service "incorrectly"  assumes  the  year 2000 is a leap
  year.


RESPONSE:

  Thank you for your forward-looking bug report.

  Various system services, such as [the one you reported] assume that the
  year 2000 will be a leap year. Although one can never be sure of what will
  happen at some future time, there is strong historical precedent for
  presuming that the present Gregorian calendar will still be in affect by
  the year 2000. Since we also hope that [our system] will still be around
  by then, we have chosen to adhere to these precedents.

  The purpose of a calendar is to reckon time in advance, to show how many
  days have to elapse until a certain event takes place in the future, such
  as the harvest or the release of [the next version of our system]. The
  earliest calendars, naturally, were crude and tended to be based upon the
  seasons or the lunar cycle.

  The calendar of the Assyrians, for example, was based upon the phases of
  the moon. They knew that a lunation (the time from one full moon to the
  next) was 29 1/2 days long, so their lunar year had a duration of 354
  days. This fell short of the solar year by about 11 days.  (The exact time
  for the solar year is approximately 365 days, 5 hours, 48 minutes, and 46
  seconds.) After 3 years, such a lunar calendar would be off by a whole
  month, so the Assyrians added an extra month from time to time to keep
  their calendar in synchronization with the seasons.

  The best approximation that was possible in antiquity was a 19-year
  period, with 7 of these 19 years having 13 months (leap months). This
  scheme was adopted as the basis for the religious calendar used by the
  Jews. (The Arabs also used this calendar until Mohammed forbade shifting
  from 12 months to 13 months.)

  When Rome emerged as a world power, the difficulties of making a calendar
  were well known, but the Romans complicated their lives because of their
  superstition that even numbers were unlucky. Hence their months were 29
  or 31 days long, with the exception of February, which had 28 days. Every
  second year, the Roman calendar included an extra month called Mercedonius
  of 22 or 23 days to keep up with the solar year.

  Even this algorithm was very poor, so that in 45 BC, Caesar, advised by
  the astronomer Sosigenes, ordered a sweeping reform. By imperial decree,
  one year was made 445 days long to bring the calendar back in step with
  the seasons. The new calendar, similar to the one we now use was called
  the Julian calendar (named after Julius Caesar). It's months were 30 or
  31 days in length and every fourth year was made a leap year (having 366
  days). Caesar also decreed that the year would start with the first of
  January, not the vernal equinox in late March.

  Caesar's year was 11 1/2 minutes short of the calculations recommended by
  Sosigenes and eventually the date of the vernal equinox began to drift.
  Roger Bacon became alarmed and sent a note to Pope Clement IV, who
  apparently was not impressed. Pope Sixtus IV later became convinced that
  another reform was needed and called the German astronomer, Regiomontanus,
  to Rome to advise him. Unfortunately, Regiomontanus died of the plague
  shortly thereafter and the plans died as well.

  In 1545, the Council of Trent authorized Pope Gregory XIII to reform the
  calendar once more. Most of the mathematical work was done by Father
  Christopher Clavius, S.J. The immediate correction that was adopted was
  that Thursday, October 4, 1582 was to be the last day of the Julian
  calendar. The next day was Friday, with the date of October 15. For long
  range accuracy, a formula suggested by the Vatican librarian Aloysius
  Giglio was adopted. It said that every fourth year is a leap year except
  for century years that are not divisible by 400. Thus 1700, 1800 and 1900
  would not be leap years, but 2000 would be a leap year since 2000 is
  divisible by 400. This rule eliminates 3 leap years every 4 centuries,
  making the calendar sufficiently correct for most ordinary purposes. This
  calendar is known as the Gregorian calendar and is the one that we now
  use today.  (It is interesting to note that in 1582, all the Protestant
  princes ignored the papal decree and so many countries continued to use
  the Julian calendar until either 1698 or 1752. In Russia, it needed the
  revolution to introduce the Gregorian calendar in 1918.)

  This explains why [our system] chooses to treat the year 2000 as a leap
  year.

  Despite the great accuracy of the Gregorian calendar, it still falls
  behind very slightly every few years. If you are very concerned about this
  problem, we suggest that you tune in short wave radio station WWV, which
  broadcasts official time signals for use in the United States. About once
  every 3 years, they declare a leap second at which time you should be
  careful to adjust your system clock. If you have trouble picking up their
  signals, we suggest you purchase an atomic clock (not manufactured by [our
  company] and not a [system] option at this time).


prev [=] prev © 1999 Peter Langston []