Software multiplataforma
(leer más)
En matemáticas y computación, el sistema numérico hexadecimal (también base-16 o simplemente hex) es un sistema numérico posicional que representa números usando una raíz (base) de 16. A diferencia del sistema decimal que representa números usando 10 símbolos, el hexadecimal usa 16 símbolos distintos, más a menudo los símbolos "0"–"9" para representar valores de 0 a 9, y "A"–"F" (o alternativamente "a"–"f") para representar valores de 10 a 15.
Los desarrolladores de software y los diseñadores de sistemas utilizan mucho los números hexadecimales porque proporcionan una representación humana de los valores codificados en binario. Cada dígito hexadecimal representa cuatro bits (dígitos binarios), también conocidos como nibble (o nybble). Por ejemplo, un byte de 8 bits puede tener valores que van desde 00000000 a 11111111 en forma binaria, que se pueden representar convenientemente como 00 a FF en hexadecimal.
En matemáticas, normalmente se usa un subíndice para especificar la base. Por ejemplo, el valor decimal 13,217 se expresaría en hexadecimal como 33A116. En programación, se utilizan varias notaciones para denotar números hexadecimales, generalmente con un prefijo. El prefijo 0x
se usa en C, lo que denotaría este valor como 0x33A1
.
El hexadecimal se utiliza en la codificación de transferencia Base16, en la que cada byte del texto sin formato se divide en dos valores de 4 bits y se representa mediante dos dígitos hexadecimales.
En la mayoría de los casos de uso actuales, las letras A–F o a–f representan los valores 10–15, mientras que los números 0–9 se utilizan para representar sus valores decimales.
No existe una convención universal para usar mayúsculas o minúsculas, por lo que cada una prevalece o se prefiere en entornos particulares según los estándares o convenciones de la comunidad; incluso se utilizan mayúsculas y minúsculas. Las pantallas de siete segmentos utilizan mayúsculas y minúsculas AbCdEF para crear dígitos que se puedan distinguir entre sí.
Existe cierta estandarización en el uso de espacios (en lugar de comas u otro signo de puntuación) para separar los valores hexadecimales en una lista larga. Por ejemplo, en el siguiente volcado hexadecimal, cada byte de 8 bits es un número hexadecimal de 2 dígitos, con espacios entre ellos, mientras que el desplazamiento de 32 bits al principio es un número hexadecimal de 8 dígitos.
00000000 57 69 6b 69 70 65 64 69 61 2c 20 74 68 65 20 66 00010 72 65 65 20 65 6e 63 79 63 6c 6f 70 65 64 69 61 00020 20 74 68 61 74 20 61 6e 79 6f 6e 65 20 63 61 6e 000 00030 20 65 64 69 74 0a
En contextos donde la base no es clara, los números hexadecimales pueden ser ambiguos y confundirse con números expresados en otras bases. Existen varias convenciones para expresar valores sin ambigüedades. Un subíndice numérico (escrito en decimal) puede dar la base explícitamente: 15910 es 159 decimal; 15916 es hexadecimal 159, lo que equivale a 34510. Algunos autores prefieren un subíndice de texto, como 159decimal y 159hex, o 159d y 159h.
Donald Knuth introdujo el uso de un tipo de letra particular para representar una raíz particular en su libro The TeXbook. Las representaciones hexadecimales están escritas allí en un tipo de letra de máquina de escribir: 5A3
En los sistemas de texto lineal, como los que se utilizan en la mayoría de los entornos de programación informática, han surgido una variedad de métodos:
0x
para las constantes numéricas representadas en hex: 0x5A3
. Las constantes de caracteres y cadenas pueden expresar códigos de caracteres en hexadecimal con el prefijo x
seguido de dos dígitos hex: 'x1B'
representa el carácter de control Esc; "x1B[0mx1B[25;1H"
es una cadena que contiene 11 caracteres con dos caracteres Esc incrustados. Para producir un entero como hexadecimal con la familia función printf, el código de conversión de formato %X
o %x
se utiliza.%
: http://www.example.com/name%20with%20spaces
Donde %20
es el código para el carácter del espacio (negro), punto de código ASCII 20 en hex, 32 en decimal.ode;
, por ejemplo ’
representa el personaje U+2019 (la marca de citas simple derecha). Si no hay x
el número es decimal (por ’
es el mismo carácter).U+
seguido del valor hex, por ejemplo. U+20AC
es el signo Euro (€).#
: blanco, por ejemplo, está representado como #FFFFFF
. CSS también permite abreviaciones de 3-hexdigit con un hexdigit por componente: #FA3 abreviadas #FFAA33 (una naranja dorada: ).=
: Espa=F1a
es "España" (F1 es el código para ñ en el conjunto de caracteres ISO/IEC 8859-1).FFh
o 05A3H
. Algunas implementaciones requieren un cero líder cuando el primer dato hexadecimal no es un dígito decimal, por lo que uno escribiría 0FFh
en lugar de FFh
. Algunas otras implementaciones (como NASM) permiten números de estilo C (0x42
).$
como prefijo: $5A3
.H'ABCD'
(para ABCD16). Del mismo modo, Fortran 95 utiliza Z'ABCD'.16#5A3#
. Para las constantes de vectores de bits VHDL utiliza la notación x"5A3"
.8'hFF
, donde 8 es el número de bits en el valor y FF es la constante hexadecimal.16r
: 16r5A3
16#
: 16#5A3
. Para PostScript, los datos binarios (como píxeles de imagen) se pueden expresar como pares hexadecimales consecutivos sin prefijo: AA213FD51B3801043FBC
...#x
y #16r
. La configuración de las variables *read-base* y *print-base* a 16 también se puede utilizar para cambiar el lector e impresora de un sistema de Lisp Común a la representación de número hexadecimal para números de lectura e impresión. Así, los números hexadecimales pueden ser representados sin el código #x o #16r prefijo, cuando la base de entrada o salida se ha cambiado a 16.&H
: &H5A3
&
para Hex.0h
prefijo: 0h5A3
16r
to denote hexadecimal numbers: 16r5a3
. Los números binarios, cuaternarios (base-4) y octales se pueden especificar de forma similar.X'5A3'
, y se utiliza en Assembler, PL/I, COBOL, JCL, scripts, comandos y otros lugares. Este formato era común en otros sistemas IBM (y ahora obsoletos). En ocasiones se utilizaron comillas en lugar de apostrofes.:
). Esta, por ejemplo, es una dirección IPv6 válida: 2001:0db8:85a3:0000:0000:8a2e:0370:7334
o abreviado por la eliminación de ceros como 2001:db8:85a3::8a2e:370:7334
(Las direcciones IPv4 generalmente se escriben en decimal).3F2504E0-4F89-41D3-9A0C-0305E82C3301
.El uso de las letras A a F para representar los dígitos por encima del 9 no era universal en la historia temprana de las computadoras.
Dado que no había números tradicionales para representar las cantidades de diez a quince, se volvieron a emplear letras alfabéticas como sustituto. La mayoría de los idiomas europeos carecen de palabras no decimales para algunos de los números del once al quince. Algunas personas leen números hexadecimales dígito a dígito, como un número de teléfono, o usan el alfabeto fonético de la OTAN, el alfabeto fonético conjunto del ejército y la marina, o un sistema ad-hoc similar. A raíz de la adopción del hexadecimal entre los programadores de IBM System/360, Magnuson (1968) sugirió una guía de pronunciación que daba nombres cortos a las letras hexadecimales, por ejemplo, "A" se pronunciaba "ann", B "bet", C "chris", etc. Otro sistema de nombres fue elaborado por Babb (2015), basado en una broma en Silicon Valle. Rogers (2007) publicó en línea otro sistema de nombres que intenta hacer que la representación verbal sea distinguible en cualquier caso, incluso cuando el número real no contiene números A–F. Los ejemplos se enumeran en las tablas a continuación.
Otros han propuesto usar las convenciones verbales del Código Morse para expresar dígitos hexadecimales de cuatro bits, con "dit" y "dah" representando cero y uno, respectivamente, de modo que "0000" se expresa como "dit-dit-dit-dit" (....), dah-dit-dit-dah (-..-) expresa el dígito con un valor de nueve, y "dah-dah-dah-dah" (----) expresa el dígito hexadecimal para el decimal 15.
Se han ideado sistemas de conteo de dígitos tanto para binario como para hexadecimal. Arthur C. Clarke sugirió usar cada dedo como un bit de encendido/apagado, lo que permite contar con los dedos de cero a 102310 en diez dedos. A la derecha se ilustra otro sistema para contar hasta FF16 (25510).
Número | Pronunciación |
---|---|
A | Ann |
B | apuesta |
C | chris |
D | # |
E | Ernest |
F | helada |
1A | annteen |
A0 | No. |
5B | 50-bet |
A01C | Anty christeen |
1AD0 | annteen dotty |
3A7D | treinta y nueve setenta puntos |
Número | Pronunciación |
---|---|
A | 10 |
B | 11 |
C | 12 |
D | draze |
E | eptwin |
F | fim |
10 | tex |
11 | oneteek |
1F | fimteek |
50 | fiftek |
C0 | Twelftek |
100 | Hundrek |
1000 | Yousek |
3E | thirtek-eptwin |
E1 | eptek-one |
C4A | 12-hundrek-four-tek-ten |
1743 | 1-thousek-seven- - Vale. |
El sistema hexadecimal puede expresar números negativos de la misma manera que en decimal: −2A para representar −4210 y así sucesivamente.
El hexadecimal también se puede usar para expresar los patrones de bits exactos que se usan en el procesador, por lo que una secuencia de dígitos hexadecimales puede representar un valor con signo o incluso un punto flotante. De esta forma, el número negativo −4210 se puede escribir como FFFF FFD6 en un registro de CPU de 32 bits (en complemento a dos), como C228 0000 en un registro de FPU de 32 bits o C045 0000 0000 0000 en un registro FPU de 64 bits (en el estándar de punto flotante IEEE).
Así como los números decimales se pueden representar en notación exponencial, también se pueden representar los números hexadecimales. La notación P usa la letra P (o p, para "poder"), mientras que E (o e ) tiene un propósito similar en la notación E decimal. El número después de la P es decimal y representa el exponente binario. Aumentar el exponente por 1 se multiplica por 2, no por 16: 20p0 = 10p1 = 8p2 = 4p3 = 2p4 = 1.0p5. Por lo general, el número se normaliza para que los dígitos hexadecimales comiencen con 1. (el cero suele ser 0 sin P ).
Ejemplo: 1.3DEp42 representa 1.3DE16 × 24210.
La notación P es requerida por el estándar binario de coma flotante IEEE 754-2008 y se puede usar para literales de coma flotante en la edición C99 del lenguaje de programación C. Usando los especificadores de conversión %a o %A, esta notación puede ser producida por implementaciones de la familia de funciones printf siguiendo la especificación C99 y Especificación única de Unix (IEEE Std 1003.1) estándar POSIX.
La mayoría de las computadoras manipulan datos binarios, pero es difícil para los humanos trabajar con una gran cantidad de dígitos incluso para un número binario relativamente pequeño. Aunque la mayoría de las personas están familiarizadas con el sistema de base 10, es mucho más fácil asignar binario a hexadecimal que a decimal porque cada dígito hexadecimal se asigna a un número entero de bits (410). Este ejemplo convierte 11112 a base diez. Dado que cada posición en un número binario puede contener un 1 o un 0, su valor puede determinarse fácilmente por su posición desde la derecha:
Por lo tanto:
11112 | = 810 + 410 + 210 + 110 |
= 1510 |
Con poca práctica, la asignación de 11112 a F16 en un solo paso se vuelve fácil: vea la tabla en representación escrita. La ventaja de usar hexadecimal en lugar de decimal aumenta rápidamente con el tamaño del número. Cuando el número se vuelve grande, la conversión a decimal es muy tediosa. Sin embargo, cuando se asigna a hexadecimal, es trivial considerar la cadena binaria como grupos de 4 dígitos y asignar cada uno a un solo dígito hexadecimal.
Este ejemplo muestra la conversión de un número binario a decimal, asignando cada dígito al valor decimal y sumando los resultados.
(0101011110101101010010)2 | = 26214410 + 6553610 + 3276810 + 1638410 + 819210 + 204810 + 51210 + 25610 + 6410 + 1610 + 210 |
= 38792210 |
Compare esto con la conversión a hexadecimal, donde cada grupo de cuatro dígitos puede considerarse de forma independiente y convertirse directamente:
(0101011110101101010010)2 | = | 0101 | 1110 | 1011 | 0101 | 00102 |
= | 5 | E | B | 5 | 216 | |
= | 5EB5216 |
La conversión de hexadecimal a binario es igualmente directa.
Aunque el cuaternario (base 4) se usa poco, se puede convertir fácilmente hacia y desde hexadecimal o binario. Cada dígito hexadecimal corresponde a un par de dígitos cuaternarios y cada dígito cuaternario corresponde a un par de dígitos binarios. En el ejemplo anterior, 5 E B 5 216 = 11 32 23 11 024.
El sistema octal (base 8) también se puede convertir con relativa facilidad, aunque no tan trivialmente como con las bases 2 y 4. Cada dígito octal corresponde a tres dígitos binarios, en lugar de cuatro. Por lo tanto, podemos convertir entre octal y hexadecimal a través de una conversión intermedia a binario seguida de la reagrupación de los dígitos binarios en grupos de tres o cuatro.
Al igual que con todas las bases, existe un algoritmo simple para convertir una representación de un número a hexadecimal realizando operaciones de división de enteros y resto en la base de origen. En teoría, esto es posible desde cualquier base, pero para la mayoría de los humanos solo se puede manejar fácilmente con este método decimal y para la mayoría de las computadoras solo binario (que se puede convertir mediante métodos mucho más eficientes).
Sea d el número a representar en hexadecimal, y la serie hihi−1...h2h1 sean los dígitos hexadecimales que representan el número.
"16" puede ser reemplazada con cualquier otra base que se desee.
La siguiente es una implementación de JavaScript del algoritmo anterior para convertir cualquier número a hexadecimal en representación de cadena. Su propósito es ilustrar el algoritmo anterior. Sin embargo, para trabajar con datos en serio, es mucho más recomendable trabajar con operadores bit a bit.
función toHex()d) {} Var r = d % 16; si ()d - r == 0) {} retorno toChar()r); } retorno toHex()d - r) / 16) + toChar()r);}función toChar()n) {} const alfa = "0123456789ABCDEF"; retorno alfa.charAt()n);}
También es posible realizar la conversión asignando a cada lugar en la base de origen la representación hexadecimal de su valor posicional, antes de realizar la multiplicación y la suma para obtener la representación final. Por ejemplo, para convertir el número B3AD a decimal, se puede dividir el número hexadecimal en sus dígitos: B (1110), 3 (310), A (10 10) y D (1310), y luego obtener el resultado final multiplicando cada representación decimal por 16p (p es la posición del dígito hexadecimal correspondiente, contando de derecha a izquierda, comenzando con 0). En este caso, tenemos que:
B3AD = (11 × 163) + (3 × 162) + (10 × 161) + (13 × 160)
que es 45997 en base 10.
Muchos sistemas informáticos proporcionan una utilidad de calculadora capaz de realizar conversiones entre las distintas raíces, incluido con frecuencia el hexadecimal.
En Microsoft Windows, la utilidad Calculadora se puede configurar en el modo Programador, lo que permite realizar conversiones entre radix 16 (hexadecimal), 10 (decimal), 8 (octal) y 2 (binario), las bases más utilizadas por los programadores. En el modo de programador, el teclado numérico en pantalla incluye los dígitos hexadecimales de la A a la F, que están activos cuando "Hex" es seleccionado. Sin embargo, en el modo hexadecimal, la Calculadora de Windows solo admite números enteros.
Las operaciones elementales como la suma, la resta, la multiplicación y la división se pueden realizar indirectamente a través de la conversión a un sistema numérico alternativo, como el sistema decimal de uso común o el sistema binario donde cada dígito hexadecimal corresponde a cuatro dígitos binarios.
Alternativamente, también se pueden realizar operaciones elementales directamente dentro del propio sistema hexadecimal, confiando en sus tablas de suma/multiplicación y sus algoritmos estándar correspondientes, como la división larga y el algoritmo de resta tradicional.
Al igual que con otros sistemas numéricos, el sistema hexadecimal se puede usar para representar números racionales, aunque las expansiones repetidas son comunes ya que dieciséis (1016) tiene un solo factor primo; dos.
Para cualquier base, 0,1 (o "1/10") siempre es equivalente a uno dividido por la representación de ese valor base en su propio sistema numérico. Por lo tanto, ya sea dividiendo uno por dos para binario o dividiendo uno por dieciséis para hexadecimal, ambas fracciones se escriben como 0.1
. Debido a que la base 16 es un cuadrado perfecto (42), las fracciones expresadas en hexadecimal tienen un período impar con mucha más frecuencia que las decimales, y no hay números cíclicos (aparte de los dígitos sencillos triviales). Los dígitos recurrentes se exhiben cuando el denominador en términos más bajos tiene un factor primo que no se encuentra en la raíz; por lo tanto, cuando se usa la notación hexadecimal, todas las fracciones con denominadores que no son una potencia de dos dan como resultado una cadena infinita de dígitos recurrentes (como tercios y quintos). Esto hace que el hexadecimal (y el binario) sea menos conveniente que el decimal para representar números racionales, ya que una proporción mayor se encuentra fuera de su rango de representación finita.
Todos los números racionales finitamente representables en hexadecimal también son finitamente representables en decimal, duodecimal y sexagesimal: es decir, cualquier número hexadecimal con un número finito de dígitos también tiene un número finito de dígitos cuando se expresa en esas otras bases. Por el contrario, solo una fracción de los finitamente representables en las últimas bases son finitamente representables en hexadecimal. Por ejemplo, el decimal 0.1 corresponde a la representación infinita recurrente 0.19 en hexadecimal. Sin embargo, el hexadecimal es más eficiente que el duodecimal y el sexagesimal para representar fracciones con potencias de dos en el denominador. Por ejemplo, 0,062510 (un dieciseisavo) equivale a 0,116, 0,0912 y 0;3,4560 .
n | Decimal Principales factores: base, b = 10: 2, 5; b − 1 = 9: 3 | Hexadecimal Principales factores: base, b = 1610 = 10: 2b) 1 = 1510 = F: 3, 5 | ||||
---|---|---|---|---|---|---|
Reciprocal | Factores primas | Representación posicional (decimal) | Representación posicional (hexadecimal) | Factores primas | Reciprocal | |
2 | 1/2 | 2 | 0.5 | 0,8 | 2 | 1/2 |
3 | 1/3 | 3 | 0.3333... = 0.3 | 0.5555... = 0.5 | 3 | 1/3 |
4 | 1/4 | 2 | 0,25 | 0,4 | 2 | 1/4 |
5 | 1/5 | 5 | 0.2 | 0.3 | 5 | 1/5 |
6 | 1/6 | 2, 3 | 0.16 | 0.2A | 2, 3 | 1/6 |
7 | 1/7 | 7 | 0.142857 | 0.249 | 7 | 1/7 |
8 | 1/8 | 2 | 0.125 | 0.2 | 2 | 1/8 |
9 | 1/9 | 3 | 0.1 | 0.1C7 | 3 | 1/9 |
10 | 1/10 | 2, 5 | 0.1 | 0.19 | 2, 5 | 1/A |
11 | 1/11 | 11 | 0.09 | 0.1745D | B | 1/B |
12 | 1/12 | 2, 3 | 0,083 | 0.15 | 2, 3 | 1/C |
13 | 1/13 | 13 | 0.076923 | 0.13B | D | 1/D |
14 | 1/14 | 2, 7 | 0,0714285 | 0.1249 | 2, 7 | 1/E |
15 | 1/15 | 3, 5 | 0,06 | 0.1 | 3, 5 | 1/F |
16 | 1/16 | 2 | 0,0625 | 0.1 | 2 | 1/10 |
17 | 1/17 | 17 | 0.0588235294117647 | 0.0F | 11 | 1/11 |
18 | 1/18 | 2, 3 | 0,05 | 0,0E38 | 2, 3 | 1/12 |
19 | 1/19 | 19 | 0.052631578947368421 | 0.0D79435E5 | 13 | 1/13 |
20 | 1/20 | 2, 5 | 0,05 | 0,0C | 2, 5 | 1/14 |
21 | 1/21 | 3, 7 | 0.047619 | 0.0C3 | 3, 7 | 1/15 |
22 | 1/22 | 2, 11 | 0,045 | 0,0BA2E8 | 2, B | 1/16 |
23 | 1/23 | 23 | 0.0434782608695652173913 | 0.0B21642C859 | 17 | 1/17 |
24 | 1/24 | 2, 3 | 0,0416 | 0,0A | 2, 3 | 1/18 |
25 | 1/25 | 5 | 0,04 | 0.0A3D7 | 5 | 1/19 |
26 | 1/26 | 2, 13 | 0,0384615 | 0,09D8 | 2, D | 1/1A |
27 | 1/27 | 3 | 0.037 | 0.097B425ED | 3 | 1/1B |
28 | 1/28 | 2, 7 | 0,03571428 | 0,0924 | 2, 7 | 1/1C |
29 | 1/29 | 29 | 0.0344827586206896551724137931 | 0.08D3DCB | 1D | 1/1D |
30 | 1/30 | 2, 3, 5 | 0,03 | 0,08 | 2, 3, 5 | 1/1E |
31 | 1/31 | 31 | 0.032258064516129 | 0.08421 | 1F | 1/1F |
32 | 1/32 | 2 | 0,03125 | 0,08 | 2 | 1/20 |
33 | 1/33 | 3, 11 | 0.03 | 0.07C1F | 3, B | 1/21 |
34 | 1/34 | 2, 17 | 0,02941176470588235 | 0,078 | 2, 11 | 1/22 |
35 | 1/35 | 5, 7 | 0,0285714 | 0.075 | 5, 7 | 1/23 |
36 | 1/36 | 2, 3 | 0,027 | 0,071C | 2, 3 | 1/24 |
La siguiente tabla muestra las expansiones de algunos números irracionales comunes en decimal y hexadecimal.
Número | Representación posicional | |
---|---|---|
Decimal | Hexadecimal | |
√2 (la longitud de la diagonal de un cuadrado de unidad) | 1.414213562373095048... | 1.6A09E667F3BCD... |
√3 (la longitud de la diagonal de un cubo de unidad) | 1.732050807568877293... | 1.BB67AE8584CAA... |
√5 (la longitud de la diagonal de un rectángulo 1×2) | 2.236067977499789696... | 2.3C6EF372FE95... |
φ (fi, la relación de oro = (1+√5)/2) | 1.618033988749894848... | 1.9E3779B97F4A... |
π (pi, la relación de circunferencia al diámetro de un círculo) | 3.141592653589793238462643 383279502884197169399375105... | 3.243F6A8885A308D313198A2E0 3707344A4093822299F31D008... |
e (la base del logaritmo natural) | 2.718281828459045235... | 2.B7E151628AED2A6B... |
τ (la constante Thue-Morse) | 0.412454033640107597... | 0.6996 9669 9669 6996... |
γ (la diferencia límite entre la serie armónica y el logaritmo natural) | 0.577215664901532860... | 0.93C467E37DB0C7A4D1B... |
Las potencias de dos tienen expansiones muy simples en hexadecimal. Las primeras dieciséis potencias de dos se muestran a continuación.
2x | Valor | Valor (decimal) |
---|---|---|
20 | 1 | 1 |
21 | 2 | 2 |
22 | 4 | 4 |
23 | 8 | 8 |
24 | 10Hex | 16dec |
25 | 20Hex | 32dec |
26 | 40Hex | 64dec |
27 | 80Hex | 128dec |
28 | 100Hex | 256dec |
29 | 200Hex | 512dec |
2A (22)10dec) | 400Hex | 1024dec |
2B (22)11dec) | 800Hex | 2048dec |
2C (22)12dec) | 1000Hex | 4096dec |
2D (22)13dec) | 2000Hex | 8192dec |
2E (22)14dec) | 4000Hex | 16.384dec |
2F (22)15dec) | 8000Hex | 32.768dec |
210 (22)16dec) | 10000Hex | 65.536dec |
Las unidades de medida chinas tradicionales eran base-16. Por ejemplo, un jīn (斤) en el antiguo sistema equivale a dieciséis taels. El suanpan (ábaco chino) se puede utilizar para realizar cálculos hexadecimales como sumas y restas.
Al igual que con el sistema duodecimal, ha habido intentos ocasionales de promover el hexadecimal como el sistema numérico preferido. Estos intentos a menudo proponen pronunciación y símbolos específicos para los números individuales. Algunas propuestas unifican medidas estándar para que sean múltiplos de 16. Una de las primeras propuestas de este tipo fue presentada por John W. Nystrom en Project of a New System of Arithmetic, Weight, Measure and Coins: Proposed to be named the Tonal System, with Sixteen to the Base, publicado en 1862. Nystrom, entre otras cosas, sugirió el tiempo hexadecimal, que subdivide un día en 16, para que haya 16 "horas" (o "10 tims", pronunciado tontim) en un día.
La palabra hexadecimal se registró por primera vez en 1952. Es macarónica en el sentido de que combina el griego ἕξ (hex) "seis" con latín -decimal. La alternativa totalmente latina sexadecimal (compárese con la palabra sexagesimal para la base 60) es más antigua y tiene un uso al menos ocasional desde finales del siglo XIX. Todavía está en uso en la década de 1950 en la documentación de Bendix. Schwartzman (1994) argumenta que el uso de sexadecimal puede haberse evitado debido a su abreviatura sugestiva de sexo. Muchos idiomas occidentales desde la década de 1960 han adoptado términos equivalentes en formación a hexadecimal (por ejemplo, hexadecimal francés, esadecimale italiano, hexazecimal rumano i>, serbio хексадецимални, etc.) pero otros han introducido términos que sustituyen palabras nativas por "dieciséis" (por ejemplo, griego δεκαεξαδικός, islandés sextándakerfi, ruso шестнадцатеричной, etc.)
La terminología y la notación no se asentaron hasta finales de la década de 1960. Donald Knuth en 1969 argumentó que el término etimológicamente correcto sería senidenario, o posiblemente sedenario, un término en latín destinado a transmitir "agrupados por 16" modelado en binario, ternario y cuaternario etc. Según el argumento de Knuth, los términos correctos para la aritmética decimal y octal serían denary y octonary, respectivamente. Alfred B. Taylor usó senidenario en su trabajo de mediados del siglo XIX sobre bases numéricas alternativas, aunque rechazó la base 16 debido a su "incómodo número de dígitos".
La notación actual que usa las letras A a F se establece como el estándar de facto a partir de 1966, a raíz de la publicación del manual Fortran IV para IBM System/360, que (a diferencia de las variantes anteriores de Fortran) reconoce un estándar para ingresar constantes hexadecimales. Como se señaló anteriormente, NEC (1960) y The Pacific Data Systems 1020 (1964) utilizaron notaciones alternativas. El estándar adoptado por IBM parece haberse adoptado ampliamente en 1968, cuando Bruce Alan Martin en su carta al editor del CACM se queja de que
Con la ridícula elección de letras A, B, C, D, E, F como símbolos de número hexadecimal añadiendo a problemas ya problemáticos de distinguir números octal (o hex) de números decimales (o nombres variables), el tiempo se superpone para la reconsideración de nuestros símbolos número. Esto debería haber sido hecho antes de que las malas decisiones se congelen en un estándar de facto!
El argumento de Martin era que el uso de números del 0 al 9 en números no decimales "implica para nosotros un esquema de valor posicional en base diez": ¿Por qué no usar símbolos (y nombres) completamente nuevos para los siete o quince dígitos distintos de cero necesarios en octal o hexadecimal? Incluso el uso de las letras de la A a la P sería una mejora, pero los símbolos completamente nuevos podrían reflejar la naturaleza binaria del sistema. También argumentó que "reutilizar letras alfabéticas para dígitos numéricos representa un gigantesco paso atrás desde la invención de glifos distintos y no alfabéticos para números hace dieciséis siglos". (como números de Brahmi, y más tarde en un sistema de numeración hindú-árabe), y que los estándares ASCII recientes (ASA X3.4-1963 y USAS X3.4-1968) "debería haber conservado seis posiciones de la tabla de códigos después de los diez dígitos decimales -- en lugar de llenarlos innecesariamente con caracteres de puntuación" (":;<=>?") que podría haberse colocado en otro lugar entre los 128 puestos disponibles.
Base16 (como nombre propio sin espacio) también puede referirse a una codificación de binario a texto que pertenece a la misma familia que Base32, Base58 y Base64.
En este caso, los datos se dividen en secuencias de 4 bits y cada valor (entre 0 y 15 inclusive) se codifica con uno de los 16 símbolos del juego de caracteres ASCII. Aunque se pueden usar 16 símbolos cualesquiera del conjunto de caracteres ASCII, en la práctica los dígitos ASCII '0'–'9' y las letras 'A'–'F' (o las minúsculas 'a'–'f') siempre se eligen para alinearse con la notación escrita estándar para números hexadecimales.
Hay varias ventajas de la codificación Base16:
Las principales desventajas de la codificación Base16 son:
La compatibilidad con la codificación Base16 es omnipresente en la informática moderna. Es la base del estándar W3C para la codificación de porcentaje de URL, donde un carácter se reemplaza con un signo de porcentaje "%" y su forma codificada en Base16. La mayoría de los lenguajes de programación modernos incluyen soporte directo para formatear y analizar números codificados en Base16.
(leer más)
(leer más)
(leer más)