x
1

Universal Product Code



El Código Universal de Producto (UPC) es una simbología de código de barras que se utiliza ampliamente en los Estados Unidos, Canadá, Reino Unido, Australia, Nueva Zelanda, Europa y otros países para rastrear artículos comerciales en las tiendas.

UPC (técnicamente se refiere a UPC-A) consta de 12 dígitos numéricos, que se asignan de forma única a cada artículo comercial. Junto con el código de barras EAN relacionado, el UPC es el código de barras utilizado principalmente para el escaneo de artículos comerciales en el punto de venta, según las especificaciones GS1.[1]​ Las estructuras de datos de la UPC son un componente de los GTIN y siguen la especificación GS1 global, que se basa en estándares internacionales. Pero algunos minoristas (ropa, muebles) no usan el sistema GS1 (más bien otras simbologías de códigos de barras o sistemas de números de artículos). Por otro lado, algunos minoristas utilizan la simbología de códigos de barras EAN / UPC, pero sin utilizar un GTIN (solo para productos vendidos en sus propias tiendas).

Wallace Flint propuso un sistema de pago automatizado en 1932 utilizando tarjetas perforadas. Bernard Silver y Norman Joseph Woodland, un estudiante graduado del Instituto de Tecnología Drexel (ahora Universidad de Drexel), desarrollaron un código de estilo bull's-eye (de ojo de buey) y solicitaron la patente en 1949.

En la década de 1960, los ferrocarriles experimentaron con un código de barras multicolor para rastrear vagones, pero finalmente lo abandonaron.[2]

Un grupo de asociaciones comerciales de la industria de comestibles formó el Consejo Uniforme de Código de Productos de Comestibles que, junto con los consultores Larry Russell y Tom Wilson de McKinsey & Company, definieron el formato numérico del Código Uniforme de Productos.[3]​ Las empresas de tecnología como Charegon, IBM, Litton-Zellweger, Pitney Bowes-Alpex, Plessey-Anker, RCA, Scanner Inc., Singer, y Dymo Industries/Data General propusieron representaciones alternativas de símbolos para el consejo. Al final, el Comité de selección de símbolos eligió modificar ligeramente, cambiando la fuente en el área legible por humanos, la propuesta de IBM diseñada por George J. Laurer.

El primer artículo marcado UPC que se escaneó en una venta minorista fue en el supermercado Marsh en Troy, Ohio, a las 8:01 a.m. del 26 de junio de 1974, y era un paquete de 10 (50 cartuchos) de chicle Wrigley's Juicy Fruit. El comprador fue Clyde Dawson y la cajera Sharon Buchanan realizó el primer escaneo UPC. La caja registradora de NCR registró un aumento de 67 centavos.[4]​ Todo el carro de la compra también tenía artículos con código de barras, pero el chicle fue el primero recogido. Este artículo se exhibió en el Museo Nacional de Historia Estadounidense del Instituto Smithsoniano en Washington, D.C.[5]

Hacia fines de 1969, IBM en Research Triangle Park (RTP) en Carolina del Norte asignó a George Laurer la tarea de determinar cómo hacer un escáner y una etiqueta de supermercado. A fines de 1970, Heard Baumeister proporcionó ecuaciones para calcular los caracteres por pulgada que se pueden obtener mediante dos códigos de barra de IBM, Delta A y Delta B. En febrero de 1971, Baumeister se unió a Laurer.

A mediados de 1971, William "Bill" Crouse inventó un nuevo código de barras llamado Delta C. Logró cuatro veces los caracteres por pulgada que Delta B. Delta B comparó los anchos de barra con el ancho del espacio para codificar los bits.[6]​ Esto era extremadamente sensible a la extensión de la tinta donde demasiada tinta o presión causarían que ambos bordes de una barra se extendieran hacia afuera y demasiado poco para hacer que se encogieran. Para empeorar las cosas, los espacios de barras se reducen y viceversa. Delta C logró su mayor rendimiento al usar únicamente bordes de entrada o de salida a finales que no se vieron afectados por la dispersión de tinta uniforme. El código proporcionaba el mejor rendimiento cuando tenía un juego de caracteres definido con una distancia de referencia fija que abarcaba la mayoría o preferiblemente todo el carácter. En agosto de 1971, Crouse se unió al esfuerzo del escáner. Después de varios meses, no progresaron. Estaban al tanto de la etiqueta de ojo de buey de RCA que se podía escanear con un escáner láser de línea recta simple, pero una etiqueta legible era demasiado grande. Aunque Litton Industries propuso un símbolo de ojo de buey cortado a la mitad para reducir el área, seguía siendo demasiado grande y presentaba los mismos problemas de impresión de tinta que el símbolo RCA. La redundancia y la capacidad de comprobación se eliminaron por completo. También conocían las numerosas propuestas de todo el mundo, ninguna de las cuales era factible.

En la primavera de 1972, Baumeister anunció un gran avance. Propuso una etiqueta con barras que eran un poco más largas que la distancia en todas las barras que necesitaban leerse en una sola pasada. Esta etiqueta se puede escanear con un simple escáner "X", solo un poco más complejo que el escáner láser de línea recta. Al día siguiente, Baumeister sugirió que si la etiqueta se dividía en dos mitades, la longitud de las barras podría reducirse casi a la mitad. Estas dos propuestas redujeron el área del ojo de buey en un tercio y luego en un sexto. La imagen a la derecha muestra la etiqueta propuesta por Baumeister. Él no especificó ningún código de barras específico, ya que eso se entendía bien. Excepto por la codificación de barras y los diez dígitos, la etiqueta de UPC hoy es su propuesta. Poco después, Baumeister se transfirió a otra área de RTP.

Laurer procedió a definir los detalles de la etiqueta y a escribir una propuesta. N.J. Woodland fue asignado como planificador para el proyecto y ayudó a Laurer a escribir su propuesta.

El primer intento de Laurer con un código de barras usó Delta B. El tamaño resultante de la etiqueta era aproximadamente seis pulgadas por tres pulgadas, que era demasiado grande. Crouse sugirió que Laurer usara su código de barras Delta C y proporcionó una copia de su patente que tenía un conjunto de caracteres alfanuméricos de muestra y reglas para generar alfabetos de otros tamaños. Esto redujo el tamaño de la etiqueta a aproximadamente 1.5 "x 0.9". Más tarde, Laurer le pidió ayuda a Crouse sobre cómo el escáner podría detectar una etiqueta. Juntos definieron barras de protección y una definición de cómo detectar la etiqueta. Las barras de protección también proporcionaron identificación para la mitad de la discriminación de etiquetas y barras de entrenamiento para los circuitos de umbral del escáner. Laurer tenía una definición de etiqueta completa y procedió a escribir su propuesta.[7]

Anteriormente, Crouse tenía una idea para una varita simple que se usaba como un anillo y una pulsera. Decidió desarrollar esa varita para proporcionar una demostración de la etiqueta.

El 1 de diciembre de 1972, IBM presentó la propuesta de Laurer al Comité de Supermercados en Rochester, Minnesota, la ubicación donde IBM desarrollaría el escáner. Durante la presentación, Crouse realizó una demostración de laboratorio en la que leyó etiquetas tipo UPC con su varita mágica. Además de leer las etiquetas regulares, leyó la etiqueta grande de dos páginas en el folleto de la propuesta. Luego pasó a una página que muestra una foto de artículos etiquetados que se sientan en una mesa. Las etiquetas eran pequeñas y defectuosas debido a la resolución de la foto impresa, pero la varita leyó muchas de ellas. Esta demostración mostró la solidez del código Delta C puro. La propuesta fue aceptada.

Un mes después, el 1 de enero de 1973, Crouse se transfirió nuevamente al grupo de Tecnología Avanzada de IBM, y Laurer se quedó con la plena responsabilidad de la etiqueta.

Dymo Industries, fabricantes de dispositivos de impresión de mano, insistió en que el código debe ser independiente del carácter, de modo que los dispositivos de impresión portátiles puedan producir el código de barras en la tienda si los artículos no tienen códigos de barras por parte de los fabricantes. La propuesta de Dymo fue aceptada por IBM e incorporada en la última propuesta de IBM.

Se decidió que las dos mitades de la etiqueta deberían tener un conjunto diferente de caracteres numéricos. El conjunto de caracteres Laurer derivado de la patente Delta C utilizó siete incrementos o unidades imprimibles en los que se imprimirían dos barras y dos espacios. Esto produjo veinte combinaciones de caracteres, pero hubo dos pares que, cuando fueron leídos por las reglas de Delta C, arrojaron el mismo código para el par. Como dieciocho caracteres no eran suficientes, Laurer intentó agregar una unidad al juego de caracteres. Esto produjo veintiséis caracteres de Delta C que podrían proporcionar los dos conjuntos de caracteres decimales pero también agregó catorce por ciento del ancho de la etiqueta y, por lo tanto, la altura. Esto sería un aumento del treinta por ciento en el área o una etiqueta de 1.7 "x1.03". Laurer sintió que esto no era aceptable. Volvió al juego de caracteres original con veinte caracteres, pero cuatro de ellos eran dos pares con la misma lectura de Delta C. Él decidió usarlos a todos. Para distinguir entre los pares, mediría un ancho de barra en cada uno de los pares para distinguirlos entre sí. Para cada par, esas barras tendrían una o dos unidades de ancho. Laurer no aplicó las ecuaciones de Baumeister a este conjunto. Sintió que solo una medición de ancho de barra no sería demasiado seria. Resultó que habría requerido más del cincuenta por ciento de aumento en ancho y alto para un aumento de área de más del doble. Laurer más tarde admitió que estos cuatro personajes en cada conjunto eran responsables de la mayoría de los errores de lectura del escáner.

A David Savir, un matemático, se le dio la tarea de probar que el símbolo podía imprimirse y que cumpliría con los requisitos de confiabilidad, y muy probablemente no conocía las ecuaciones de Baumeister. Él y Laurer agregaron dos dígitos más a los diez para la corrección de errores y la detección. Luego decidieron agregar la paridad impar / par a la cantidad de unidades llenas de barras en cada lado. La paridad impar / par es una técnica utilizada para detectar cualquier cantidad impar de errores de bit en un flujo de bits. Decidieron usar impar en una mitad e incluso en la otra. Esto proporcionaría una indicación adicional de qué medio ticket se estaba leyendo. Esto significaba que cada ancho de barra debía leerse con precisión para proporcionar una buena lectura. También significaba que cada espacio también sería conocido. Exigir que se lea el ancho de todos los bits, básicamente anuló la ventaja de Delta C, excepto para la medición de referencia Delta C. Solo el extraño conjunto de caracteres y el tamaño de la etiqueta permanecen como una sombra del código Delta C. El tamaño todavía era el calculado para Delta C puro. Si el tamaño de la etiqueta se hubiera recalculado correctamente, teniendo en cuenta las medidas de ancho de barra requeridas, la etiqueta habría sido demasiado grande para ser aceptable.

La ingeniería mecánica y el diseño de circuitos electrónicos comúnmente requieren diseños de peor caso con tolerancias conocidas. Muchos ingenieros que trabajan con códigos de barras tenían poca experiencia con tales cosas y usaban métodos algo intuitivos. Esta fue la causa del bajo rendimiento del código Delta B y muy probablemente el fallo del escáner de ojo de buey de RCA.

La siguiente tabla muestra las etiquetas viables, disponibles a principios de la década de 1970, con sus tamaños.

Esto es suponiendo un ojo de buey con la misma información y la legibilidad fiable.

Cada código de barras UPC-A consiste en una franja escaneable de barras negras y espacios en blanco sobre una secuencia de 12 dígitos numéricos. No pueden aparecer letras, caracteres u otro contenido de ningún tipo en un código de barras UPC-A. Hay una correspondencia de uno a uno entre el número de 12 dígitos y la tira de barras negras y espacios en blanco, es decir, solo hay una forma de representar visualmente cada número de 12 dígitos y solo hay una forma de representar cada banda de barras negras y espacios en blanco numéricamente.

622/5000 El área escaneable de cada código de barras UPC-A sigue el patrón SLLLLLLMRRRRRRE, donde los patrones de protección S (inicio), M (medio) y E (extremo) se representan de la misma manera en cada código de barras UPC-A y en la izquierda (L) Las secciones R (derecha) representan colectivamente los 12 dígitos numéricos que hacen que cada UPC-A sea único. El primer dígito L indica un sistema numérico particular para ser utilizado por los siguientes dígitos. El último dígito R es un código de control de detección de errores que permite detectar algunos errores en el escaneo o la entrada manual. Los patrones de guardia separan los dos grupos de seis dígitos numéricos y establecen el tiempo.

Nota: UPC-A 042100005264 es equivalente a UPC-E 425261 con el patrón de paridad "EOEEOO", que se define mediante el sistema de número UPC-A 0 y el dígito de control 4 de UPC-A.

Los códigos de barras UPC-A se pueden imprimir en varias densidades para adaptarse a una variedad de procesos de impresión y escaneo. El parámetro dimensional significativo se denomina dimensión x (ancho del elemento de módulo individual). El ancho de cada barra (espacio) se determina multiplicando la dimensión xy el ancho del módulo (1, 2, 3 o 4 unidades) de cada barra (espacio). Dado que los patrones de protección incluyen dos barras, y cada uno de los 12 dígitos del código de barras UPC-A consta de dos barras y dos espacios, todos los códigos de barras de UPC-A consisten exactamente (3 × 2) + (12 × 2) = 30 barras, de las cuales 6 representan patrones de guardia y 24 representan dígitos numéricos.

La dimensión x para el UPC-A en el tamaño nominal es de 0,33 mm (0,013 "). La altura nominal del símbolo para UPC-A es de 25,9 mm (1,02"). Las barras que forman los patrones de protección S (inicio), M (medio) y E (extremo) se extienden hacia abajo 5 veces x dimensión, con una altura de símbolo nominal resultante de 27.55 mm (1.08 "). Esto también se aplica a las barras del primer y último dígito numérico del código de barras del UPC-A. UPC-A puede reducirse o magnificarse entre 80% y 200%. 

Una zona silenciosa, con un ancho de al menos 9 veces la dimensión x, debe estar presente en cada lado del área escaneable del código de barras UPC-A.[8][9]​ Para un número GTIN-12 codificado en un código de barras UPC-A, los primeros y últimos dígitos se colocan siempre fuera del símbolo para indicar las zonas silenciosas que son necesarias para que los escáneres de códigos de barras funcionen correctamente.

El código de barras UPC-A se representa visualmente mediante tiras de barras y espacios que codifican el número UPC de 12 dígitos. Cada dígito está representado por un patrón único de 2 barras y 2 espacios. Las barras y los espacios son de ancho variable, es decir, 1, 2, 3 o 4 módulos de ancho. El ancho total para un dígito es siempre 7 módulos; en consecuencia, el número UPC de 12 dígitos requiere un total de 7 × 12 = 84 módulos.

Un UPC-A completo tiene 95 módulos de ancho: 84 módulos para los dígitos (secciones L y R) combinados con 11 módulos para los patrones de protección S (inicio), M (medio) y E (final). Los patrones de protección S (inicio) y E (final) tienen 3 módulos de ancho y utilizan el patrón bar-barra-espacio, donde cada barra y espacio tiene un ancho de módulo. El patrón de guardia M (medio) tiene 5 módulos de ancho y utiliza el patrón espacio-barra-espacio-barra-espacio, donde cada barra y espacio también tiene un ancho de módulo. Además, un símbolo UPC-A requiere una zona silenciosa (espacio adicional de 9 módulos de ancho) antes de los patrones de protección S (inicio) y después de E (final).

inicio

dígito numérico izquierdo

medio

dígito numérico derecho

fin

Los dígitos del lado izquierdo del UPC-A (los dígitos a la izquierda del patrón de protección M (medio)) tienen una paridad impar, lo que significa que el ancho total de las barras negras es un número impar de módulos. Por el contrario, los dígitos del lado derecho tienen paridad par. En consecuencia, un escáner UPC puede determinar si está escaneando un símbolo de izquierda a derecha o de derecha a izquierda (el símbolo está al revés). Después de ver un patrón de protección S (inicio) o E (final) (son lo mismo, barra-barra-espacio, cualquiera que sea la dirección en que se leen), el escáner verá primero dígitos impares de paridad, si está escaneando de izquierda a derecha, o incluso dígitos de paridad, si escanea de derecha a izquierda. Con la información de paridad / dirección, un símbolo al revés no confundirá al escáner. Cuando se enfrenta con un símbolo al revés, el escáner simplemente puede ignorarlo (muchos escáneres alternan escaneos de izquierda a derecha y de derecha a izquierda, por lo que leerán el símbolo en un pase posterior) o reconocer los dígitos y ponerlos en el orden correcto. Hay otra propiedad en la codificación de dígitos. Los dígitos del lado derecho son el inverso óptico de los dígitos del lado izquierdo, es decir, las barras negras se convierten en espacios en blanco y viceversa. Por ejemplo, el lado izquierdo "4" es el espacio × 1 - barra × 1 - espacio × 3 - barra × 2, mientras que el lado derecho "4" es barra × 1 - espacio × 1 - barra × 3 - espacio × 2.

La cantidad de códigos de barras UPC-A y UPC-E está limitada por los estándares utilizados para crearlos.

UPC-A: (10 valores posibles por dígito izquierdo ^ 6 dígitos de la izquierda) × (10 valores posibles por dígito derecho ^ 5 dígitos de la derecha) = 100,000,000,000.UPC-E: (10 valores posibles por dígito ^ 6 dígitos) × (2 posibles patrones de paridad por número UPC-E) = 2,000,000.

A continuación se incluye una descripción de todos los sistemas de números posibles con el correspondiente esquema de numeración UPC-A de 12 dígitos LLLLLLRRRRRR, donde L indica el dígito del sistema numérico y el dígito de control R:

Si un código ingresado no satisface la ecuación, entonces no es un UPC-A válido.

El dígito de control UPC-A se puede calcular de la siguiente manera:

Por ejemplo, en un código de barras UPC-A "03600029145x12", donde x12 es el dígito de control desconocido, x12 puede calcularse mediante:

Por lo tanto, el dígito de verificación de x12 es 2.

La ecuación del dígito de verificación se selecciona para tener propiedades razonables de detección de errores (véase algoritmo de Luhn).

UPC en su uso más común técnicamente se refiere a UPC-A.

Existen otras variantes de la UPC:

A medida que la UPC se vuelve tecnológicamente obsoleta, se espera que UPC-B y UPC-C desaparezcan del uso común para la década de 2010. El estándar UPC-D puede modificarse en EAN 2.0 o eliminarse por completo.[¿quién?]

Para permitir el uso de códigos de barras UPC en paquetes más pequeños, donde un código de barras completo de 12 dígitos puede no ajustarse, se desarrolló una versión de UPC "suprimida por cero", llamada UPC-E, en la que el dígito del sistema numérico, todos los ceros finales en el código del fabricante y todos los ceros a la izquierda en el código del producto se suprimen (se omiten).[13]​ Esta simbología difiere de UPC-A en que solo usa un código de 6 dígitos, no usa un patrón de guarda M (medio) y el patrón de guarda E (final) está formado como barra-espacio-barra-espacio-barra-espacio-barra-espacial , es decir, el código de barras UPC-E sigue el patrón SDDDDDDE. La forma en que un UPC-E de 6 dígitos se relaciona con un UPC-A de 12 dígitos se determina mediante el patrón numérico UPC-E y el patrón de paridad UPC-E. Solo puede corresponder al sistema numérico de UPC-A 0 o 1, cuyo valor, junto con el dígito de control UPC-A, determina el patrón de paridad UPC-E de la codificación. Con los dígitos del código del fabricante representados por X, y los dígitos del código del producto por N, entonces:

Por ejemplo, un UPC-E 654321 puede corresponder al UPC-A 065100004327 o 165100004324, dependiendo del patrón de paridad UPC-E de los dígitos codificados, como se describe a continuación:

sistema numérico 0

sistema numérico 1

UPC-E 654321 con patrón de paridad "EOEOEO" (UPC-A 065100004327) se codificaría como:

1-1-1  4-1-1-1  1-2-3-1  2-3-1-1  1-4-1-1  2-2-1-2  2-2-2-1  1-1-1-1-1-1.

El EAN-13 fue desarrollado como un superconjunto de UPC-A, agregando un dígito extra al comienzo de cada número UPC-A. Esto amplió el número de valores únicos teóricamente posibles en diez veces a 1 billón. Los códigos de barras EAN-13 también indican el país en el que se basa la empresa que vende el producto (que puede ser o no igual que el país en el que se fabrica el bien). Los tres dígitos iniciales del código determinan esto, de acuerdo con los códigos de país GS1. Cada código UPC-A se puede convertir fácilmente al código EAN-13 equivalente al anteponer 0 dígitos al código UPC-A. Esto no cambia el dígito de control. Todos los sistemas de punto de venta ahora pueden entender ambos por igual

EAN-8 es una variación de 8 dígitos del código de barras EAN.

Notas de uso de UPC:



Escribe un comentario o lo que quieras sobre Universal Product Code (directo, no tienes que registrarte)


Comentarios
(de más nuevos a más antiguos)


Aún no hay comentarios, ¡deja el primero!