Misplaced Pages

Binary prefix: Difference between revisions

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editNext edit →Content deleted Content addedVisualWikitext
Revision as of 17:15, 12 April 2007 editOmegatron (talk | contribs)Administrators35,798 edits Adoption← Previous edit Revision as of 20:12, 12 April 2007 edit undoSLi (talk | contribs)Extended confirmed users1,646 edits JEDEC units of semiconductor storage capacity: POVNext edit →
Line 252: Line 252:


==JEDEC units of semiconductor storage capacity == ==JEDEC units of semiconductor storage capacity ==

{{POV-section-because|It is possible that this section gives undue weight to a allegedly relatively minor organization which does not consider unit standardization as its mission.}}

{{main|JEDEC memory standards}} {{main|JEDEC memory standards}}



Revision as of 20:12, 12 April 2007

The SI defines a system of prefixes (nano-, micro-, milli-, kilo-, mega-, giga- etc.) and symbols (n, µ, m, k, M, G, etc.) that denote powers of ten. When discussing things that naturally come in powers of two (such as computer memory sizes) it is convenient to abbreviate as well, but the SI prefixes do not fit this purpose perfectly, and various conventions have been used to designate power-of-two prefixes.

History

For instance, 2=1,024 bytes is accurately designated as 1.0 kilobytes to two significant digits. In the absence of other information, it is never clear what an author means by k (or K) for any power of 2 lower than 2. "32k" equals 32,000 according to the SI usage or 2=32,768 in the power-of-two usage; the latter rounds to 33k in the SI.

This led to much confusion about the meaning of the SI prefixes combined with "byte" (kilobyte, megabyte, gigabyte, etc.).

The practice of using binary-based prefixes for computer memory arose as early as 1964.

As storage size increased, binary meaning was also extended to higher SI prefixes, such as mega, M, and giga, G, where differences become greater.

In January 1999, the International Electrotechnical Commission introduced the prefixes kibi-, mebi-, gibi-, etc., and the symbols Ki, Mi, Gi, etc. to specify binary multiples of a quantity and eliminate this ambiguity. The names for the new standard are derived from the first two letters of the original SI prefixes followed by bi, short for "binary". The new standard also clarifies that, from the point of view of the IEC, the SI prefixes will henceforth only have their base-10 meaning and never have a base-2 meaning.

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

On March 19, 2005 the IEEE standard IEEE 1541-2002 (Prefixes for Binary Multiples) has been elevated to a full-use standard by the IEEE Standards Association after a two-year trial period.

Consumer confusion

File:Seagate 160 GB hard drive box.jpg
This hard disk can hold 160×10 bytes, and is marketed using standard SI prefixes as "160 GB"
File:Fdisk showing 160 GB disk.png
Linux's fdisk uses standard SI prefixes to display a disk that can hold 160×10 bytes as "160.0 GB"

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 the computer manufacturers to specify (as opposed to advertise) their products with decimal digits of sufficient places, e.g., the 1968 IBM stated System 360 "Model 91s can accommodate up to 6,291,496 bytes of main storage." The confusion appears to relate to the advent of graphical user interfaces where there was not enough space to provide sufficient digits to fully state the capacity. In such GUIs, storage capacity was reported in a mixed system of decimal digits and binary prefixes using the SI notation. Apparently, some computer programmers were unaware that disk drive manufacturers used the SI notation when specifying and/or advertising capacity of their hard disk drives. This mixed presentation appears as early as Microsoft Windows 98 which, for example, would report the space available on a 41,959,424 byte hard disk drive as 40 MB. In Microsoft Windows XP, a 30 gigabyte drive has its capacity reported both 30,064,771,072 bytes and as 28 GB. The confusion has sometimes led to litigation.

Binary prefixes using SI symbols

File:Windows XP Disk management for 160 GB disk.png
Windows XP uses SI prefixes in a binary sense to display a disk that can hold 160×10 bytes as "149.05 GB".
Name Symbol Value Base 16 Base 10
kilo k/K 2 = 1,024 = 16 > 10
mega M 2 = 1,048,576 = 16 > 10
giga G 2 = 1,073,741,824 = 16 > 10
tera T 2 = 1,099,511,627,776 = 16 > 10
peta P 2 = 1,125,899,906,842,624 = 16 > 10
exa E 2 = 1,152,921,504,606,846,976 = 16 > 10
zetta Z 2 = 1,180,591,620,717,411,303,424 = 16 > 10
yotta Y 2 = 1,208,925,819,614,629,174,706,176  = 16 > 10

The one-letter symbols are identical to SI prefixes, except for "K", which is used interchangeably with "k" (in SI, the upper-case or capital "K" stands for kelvin, and only the lower-case "k" represents 1,000).

These prefixes are in common use in contexts where accuracy is not important, such as file and memory sizes, but conflict with SI definitions. The names and values of the SI prefixes were defined in the 1960 SI standard, with powers-of-1000 values. As of 2005, standard dictionaries do not recognize the binary meanings for these prefixes.

BIPM (which maintains SI) expressly prohibits the binary prefix usage, and recommends the use of the IEC prefixes as an alternative (computing units are not included in SI).

Some have suggested that "k" be used for 1,000, and "K" for 1,024, but this cannot be extended to the higher order prefixes and has never been widely recognised.

Although the prefixes denoting fractions of a bit or byte might theoretically find application in areas such as cryptography, data compression, and data transfer rates, they are not used in practice.

Informally, the prefixes are often used on their own. Thus one might hear about "a 40K file" (40 binary kilobytes) or "a 2M Internet connection" (2 decimal megabits per second). What units are being used, and whether the multipliers are decimal or binary, depends on context and cannot be determined by the units alone.

IEC standard prefixes

GNOME's partition editor uses IEC prefixes to display partition sizes. The drive's total capacity is displayed as "149.05 GiB"
Name Symbol Base 2 Base 16 Base 10
kibi Ki 2 16 0x400 = 1,024 > 10
mebi Mi 2 16 0x10 0000 = 1,048,576 > 10
gibi Gi 2 16 0x4000 0000 = 1,073,741,824 > 10
tebi Ti 2 16 0x100 0000 0000 = 1,099,511,627,776 > 10
pebi Pi 2 16 0x4 0000 0000 0000 = 1,125,899,906,842,624 > 10
exbi Ei 2 16 0x1000 0000 0000 0000 = 1,152,921,504,606,846,976 > 10
zebi Zi 2 16 0x40 0000 0000 0000 0000 = 1,180,591,620,717,411,303,424 > 10
yobi Yi 2 16 0x1 0000 0000 0000 0000 0000 = 1,208,925,819,614,629,174,706,176 > 10

Example: 300 GB ≅ 279.5 GiB (= 0x117.6592E GiB = 0x45D96.4B8 MiB = 0x1176592E KiB = 0x45D964B800 bytes).

Approximate ratios between binary and decimal prefixes

As the order of magnitude increases, the percentage difference between the binary and decimal values of a prefix increases, from 2.4% (with the kilo prefix) to over 20% (with the yotta prefix). This makes differentiating between the two increasingly important as larger and larger data storage and transmission technologies are developed.

Name Bin ÷ Dec Dec ÷ Bin Example Percentage difference
kilobyte : kibibyte 1.024 0.976 100 kB ≅ 97.6 KiB +2.4% or −2.3%
megabyte : mebibyte 1.049 0.954 100 MB ≅ 95.4 MiB +4.9% or −4.6%
gigabyte : gibibyte 1.074 0.931 100 GB ≅ 93.1 GiB +7.4% or −6.9%
terabyte : tebibyte 1.100 0.909 100 TB ≅ 90.9 TiB +10% or −9.1%
petabyte : pebibyte 1.126 0.888 100 PB ≅ 88.8 PiB +12.6% or −11.2%
exabyte : exbibyte 1.153 0.867 100 EB ≅ 86.7 EiB +15.3% or −13.3%
zettabyte : zebibyte 1.181 0.847 100 ZB ≅ 84.7 ZiB +18.1% or −15.3%
yottabyte : yobibyte 1.209 0.827 100 YB ≅ 82.7 YiB +20.9% or −17.3%

Adoption

As of 2007, the IEC binary naming convention is not widespread, but its use is growing.

It is strongly supported by many standardization bodies and technical organizations, such as IEEE, CIPM, NIST, and SAE. 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. This document will be adopted as a European standard.

The prefixes are beginning to be used in technical articles and software where it is important to avoid ambiguity.

JEDEC units of semiconductor storage capacity

Template:POV-section-because

Main article: JEDEC memory standards

The JEDEC Solid State Technology Association is the semiconductor engineering standardization body of the Electronic Industries Alliance (EIA). JEDEC committees are very active in developing standards for semiconductor memory.

JEDEC Standard 100B.01 defines the "prefix to units of semiconductor storage capacity" as follows:

  • kilo (K): A multiplier equal to 1024 (2).
  • mega (M): A multiplier equal to 1 048 576 (2 or K, where K = 1024).
  • giga (G): A multiplier equal to 1 073 741 824 (2 or K, where K = 1024).

It notes that these prefixes are used in their decimal sense for data rates:

Contrast with the SI prefix kilo (k) equal to 10, as in a 1-kb/s data transfer rate, which is equal to 1000 bits per second.

It also defines:

  • bit (b): In the binary numeration system, either of the digits 0 or 1. (Ref. ANSI X3.172.)
  • byte (B): A binary character string operated upon as a unit and usually shorter than a computer word. (Ref. ANSI X3.172.) NOTE A byte is usually eight bits.

Their rationale for including these definitions is explained and contrasted to the IEC system:

The definitions of kilo, giga, and mega based on powers of two are included only to reflect common usage. IEEE/ASTM SI 10-1997 states “This practice frequently leads to confusion and is deprecated.” Further confusion results from the popular use of a “megabyte” consisting of 1 024 000 bytes to define the capacity of the familiar “1.44-MB” diskette. An alternative system is found in Amendment 2 to IEC 60027-2: Letter symbols to be used in electrical technology – Part 2

All JEDEC standards avoid the use of the terms megabit, megabyte, gigabyte, etc, and refer to memory capacity as a number followed by the units. (64Mb, 256MB or 1GB.)

JEDEC Standard 21 specifies semiconductor memories from the 256 bit static RAM (.25Kb) to the latest DDR2 SDRAM modules.

Modern memory modules are defined by more than capacity. The modules are required to have JEDEC standard product labels. For example:

1GB 2Rx4 PC2-3200P-333-11-D2 is a 1GB DDR2 Registered DIMM, with address/command parity function, using 2 ranks of x4 SDRAMs operational to PC2-3200 performance with CAS Latency = 3, tRCD = 3, tRP = 3, using JEDEC SPD revision 1.1, raw card reference design file D revision 2 used for the assembly.

Usage notes

The phrase "decimal unit" will be used to denote "SI designation understood in its standard, decimal, power-of-1000 sense" and "binary unit" will mean "SI designation understood in its binary, power-of-1024 sense." B will be used as the symbol for byte as per computer-industry standard (IEEE 1541 and IEC 60027; B is also the symbol for bel, a common non-SI unit used for ratio measurement).

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 1,000,000,000 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 1,000,000 bits (125 kB, approx 122 KiB) per second, assuming an 8-bit byte, and no overhead.

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."

Computer memory

Measurements of most types of electronic memory such as RAM and 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.

Internally, some 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 33,554,432 bytes of hardware memory. It is convenient to informally express that as 64 K items, or as 8 K pages of 4 Kbytes (KiB) each within 32 MBytes (MiB) of memory. A programmer could easily mentally calculate that "8 kay times 4 kay is 32 meg" and get it exactly right, within this powers-of-two only context. This convenience is likely one source of originally adapting "Kilo" and "Mega" from SI as shorthand for 1024 and 1,048,576, as specialized jargon within a segment of the industry.

Almost all computer user tasks (and many high-level programming tasks) have no natural affinity or need for explicit powers of two. The consumer confusion between powers of 1000 and powers of 1024 may derive largely from some operating systems and applications that were originally written by and for programmers, and which thus reported quantities such as file sizes in familiar (to programmers) powers of 1024 while using SI (powers of 1000) abbreviations. Without such reporting, most users might not have been substantially exposed to powers of 1024, as the net memory available to users after various overheads is rarely a power of two. This legacy behavior of operating systems reporting sizes in powers of 1024 has continued to this day (in 2007) even in many GUI oriented operating systems intended mainly for non-programmers.

Hard disk drives

HDD manufacturers 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,000,000 6 bit characters organized in 100 character sectors (i.e., blocks). This predates the SI system.
  • In the 1960s virtually all disk drives used IBM's variable block length format (called, Count Key Data or "CKD"). 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 (not MiB) and with the Xebec controller and 512 byte blocks it formatted to and was advertised as a 10.0 MB (not MiB) 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.

Regardless of the HDD manufacturer's continuous practice of specifying with conventional SI prefixes, some systems GUI's took the HDD capacity, reported by the operating system as a binary number without prefixes, and reported the HDD capacity in a mixed decimal number/binary prefix leading to some confusion. As of January 2007, most, if not all, HDD manufacturers continue to use decimal prefixes to identify capacity.

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: 32 MB, 64 MB, 128 MB, 256 MB, 512 MB. Although the devices usually have at least the expected byte capacity as defined by the "decimal" calculation (256 million bytes for a 256 MB classified device), each manufacturer allocates different portions of the device's ultimate capacity for such things as wear levelling.

Floppy drives

The confused usage of decimal prefixes may have started in floppy drives where the drive and media manufacturers stated their unformatted capacity while various systems houses published differing formatted capacities as a consequence of their varying controller designs. It appears that some system manufacturers and OS vendors began reporting in what we now know as Ki bytes. A very confusing hybrid system developed with the double sided high density 3½" floppy disk, in which a "megabyte" means a thousand 1024-byte "kilobytes". Thus, as of 2005, manufacturers universally use the designation "1.44 MB diskette" for a product which holds neither 1.44×2 bytes nor 1.44×10 bytes, but rather 1.44×1000×1024 bytes (approximately 1.406 MiB, or 1.475 MB). This is probably because some marketing person decided that this was best advertised as a double capacity version of the prior generation 720 KB product (of course, it was 720 KiB).

CD and DVD

CD capacities are always given in binary units. A "700 MB" (or "80 minute") CD has a nominal capacity of about 700 MiB. But DVD capacities are given in decimal units. A "4.7 GB" DVD has a nominal capacity of about 4.38 GiB.

Buses

Bus bandwidth is given in decimal units. This is not because hard drive capacities use the decimal versions, nor because bit rates do, but because clock speeds do. For example, "PC3200" memory runs on a double pumped 200 MHz bus, transferring 8 bytes per cycle, and hence has a bandwidth of 200,000,000×2×8 = 3,200,000,000 byte/s.

Legal disputes

The implicit use of decimal units to describe the capacity of storage devices has become a source of confusion as these devices are increasingly marketed to non-technical consumers. When a user buys a device advertised using decimal units, and installs it in a system that shows the available space in binary units, a misinformed user may be disturbed by the apparent discrepancy. As a result, there have been several lawsuits against companies who sell hard drives, flash memory devices, and computer systems that list drive capacities.

Several significant lawsuits have been filed:

See also

Specific units of IEC 60027-2 A.2

These units have individual articles:

Bit rates (data-rate units)
Name Symbol Multiple
bit per second bit/s 1 1
Metric prefixes (SI)
kilobit per second kbit/s 10 1000
megabit per second Mbit/s 10 1000
gigabit per second Gbit/s 10 1000
terabit per second Tbit/s 10 1000
Binary prefixes (IEC 80000-13)
kibibit per second Kibit/s 2 1024
mebibit per second Mibit/s 2 1024
gibibit per second Gibit/s 2 1024
tebibit per second Tibit/s 2 1024
Multiple-byte units
Decimal
Value Metric
1000 kB kilobyte
1000 MB megabyte
1000 GB gigabyte
1000 TB terabyte
1000 PB petabyte
1000 EB exabyte
1000 ZB zettabyte
1000 YB yottabyte
1000 RB ronnabyte
1000 QB quettabyte
Binary
Value IEC Memory
1024 KiB kibibyte KB kilobyte
1024 MiB mebibyte MB megabyte
1024 GiB gibibyte GB gigabyte
1024 TiB tebibyte TB terabyte
1024 PiB pebibyte
1024 EiB exbibyte
1024 ZiB zebibyte
1024 YiB yobibyte
Orders of magnitude of data
Multiple-bit units
Decimal
Value Metric
1000 kbit kilobit
1000 Mbit megabit
1000 Gbit gigabit
1000 Tbit terabit
1000 Pbit petabit
1000 Ebit exabit
1000 Zbit zettabit
1000 Ybit yottabit
1000 Rbit ronnabit
1000 Qbit quettabit
Binary
Value IEC Memory
1024 Kibit kibibit Kbit Kb kilobit
1024 Mibit mebibit Mbit Mb megabit
1024 Gibit gibibit Gbit Gb gigabit
1024 Tibit tebibit
1024 Pibit pebibit
1024 Eibit exbibit
1024 Zibit zebibit
1024 Yibit yobibit
Orders of magnitude of data

References

  1. "Architecture of the IBM System/360," ©1964 gives memory capacity ranges of the various models in "Capacity 8 bit bytes 1 KB = 1024"
  2. Amendment 2 to IEC International Standard IEC 60027-2: Letter symbols to be used in electrical technology — Part 2: Telecommunications and electronics
  3. IEC 60027-2 (2000-11) Ed. 2.0
  4. "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 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. {{cite web}}: Check date values in: |date= (help)
  5. System/360 Model 91
  6. ^ "§3.1 SI prefixes". The International System of Units (SI) (PDF) (in French/English) (8th edition ed.). Paris: STEDI Media. 2006. pp. p. 127. ISBN 92-822-2213-6. Retrieved 2007-02-25. 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 2, 2, 2, 2, 2, and 2 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 = 2 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}}: |edition= has extra text (help); |pages= has extra text (help)CS1 maint: unrecognized language (link)
  7. IEEE Trial-Use Standard for Prefixes for Binary Multiples (PDF). New York. 2003-02-12. ISBN 0-7381-3386-8. Retrieved 2007-02-25. 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 book}}: Check date values in: |date= (help)
  8. ^ Prefixes for Binary Multiples — The NIST Reference on Constants, Units, and Uncertainty
  9. Rules for SAE Use of SI (Metric) Units — Section C.1.12 — SI prefixes
  10. HD 60027-2:2003 Information about the harmonization document (obtainable on order)
  11. prEN 60027-2:2006 Information about the EN standardization process
  12. JEDEC Solid State Technology Association (December 2002), "Terms, Definitions, and Letter Symbols for Microcomputers, Microprocessors, and Memory Integrated Circuits" (PDF), JESD 100B.01
  13. Binary vs. Decimal Measurements
  14. http://www.answers.com/topic/ckd
  15. It is not clear when such mis-reporting began, perhaps as early as the mid-1970s with the advent of floppy disk drive capacity reporting; however it became a significant issue with the advent of GUI based personal computers.
  16. On January 6 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.
  17. Data capacity of CDs
  18. Understanding Recordable and Rewritable DVD

External links

Categories:
Binary prefix: Difference between revisions Add topic