2.3: Extensión de Códigos
- Page ID
- 82269
\( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)
\( \newcommand{\id}{\mathrm{id}}\) \( \newcommand{\Span}{\mathrm{span}}\)
( \newcommand{\kernel}{\mathrm{null}\,}\) \( \newcommand{\range}{\mathrm{range}\,}\)
\( \newcommand{\RealPart}{\mathrm{Re}}\) \( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)
\( \newcommand{\Argument}{\mathrm{Arg}}\) \( \newcommand{\norm}[1]{\| #1 \|}\)
\( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)
\( \newcommand{\Span}{\mathrm{span}}\)
\( \newcommand{\id}{\mathrm{id}}\)
\( \newcommand{\Span}{\mathrm{span}}\)
\( \newcommand{\kernel}{\mathrm{null}\,}\)
\( \newcommand{\range}{\mathrm{range}\,}\)
\( \newcommand{\RealPart}{\mathrm{Re}}\)
\( \newcommand{\ImaginaryPart}{\mathrm{Im}}\)
\( \newcommand{\Argument}{\mathrm{Arg}}\)
\( \newcommand{\norm}[1]{\| #1 \|}\)
\( \newcommand{\inner}[2]{\langle #1, #2 \rangle}\)
\( \newcommand{\Span}{\mathrm{span}}\) \( \newcommand{\AA}{\unicode[.8,0]{x212B}}\)
\( \newcommand{\vectorA}[1]{\vec{#1}} % arrow\)
\( \newcommand{\vectorAt}[1]{\vec{\text{#1}}} % arrow\)
\( \newcommand{\vectorB}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vectorC}[1]{\textbf{#1}} \)
\( \newcommand{\vectorD}[1]{\overrightarrow{#1}} \)
\( \newcommand{\vectorDt}[1]{\overrightarrow{\text{#1}}} \)
\( \newcommand{\vectE}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash{\mathbf {#1}}}} \)
\( \newcommand{\vecs}[1]{\overset { \scriptstyle \rightharpoonup} {\mathbf{#1}} } \)
\( \newcommand{\vecd}[1]{\overset{-\!-\!\rightharpoonup}{\vphantom{a}\smash {#1}}} \)
\(\newcommand{\avec}{\mathbf a}\) \(\newcommand{\bvec}{\mathbf b}\) \(\newcommand{\cvec}{\mathbf c}\) \(\newcommand{\dvec}{\mathbf d}\) \(\newcommand{\dtil}{\widetilde{\mathbf d}}\) \(\newcommand{\evec}{\mathbf e}\) \(\newcommand{\fvec}{\mathbf f}\) \(\newcommand{\nvec}{\mathbf n}\) \(\newcommand{\pvec}{\mathbf p}\) \(\newcommand{\qvec}{\mathbf q}\) \(\newcommand{\svec}{\mathbf s}\) \(\newcommand{\tvec}{\mathbf t}\) \(\newcommand{\uvec}{\mathbf u}\) \(\newcommand{\vvec}{\mathbf v}\) \(\newcommand{\wvec}{\mathbf w}\) \(\newcommand{\xvec}{\mathbf x}\) \(\newcommand{\yvec}{\mathbf y}\) \(\newcommand{\zvec}{\mathbf z}\) \(\newcommand{\rvec}{\mathbf r}\) \(\newcommand{\mvec}{\mathbf m}\) \(\newcommand{\zerovec}{\mathbf 0}\) \(\newcommand{\onevec}{\mathbf 1}\) \(\newcommand{\real}{\mathbb R}\) \(\newcommand{\twovec}[2]{\left[\begin{array}{r}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\ctwovec}[2]{\left[\begin{array}{c}#1 \\ #2 \end{array}\right]}\) \(\newcommand{\threevec}[3]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\cthreevec}[3]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \end{array}\right]}\) \(\newcommand{\fourvec}[4]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\cfourvec}[4]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \end{array}\right]}\) \(\newcommand{\fivevec}[5]{\left[\begin{array}{r}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\cfivevec}[5]{\left[\begin{array}{c}#1 \\ #2 \\ #3 \\ #4 \\ #5 \\ \end{array}\right]}\) \(\newcommand{\mattwo}[4]{\left[\begin{array}{rr}#1 \amp #2 \\ #3 \amp #4 \\ \end{array}\right]}\) \(\newcommand{\laspan}[1]{\text{Span}\{#1\}}\) \(\newcommand{\bcal}{\cal B}\) \(\newcommand{\ccal}{\cal C}\) \(\newcommand{\scal}{\cal S}\) \(\newcommand{\wcal}{\cal W}\) \(\newcommand{\ecal}{\cal E}\) \(\newcommand{\coords}[2]{\left\{#1\right\}_{#2}}\) \(\newcommand{\gray}[1]{\color{gray}{#1}}\) \(\newcommand{\lgray}[1]{\color{lightgray}{#1}}\) \(\newcommand{\rank}{\operatorname{rank}}\) \(\newcommand{\row}{\text{Row}}\) \(\newcommand{\col}{\text{Col}}\) \(\renewcommand{\row}{\text{Row}}\) \(\newcommand{\nul}{\text{Nul}}\) \(\newcommand{\var}{\text{Var}}\) \(\newcommand{\corr}{\text{corr}}\) \(\newcommand{\len}[1]{\left|#1\right|}\) \(\newcommand{\bbar}{\overline{\bvec}}\) \(\newcommand{\bhat}{\widehat{\bvec}}\) \(\newcommand{\bperp}{\bvec^\perp}\) \(\newcommand{\xhat}{\widehat{\xvec}}\) \(\newcommand{\vhat}{\widehat{\vvec}}\) \(\newcommand{\uhat}{\widehat{\uvec}}\) \(\newcommand{\what}{\widehat{\wvec}}\) \(\newcommand{\Sighat}{\widehat{\Sigma}}\) \(\newcommand{\lt}{<}\) \(\newcommand{\gt}{>}\) \(\newcommand{\amp}{&}\) \(\definecolor{fillinmathshade}{gray}{0.9}\)Muchos códigos son diseñados por humanos. A veces, los códigos son increíblemente robustos, simples, fáciles de trabajar y extensibles. A veces son frágiles, arcanos, complejos, y desafían hasta la generalización más simple. A menudo se desarrolla un código simple y práctico para representar un pequeño número de elementos, y su éxito llama la atención y la gente comienza a usarlo fuera de su contexto original, para representar una clase más grande de objetos, para fines no previstos originalmente.
Los códigos generalizados a menudo llevan consigo sesgos involuntarios de su contexto original. A veces los resultados son simplemente divertidos, pero en otros casos tales sesgos hacen que sea difícil trabajar con los códigos.
Un ejemplo de un sesgo razonablemente benigno es el hecho de que ASCII tiene dos caracteres que originalmente estaban destinados a ser ignorados. ASCII comenzó como el patrón de 7 bits de agujeros en cinta de papel, utilizado para transferir información hacia y desde máquinas de teletipo. La cinta originalmente no tenía agujeros (excepto una serie de pequeños agujeros, siempre presentes, para alinear y alimentar la cinta), y viajó a través de un punzón. La cinta podría ser punzonada ya sea desde una transmisión recibida, o bien por un humano escribiendo en un teclado. Los escombros de esta operación de perforación se conocían como “chad”. El líder (la primera parte de la cinta) estaba sin perforar, y por lo tanto representó, en efecto, una serie del carácter 0000000 de longitud indeterminada (0 se representa como sin agujero). Por supuesto, cuando se leyó la cinta se debía ignorar al líder, por lo que por convención el personaje 0000000 se llamaba NUL y fue ignorado. Posteriormente, cuando se utilizó ASCII en computadoras, diferentes sistemas trataron NUL de manera diferente. Unix trata a NUL como el final de una palabra en algunas circunstancias, y este uso interfiere con aplicaciones en las que a los caracteres se les da una interpretación numérica. El otro código ASCII que originalmente se pretendía ignorar es DEL, 1111111. Esta convención fue útil para los mecanógrafos que podían “borrar” un error haciendo una copia de seguridad de la cinta y perforando cada agujero. En contextos modernos, EL suele tratarse como un retroceso destructivo, pero algunos editores de texto en el pasado han usado DEL como un carácter de eliminación hacia adelante, y a veces simplemente se ignora.
Un sesgo mucho más serio que lleva ASCII es el uso de dos caracteres, CR (retorno de carro) y LF (avance de línea), para pasar a una nueva línea de impresión. El mecanismo físico en las máquinas de teletipo tenía hardware separado para mover el papel (en rollo continuo) hacia arriba y reposicionar el elemento de impresión al margen izquierdo. Los ingenieros que diseñaron el código que evolucionó a ASCII seguramente sintieron que estaban haciendo algo bueno al permitir que estas operaciones se llamaran por separado. No podrían haber imaginado el dolor que han dado a generaciones posteriores ya que ASCII se adaptó a situaciones con diferentes herrajes y sin necesidad de mover el punto de impresión como lo piden CR o LF por separado. Diferentes sistemas informáticos hacen las cosas de manera diferente: UNIX usa LF para una nueva línea e ignora CR, Macintoshes (al menos antes de OS X) usa CR e ignora LF, y DOS/Windows requiere ambos. Esta incompatibilidad es una fuente continua, grave de frustración y errores. Por ejemplo, en la transferencia de archivos usando FTP (File Transfer Protocol) CR y LF deben convertirse para que se adapten a la plataforma de destino para archivos de texto, pero no para archivos binarios. Algunos programas FTP defieren el tipo de archivo (texto o binario) de la extensión de archivo (la parte del nombre del archivo siguiente al último período). Otros miran dentro del archivo y cuentan el número de “personajes divertidos”. Otros dependen del aporte humano. Estas técnicas suelen funcionar pero no siempre. Las convenciones de extensión de archivos no se siguen universalmente. Los humanos cometen errores. ¿Y si parte de un archivo es texto y parte binaria?