Year 10,000 problem

Year 10,000 problem

The Year 10,000 problem, or Y10K, is the class of all potential software bugs that may emerge should the need to express years with five digits arise. The problem can have discernible effects today, but is also sometimes mentioned because of its humorous connotations.

Practical relevance

Historical and technological trends suggest that in the actual year 10,000 it is unlikely that any of the data processing technology or software in use today will still be active, or that the present Gregorian calendar system will even still be in use. However, five-digit years are already a problem today for some forward-looking analysis programs, such as software that examines proposals for the long-term handling of nuclear waste. [cite web|url=http://www.publicinterestpolling.com/alookback.htm|work=American Talk Issues|title=Millennium Bug: New Y2K Survey Finds Americans Ready To Do Their Bit-Because They Don't Trust Government or Business|publisher=Market Strategies, Inc.|author=Alan F. Kay and Hazel Henderson|date=September 1998]

Problems with date-handling programs

Many date-handling programs or routines created prior to the recognition of the Y2K problem only used the last two digits of a year for storage and calculation, such as "60" for 1960. The routines would then either add the constant 1900 to the result, or even just insert the text string "19" in front of the result when displaying it, causing the year 2000 to be displayed or interpreted as 1800, 1900, 19100, or 100. Although this was often done to preserve what was at the time precious storage and memory space—reasons now unlikely to be relevant—it was also done as a mirror of cultural practice (saying "the '60s" instead of "the 1960s", for example) or to convey information in a limited display space.

Since (barring yet-unforeseen breakthroughs in life extension, geriatrics, cryonics or time travel) no one alive today nor their imaginably near predecessor or successor generations will ever experience anything but a four-digit Gregorian year, there is a strongly-ingrained cultural inclination to format years in a way that only considers their last four digits, which is likely to cause years greater than 9999 to be presented or stored incorrectly.

Examples

This problem can be seen in the spreadsheet program Microsoft Excel through at least the Office Excel 2007 release, which stores dates as the number of days since 31 December 1899 (day 1 is 1900-01-01), and the database program Microsoft Access, which stores dates as the number of days since 30 December 1899 (day 1 is 1899-12-31). In either application, a date value of 2958465 will be correctly formatted as "31 December 9999" but adding 1 to that to step over to the expected date of "1 January 10000" will cause a formatting error; in Excel 2000, for example, it will be displayed in the cell as a series of "#" characters. Excel also cannot automatically convert date-formatted strings such as "12/12/2007" to dates if the year exceeds 9999; "12/12/9999" is automatically converted to a date when entered into a cell, but "12/12/10000" is not.

The open source OpenOffice.org Calc program is able to display dates beyond the year 9999 correctly with 5 digit years, but at least through version 2.4 falls victim to the Year 32,768 problem: "31 December 32767" is the highest available date it can properly display. 32767, or 215-1, is the highest positive number that can be represented using a 16-bit signed integer, adding one to this value causes it to overflow, and Calc interprets the year as a large negative number, "1 January -32768".

The GNU Fortran compiler, g77, makes reference in run-time environment limits to year 10000 (Y10K) problems when using intrinsic functions with this compiler suite. The problem is simply stated as, "Most intrinsics returning, or computing values based on, date information are prone to Year-10000 (Y10K) problems, due to supporting only 4 digits for the year." The failure mode suggested in all of the intrinsic functions is that, "Programs making use of this intrinsic might not be Year 10000 (Y10K) compliant. For example, the date might appear, to such programs, to wrap around (change from a larger value to a smaller one) as of the Year 10000." [cite web|url=http://gcc.gnu.org/onlinedocs/gcc-3.4.6/g77/Year-10000-_0028Y10K_0029-Problems.html#Year-10000-_0028Y10K_0029-Problems|title=Year 10000 (Y10K) Problems]

Problems with data representation

Unlike the Y2K problem, where significant digits were omitted from the stored values of years, the Year 10,000 problem does not require updating old records (assuming they are already Y2K compliant), since all four significant digits are present. It will only require that record storage in decimal will be able to store five digits.

There is, however, a potential problem with record sets that make use of lexical sorting. For example, representations of dates in the range 10,000-19,999 could appear adjacent to dates in the range 1000-1999 rather than after the year 9999.

Mitigation

The Long Now Foundation is attempting to foster the custom of writing years with five digits, so that the year 2000 would be written as "02000". This would preempt the Year 10,000 problem, but would in turn be susceptible to a "Year 100,000 problem".

The Internet Kermit Service Daemon (IKSD) uses a 5-digit field for the year in the Database Record Format: "Date-time fields are right-adjusted within a field of 18 with the leading blank reserved for Y10K". [cite web|url=http://www.columbia.edu/kermit/ftp/c-kermit/iksd.txt|title=IKSD - The Internet Kermit Service Daemon|publisher=Columbia University|date=12 Dec 2001]

Humorous references

In the months leading up to the Year 2000 problem, the Year 10,000 problem was given humorous exposure in such forms as the April Fool's Day RFC 2550. [cite web
url=http://tools.ietf.org/html/rfc2550
title=RFC 2550 - Y10K and Beyond
publisher=The Internet Society (1999)
date=1 April 1999
This is one of a series of April Fool's Day RFCs, but still contains many useful ideas.
]

ee also

*Holocene calendar
*Long Now Foundation
*System time
*Year 2000 problem
*Year 2038 problem
*Time formatting and storage bugs

References

Further reading

*cite web|title=The Y10K Problem, Pascal's Wager, and Petersberg|url=http://www.mathpages.com/home/kmath200.htm|work=MathPages: Probability and Statistics — MathPages notes a similarity between the Y10K problem and both Pascal's wager and the St. Petersburg paradox, stating that the cost of fixing the various Y10K, Y100K, and successive problems is increased in direct proportion to the remoteness of the date, and that therefore each problem should in fact be given equal weight.
*cite web|url=http://www.templetons.com/brad/y10k.html|title=Computer systems worry over pending "year 10,000" problem|author=Brad Templeton — Templeton hypothesizes the impact of the Year 10000 problem.
*cite news|title=Beyond Year 2000 Compliance: Year 10,000 Compliance|url=http://www.recapinc.com/aprecap_S97_year10000.htm|work=A/P Recap|author=
*cite web|url=http://www.stsc.hill.af.mil/crosstalk/1996/11/xt96d11k.asp|title=The Year 10,000 Problem: It's Not Too Late to Start|author=Lorin May


Wikimedia Foundation. 2010.

Игры ⚽ Поможем написать реферат

Look at other dictionaries:

  • Year 2000 problem — Y2K redirects here. For other uses, see Y2K (disambiguation). The (French) sign reads 3 January 1900 instead of 3 January 2000 The Year 2000 problem (also known as the Y2K problem, the Millennium bug, the Y2K bug, or simply Y2K) was a problem for …   Wikipedia

  • Year 2038 problem — The year 2038 problem (also known as Unix Millennium bug , or Y2K38 by analogy to the Y2K problem) may cause some computer software to fail before or in the year 2038. The problem affects all software and systems that store system time as a… …   Wikipedia

  • Year 1900 problem — The year 1900 problem is a problem understanding which century before or after year 1900 an event occurred. Unlike the year 2000 problem, it is not a problem tied to computer software alone, since the problem existed before electronic computers… …   Wikipedia

  • Year 2007 problem — The Year 2007 problem also known as Y2K7 (or DST07) is an issue caused by a US mandated change to daylight saving time, which has repercussions in the computer industry.cite web | date = 2007 01 29 | accessdate = 2007 03 01 | title = Daylight… …   Wikipedia

  • Problem solving — forms part of thinking. Considered the most complex of all intellectual functions, problem solving has been defined as higher order cognitive process that requires the modulation and control of more routine or fundamental skills (Goldstein Levin …   Wikipedia

  • Year 2000 problem — Passage informatique à l an 2000 Le passage informatique à l an 2000, couramment appelé bug de l an 2000 ou bogue de l an 2000 (ou Y2K aux États Unis), était un ensemble de problèmes de programmation portant sur le format de la date dans les… …   Wikipédia en Français

  • Problem Boy — Armin van Buuren 2007 in New York Armin van Buuren (* 25. Dezember 1976 in Leiden, Niederlande) ist ein niederländischer Trance DJ und Produzent. Inhaltsverzeichnis 1 …   Deutsch Wikipedia

  • Problem Child (1990 film) — Infobox Film name = Problem Child caption = Theatrical release poster director = Dennis Dugan producer = Robert Simonds writer = Scott Alexander Larry Karaszewski starring = John Ritter Jack Warden Michael Oliver Gilbert Gottfried Amy Yasbeck… …   Wikipedia

  • Year of the Dolphin — The year 2007 (extended to 2008) [ [http://www.yod2007.org/ Year of the Dolphin homepage] ] has been declared as (International) Year of the Dolphin by the United Nations and United Nations Environment Programme (UNEP). [ [http://www.yod2007.org… …   Wikipedia

  • Fermi problem — In physics, particularly in physics education, a Fermi problem, Fermi question, or Fermi estimate is an estimation problem designed to teach dimensional analysis, approximation, and the importance of clearly identifying one s assumptions. Named… …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”