Código 128


De Wikipedia, la enciclopedia libre
  (Redirigido desde Code128 )
Saltar a navegación Saltar a búsqueda
Un código de barras postal suizo que codifica "RI 476 394 652 CH" en el código 128-B

El código 128 es una simbología de código de barras lineal de alta densidad definida en ISO / IEC 15417: 2007. [1] Se utiliza para códigos de barras alfanuméricos o solo numéricos . Puede codificar los 128 caracteres de ASCII y, mediante el uso de un símbolo de extensión (FNC4), los caracteres Latin-1 definidos en ISO / IEC 8859-1 . [ cita requerida ] . Generalmente da como resultado códigos de barras más compactos en comparación con otros métodos como el Código 39 , especialmente cuando los textos contienen principalmente dígitos.

GS1-128 (anteriormente conocido como UCC / EAN-128) es un subconjunto del Código 128 y se utiliza ampliamente en todo el mundo en las industrias de envío y embalaje como código de identificación de producto para los niveles de contenedores y palés en la cadena de suministro.

Especificación

"Código 128 secciones"
Esquema de un código de barras (Código 128B).
1 : zona tranquila, 2 : código de inicio, 3 : datos, 4 : suma de comprobación, 5 : código de parada

Un código de barras Code 128 tiene siete secciones:

  1. Zona tranquila
  2. Símbolo de inicio
  3. Datos codificados
  4. Símbolo de verificación (obligatorio)
  5. Símbolo de parada
  6. Barra final (a menudo considerada parte del símbolo de parada)
  7. Zona tranquila

El símbolo de verificación se calcula a partir de una suma ponderada ( módulo 103) de todos los símbolos.

Subtipos

El código 128 incluye 108 símbolos: 103 símbolos de datos, 3 símbolos de inicio y 2 símbolos de parada. Cada símbolo consta de tres barras negras y tres espacios en blanco de diferentes anchos. Todos los anchos son múltiplos de un "módulo" básico. Cada barra y espacio tiene de 1 a 4 módulos de ancho, y los símbolos son de ancho fijo: la suma de los anchos de las tres barras negras y tres barras blancas es 11 módulos.

El patrón de parada se compone de dos símbolos superpuestos y tiene cuatro barras. El patrón de parada permite un escaneo bidireccional. Cuando el patrón de parada se lee de izquierda a derecha (el caso habitual), se reconoce el símbolo de parada (seguido de una barra de 2 módulos). Cuando el patrón de parada se lee de derecha a izquierda, se reconoce el símbolo de parada inversa (seguido de una barra de 2 módulos). Un escáner que ve el símbolo de parada en reversa sabe que debe omitir la barra de 2 módulos y leer el resto del código de barras al revés.

A pesar de su nombre, Code 128 no tiene 128 símbolos distintos, por lo que no puede representar 128 puntos de código directamente. Para representar los 128 valores ASCII, cambia entre tres conjuntos de códigos (A, B, C). Juntos, los conjuntos de códigos A y B cubren los 128 caracteres ASCII. El conjunto de códigos C se utiliza para codificar eficazmente cadenas de dígitos. El subconjunto inicial se selecciona utilizando el símbolo de inicio apropiado. Dentro de cada conjunto de códigos, algunos de los 103 puntos de código de datos están reservados para cambiar a uno de los otros dos conjuntos de códigos. Los cambios se realizan utilizando los puntos de código 98 y 99 en los conjuntos de códigos A y B, 100 en los conjuntos de códigos A y C y 101 en los conjuntos de códigos B y C para cambiar entre ellos):

  • 128A (conjunto de códigos A): caracteres ASCII 00 a 95 (0–9, A – Z y códigos de control), caracteres especiales y FNC 1–4
  • 128B (conjunto de códigos B): caracteres ASCII de 32 a 127 (0–9, A – Z, a – z), caracteres especiales y FNC 1–4
  • 128C (conjunto de códigos C) - 00–99 (codifica dos dígitos con un solo punto de código) y FNC1

El ancho mínimo de la zona silenciosa a la izquierda y derecha del Código 128 es 10x, donde x es el ancho mínimo de un módulo. Es obligatorio en el lado izquierdo y derecho del código de barras.

Iniciar / detener y datos codificados

Cada símbolo del código de barras se compone de tres barras y tres espacios. Cada barra o espacio tiene 1, 2, 3 o 4 unidades de ancho, la suma de los anchos de las barras debe ser par (4, 6 u 8 unidades), la suma de los anchos de los espacios debe ser impar (3, 5 o 7 unidades), y un total de 11 unidades por símbolo. Por ejemplo, la codificación del carácter ASCII "0" puede verse como 10011101100, donde una secuencia de unos es una barra y una secuencia de ceros es un espacio. Un solo 1 sería la línea más delgada del código de barras. Tres unos en secuencia (111) indican una barra tres veces más gruesa que una sola barra de 1.

Hay 108 posibles símbolos de 11 unidades de ancho y el código usa todos los símbolos posibles. Dos de los símbolos se utilizan para la indicación de parada (final del código de barras), parada y parada en reversa. Los dos símbolos de parada son especiales porque siempre van seguidos de una barra de 2 unidades, formando un patrón de parada de 13 unidades de largo. Leer el patrón de parada de izquierda a derecha es el símbolo de parada (seguido de una barra de 2 unidades), y leer el patrón de parada de derecha a izquierda es el símbolo de parada inversa (seguido de una barra de 2 unidades).

Cálculo de dígitos de control

El dígito de control es una suma de control de módulo 103 ponderada. Se calcula sumando el 'valor' del código de inicio a los productos del 'valor' de cada símbolo multiplicado por su posición en la cadena del código de barras. El símbolo de inicio y el primer símbolo codificado están en la posición 1. La suma de los productos se reduce en módulo 103. El resto se convierte de nuevo en uno de los 103 símbolos no delimitadores (siguiendo las instrucciones que se dan a continuación ) y se agrega al código de barras. , inmediatamente antes del símbolo de parada.

Por ejemplo, en la siguiente tabla, se calcula el valor de suma de comprobación A de la variante del código 128 para la cadena alfanumérica PJJ123C:

Para calcular el símbolo de verificación, los símbolos de cambio y de cambio de código se tratan de la misma manera que cualquier otro símbolo en el código de barras. La suma de comprobación se calcula sobre los valores de los símbolos, sin tener en cuenta qué conjunto de códigos está activo en ese momento. Por ejemplo, el valor del conjunto de códigos C "33" y el valor del conjunto de códigos B "A" se consideran ambos un valor de Código 128 de 33, y el dígito de control se calcula en función del valor de 33 veces la posición del símbolo dentro del código de barras. .

Usar FNC4 para codificar caracteres altos (128-255)

El símbolo especial FNC4 ("Función 4"), presente solo en los conjuntos de códigos A y B, se puede utilizar para codificar todos los caracteres Latin-1 ( ISO-8859-1 ) en un código de barras Code 128. [2] La función no es ampliamente compatible y no se utiliza en GS1-128. [3] [4] Cuando un solo FNC4 está presente en una cadena, el siguiente símbolo se convierte a ASCII como de costumbre, y luego se agrega 128 al valor ASCII. (Si el siguiente símbolo es un cambio, se utilizará un segundo símbolo para obtener el carácter). Si se utilizan dos FNC4 consecutivamente, todos los caracteres siguientes se tratarán como tales, hasta el final de la cadena u otro par de FNC4 . Entre los FNC4 dobles, se utilizará un solo FNC4 para indicar que el siguiente carácter será ASCII estándar .[5]

Anchos de código de barras

Code128 especifica una combinación de 6 barras y espacios alternados (3 de cada uno) para cada símbolo. Así, cada símbolo comienza con una barra y termina con un espacio. En las fuentes de códigos de barras, la barra final generalmente se combina con el símbolo de parada para hacer un patrón de parada más amplio. La siguiente tabla detalla los anchos asociados con cada barra y el espacio para cada símbolo. El ancho de cada barra o espacio puede ser de 1, 2, 3 o 4 unidades (módulos). Usando el ejemplo anterior, se representaría una 'A' con el patrón 10100011000, o como anchos 111323 en las tablas siguientes.

El valor de los anchos se obtiene contando la longitud de cada serie de 1 y luego 0 en el patrón, comenzando por la izquierda. Siempre habrá 6 corridas y las longitudes de estas 6 corridas forman el valor de Anchuras. Por ejemplo, utilizando el patrón 10100011000, las longitudes de ejecución son 1 (dígito 1), 1 (dígito 0), 1 (dígito 1), 3 (dígito 0), 2 (dígito 1), 3 (dígito 0). Informar solo las longitudes de cada corrida da 1, 1, 1, 3, 2, 3, lo que produce un valor de ancho de 111323.

Los símbolos "Código A", "Código B" y "Código C" hacen que todos los símbolos siguientes se interpreten de acuerdo con el subcódigo correspondiente (es decir, 128A, 128B o 128C). El símbolo "Shift" cambia la interpretación de un solo símbolo siguiente entre los subcódigos A y B.

El carácter ASCII codificado depende de la fuente de código de barras utilizada. Especialmente, el carácter ASCII de valor 0 y de valor 95 y superior puede definirse de manera diferente en la fuente que está instalada.

Los códigos FNC x se utilizan para fines especiales. FNC1 al comienzo de un código de barras indica un código de barras GS1-128 que comienza con un identificador de aplicación de 2 a 3 o 4 dígitos asignado por el Uniform Code Council , que explica los siguientes dígitos. Por ejemplo, el identificador de aplicación 421 indica que sigue un código de país numérico ISO 3166-1 y un código postal de destino. Por lo tanto, el código postal de EE. UU. Para la Casa Blanca generalmente se imprime como "(421) 840 20500", pero en realidad se codifica como " [Start C] [FNC1] 42 18 40 20 50 [Code A] 16 [Check symbol 92] [Stop]".

Verifique el cálculo de dígitos para el ejemplo de código postal anterior:

Disponibilidad

Para el usuario final, los códigos de barras Code 128 pueden ser generados por una aplicación externa para crear una imagen del código de barras o por una solución de código de barras basada en fuentes. Cualquiera de las soluciones requiere el uso de una aplicación o un complemento de aplicación para calcular el dígito de control y crear el código de barras.

Optimización de la longitud del código de barras

El conjunto de códigos C usa un símbolo de código para representar dos dígitos, por lo que cuando el texto contiene solo dígitos, generalmente resultará en códigos de barras más cortos. Sin embargo, cuando la cadena contiene solo unos pocos dígitos o se mezcla con caracteres que no son dígitos, no siempre produce un código más compacto que los conjuntos de códigos A o B. El uso del conjunto de códigos C ahorra un símbolo por cada dos dígitos, pero cuesta un modo -Símbolo de cambio para entrar y salir del conjunto. Por lo tanto, solo vale la pena usarlo si hay suficientes dígitos consecutivos. Por ejemplo, codificar la cadena "X00Y" con el conjunto de códigos A o B requiere 7 símbolos de código ( [Start B] 56 16 16 57 [checksum] [Stop]), mientras que usar el conjunto de códigos C para el "00" daría como resultado un código de 8 símbolos de longitud ( [Start B] 56 [Code C] 00 [Code B] 57 [checksum] [Stop]).

El uso del conjunto de códigos C solo es ventajoso en las siguientes condiciones:

Al final de una cadena, retrasar la transición al conjunto de códigos C hasta que quede un número par de dígitos evita un símbolo adicional. Considere la cadena "... 01234": un cambio retrasado produce ... 0 [Code C] 12 34 [checksum] [Stop]pero produce un cambio temprano ... [Code C] 01 23 [Code A] 4 [checksum] [Stop]. [6]

Por ejemplo, dada la cadena "098x1234567y23", los ahorros en la longitud del código de barras utilizando el conjunto de códigos C se logran solo si se aplica a la parte media de la cadena. Para la parte inicial y final de la cadena, el cambio al conjunto de códigos C no es efectivo. Como hay un número impar de dígitos en el medio de la cadena, el impar debe usar un código diferente, establecido, pero no importa si es el primero o el último; Se requieren 16 símbolos en cualquier caso:, [Start B] 0 9 8 x 1 [Code C] 23 45 67 [Code B] y 2 3 [checksum] [Stop]o [Start B] 0 9 8 x [Code C] 12 34 56 [Code B] 7 y 2 3 [checksum] [Stop].

La optimización de la longitud del código de barras resultante es importante cuando se utilizan lectores de códigos de barras que deben detectar la imagen completa del código de barras a la vez para poder leerla, como los escáneres láser comunes . Cuanto más largo es el código de barras, se necesita mayor distancia entre el lector de códigos de barras láser y la imagen del código de barras, lo que dificulta o imposibilita la lectura por encima de algunas longitudes / distancias de umbral.

La codificación óptima se puede encontrar utilizando un algoritmo de programación dinámica . [7]

Referencias

  1. ^ "ISO / IEC 15417: 2007 - Tecnología de la información - Técnicas de captura de datos e identificación automática - Especificación de simbología de código de barras Código 128" . www.iso.org . Consultado el 15 de febrero de 2018 .
  2. ^ Aparentemente ISO 15417 Anexo F
  3. ^ "Código 128 explicado" . Softmatic GmbH . Consultado el 21 de enero de 2017 . En principio, los caracteres no ASCII como diéresis alemanas (p. Ej., ÄÖÜ) se pueden codificar en un símbolo Code 128 utilizando un carácter especial (FNC4). Sin embargo, esta función no es ampliamente compatible. Usar una simbología de código de barras 2D como Aztec o Datamatrix con soporte dedicado para datos que no son ASCII podría ser una mejor opción.
  4. ^ Especificaciones Generales GS1 (Enero de 2006 - Versión 7.0), sección 5.3.1.1 Características de Simbología GS1-128, indicando, "Los caracteres con valores ASCII 128 a 255 también se pueden codificar en Símbolos del Código 128. Caracteres con valores ASCII 128 a 255 accedidos por Los caracteres de función 4 (FNC4) están reservados para uso futuro y no se utilizan en los símbolos de códigos de barras GS1-128 ".
  5. ^ "TBarcode1D_Code128" . Corporación Han-Soft . Consultado el 21 de enero de 2017 .Si se utiliza un solo carácter "FNC 4", indica que el siguiente carácter de datos en el símbolo es un carácter ASCII extendido. Un carácter 'SHIFT' puede seguir al carácter 'FNC 4' si es necesario cambiar el subconjunto de caracteres para el siguiente carácter de datos. Los caracteres de datos posteriores vuelven al juego de caracteres ASCII estándar. Si se utilizan dos caracteres 'FNC4' consecutivos, todos los caracteres de datos siguientes son caracteres ASCII extendidos hasta que se encuentren dos caracteres 'FNC4' consecutivos más o se alcance el final del símbolo. Si durante esta secuencia de codificación extendida se encuentra un solo carácter "FNC4", se utiliza para volver a la codificación ASCII estándar solo para el siguiente carácter de datos. 'CAMBIO'y los caracteres del subconjunto de caracteres tendrán su efecto normal durante dicha secuencia.
  6. ^ Especificaciones generales GS1, versión 13, edición 1, enero de 2013, sección 5.4.7.7. Uso de símbolos de inicio, conjunto de códigos y cambio para minimizar la longitud del símbolo (informativo), páginas 268 a 269. Esta sección brinda la estrategia de compresión.
  7. ^ Skiena, Steven S. (2010). "8.9 War Story: compresión de texto para códigos de barras". El Manual de diseño de algoritmos (2ª ed.). ISBN 1-849-96720-2. La programación dinámica condujo a una codificación un 8% más ajustada en promedio.

enlaces externos

  • Especificación GS1-128 : una lista detallada de identificadores de aplicación.
  • Barcodesoft : mapeo de fuentes de Barcodesoft, que difiere del mapeo ascii común (consulte http://ascii-code.com/ ).
  • El código 128 : aprenda el algoritmo de codificación del Código 128 con una solución de código de barras basada en fuentes.
  • Generador de códigos de barras en línea: generador de códigos de barras en línea gratuito para los distintos tipos de códigos de barras.

Código de muestra

  • ZXing - Escáner / generador de código de barras multiplataforma de código abierto con versiones disponibles en Java (proyecto principal) y puertos para ActionScript, C ++, C #, ObjectiveC y Ruby.
  • Código de barras 128 de Python : este código parece dibujar cuadros de un píxel de ancho. Parece que se modificó a partir de un código de barras de línea corta y larga que habría dibujado líneas. Las "cajas negras" deben tener el mismo tamaño que las "cajas blancas".
  • GenCode128 : implementación gratuita del código fuente C # de Code128. Casi todas las funciones están implementadas, pero no están completas al 100%.
  • Barcode1DTools Ruby gem : código fuente de Ruby para muchas simbologías de códigos de barras 1D, incluido el código 128.
  • Código de generación de códigos de barras Perl: código fuente de Perl para muchas simbologías de códigos de barras 1D, incluido el Código 128.
  • Barcode :: Code128 - Módulo gratuito de generación de códigos de barras Perl.
  • GOCR : OCR gratuito con reconocimiento de código 128.
  • Código de barras 128 : implementación gratuita del código fuente JavaScript de Code128.
  • Barcode4J : API Java gratuita con implementación de Code128 y otros códigos de barras estándar.
  • JavaScript Code 128 : implementación de JavaScript de código abierto de Code128 y otros códigos de barras lineales.
  • Introducción a la creación de códigos de barras Code 128 Guía para convertir texto a códigos de barras Code 128. Escrito para Lazarus (GUI Pascal multiplataforma de código abierto) pero de uso general.
Obtenido de " https://en.wikipedia.org/w/index.php?title=Code_128&oldid=1043931427 "