Jump to content

Binary prefix

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Dacoutts (talk | contribs) at 13:06, 29 August 2009 (External links). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

In computing, a binary prefix is a set of letters that precede a unit of measure (such as a byte) to indicate multiplication by a power of two. In certain contexts in computing, such as computer memory sizes, units of information storage and communication traffic (Byte) have traditionally been reported in multiples of powers of two. The term binary prefix is intended to differentiate usage of certain symbolic abbreviations (for example, k or kilo) from the SI prefixes, which are always decimal (power of 10) multiples.[1]

The first few binary multipliers, e.g., 1024 (210), 1048576 (220), are close in value to SI prefixes, such as kilo (1000 = 103) and mega (1000000 = 106), respectively. Therefore it became common practice amongst computer professionals to use these prefixes for the binary multiples – for example, to use the symbol M (mega) to mean 1048576 instead of 1000000. However, when used with SI units and in some other contexts, these prefixes retain their decimal meanings. Certain disciplines of computing have always used these prefixes as decimal multipliers, for example, when specifying quantities of bits transmitted on a serial transmission medium. This has led to ambiguity in intended use of these prefixes.[2]

In 1999, following recommendations by the International Union of Pure and Applied Chemistry (IUPAC) in 1995[3] and National Institute of Standards and Technology (NIST), the standards organization known as the International Electrotechnical Commission (IEC) adopted a set of distinct prefixes (cf. IEC 60027), e.g., kibi (symbol Ki, from "kilobinary")[2] and mebi (symbol Mi, from "megabinary"), to indicate binary multipliers. The system used the multiplier 1024 (210), rather than 1000 (103) as in the SI system, to arrive at successively larger prefixes. Under this recommendation, the SI prefixes should only be used in the decimal sense: kilobyte and megabyte denote one thousand bytes and one million bytes respectively, while kibibyte and mebibyte denote 1024 bytes and 1048576 bytes respectively. This recommendation has since been adopted by some other leading national and international standards bodies, that now prescribe that the prefixes k, M and G should always refer to powers of ten, even in the context of information technology.[4][2][5][6] Notwithstanding the availability of the new binary prefixes and their unambiguous meaning, they have seen limited adoption in practice; the use of K (or k), M and G as binary multipliers when denoting the capacity of solid‑state memory like random access memory (RAM) remains a ubiquitous industry practice.[7]

History

Early usage

Early computers used one of two addressing methods to access the system memory; binary (base-2) or decimal (base-10). For instance, the IBM 701 (1952) used binary and could address 2,048 36-bit words, while the IBM 702 (1953) used decimal and could address 10,000 7-bit words.

By the mid 1960s, binary addressing had become the standard architecture in computer design. The computer system documentation would specify the memory size with an exact number such as 32768, 65536 or 131072 words of storage (all powers of 2). There were several methods used to abbreviate these quantities. The use of K in the binary sense as in a "32K core" can be found as early as 1959[8][9] Gene Amdahl's seminal 1964 article on IBM System/360 used 1K to mean 1024.[10] This style was used by other computer vendors, the CDC 7600 System Description (1968) made extensive use of K as 1024.[11] Another style was to truncate the last 3 digits and append K. The exact values 32768, 65536 and 131072 would then become 32K, 65K and 131K.[12] (If 32768 were instead rounded off, it would be 33K; if K = 1024 were used, 65,536 would become "64K".) This style was used from about 1965 to 1975.

These two styles (K = 1024 and truncation) were used loosely around the same time, sometimes by the same company. (In discussions of binary-addressed memories, the exact size was evident from context.) The HP 21MX real-time computer (1974) denoted 196608 as 196K and 1048576 as 1 M,[13] while the HP 3000 business computer (1973) could have 64K, 96K, or 128K bytes of memory.[14]

The terms Kbit, Kbyte, Mbit and Mbyte started to be used as binary units in the early 1970s.[15] Most memory capacities were expressed in K, even when M could have been used: The IBM System/370 Model 158 brochure (1972) had the following: "Real storage capacity is available in 512K increments ranging from 512K to 2,048K bytes."[16] Megabyte was used to describe the 22-bit addressing of DEC PDP-11/70 (1975)[17] and gigabyte the 30-bit addressing DEC VAX-11/780 (1977).

By the mid 1970s it was common to see K (e.g. Kbyte) meaning 1024 and the occasional M (e.g. Mbyte) as 1048576 for words or bytes of computer memory (RAM) while K and M were commonly used with their decimal meaning for disk storage. In the 1980s the term G (e.g. GB) with decimal meaning was commonly applied to disk storage while M in its binary meaning became common for computer memory. In the 1990s G in its binary meaning became common usage for computer memory. The first TB hard disk drive (terabyte, decimal meaning) was introduced in 2007.[18]

The dual use of these prefixes as both decimal and binary quantities was defined in standards and dictionaries. The 1986 ANSI/IEEE Std 1084-1986[19] defined dual uses for kilo and mega.

kilo (K). (1) A prefix indicating 1000. (2) In statements involving size of computer storage, a prefix indicating 210, or 1024.

mega (M). (1) A prefix indicating one million. (2) In statements involving size of computer storage, a prefix indicating 220, or 1048576.

The binary units Kbyte and Mbyte were formally defined in ANSI/IEEE Std 1212-1991.[20] The terms Kbyte, Mbyte, and Gbyte are found in the trade press and in IEEE journals. "Gigabyte" was formally defined in IEEE Std 610.10-1994 as either 1000000000 or 230 bytes.[21] Kilobyte, Kbyte, and KB are equivalent units and all are defined in the current standard, IEEE 100-2000.[22]

The industry has coped with the dual definitions because system memory (RAM) typically uses the binary meaning while disk storage uses the decimal meaning. There are exceptions like diskettes and CDs. There are no SI units for computer storage capacity but the decimal prefix meanings of KB, MB, and GB are often referred to as SI prefixes.

Suggestions for new prefixes

While computer scientists typically used k to mean 1000, they recognized the convenience that would result from working with powers of 1024 and the confusion that resulted from using the same abbreviation for two definitions.[23] Several proposals for unique symbols were made in 1968. (At the time, memory size was small, and only K was in widespread use.) Donald Morrison proposed to use the Greek letter κ to denote 1024, κ² to denote 1024×1024, and so on.[23] Wallace Givens responded with a proposal to use bK as an abbreviation for 1024 and bK2 or bK² for 1024×1024, though he noted that neither the Greek letter nor lowercase letter b would be easy to reproduce on computer printers of the day.[24] Bruce A. Martin further proposed that the units be abandoned altogether, and the letter B be used as a binary exponent, similar to E notation, to create shorthands like 3B20 for 3×220[25] None of these gained much acceptance, and capitalization of the letter K became the de facto standard for binary notation, though this could not be extended to higher powers. Later, as the discrepancy between the two systems increased, more proposals for unique units were made. In 1996, Markus Kuhn proposed a system of units with di prefixes, like the "dikilobyte" (K₂B or K2B).[26]

The binary set of prefixes seem to have been first proposed[27] by the IUPAC Interdivisional Committee on Nomenclature and Symbols in 1995. At that time, it was proposed that the terms kilobyte and megabyte be used only for 103 bytes and 106 bytes respectively. The new prefixes "kibi" (kilobinary), "mebi" (megabinary) and "gibi" (gigabinary) were also proposed at the time, and the proposed symbols for the prefixes were "kb", "Mb" and "Gb" respectively, rather than "Ki", "Mi" and "Gi".[3] The proposal was not accepted at the time.

The IEEE had begun to collaborate with the ISO and IEC to find acceptable names for binary prefixes. The IEC proposed "kibi", "mebi", "gibi" and "tebi", with the prefixes "Ki", "Mi", "Gi" and "Ti" respectively, in 1996.[28] The IEEE decided that IEEE standards would use the prefixes "kilo" etc. with their metric definitions, allowing the base-two definitions to be used in an interim period as long as such usage was explicitly pointed out on a case-by-case basis.[29]

In January 1999, the IEC published the first international standard (IEC 60027-2 Amendment 2) with the new prefixes, extended up to "pebi" (Pi) and "exbi" (Ei).[30][31]

Proposals for alternative sets of prefixes have continued following the introduction of these prefixes as well. Donald Knuth, who uses decimal notation like 1 MB = 1000 kB,[32] has proposed that the powers of 1024 be designated as "large kilobytes" and "large megabytes" (abbreviated KKB and MMB, as "doubling the letter connotes both binary-ness and large-ness").[27][32]

Prefixes

IEC prefix Representations SI prefix names in binary use
Name Symbol Base 2 Base 1024 Value Base 10 Name Symbol
kibi Ki 210 10241 1024 ~1.02×10^3 kilo k, K
mebi Mi 220 10242 1048576 ~1.05×10^6 mega M
gibi Gi 230 10243 1073741824 ~1.07×10^9 giga G
tebi Ti 240 10244 1099511627776 ~1.10×10^12 tera T
pebi Pi 250 10245 1125899906842624 ~1.13×10^15 peta P
exbi Ei 260 10246 1152921504606846976 ~1.15×10^18 exa E
zebi Zi 270 10247 1180591620717411303424 ~1.18×10^21 zetta Z
yobi Yi 280 10248 1208925819614629174706176 ~1.21×10^24 yotta Y

SI prefix names in binary use

Quantities that are multiples of the unit by a power of 2 are indicated using similarly-valued SI prefixes, such as using kilo (the SI prefix for 1000) to indicate 210=1024. Byte multiples using binary powers up to yottabyte are given by the on-line computing dictionary FOLDOC.[33]

The one-letter symbols are identical to SI prefixes, except for "K", which is used interchangeably with "k" (in SI, only the lower-case "k" represents 1000).

These prefixes are in common use in contexts such as file and memory sizes. The names and values of the SI prefixes were defined in the 1960 SI standard, with powers-of-1000 values. Standard dictionaries do recognize the binary use of these prefixes.[34][35] Oxford online dictionary defines, for example, megabyte as: "Computing a unit of information equal to one million or (strictly) 1048576bytes."[36]

IEC standard prefixes

In January 1999, the International Electrotechnical Commission introduced in an addendum to IEC 60027-2 the prefixes kibi (kibibyte), mebi, gibi, etc., and the symbols Ki, Mi, Gi, etc. to specify binary multiples of a quantity and eliminate the ambiguity with their SI meanings.[37] The names for the new standard are derived from the original SI prefixes followed by "binary", such as "kilobinary", and can be shortened to a prefix like "kibi". The new standard also clarifies that, from the point of view of the IEC, the SI prefixes will remain to have their base-10 meaning and never have a base-2 meaning.

The second edition of the standard[38] defined them only up to exbi,[39] but in 2005, the third edition added prefixes zebi and yobi, thus matching all SI prefixes with their binary counterparts.[40]

On 19 March 2005 the IEEE standard IEEE 1541-2002 (Prefixes for Binary Multiples) was elevated to a full-use standard by the IEEE Standards Association after a two-year trial period.[41] Nevertheless, as of April 2008, the IEEE Publications division does not use the IEC prefixes in its major magazines such as Spectrum[42] or Computer.[43]

The harmonized ISO/IEC IEC 80000-13:2008 standard cancels and replaces subclauses 3.8 and 3.9 of IEC 60027-2:2005 (those defining Prefixes for binary multiples). The only significant change is the addition of explicit definitions for some quantities. [44]

BIPM (the International Bureau of Weights and Measures which maintains SI) expressly prohibits the use of SI prefixes to denote powers of two, and recommends the use of the IEC prefixes as an alternative since computing units are not included in SI.[4]. The binary definition of the prefixes k, M, G etc is not permitted by the United States National Institute of Standards and Technology (NIST).[45]

Deviation between binary and decimal interpretations

The relative difference between the values in the binary and decimal interpretations increases, when using the SI prefixes, from 2.4% for kilo to over 20% for the yotta prefix.

This makes differentiating between the two unit interpretations increasingly important as larger data storage and transmission technologies are developed.

Prefix Bin ÷ Dec Dec ÷ Bin Percentage difference
kilo 1.024 0.9766 +2.4% or −2.3%
mega 1.049 0.9537 +4.9% or −4.6%
giga 1.074 0.9313 +7.4% or −6.9%
tera 1.100 0.9095 +10.0% or −9.1%
peta 1.126 0.8882 +12.6% or −11.2%
exa 1.153 0.8674 +15.3% or −13.3%
zetta 1.181 0.8470 +18.1% or −15.3%
yotta 1.209 0.8272 +20.9% or −17.3%

Example: 300 GB (300×109 B) ≅ 300×0.9313 GiB ≅ 279.4 GiB

Usage notes

In this section, the phrase "decimal unit" is used to denote "SI designation understood in its standard, decimal, power-of-1000 sense" and "binary unit" means "SI designation understood in its binary, power-of-1024 sense." B is the symbol for bytes (as per computer-industry standard IEEE 1541 and IEC 60027), while both bit (as per ISO/IEC 80000) and b (as per IEEE 1541-2002) are used as the symbol for bits.

Certain units are always understood as decimal even in computing contexts. For example, hertz (Hz), which is used to measure clock rates of electronic components, and bit/s, used to measure bit rate. So a 1 GHz processor performs 1000000000 clock ticks per second, a 128 kbit/s MP3 stream consumes 128,000 bits (16 kB, 15.625 KiB) per second, and a 1 Mbit/s Internet connection can transfer 1000000bits (125 kB, approx 122 KiB) per second, assuming an 8-bit byte, and no overhead.[46]

Pronunciation

It is suggested that in English, the first syllable of the name of the binary-multiple prefix should be pronounced in the same way as the first syllable of the name of the corresponding SI prefix, and that the second syllable should be pronounced as "bee."[2]

Files

Prior to the release of Mac OS (1984), file sizes were typically reported by the operating system in decimal digits without prefixes of any sort.[citation needed] Today, most operating systems are capable of reporting file sizes with prefixes.

Most Unix-like systems which use the ls command to display file sizes use powers of 1024 indicated as KB/MB. In Linux, the directory listing tool (ls) has options for decimal file size listings. Microsoft Windows reports file sizes in binary units but does not use IEC standard prefixes.

Computer memory

The 536,870,912 byte (512×220) capacity of these RAM modules is stated as "512 MB" on the label.

Measurements of most types of electronic memory such as RAM, ROM and Flash (large scale disk-like flash is sometimes an exception) are given in binary units, as they are made in power-of-two sizes. This is the most natural configuration for memory, as all combinations of their address lines map to a valid address, allowing easy aggregation into a larger contiguous block of memory.

JEDEC Solid State Technology Association, the semiconductor engineering standardization body of the Electronic Industries Alliance (EIA) in Standard 100B.01[6][47] continues to include definitions in the binary sense K, M and G as prefixes to units of semiconductor memory (see JEDEC memory standards), noting that these definitions are "only included to reflect common usage" and noting that "IEEE/ASTM SI 10-1997 states 'This practice frequently leads to confusion and is deprecated.'" All standards published by JEDEC use the common usage, including end-user packaging recommendations for memory chips.

Many computer programming tasks naturally reference memory in terms of powers of two. For example, a 16-bit pointer can reference at most 65,536 items (bytes, words, or other objects), or an operating system might map memory in terms of 4096-byte pages, in which case exactly 8192 pages could be allocated within 33554432bytes of hardware memory. It is convenient to informally express these numbers, respectively, as 64K items, or as 8K pages of 4 Kbytes (KiB) each within 32 MBytes (MiB) of memory. A programmer can easily mentally calculate that "8K × 4K is 32 meg" and get it exactly right, within this powers-of-two context. This convenience is likely one source of originally adapting "kilo" and "mega" into shorthand for 1024 and 1048576 as jargon within a segment of the industry.

Hard disk drives

HDD manufacturers mostly state capacity in decimal units. This usage has a long tradition, even predating the SI system of decimal prefixes adopted in 1960, as follows:

  • The first disk drive the IBM 350 (1950s) had 5 million 6 bit characters organized in 100 character sectors (i.e., blocks). This predates the SI system.
  • In the 1960s most disk drives used IBM's variable block length format (called, Count Key Data or "CKD").[48] Any block size could be specified up to the maximum track length. Blocks ("records" in IBM's terminology) of 88, 96, 880 and 960 were often used because they related to the fixed block size of punch cards. The drive capacity was usually stated in full track record blocking, for example, the 100 megabyte 3336 disk pack only achieved that capacity with a full track block size of 13,030 bytes.
  • CKD continued into the 1990s and perhaps into this day. In the 1970s and 1980s most drives were specified with unformatted tracks (the unformatted capacity) with the particular block size and formatted capacity a function of the controller design. For example, the ST412 of IBM PC/XT fame had an unformatted capacity of 12.75 MB (12.75×106 B) and with the Xebec controller and 512 byte blocks it formatted to and was advertised as a 10.0 MB (10.0×106 B) HDD. Other controllers supported other block sizes resulting in other formatted capacities.
  • The advent of intelligent interfaces (SCSI and IDE) in the early 1990s took the block size decision into the drive and virtually all chose 512 bytes, for no reason other than that was what IBM had chosen when they picked the Xebec controller for the PC/XT. Capacity continued to be specified by the HDD manufacturers with SI prefix definitions.

As of January 2007, most, if not all, HDD manufacturers continue to use decimal prefixes to identify capacity.[49]

Flash drives

USB Flash Drive and Flash-based memory cards like CompactFlash and Secure Digital are typically classified in "powers of two" multiples of decimal megabytes; for example, a "256 MB" card provides at least 256 million bytes (256000000), not 256×1024×1024 (268435456).[50] Although the devices usually have at least the expected byte capacity, each manufacturer allocates different portions of the device's ultimate capacity for such things as wear levelling.

Floppy drives

Floppy disk drive and media manufacturers use decimal units for unformatted recording capacity while most computer operating systems use binary units to measure the formatted capacity. The original IBM Personal Computer (1981) used a Tandon TM100 5¼ inch floppy disk drive. The single sided drive was rated at 250 kilobytes (unformatted) and the double sided version was rated at 500 kilobytes.[51]

A 5¼ inch diskette recorded at double density (MFM) will hold 6,250 bytes per track and has 40 tracks per side, yielding 250,000 bytes per side. To make it practical to record smaller blocks of data, the tracks are formatted into sectors with gaps between them. The gaps allow individual sectors to be recorded without overwriting adjacent sectors. Each sector also has additional header bytes to identify the sector.

With IBM PC-DOS 1.0 and 1.1, each track has 8 sectors of 512 bytes and this provides 163,840 bytes per side (8 × 512 × 40). The IBM user documentation referred to this as "160KB" for single sided diskette and "320KB" for double sided diskette.[52] Starting with PC-DOS 2.0 (1983), each track had 9 sectors of 512 bytes. The formatted capacity was increased to 184,320 bytes per side or 368,640 bytes per diskette. The IBM documentation referred to these as "180KB" and "360KB" diskettes. The same drives and media can have different capacities depending on format.[53]

On all diskettes the capacity available to the user will be smaller that the total number of sectors because some are reserved by the operating system for boot records or directory tables.

The IBM Personal Computer/AT (1984) had a new 5¼ inch disk drive that had 80 tracks per side, rotated at 360 rpm (versus 300 rpm) and had a new diskette media. The formatted capacity was 1228800 bytes or 1200 KB. (80 tracks × 15 sectors × 512 bytes × 2 sides)

The IBM PC Convertible (1986) used the 3½ inch diskettes. These were similar in recording technology to the original 5¼ inch drives except they had 80 tracks per side. The formatted capacity was 737,280 bytes or 720 KB. Apple used the same disk with a different recording technology, GCR, that gave a formatted capacity of 819,200 bytes or 800 KB. Apple referred to this as an "800K" disk.[54]

The last widely adopted diskette was the 3½ inch high density. This has twice the capacity as the 720 KB diskettes, 1474560 bytes or 1440 KB. The drive was marketed as 1.44 MB when a more accurate value would have been 1.4 MB (1.40625 MB). Some users have noticed the missing 0.04 MB and both Apple and Microsoft have support bulletins referring to them as 1.4 MB.[54][55] The 1200 KB 5¼ inch diskette was marketed as 1.2 MB (1.171875 MiB) without any controversy.

Optical discs

CD capacities are always given in binary units. A "700 MB" (or "80 minute") CD has a nominal capacity of about 700 MiB (approx 730 MB).[56] However, the capacities of other optical disc storage media like DVD, Blu-ray Disc, HD DVD are given in decimal units. A "4.7 GB" DVD has a nominal capacity of about 4.38 GiB.[57]

Buses

Bus clock speeds and therefore bandwidths are both given in decimal units. For example, "PC3200" memory on a double pumped bus, transferring 8 bytes per cycle running with a clock speed of 200 MHz = 200,000,000 cycles per second has a bandwidth of 200,000,000 × 2 × 8 = 3,200,000,000 B/s = 3.2 GB/s (about 2.98 GiB/s).

Software

As of 2008, most software does not distinguish symbols for binary and decimal units. The IEC binary naming convention has been adopted by some, but is not used universally.

The binary convention is supported by standardization bodies and technical organizations such as IEEE, CIPM, NIST, and SAE.[4][2][5][58] The new binary prefixes have also been adopted by the European Committee for Electrotechnical Standardization (CENELEC) as the harmonization document HD 60027-2:2003-03.[59] This document will be adopted as a European standard.[60]

Examples of software that use IEC standard prefixes (along with standard SI prefixes) include:

One of the stated goals of the introduction of the binary prefixes was "to preserve the SI prefixes as unambiguous decimal multipliers."[5] Programs such as fdisk/cfdisk, parted, and apt-get use SI prefixes with their decimal meaning.

Consumer confusion

In the early days of computers there was little or no consumer confusion because of the sophisticated nature of the consumers and the practice of computer manufacturers to specify their products with capacities in full precision, e.g., the 1968 IBM stated System 360 "Model 91s can accommodate up to 6 291 496 bytes of main storage."[82]

Hard disk drive manufacturers used MB, i.e. 106 bytes, to characterize their products as early as 1974.[83] By 1977, in its first edition, Disk/Trend, a leading hard disk drive industry marketing consultancy segmented the industry according to MBs (decimal sense) of capacity.[84]

The presentation of hard disk drive capacity by an operating system using MB in a binary sense appears no earlier than Macintosh Finder after 1984. Prior to that, on the systems that had a hard disk drive, capacity was presented in decimal digits with no prefix of any sort (e.g., MS/PC DOS CHKDSK command).

The following three images show the discrepancy of reporting the identical disk capacity on the manufacturer's packaging (160 GB), the Windows XP disk manager (149.05 GB), and the drive properties display (152625 MB). Consumers are often confused by the differences in the reported values.

There have been two significant class action lawsuits against digital storage manufactures. One case involved flash memory and the other involved hard disk drives. Both were settled with the manufactures agreeing to clarify the storage capacity of their products on the consumer packaging.

Willem Vroegh v. Eastman Kodak Company

On 20 February 2004, Willem Vroegh filed a lawsuit against Lexar Media, Dane–Elec Memory, Fuji Photo Film USA, Eastman Kodak Company, Kingston Technology Company, Inc., Memorex Products, Inc.; PNY Technologies Inc., SanDisk Corporation, Verbatim Corporation, and Viking InterWorks alleging that their descriptions of the capacity of their flash memory cards were false and misleading.

Vroegh claimed that a 256 MB Flash Memory Device had only 244 MB of accessible memory. "Plaintiffs allege that Defendants marketed the memory capacity of their products by assuming that one megabyte equals one million bytes and one gigabyte equals one billion bytes." The plaintiffs wanted the defendants to use the non-standard binary values 220 for megabyte and 230 for gigabyte. The plaintiffs acknowledged that the IEC and IEEE standards define a MB as one million bytes but stated that the industry has largely ignored the IEC standards.[85]

The manufacturers agreed to clarify the flash memory card capacity on the packaging and web sites.[86] The consumers could apply for "a discount of ten percent off a future online purchase from Defendants' Online Stores Flash Memory Device".[87]

Orin Safier v. Western Digital Corporation

On 7 July 2005, an action entitled "Orin Safier v. Western Digital Corporation, et al.," was filed in the Superior Court for the City and County of San Francisco, Case No. CGC-05-442812. The case was subsequently moved to the Northern District of California, Case No. 05-03353 BZ.[88]

Although Western Digital maintained that their usage of units is consistent with "the indisputably correct industry standard for measuring and describing storage capacity", and that they "cannot be expected to reform the software industry", they agreed to settle in March 2006 with 14 June 2006 as the Final Approval hearing date.[89]

Western Digital offered to compensate customers with a free download of backup and recovery software valued at US$30. They also paid $500,000 in fees and expenses to San Francisco lawyers Adam Gutride and Seth Safier, who filed the suit.[90]

Western Digital had this footnote in their settlement. "Apparently, Plaintiff believes that he could sue an egg company for fraud for labeling a carton of 12 eggs a "dozen," because some bakers would view a "dozen" as including 13 items."[91]

The settlement called for Western Digital to add a disclaimer;[90] flash memory and hard disk manufacturers have disclaimers on their packaging and web sites clarifying the formatted capacity of the flash memory[50] or defining MB as 1 million bytes and 1 GB as 1 billion bytes.[92]

Specific units of IEC 60027-2 A.2 and ISO/IEC 80000

Bit rates (data-rate units)
Name Symbol Multiple
bit per second bit/s 1 1
Metric prefixes (SI)
kilobit per second kbit/s 103 10001
megabit per second Mbit/s 106 10002
gigabit per second Gbit/s 109 10003
terabit per second Tbit/s 1012 10004
Binary prefixes (IEC 80000-13)
kibibit per second Kibit/s 210 10241
mebibit per second Mibit/s 220 10242
gibibit per second Gibit/s 230 10243
tebibit per second Tibit/s 240 10244
Multiple-byte units
Decimal
Value Metric
1000 kB kilobyte
10002 MB megabyte
10003 GB gigabyte
10004 TB terabyte
10005 PB petabyte
10006 EB exabyte
10007 ZB zettabyte
10008 YB yottabyte
10009 RB ronnabyte
100010 QB quettabyte
Binary
Value IEC Memory
1024 KiB kibibyte KB kilobyte
10242 MiB mebibyte MB megabyte
10243 GiB gibibyte GB gigabyte
10244 TiB tebibyte TB terabyte
10245 PiB pebibyte
10246 EiB exbibyte
10247 ZiB zebibyte
10248 YiB yobibyte
Orders of magnitude of data
Decimal
Value Metric
1000 kbit kilobit
10002 Mbit megabit
10003 Gbit gigabit
10004 Tbit terabit
10005 Pbit petabit
10006 Ebit exabit
10007 Zbit zettabit
10008 Ybit yottabit
10009 Rbit ronnabit
100010 Qbit quettabit
Binary
Value IEC Memory
1024 Kibit kibibit Kbit Kb kilobit
10242 Mibit mebibit Mbit Mb megabit
10243 Gibit gibibit Gbit Gb gigabit
10244 Tibit tebibit
10245 Pibit pebibit
10246 Eibit exbibit
10247 Zibit zebibit
10248 Yibit yobibit
Orders of magnitude of data

See also

References

  1. ^ "BIPM - SI prefixes" (html).
  2. ^ a b c d e Prefixes for Binary Multiples — The NIST Reference on Constants, Units, and Uncertainty
  3. ^ a b IUCr 1995 Report - IUCr IUPAC Interdivisional Committee on Nomenclature and Symbols (IDCNS)
  4. ^ a b c Bureau International des Poids et Mésures. (2006). "§3.1 SI prefixes". The International System of Units (SI) (PDF) (in French/English) (8th ed.). Paris: STEDI Media. p. 127. ISBN 92-822-2213-6. Retrieved 2007-02-25. [Side note:] These SI prefixes refer strictly to powers of 10. They should not be used to indicate powers of 2 (for example, one kilobit represents 1000 bits and not 1024 bits). The IEC has adopted prefixes for binary powers in the international standard IEC 60027-2: 2005, third edition, Letter symbols to be used in electrical technology — Part 2: Telecommunications and electronics. The names and symbols for the prefixes corresponding to 210, 220, 230, 240, 250, and 260 are, respectively: kibi, Ki; mebi, Mi; gibi, Gi; tebi, Ti; pebi, Pi; and exbi, Ei. Thus, for example, one kibibyte would be written: 1 KiB = 210 B = 1024 B, where B denotes a byte. Although these prefixes are not part of the SI, they should be used in the field of information technology to avoid the incorrect usage of the SI prefixes.{{cite book}}: CS1 maint: unrecognized language (link)
  5. ^ a b c "IEEE Std 1541-2002: IEEE Trial-Use Standard for Prefixes for Binary Multiples" (PDF). Reaffirmed 27 March 2008. 12 February 2003. doi:10.1109/IEEESTD.2003.94236. Retrieved 2007-07-29. This standard is prepared with two goals in mind: (1) to preserve the SI prefixes as unambiguous decimal multipliers and (2) to provide alternative prefixes for those cases where binary multipliers are needed. The first goal affects the general public, the wide audience of technical and nontechnical persons who use computers without much concern for their construction or inner working. These persons will normally interpret kilo, mega, etc., in their proper decimal sense. The second goal speaks to specialists—the prefixes for binary multiples make it possible for persons who work in the information sciences to communicate with precision. {{cite journal}}: Cite journal requires |journal= (help)
  6. ^ sponsor, Standards Coordinating Committee on Quantities, Units, and Letter Symbols. (23 September 2004). IEEE Std 260.1-2004, IEEE Standard Letter Symbols for Units of Measurement (SI Units, Customary Inch-Pound Units, and Certain Other Units). Revision of 260.1-1993. IEEE. ISBN 073813998X.{{cite book}}: CS1 maint: multiple names: authors list (link)
  7. ^ Hewlett-Packard, Dell, Sony, Apple Inc., Toshiba, Gateway
    Sun Microsystems, 4AllMemory.com
  8. ^ Real, P. (1959). "A generalized analysis of variance program utilizing binary logic". ACM '59: Preprints of papers presented at the 14th national meeting of the Association for Computing Machinery. ACM Press: 78-1 – 78-5. doi:10.1145/612201.612294. On a 32k core size 704 computer, approximately 28,000 datum may be analyzed, ... without resorting to auxiliary tape storage. {{cite journal}}: Unknown parameter |month= ignored (help) Note: the IBM 704 core memory units had 4096 36-bit words. Up to 32,768 words could be installed
  9. ^ Gruenberger, Fred (1960). "Letters to the Editor". Communications of the ACM. 3 (10). doi:10.1145/367415.367419. {{cite journal}}: Unknown parameter |month= ignored (help) "The 8K core stores were getting fairly common in this country in 1954. The 32K store started mass production in 1956; it is the standard now for large machines and at least 200 machines of the size (or its equivalent in the character addressable machines) are in existence today (and at least 100 were in existence in mid-1959)." Note: The IBM 1401 was a character addressable computer.
  10. ^ Amdahl, Gene M. (1964). "Architecture of the IBM System/360" (PDF). IBM Journal of Research and Development. 8 (2). IBM. {{cite journal}}: Unknown parameter |coauthors= ignored (|author= suggested) (help) Figure 1 gives storage (memory) capacity ranges of the various models in "Capacity 8 bit bytes, 1 K = 1024"
  11. ^ Control Data Corporation (1968). Control Data 7600 Computer System: Preliminary System Description (PDF). One type, designated as the small core memory (SCM) is a many bank coincident current type memory with a total of 64K words of 60 bit length (K=1024). {{cite book}}: Unknown parameter |month= ignored (help)
  12. ^ Control Data Corporation (1965–1967). Control Data 6400/6500/6600 Computer Systems Reference Manual (Pub No. 60100000 ed.). pp. pg 2–1. Central Memory is organized into 32K, 65K, or 131K words (60-bit) in 8, 16, or 32 banks of 4096 words each. {{cite book}}: |pages= has extra text (help)CS1 maint: date format (link)
  13. ^ Frankenberg, Robert (1974). "All Semiconductor Memory Selected for New Minicomputer Series" (PDF). Hewlett-Packard Journal. 26 (2). Hewlett-Packard: pg 15–20. Retrieved 2007-06-18. 196K-word memory size {{cite journal}}: |pages= has extra text (help); Unknown parameter |month= ignored (help)
  14. ^ Hewlett-Packard (November 1973), "HP 3000 Configuration Guide" (PDF), HP 3000 Computer System and Subsystem Data: pg 59 {{citation}}: |pages= has extra text (help)
  15. ^ Lin, Yeong (1972). "Cost-performance evaluation of memory hierarchies". Magnetics, IEEE Transactions on. 8 (3). IEEE: pg 390–392. doi:10.1109/TMAG.1972.1067329. Also, random access devices are advantageous over serial access devices for backing store applications only when the memory capacity is less than 1 Mbyte. For capacities of 4 Mbyte and 16 Mbyte serial access stores with shift register lengths of 256 bit and 1024 bit, respectively, look favorable. {{cite journal}}: |pages= has extra text (help); Unknown parameter |coauthors= ignored (|author= suggested) (help); Unknown parameter |month= ignored (help)
  16. ^ IBM (1972). "System/370 Model 158 brochure" (PDF). IBM. All-monolithic storage ... (1024-bit NMOS) This new improvement of processor storage makes system expansion more economical. Real storage capacity is available in 512K increments ranging from 512K to 2,048K bytes. {{cite journal}}: Cite journal requires |journal= (help)
  17. ^ Bell, Gordon (1975). "Computer structures: What have we learned from the PDP-11?" (PDF). ISCA '76: Proceedings of the 3rd annual symposium on Computer architecture. ACM Press: pg 1–14. memory size (8k bytes to 4 megabytes). {{cite journal}}: |pages= has extra text (help); Unknown parameter |coauthors= ignored (|author= suggested) (help); Unknown parameter |month= ignored (help)
  18. ^ PC World - Hitachi Introduces 1-Terabyte Hard Drive
  19. ^ ANSI/IEEE Std 1084-1986 IEEE Standard Glossary of Mathematics of Computing Terminology. 30 October 1986. kilo (K). (1) A prefix indicating 1000. (2) In statements involving size of computer storage, a prefix indicating 210, or 1024. mega (M). (1) A prefix indicating one million. (2) In statements involving size of computer storage, a prefix indicating 220, or 1048576.
  20. ^ ANSI/IEEE Std 1212-1991 IEEE Standard Control and Status Register (CSR) Architecture for Microcomputer Buses. 22 July 1992. Kbyte. Kilobyte. Indicates 210 bytes. Mbyte. Megabyte. Indicates 220bytes. Gbyte is used in the Foreword.
  21. ^ IEEE Std 610.10-1994 IEEE Standard Glossary of Computer Hardware Terminology. 24 June 1994. gigabyte (gig, GB). This term may mean either a) 1000000000 bytes or b) 230 bytes. ... As used in this document, the terms kilobyte (kB) means 210 or 1024 bytes, megabyte (MB) means 1024 kilobytes, and gigabyte (GB) means 1024 megabytes.
  22. ^ Institute of Electrical and Electronics Engineers (2000). The Authoritative Dictionary of IEEE Standards Terms. IEEE Computer Society Press. ISBN 0-7381-2601-2. "kB See kilobyte." "Kbyte Kilobyte. Indicates 210 bytes." "Kilobyte Either 1000 or 210 or 1024 bytes." The standard also defines megabyte and gigabyte. There is a note that an alternative notation for base-2 is under development.
  23. ^ a b Letters to the editor: Abbreviations for computer and memory sizes. Donald R. Morrison, Sandia Corp, Communications of the ACM, Volume 11, Issue 3 (March 1968) Page: 150 doi:10.1145/362929.362962
  24. ^ Letters to the editor: proposed abbreviation for 1024: bK, Wallace Givens, Applied National Lab, Communications of the ACM archive, Volume 11, Issue 6 (June 1968), Page: 391 doi:10.1145/363347.363351
  25. ^ Letters to the editor: On binary notation, Bruce A. Martin, Associated Universities Inc., Communications of the ACM, Volume 11, Issue 10 (October 1968) Page: 658 doi:10.1145/364096.364107
  26. ^ Standardized units for use in information technology, Markus Kuhn, 1996-12-29
  27. ^ a b Knuth: Recent News (1999)
  28. ^ 1996 IUCr IUPAC Interdivisional Committee on Nomenclature and Symbols (IDCNS) report
  29. ^ Bruce Barrow, "A Lesson in Megabytes," IEEE Standards Bearer, January 1997, page 5
  30. ^ "These prefixes for binary multiples, which were developed by IEC Technical Committee (TC) 25, Quantities and units, and their letter symbols, with the strong support of the International Committee for Weights and Measures (CIPM) and the Institute of Electrical and Electronics Engineers (IEEE), were adopted by the IEC as Amendment 2 to IEC International Standard IEC 60027-2: Letter symbols to be used in electrical technology - Part 2: Telecommunications and electronics."
  31. ^ IUCR 1999 report on IUPAC Interdivisional Committee on Nomenclature and Symbols
  32. ^ a b The Art of Computer Programming Volume 1, Donald Knuth, pp. 24 and 94
  33. ^ Free on-line Dictionary of Computing
  34. ^ "Definition of megabyte" (html).
  35. ^ "Definitions of Megabyte on Dictionary.com"" (html).
  36. ^ "AskOxford: megabyte" (html).
  37. ^ ""International System of Units (SI): Prefixes for binary multiples"". The NIST Reference on Constants, Units, and Uncertainty. National Institute of Science and Technology. Retrieved 2007-09-09.
  38. ^ IEC 60027-2 (2000-11) Ed. 2.0
  39. ^ A.J.Thor (2000). "Prefixes for binary multiples" (PDF). Metrologica. 37 (81): 81. doi:10.1088/0026-1394/37/1/12.
  40. ^ "HERE COME ZEBI AND YOBI" (Press release). International Electrotechnical Commission. 2005-08-15.
  41. ^ "IEEE-SA STANDARDS BOARD STANDARDS REVIEW COMMITTEE (RevCom) MEETING AGENDA". 2005-03-19. Retrieved 2007-02-25. 1541-2002 (SCC14) IEEE Trial-Use Standard for Prefixes for Binary Multiples [No negative comments received during trial-use period, which is now complete; Sponsor requests elevation of status to full-use.] Recommendation: Elevate status of standard from trial-use to full-use. Editorial staff will be notified to implement the necessary changes. The standard will be due for a maintenance action in 2007.
  42. ^ Wallich, Paul (2008). "Tools & toys: Hacking the Nokia N800". IEEE Spectrum. 45 (4): 25. doi:10.1109/MSPEC.2008.4476441. {{cite journal}}: Unknown parameter |month= ignored (help) "A lot can happen in a decade. You can hold the Nokia N800 in your hand, yet it’s a near-exact match for a high-end desktop PC from 10 years ago. It has a 320-megahertz processor, 128 megabytes of RAM, and a few gigabytes of available mass storage."
  43. ^ Gschwind,, Michael (2007). "An Open Source Environment for Cell Broadband Engine System Software". Computer. 40 (6). IEEE Computer Society: 37–47. doi:10.1109/MC.2007.192. {{cite journal}}: Unknown parameter |coauthors= ignored (|author= suggested) (help); Unknown parameter |month= ignored (help)CS1 maint: extra punctuation (link) "The processor has a memory subsystem with separate first-level 32-Kbyte instruction and data caches, and a 512-Kbyte unified second-level cache." Authors are with IBM.
  44. ^ niso, New Specs and Standards
  45. ^ Barry N. Taylor & Ambler Thompson Ed. The International System of Units (SI) (PDF). Gaithersburg, MD: National Institute of Standards and Technology. p. 23. Retrieved 2008-06-18.
  46. ^ Binary vs. Decimal Measurements
  47. ^ JEDEC Solid State Technology Association (December 2002), "Terms, Definitions, and Letter Symbols for Microcomputers, Microprocessors, and Memory Integrated Circuits" (PDF), Jesd 100B.01
  48. ^ IBM invented the disk drive in 1956 and until the late 1960s its drives and their clones were dominant. See, e.g. US vs. IBM antitrust litigation (Jan 1969), especially IBM analyses of Memorex and other disk drive companies.
  49. ^ On 6 January 2007, a check of the websites of Fujitsu, HGST, Samsung, Seagate, Toshiba and Western Digital showed these companies (representing virtually all of the HDD industry by unit volume) specify capacity with the SI prefix definitions.
  50. ^ a b ""Secure Digital Capacity Disclaimer"" (PDF). sandisk.com. SanDisk Corporation. Retrieved 2007-09-09.
  51. ^ Tandon (January 1984). TM100-1, TM100-2 Flexible Disk Drives: Product Specification and User's Manual (PDF). Tandon Corporation. pp. pg 2–4. {{cite book}}: |pages= has extra text (help)
  52. ^ IBM (1982). Disk Operating System by Microsoft (Version 1.1). IBM Corporation. pp. G–1. {{cite book}}: Unknown parameter |month= ignored (help) Some software applications "used with DOS 1.10, will operate with either two 160KB drives or two 320KB drives. Both drives MUST be of the same type..."
  53. ^ IBM (1983). Disk Operating System by Microsoft (Version 2.0). IBM Corporation. pp. A–2. {{cite book}}: Unknown parameter |month= ignored (help) "Beginning with DOS Version 2.00, DOS formats diskettes at 9 sectors per track, which increases capacity from 163,840 to 184,320 characters of information for single-sided diskettes and from 327,680 to 368,640 characters for dual-sided diskettes. The smaller capacity diskettes created by DOS Version 1.00 or DOS Version 1.10 (8 sectors per track) are also usable with DOS Version 2.00."
  54. ^ a b Apple Inc. (1991-08-22). "Double-Density Versus High-Density Disks". Article ID: 3802. Apple Inc. Retrieved 2007-07-07. "This article gives the specifications for the 800K floppy disks and the 1.4MB floppy disks." 800K Disk has 1600 sectors and 1.4MB Disk has 2880 sectors. A sector is 512 bytes.
  55. ^ Microsoft (2003-05-06). "Determining Actual Disk Size: Why 1.44 MB Should Be 1.40 MB". Article ID: 121839. Microsoft. Retrieved 2007-07-07. "The 1.44-megabyte (MB) value associated with the 3.5-inch disk format does not represent the actual size or free space of these disks. Although its size has been popularly called 1.44 MB, the correct size is actually 1.40 MB."
  56. ^ Data capacity of CDs
  57. ^ Understanding Recordable and Rewritable DVD
  58. ^ Rules for SAE Use of SI (Metric) Units — Section C.1.12 — SI prefixes
  59. ^ HD 60027-2:2003 Information about the harmonization document (obtainable on order)
  60. ^ prEN 60027-2:2006 Information about the EN standardization process
  61. ^ "UNITS". Linux Programmer's Manual. 2001-12-22. Retrieved 2007-05-20. When the Linux kernel boots and says hda: 120064896 sectors (61473 MB) w/2048KiB Cache the MB are megabytes and the KiB are kibibytes.
  62. ^ ESR post on LKML
  63. ^ "2.2 Block size". GNU Core Utilities manual. Free Software Foundation. 2002-12-28. Retrieved 2007-05-20. Integers may be followed by suffixes that are upward compatible with the SI prefixes for decimal multiples and with the IEC 60027-2 prefixes for binary multiples. {{cite web}}: External link in |quote= (help); line feed character in |quote= at position 37 (help)
  64. ^ Flyspray
  65. ^ bugs.mysql.com
  66. ^ "gparted-0.2 changelog". SourceForge. 2006-01-30. Retrieved 2007-05-20. changed KB/MB/GB/TB to KiB/MiB/GiB/TiB after reading http://www.iec.ch/zone/si/si_bytes.htm {{cite web}}: External link in |quote= (help)
  67. ^ DFSee
  68. ^ disktype
  69. ^ Mac OS X Manual Page For raidutil(8)
  70. ^ FreeDOS-32 - Standards Compliance
  71. ^ "IFCONFIG". Linux Programmer's Manual. 2005-06-30. Retrieved 2007-05-20. Since net-tools 1.60-4 ifconfig is printing byte counters and human readable counters with IEC 60027-2 units. So 1 KiB are 2^10 byte.
  72. ^ GNOME Network
  73. ^ SLIB
  74. ^ Cygwin/XFree86
  75. ^ Re: minor typo - HTTrack Website Copier Forum
  76. ^ http://developer.pidgin.im/ticket/1684 Developer discussion
  77. ^ "Deluge changeset". Retrieved 2007-06-13. proper prefix for size
  78. ^ What's New in zFTPServer Suite
  79. ^ SourceForge.net: Files
  80. ^ archive.netbsd.se
  81. ^ WinSCP :: Recent Version History
  82. ^ System/360 Model 91
  83. ^ The Product Line Card unambiguously uses MB to characterize HDD capacity in millions of bytes
  84. ^ 1977 Disk/Trend Report - Rigid Disk Drives, published June 1977
  85. ^ ""Vreogh Third Amended Complaint (Case No. GCG-04-428953)"" (PDF). pddocs.com. Poorman-Douglas Corporation. 10 March 2005. Retrieved 2007-09-09.
  86. ^ http://www.sandisk.com/Assets/Categories/Products/sd_capacitydisclaimer.pdf
  87. ^ Safier, Seth A. "Frequently Asked Questions". Flash Memory Settlement. Poorman-Douglas Corporation. Retrieved 2007-09-09.
  88. ^ Gutride, Adam (29 March 2006). ""Class Action Complaint"". Orin Safier v. Western Digital Corporation. Western Digital Corporation. Retrieved 2007-09-09. {{cite web}}: Italic or bold markup not allowed in: |work= (help); Unknown parameter |coauthors= ignored (|author= suggested) (help)
  89. ^ Zimmerman, Bernard (2006). ""Notice of Class Action and Proposed Settlement"". Orin Safier v. Western Digital Corporation. Western Digital Corporation. Retrieved 2007-09-09.
  90. ^ a b News article
  91. ^ Baskin, Scott D. (1 February 2006). ""Defendant Western Digital Corporation's Brief in Support of Plaintiff's Motion for Preliminary Approval"". Orin Safier v. Western Digital Corporation. Western Digital Corporation. Retrieved 2007-09-09. {{cite web}}: Italic or bold markup not allowed in: |work= (help)
  92. ^ ""WD Caviar SE16 SATA Hard Drives"". Western Digital: Products. Western Digital Corporation. Retrieved 2007-09-09.

Further reading

Converters