Tải về định dạng Word (2.8MB) Tải về định dạng PDF (40MB)

Tiêu chuẩn quốc gia TCVN 8655:2010 (ISO/IEC 15438:2006) về Công nghệ thông tin – Kỹ thuật phân định và thu nhận dữ liệu tự động – Yêu cầu kỹ thuật về mã vạch PDF 417

TIÊU CHUẨN QUỐC GIA

TCVN 8655:2010

ISO/IEC 15438:2006

CÔNG NGHỆ THÔNG TIN - KĨ THUẬT PHÂN ĐỊNH VÀ THU NHẬN DỮ LIỆU TỰ ĐỘNG - YÊU CẦU KĨ THUẬT VỀ MÃ VẠCH PDF417

Information technology - Automatic identification and data capture techniques - PDF417 bar code symbology specification

Lời nói đầu

TCVN 8655:2010 hoàn toàn tương đương với ISO/IEC 15438:2006.

TCVN 8655:2010 do Tiểu Ban kĩ thuật tiêu chuẩn quốc gia TCVN/JTC1/SC31 "Thu thập dữ liệu tự động" biên soạn, Tổng cục Tiêu chuẩn Đo lường Chất lượng đề nghị, Bộ Khoa học và Công nghệ công bố.

Lời giới thiệu

Công nghệ mã hóa bằng vạch dựa vào sự công nhận các vạch và khoảng trống có kích thước xác định. Có nhiều biện pháp mã hóa thông tin vào dạng vạch, được biết đến với tên gọi là kí hiệu mã hóa, các qui tắc xác định việc chuyển dịch kí tự vào các vạch và khoảng trống và các đặc trưng quan trọng khác được biết đến như quy định kĩ thuật về mã vạch.

Nhà sản xuất thiết bị mã vạch và người sử dụng công nghệ mã vạch yêu cầu có sẵn các tiêu chuẩn quy định kĩ thuật về mã vạch để họ tham khảo khi xây dựng các tiêu chuẩn ứng dụng và tiêu chuẩn về thiết bị. ISO và IEC hiểu rõ và có mục tiêu đối với việc quy định mã vạch trong tiêu chuẩn này là hoàn toàn trong phạm vi chung, không bị ràng buộc vào bất kì hạn chế, giấy phép và phí nào.

 

CÔNG NGHỆ THÔNG TIN - KĨ THUẬT PHÂN ĐỊNH VÀ THU NHẬN DỮ LIỆU TỰ ĐỘNG - YÊU CẦU KĨ THUẬT VỀ MÃ VẠCH PDF417

Information technology - Automatic identification and data capture techniques - PDF417 bar code symbology specification

1. Phạm vi áp dụng

Tiêu chuẩn này quy định các yêu cầu đối với mã vạch PDF417, các đặc tính của mã vạch, việc mã hóa các ký tự dữ liệu, các định dạng mã vạch, các kích thước, các quy tắc sửa lỗi, thuật toán giải mã tham khảo, và số lượng các tham s ứng dụng.

2. Tài liệu viện dẫn

Các tài liệu viện dẫn sau là cần thiết cho việc áp dụng tiêu chuẩn này. Đối với các tài liệu viện dẫn ghi năm công bố thì áp dụng phiên bản được nêu. Đối với tài liệu viện dẫn không ghi năm công bố thì áp dụng phiên bản mới nhất, bao gồm cả các sửa đổi.

TCVN 8656-1:2010 (ISO/IEC 19762-1) Công nghệ thông tin - Kĩ thuật phân định và thu nhận dữ liệu tự động (AIDC) - Thuật ngữ hài hòa - Phần 1: Các thuật ngữ chung liên quan đến AIDC

ISO/IEC 646:1991 Information technology - ISO 7-bit coded character set for information interchange (Công nghệ thông tin - Bộ kí tự mã hóa ISO 7-bit dành cho trao đổi thông tin)

ISO/IEC 8859-1 Information technology - 8-bit single-byte coded graphic character sets - Part 1: Lantin alphabet No. 1 (Công nghệ thông tin - Bộ kí tự đồ họa mã hóa 8 bit đơn - Phần 1: Bảng chữ cái latinh Số 1)

ISO/IEC 15415 Information technology - Automatic identification and data capture techniques - Bar code print quality test specification - two - dimension symbols (Công nghệ thông tin - Kĩ thuật phân định và thu nhận dữ liệu tự động - Yêu cầu kĩ thuật đối với kiểm tra chất lượng in mã vạch - Mã vạch hai chiều)

ISO/IEC 15424 Information technology - Automatic identification and data capture techniques - Data carrier identifiers including symbology identifiers (Công nghệ thông tin - Kĩ thuật phân định và thu nhận dữ liệu tự động - Các số phân định vật mang dữ liệu (gồm cả các mã nhận dạng mã vạch))

ISO/IEC 19762-2 (Information technology - Automatic identification and data capture (AIDC) techniques - Harmonized vocabulary - Part 2: Optically readable media (ORM)) (Công nghệ thông tin - Kĩ thuật phân định và thu nhận dữ liệu tự động (AIDC) - Thuật ngữ hài hòa - Phần 2: Phương tiện đọc quang học)

ISO/IEC 24723, Information technology - Automatic identification and data capture techniques - EAN.UCC Composite bar code symbology specification (Công nghệ thông tin - Kĩ thuật phân định và thu nhận dữ liệu tự động - Yêu cầu kĩ thuật về mã vạch ghép EAN.UCC)

AIM Inc. International technical Standard: ITS/04-001, Extended Channel Interpretations - Part 1: ldentification Schemes and protocols (Tiêu chuẩn kỹ thuật quốc tế: ITS/04/001, Diễn dịch kênh m rộng - Phần 1: Các lược đồ và giao thức phân định)

3. Thuật ngữ và định nghĩa

Trong tiêu chuẩn này sử dụng các thuật ngữ và định nghĩa nêu trong TCVN 8656-1:2010 (ISO/IEC 19762-1).

3.1. Mô hình kênh cơ sở (basic channel model)

Hệ thống chuẩn về việc mã hóa và truyền dữ liệu mã vạch, trong đó các byte gói tin dữ liệu được lấy từ bộ giải mã nhưng không có thông tin kiểm soát về gói tin được truyền

CHÚ THÍCH: Bộ giải mã tuân theo mô hình hoạt động trong Phương thức Kênh Cơ sở.

3.2. Chuỗi vạch-khoảng trống (bar-space sequence)

Chuỗi biểu diễn chiều rộng môđun của các phần tử kí tự mã vạch

3.3. Cụm (cluster)

Bất kỳ ba tập con loại trừ lẫn nhau của các kí tự mã vạch PDF417, các kí tự mã vạch trong cụm đã cho phù hợp với các quy tắc cấu trúc riêng được sử dụng trong việc giải mã mã vạch

3.4. Phương thức nén (compaction mode)

Bất kì ba thuật toán nén dữ liệu trong PDF417 (văn bản, các phương thức nén số và byte) được sử dụng để ánh xạ các byte dữ liệu 8 bít một cách hiệu quả đến các từ mã của PDF417

3.5. Khoảng cách e (e-distance)

Khoảng cách từ đường biên chủ đạo của một phần tử đến đường biên ch đạo của phần tử tương tự tiếp theo, hoặc từ đường biên cuối đến đường biên cuối

3.6. Từ mã điều chỉnh lỗi (error correction codeword)

Từ mã mã hóa giá trị được bắt nguồn từ thuật toán về từ mã điều chỉnh lỗi để kích hoạt các lỗi giải mã được phát hiện và, phụ thuộc vào mức điều chỉnh lỗi, được điều chỉnh

3.7. Diễn dịch kênh mở rộng (Extended Channel Interpretation)

Quy trình trong phạm vi một vài mã vạch, bao gồm PDF417, để thay thế diễn dịch mặc định bằng diễn dịch mặc định khác theo một cách đáng tin cậy

CHÚ THÍCH: Diễn dịch trước khi tạo ra mã vạch có thể được lấy lại sau khi giải mã mã vạch được quét để tái tạo gói tin dữ liệu trong định dạng gốc của nó.

3.8. Mô hình kênh mở rộng (Extended Channel Model)

Hệ thống về mã hóa và truyền các byte gói tin dữ liệu và thông tin kiểm soát về gói tin, thông tin kiểm soát được truyền tải sử dụng các chuỗi thoát ECI

CHÚ THÍCH: Bộ giải mã tuân theo mô hình này hoạt động trong Phương thức Kênh mở rộng.

3.9. Từ mã chức năng (Function codeword)

Trong mã vạch, từ mã bắt đầu bằng một phép tính riêng, ví dụ để chuyển giữa các bộ mã hóa dữ liệu, để gọi một lược đồ nén, để lập trình bộ đọc, hoặc để gọi các ECI

3.10. Mã phân định nhãn toàn cầu (Global Label Identifier)

GLI

Quy trình trong mã vạch PDF417 hoạt động theo một cách tương tự với ECI

CHÚ THÍCH: Hệ thống GLI là tiền thân của hệ thống ECI độc lập

3.11. Macro PDF417 (Macro PDF417)

Quy trình trong mã vạch PDF417 phân tán dữ liệu từ một tệp tin máy tính qua một số mã vạch PDF417 liên quan một cách hợp lý

CHÚ THÍCH 1: Quy trình mở rộng dung lượng dữ liệu ngoài một mã vạch đơn.

CHÚ THÍCH 2: Quy trình này tương tự với đặc tính gắn với cấu trúc trong các mã vạch khác.

3.12. Từ mã Mode latch (Mode Latch codeword)

Từ mã được sử dụng để chuyển từ một phương thức này sang một phương thức khác, có hiệu lực cho tới khi từ mã latch hoặc shift khác trở nên đơn giản hoặc rõ ràng để sử dụng, hoặc đến khi kết thúc mã

3.13. Từ mã Mode Shift (Mode Shift codeword)

Từ mã được sử dụng để chuyển từ một phương thức sang này một phương thức khác, sau khi việc mã hóa trở về phương thức ban đầu

3.14. Từ mã ch báo hàng (Row Indicator codeword)

Từ mã PDF417 sát với kí tự bắt đầu và kí tự kết thúc trong một hàng, trong đó mã hóa thông tin về cấu trúc của mã vạch PDF417 dưới dạng phân định hàng, tổng số hàng và cột, và mức điều chỉnh lỗi

3.15. Bộ Mô tả độ dài mã vạch (Symbol Length Descriptor)

Từ mã đầu tiên trong mã vạch PDF417, trong đó mã hóa tổng số từ mã dữ liệu trong mã vạch

4. Mã vạch, phép tính và thuật ngữ viết tắt

4.1. Mã vạch

Các mã vạch toán học sau đây được áp dụng nhằm đáp ứng các mục đích nêu trong tiêu chuẩn này. Có nhiều trường hợp các mã vạch được sử dụng trong phương trình theo nhiều cách khác nhau. Điều này được áp dụng để nhất quán với việc sử dụng ký hiệu chung và được định nghĩa rõ trong tiêu chuẩn này.

A tỉ lệ bề mặt mã vạch (chiều cao đến chiều rộng) của mã vạch PDF417

b độ dài phần tử trong một ký tự của mã vạch

c số cột của mã vạch trong miền dữ liệu (không bao gồm các từ mã đầu, cuối và chỉ báo hàng)

d từ mã dữ liệu bao gồm tất cả từ mã chức năng

E từ mã điều chỉnh lỗi

e đường biên đến kích thước đường biên tương tự trong kí tự mã vạch

F số hàng

f số lỗi thay thế

H độ cao của mã vạch bao gồm vùng trống

K số cụm

k số từ mã sửa lỗi

L ch báo hàng trái

l số vết xóa

m số từ mã dữ liệu nguồn trước khi bổ sung bộ Mô tả Độ dài Mã vạch và các từ mã đệm

n tổng số các từ mã dữ liệu bao gồm bộ Mô tả Độ dài Mã vạch và các từ mã đệm

p độ dốc và chiều rộng của ký tự mã vạch

QH vùng trống nằm ngang

Qv vùng trống thẳng đứng

R chỉ báo hàng phải

r số hàng trong mã vạch

s mức điều chỉnh lỗi

W độ rộng của mã vạch bao gồm vùng trống

X độ rộng môđun hoặc kích thước X

Y độ cao môđun (cũng được gọi là độ cao của hàng)

4.2. Các phép tính toán học

Các phép tính toán học sau đây áp dụng nhằm đáp ứng các mục đích nêu trong tiêu chuẩn này.

div là toán tử phân chia số nguyên, làm tròn xuống

INT là giá trị nguyên còn lại sau khi chia

mod là số dư nguyên dương sau khi chia. Nếu số dư là âm, thì sẽ cộng số dư với số chia để được kết quả là số dương. Ví dụ, -29160 chia 929 dư -361, khi đó lấy phần dư cộng với 929 được kết quả là 568.

4.3. Thuật ngữ viết tắt

Các thuật ngữ viết tắt sau đây áp dụng nhằm đáp ứng các mục đích nêu trong tiêu chuẩn này.

ECI Diễn dịch kênh mở rộng

GLI Số phân định nhãn toàn cầu

5. Yêu cầu

5.1. Đặc tính của mã vạch

5.1.1. Đặc tính cơ bản

PDF417 là một loại mã vạch với các đặc tính cơ bản sau đây:

a) Bộ kí tự mã hóa

1. Phương thức nén văn bản (xem 5.4.1.5) thừa nhận tất cả các kí tự ASCII có thể in ra sẽ được mã hóa, ví dụ: các giá trị từ 32 đến 126 theo ISO/IEC 646 (IRV), cũng như các kí tự kiểm soát đã chọn.

2. Phương thức nén byte (xem 5.4.3) thừa nhận tất cả 256 giá trị byte 8 bit có thể được mã hóa. Điều này bao gồm tất cả các ký tự ASCII giá trị từ 0 đến 127 và hỗ trợ bộ kí tự quốc tế.

3. Phương thức nén số (xem 5.4.4) thừa nhận việc mã hóa hiệu quả các chuỗi dữ liệu số.

4. Trên 811 800 bộ kí tự khác nhau hoặc các diễn dịch dữ liệu.

5. Các từ mã chức năng khác nhau dùng cho các mục đích kiểm soát.

b) Cấu trúc kí tự của mã vạch: các ký tự (n, k, m) của 17 môđun (n), 4 vạch và 4 yếu tố trống (k), với 6 môđun chiều rộng của yếu tố lớn nhất (m).

c) Số lượng tối đa có thể các kí tự dữ liệu trong mỗi mã vạch (ở mức điều chỉnh lỗi là 0): 925 từ mã dữ liệu có thể mã hóa:

1. Phương thức nén văn bản: 1 850 ký tự (2 kí tự dữ liệu mỗi từ mã).

2. Phương thức nén byte: 1 108 ký tự (1,2 kí tự dữ liệu mỗi từ mã).

3. Phương thức nén số: 2 710 ký tự (2,93 kí tự dữ liệu mỗi từ mã).

Tại mức điều chỉnh lỗi tối thiểu đã khuyến cáo, có tối đa 863 từ mã dữ liệu có thể mã hóa:

4. Phương thức nén văn bản: 1 726 kí tự (2 kí tự dữ liệu mỗi từ mã).

5. Phương thức nén byte: 1 033 kí tự (1,2 kí tự dữ liệu mỗi từ mã).

6. Phương thức nén số: 2 528 kí tự (2,93 kí tự dữ liệu mỗi mã).

d) Kích cỡ mã vạch

1. Số hàng: 3 đến 90.

2. Số cột: 1 đến 30.

3. Chiều rộng trong các môđun: 90X đến 583X bao gồm các vùng trống.

4. Số lượng từ mã tối đa: 928 từ mã.

5. Số lượng từ mã dữ liệu tối đa: 925 từ mã.

Khi số hàng và cột được chọn, tỉ lệ bề mặt của mã PDF417 có thể bị thay đổi khi in đ phù hợp với các yêu cầu về không gian của ứng dụng.

e) Điều chỉnh lỗi có thể chọn: 2 đến 512 từ mã mỗi mã vạch (xem 5.7).

f) Vùng không chứa dữ liệu:

1. Mỗi hàng: 73 môđun, bao gồm các vùng trống.

2. Mỗi mã vạch: tối thiểu 3 từ mã, được biểu diễn như các ký tự mã vạch.

g) Kiểu mã: liên tục, hai kích thước nhiều hàng

h) Tự kiểm tra kí tự: Có

i) Có thể giải mã hai chiều: Có

5.1.2. Tóm tắt các đặc tính bổ sung

Trong mã vạch PDF417, các đặc tính bổ sung là vốn có hoặc tùy chọn được tóm tắt như sau:

a) nén dữ liệu: (vốn có) Ba lược đồ được xác định để nén một số các đặc tính dữ liệu vào các từ mã. Nhìn chung, dữ liệu không được biểu diễn trực tiếp trên một ký tự về một cơ sở từ mã (xem 5.4.1.5 đến 5.4.4).

b) Các diễn dịch kênh mở rộng: (tùy chọn) Các cơ chế này cho phép trên 811 800 bộ kí tự dữ liệu hoặc diễn dịch khác nhau được mã hóa (xem 5.5).

c) Macro PDF417: (tùy chọn) Cơ chế này cho phép các tệp dữ liệu được biểu diễn một cách logic và liền nhau trong một số mã vạch PDF417. Trên 99 999 mã vạch PDF417 khác nhau có thể được kết nối hoặc ràng buộc vào nhau và được quét theo một chuỗi nào đó giúp cho tệp dữ liệu gốc được thiết kế lại một cách chính xác (xem 5.13).

d) Đường biên đến đường biên giải mã: (vốn có) PDF417 có thể được giải mã bằng cách đo các phần tử từ đường biên đến đường biên tương tự (5.3.1).

e) Quét hàng chéo: (vốn có) Sự kết hợp của ba đặc tính sau đây trong PDF417 tạo thuận lợi cho việc quét hàng chéo:

- được đồng bộ hóa theo chiều ngang, hoặc tự định thời

- phân định hàng

- được đồng bộ hóa theo chiều dọc, bằng cách sử dụng các giá trị của cụm để hoàn tất việc phân hóa hàng cục bộ.

Sự kết hợp này cho phép máy quét mã vạch một chiều đi qua một số hàng và hoàn tất việc giải mã dữ liệu một phần miễn sao ít nhất một ký tự mã vạch hoàn thiện ở mỗi hàng được giải mã thành từ mã. Thuật toán giải mã có thể đặt các từ mã riêng lẻ vào một ma trận có ý nghĩa.

f) Điều chỉnh lỗi: (vốn có) Người dùng có thể xác định một trong 9 mức điều chỉnh lỗi. Mức 0 không chỉ phát hiện ra lỗi mà còn có thể điều chỉnh một cách thiếu chính xác các từ mã còn thiếu hoặc đã giải mã.

g) PDF417 nén: (tùy chọn) Trong các môi trường tương đối “trong sạch", có thể giảm một số hàng đầu để cải thiện mật độ của mã vạch.

CHÚ THÍCH: Trong các quy định kĩ thuật trước đây về mã vạch PDF417, PDF417 nén được gọi là PDF417 bị cắt ngắn. PDF417 nén là thuật ngữ ưu tiên để tránh nhầm lẫn với một thuật ngữ được sử dụng phổ biến hơn là “bị cắt ngắn".

5.2. Cấu trúc mã vạch

5.2.1. Tham số của mã vạch PDF417

Mỗi mã vạch PDF417 bao gồm nhiều hàng được sắp xếp theo chiều dọc với tối thiểu 3 hàng (tối đa 90 hàng). Mỗi hàng phải bao gồm tối thiểu 1 kí tự mã vạch (tối đa 30 kí tự). Không bao gồm các cột chỉ báo hàng, cột đầu và cuối. Mã vạch phải bao gồm một vùng trống ở tất cả bốn phía. Hình 1 minh họa một mã vạch PDF417 mã hóa văn bản: Chuẩn về mã vạch PDF417.

Hình 1 - Cấu trúc mã vạch PDF417

5.2.2. Tham số hàng

Mỗi hàng của mã vạch PDF417 phải bao gồm:

a) Vùng trống đầu

b) Kí tự bắt đầu

c) Kí tự mã vạch chỉ báo hàng trái

d) 1 đến 30 ký tự mã vạch

e) Kí tự mã vạch chỉ báo hàng phải

f) Kí tự kết thúc

g) Vùng trống cuối

CHÚ THÍCH: Số kí tự mã vạch (hoặc từ mã) đề cập trong mục “d" ở trên bằng với số cột dữ liệu trong mã vạch PDF417.

5.2.3. Chuỗi từ mã

Mã vạch PDF417 có thể bao gồm trên 928 kí tự mã vạch hoặc từ mã. Kí tự mã vạch là thuật ngữ thích hợp hơn để xem vạch/ khoảng trống được in; từ mã thích hợp cho giá trị số của kí tự mã vạch. Các từ mã phải theo chuỗi này:

a) Từ mã đầu tiên, bộ Mô tả độ dài mã vạch mã hóa toàn bộ số từ mã dữ liệu trong mã vạch, bao gồm bộ Mô tả độ dài mã vạch, các từ mã dữ liệu và các từ mã đệm, nhưng không bao gồm các từ mã điều chỉnh lỗi.

b) Các từ mã dữ liệu phải theo sau kí tự có khả năng mã hóa điển hình nhất. Các từ mã chức năng có thể được chèn để hoàn tất việc nén dữ liệu.

c) Các từ mã đệm cho phép chuỗi từ mã được biểu diễn theo ma trận hình chữ nhật. Các từ mã đệm cũng có thể được sử dụng để lấp đầy các hàng bổ sung nhằm đạt được tỉ lệ bề mặt mong muốn hoặc được quy định bởi ứng dụng.

d) Một khối kiểm soát Macro PDF417 tùy chọn.

e) Các từ mã điều chỉnh lỗi về việc phát hiện và điều chỉnh lỗi.

Các từ mã được sắp xếp cùng với từ mã điển hình nhất kế với bộ Mô tả độ dài mã vạch, được mã hóa từ trái qua phải và từ hàng trên cùng đến hàng dưới cùng. Hình 2 minh họa định dạng chuỗi về mã vạch giống như Hình 1. Trong Hình 2, Mức điều chỉnh lỗi 1 được sử dụng và một kí tự đệm cần lấp đầy ma trận mã vạch.

Hình 2 - Ví dụ về lược đồ mã vạch của PDF417

trong đó

L, R, d và E được đề cập trong Điều 4

d15 = bộ Mô tả độ dài mã vạch (trong ví dụ này, với một giá trị của 16)

d14 đến d1 = biểu diễn dữ liệu đã mã hóa

d0 =  từ mã đệm

Các quy tắc và lời khuyên về việc lập cấu trúc ma trận được nêu trong điều 5.9.

5.3. Mã hóa cơ bản

5.3.1. Cấu trúc ký tự mã vạch

Mỗi kí tự mã vạch PDF417 phải bao gồm bốn yếu tố vạch và yếu tố khoảng trống, mỗi yếu tố có thể có một đến sáu môđun chiều rộng. Bốn phần tử vạch và bốn phần tử khoảng trống phải đo 17 môđun tất cả. Các kí tự mã vạch có thể được giải mã bằng cách đo các khoảng cách e trong ký tự.

Mỗi kí tự mã vạch PDF417 được xác định bởi chuỗi vạch-khoảng trống gồm 8 số, trong đó biểu diễn các chiều rộng môđun của tám yếu tố của kí tự mã vạch đó. Hình 3 minh họa một kí tự mã vạch với chuỗi vạch-khoảng trống 51111125.

Hình 3 - Kí tự của mã vạch PDF417

Có 929 giá trị kí tự mã vạch (từ mã) được đánh số từ 0 đến 928.

Các từ mã được biểu diễn bởi ba bộ kí tự mã vạch hoặc các cụm loại trừ lẫn nhau. Mỗi cụm mã hóa 929 từ mã PDF417 có sẵn thành các mẫu vạch-khoảng trống khác nhau sao cho một cụm khác với cụm khác. Các số của cụm là 0, 3, và 6. Định nghĩa cụm áp dụng cho tất cả các kí tự mã vạch PDF417, ngoại trừ các kí tự bắt đầu và kết thúc.

Cụm số K được xác định bởi công thức sau đây:

K = (b1 - b2 + b3 - b4 + 9) mod 9

Trong đó b1 b2, b3, và b4 biểu diễn chiều rộng trong các môđun của bốn phần tử vạch tương ứng

Cụm số K về kí tự mã vạch trong Hình 3 là:

K = (5 - 1 + 1 - 2 + 9) mod 9 = 3

Các từ mã và chuỗi vạch-khoảng trống cho mỗi cụm kí tự mã vạch được đề cập đến trong Phụ lục A

5.3.2. Kí tự bắt đầu và kết thúc

Các kí tự bắt đầu và kết thúc phải được sắp xếp như trong Bảng 1 và minh họa trong Hình 4:

Bảng 1 - Chuỗi vạch-khoảng trống cho các kí tự bắt đầu và kết thúc

Kí tự

Chuỗi vạch-khoảng trống

B

S

B

S

B

S

B

S

B

Bắt đầu

8

1

1

1

1

1

1

3

 

Kết thúc

7

1

1

3

1

1

1

2

1

CHÚ THÍCH 1: Các kí tự bắt đầu và kết thúc của mã vạch PDF417 là duy nhất có nhiều hơn 6 môđun chiều rộng.

CHÚ THÍCH 2: Kí tự kết thúc có thêm một môđun phần từ vạch đơn.

Đối với tất cả các hàng, các kí tự bắt đầu và kết thúc phải có cùng chuỗi vạch-khoảng trống.

Hình 4 - Các kí tự bắt đầu và kết thúc của mã vạch PDF417

5.4. Mã hóa (dữ liệu) mức cao

Mã hóa mức cao biến đổi các kí tự dữ liệu thành các từ mã tương ứng.

Các lược đồ nén dữ liệu được sử dụng để hoàn tất việc mã mức cao một cách hiệu quả. Ba phương thức được đề cập dưới đây, mỗi phương thức xác định một ánh xạ riêng giữa dữ liệu người sử dụng và các chuỗi từ mã. PDF417 có ba phương thức nén dữ liệu:

- Phương thức nén văn bản (xem 5.4.1.5)

- Phương thức nén byte (xem 5.4.3)

- Phương thức nén số (xem 5.4.4)

Chuỗi các byte dữ liệu cho trước có thể được biểu diễn bởi các thứ tự từ mã khác nhau, phụ thuộc vào cách bộ mã hóa chuyển giữa các phương thức nén và phương thức con nén. Không có cách đơn l nào để mã hóa dữ liệu trong mã vạch PDF417.

900 từ mã (0 đến 899) luôn có sẵn trong mỗi phương thức về mã hóa dữ liệu và các chức năng khác trong phương thức. 29 từ mã cò lại được ấn định cho các chức năng cụ thể (xem 5.4.1) độc lập với phương thức nén hiện hành.

PDF417 cũng hỗ trợ hệ thống Diễn dịch Kênh Mở rộng, cho phép các diễn dịch dữ liệu khác được mã hóa chính xác trong mã vạch (xem 5.5).

5.4.1. Từ mã chức năng

Các từ mã từ 900 đến 928 được ấn định làm các từ mã chức năng như sau:

- chuyển giữa các phương thức (xem 5.4.1.1)

- các ứng dụng nâng cao sử dụng các Diễn dịch Kênh mở rộng (ECIs) (xem 5.4.1.2)

- các ứng dụng nâng cao khác (xem 5.4.1.3 và 5.4.1.4)

Hiện tại, các từ mã từ 903 đến 912, 914 đến 917, và 919 là các từ mã dự trữ. Bảng 2 xác định danh sách gồm đầy đủ các từ mã chức năng đã ấn định và dự trữ. Các chức năng của chúng được đề cập trong các điều từ 5.4.1.1 đến 5.4.1.5. Xem 5.4.6 về cách xử lý các từ mã dự trữ.

Bảng 2 - Nhiệm vụ của các từ mã chức năng trong mã vạch PDF417

Từ mã

Chức năng

Tham khảo điều

900

mode latch sang phương thức nén văn bản

5.4.1.1

901

mode latch sang phương thức nén byte

5.4.1.1, 5.4.3.1

902

mode latch sang phương thức nén số

5.4.1.1

903 đến 912

Dự trữ

 

913

mode shift sang phương thức nén byte

5.4.1.1

914 đến 917, 919

Dự trữ

 

918

cờ liên kết đến thành phần hàng kèm theo, trong mã vạch ghép (khác với mã vạch ghép EAN.UCC)

5.4.1.5

920

cờ liên kết đến thành phần một chiều kèm theo, trong mã vạch ghép EAN.UCC

5.4.1.5

921

khi tạo bộ đọc

5.4.1.4

922

từ mã cuối cho khối kiểm soát Macro PDF

5.13

923

thẻ phân định phần đầu các trường tùy chọn trong khối kiểm soát Macro PDF

5.13

924

mode latch sang phương thức nén byte (sử dụng khác với 901)

5.4.1.1, 5.4.3.1

925 đến 927

số phân định cho một Diễn dịch Kênh Mở rộng (ECI)

5.5

928

từ mã đánh dấu Macro biểu thị phần đầu của khối kiểm soát Macro PDF

5.13

5.4.1.1. Từ mã chức năng cho việc chuyển phương thức

Trong một mã vạch PDF417, có thể chuyển tới và lui các phương thức mỗi lần có yêu cầu. Lời khuyên về việc chọn lựa các phương thức thích hợp có trong điều 5.4.5.

Từ mã Mode Latch có thể được sử dụng để chuyển từ phương thức hiện hành tới phương thức đích mà có tác dụng đến khi bộ chuyển phương thức khác được đưa vào sử dụng. Các từ mã từ 900 đến 902 và 924 được ấn định cho mục đích này. Bảng 3 xác định chức năng của chúng.

Từ mã Mode Shift 913 tạo ra một bộ chuyển tạm thời từ phương thức nén văn bản sang phương thức nén byte. Bộ chuyển này chỉ có hiệu quả cho từ mã tiếp theo, sau khi phương thức trở lại phương thức con thịnh hành của phương thức nén văn bản. Từ mã 913 chỉ sẵn có trong phương thức nén văn bản, cách sử dụng của nó được mô tả trong điều 5.4.2.4.

Bảng 3 - Các từ mã chuyển phương thức và định nghĩa phương thức

Phương thức đích

Mode Latch

Mode Shift

Nén văn bản

900

 

Nén byte

901/924

913

Nén số

902

 

CHÚ THÍCH: Bảng 3 phân định từ mã được sử dụng để chuyển phương thức đã xác định.

Các quy tắc chuyển giữa ba phương thức được đề cập trong Bảng 4 và biểu diễn trong Hình 5.

Bảng 4 - Bảng chuyển phương thức, các từ mã biểu diễn và chức năng của chúng

Phương thức gốc

Phương thức đích

Văn bản

Byte

Số

Văn bản

mode latch 900

mode shift 913

mode latch 901

mode latch 924

mode latch 902

Byte

mode latch 900

mode latch 901

mode latch 924

mode latch 902

Số

mode latch 900

mode latch 901

mode latch 924

mode latch 902

Hình 5 - Chuyển phương thức có sẵn

Các quy tắc chuyển thành phương thức nén byte được mô tả đầy đủ hơn ở điều 5.4.3.1.

5.4.1.2. Các từ mã chức năng cho việc chuyển sang các từ mã Diễn dịch Kênh Mở rộng

Từ mã ECI có thể được sử dụng để chuyển tới một diễn dịch cụ thể, mà vẫn có tác dụng đến khi một từ mã ECI khác được đưa vào sử dụng rõ ràng hoặc đến phần cuối của dữ liệu. Các từ mã từ 925 đến 927 được ấn định cho chức năng này (xem 5.5).

5.4.1.3. Các từ mã chức năng về Macro PDF417

Các mã vạch Macro PDF417 (xem 5.13) phải sử dụng từ mã 928 tại điểm bắt đầu của khối kiểm soát Macro PDF417. Các từ mã 922 và 923 được sử dụng cho các chức năng trong Macro PDF417.

5.4.1.4. Từ mã chức năng để khởi tạo bộ đọc

Từ mã 921 phải được sử dụng để hướng dẫn người đọc dịch dữ liệu chứa trong mã vạch khi lập trình khởi tạo bộ đọc. Từ mã 921 phải xuất hiện đầu tiên sau bộ Mô tả Độ dài Mã vạch. Nếu có chuỗi khởi tạo Macro PDF417 thì từ mã 921 phải xuất hiện trong mỗi mã vạch.

Dữ liệu chứa trong mã vạch khởi tạo hoặc chuỗi các mã vạch, sẽ không được bộ đọc truyền đi.

5.4.1.5. Các từ mã chức năng cho các cờ liên kết trong mã vạch ghép

Từ mã 920 phải được sử dụng như một cờ liên kết để báo hiệu sự có mặt của thành phần một chiều EAN.UCC liên quan phù hợp ISO/IEC 24723.

Từ mã 918 phải được sử dụng làm cờ liên kết để báo hiệu sự có mặt của thành phần một chiều liên quan trong mọi mã vạch ghép.

Khi sử dụng, từ mã 918 hoặc 920 có thể xuất hiện ở mọi vị trí trong mã vạch. Yêu cầu kĩ thuật của mã vạch ghép có thể xác định vị trí cụ thể của cờ liên kết.

Các bộ đọc hỗ trợ ứng dụng ghép đã được chỉ định phải giải mã và truyền dữ liệu từ tt cả các thành phần như đã quy định trong yêu cầu kĩ thuật về mã vạch ghép liên quan. Các bộ đọc không hỗ trợ ứng dụng ghép có thể xử lý từ mã 918 hoặc 920 như một từ mã dự trữ (xem 5.4.6). Ngoài ra, các bộ đọc không hỗ trợ ứng dụng ghép 918 có thể có một lựa chọn là bỏ qua thành phần ghép 2 chiều và ch truyền dữ liệu từ thành phần một chiều liên quan.

5.4.2. Phương thức nén văn bản

Phương thức nén văn bản bao gồm tất cả các kí tự ASCII có thể in được (ví dụ: các giá trị từ 32 đến 126) và ba kí tự kiểm soát ASCII: HT hoặc tab (ASCII giá trị 9), LF (tín hiệu chuyển hàng) (ASCII giá trị 10) và CR (quay lại bộ phận vận tải) (ASCII giá trị 13). Phương thức nén văn bản cũng bao gồm các kí tự latch và shift được sử dụng dành riêng trong phương thức này.

Phương thức nén văn bản mã hóa trên 2 kí tự mỗi từ mã. Các quy tắc biến đổi dữ liệu thành các từ mã PDF417 được đề cập trong điều 5.4.2.2. Các bộ chuyển phương thức con được đề cập trong điều 5.4.2.3.

5.4.2.1. Các phương thức con về nén văn bản

Phương thức nén văn bản gồm bốn phương thức con:

- Alpha (chữ hoa)

- Lower (chữ thường)

- Hỗn hợp (số và chấm câu)

- Chấm câu

Mỗi phương thức con chứa 30 kí tự, bao gồm các kí tự shift và latch của phương thức con.

Phương thức nén mặc định cho PDF417 có hiệu quả tại lúc bắt đầu mỗi mã vạch luôn là phương thức con Alpha (chữ hoa) của phương thức nén văn bản. Từ mã latch từ một phương thức khác sang phương thức nén văn bản phải luôn chuyển sang phương thức con Alpha của phương thức nén văn bản.

Tất cả các kí tự và giá trị của chúng được đề cập trong Bảng 5

Bảng 5 - Định nghĩa phương thức con

Các giá trị của Base 30

Các phương thức con về nén văn bản

Alpha

Lower

Hn hợp

Chấm câu

Kí tự

ASCII

Kí tự

ASCII

Kí tự

ASCII

Kí tự

ASCII

0

A

65

a

97

0

48

;

59

1

B

66

b

98

1

49

<>

60

2

C

67

c

99

2

50

62

3

D

68

d

100

3

51

@

64

4

E

69

e

101

4

52

[

91

5

F

70

f

102

5

53

\

92

6

G

71

g

103

6

54

]

93

7

H

72

h

104

7

55

_

95

8

I

73

i

105

8

56

96

9

J

74

j

106

9

57

~

126

10

K

75

k

107

&

38

!

33

11

L

76

I

108

CR

13

CR

13

12

M

77

m

109

HT

9

HT

9

13

N

78

n

110

,

44

,

44

14

O

79

o

111

:

58

:

58

15

P

80

p

112

#

35

LF

10

16

Q

81

q

113

-

45

-

45

17

R

82

r

114

.

46

.

46

18

S

83

s

115

$

36

$

36

19

T

84

t

116

/

47

/

47

20

U

85

u

117

+

43

34

21

V

86

v

118

%

37

|

124

22

W

87

w

119

*

42

*

42

23

X

88

x

120

=

61

(

40

24

Y

89

y

121

^

94

)

41

25

Z

90

z

122

pl

?

63

26

khoảng trống

32

khoảng trống

32

khoảng trống

32

{

123

27

II

as

II

}

125

28

ml

ml

al

39

29

ps

ps

 ps

al

al = latch sang alpha                 ml = latch sang hỗn hợp

as = shift sang alpha                 pl = latch sang chấm câu

II = latch sang lower                   ps = shift sang chấm câu

CHÚ THÍCH: Các cột Kí tự ở trên biểu diễn diễn dịch mặc định của ECI 000003 của các giá trị byte đã được chỉ ra trong các cột ASCII liền kề. Mỗi bảng biểu diễn một nửa từ mã, ví dụ: các dãy giá trị từ 0 đến 29 (xem 5.4.2.2).

5.4.2.2. Các quy tắc nén cho việc mã hóa trong phương thức nén văn bản

Trong phương thức nén văn bản, các cặp kí tự dữ liệu được biểu diễn trong từ mã đơn. Các giá trị được ấn định cho các kí tự dữ liệu nằm trong khoảng từ 0 đến 29 (tức là cơ số/ base 30) và được đề cập trong bảng 5. Đối với mỗi cặp của các giá trị base 30, giá trị đầu tiên hoặc bên trái phải được thiết kế nhiều giá trị h hơn, các giá trị khác thiết kế ít giá trị / hơn.

Từ mã PDF417 đã mã hóa được xác định bằng việc sử dụng công thức sau:

d = h x 30 + l

trong đó: d được quy định trong điều 4

Công thức này cũng áp dụng cho các giá trị base 30 đối với các shift và latch trong phương thức nén văn bản. Các giá trị shift và latch thích hợp được sử dụng giữa các phương thức con. Nếu việc mã hóa chuỗi ký tự không có kết quả là một số chẵn các giá trị của base 30, xem điều 5.4.2.4 về cơ chế sử dụng cụ thể.

Ví dụ sau đây minh họa cách nén đạt được trong phương thức nén văn bản.

Ví DỤ: Dữ liệu được mã hóa: PDF417

Bảng 6 - Ví dụ về việc mã hóa nén văn bản

Các cặp kí tự

h

/

h x 30 + /

Từ mã

P D

15

3

15 x 30 + 3

453

F ml

5

28

5 x 0 + 28

178

4 1

4

1

4 x 30 + 1

121

7 ps

7

29

7 x 30 + 29

239

CHÚ THÍCH 1: ml (latch sang phương thức con hỗn hợp) được sử dụng để mã hóa các ký tự số

CHÚ THÍCH 2: ps được sử dụng như một giá trị đệm trong ví dụ này, các giá trị shift và latch khác có thể được sử dụng (xem 5.4.2.4)

Dữ liệu PDF417 được biểu diễn bởi các từ mã 453, 178, 121, 239

5.4.2.3. Chức năng của shift và latch trong việc chuyển phương thức con của nén văn bản

Việc chuyển từ một phương thức con sang một phương thức con khác trong phương thức nén văn bản phải thông qua các giá trị latch và shift đã xác định cho phương thức con trước bộ chuyển.

Phương thức con của shift phải được sử dụng để chuyển một phương thức con của nén văn bản sang một phương thức con khác chỉ với một kí tự dữ liệu. Các từ mã tiếp theo trở lại phương thức con đang được sử dụng trước shift (ngoại tr việc ps được sử dụng như một bước đệm, xem 5.4.2.4). Shift có các chức năng như sau:

- ps = shift chuyển sang phương thức con chấm câu

- as = shift chuyển sang phương thức con chữ viết hoa

Phương thức con của Latch phải được sử dụng để chuyển một phương thức con của nén văn bản sang một phương thức con khác mà có hiệu quả đến khi một latch hay shift khác được đưa vào sử dụng. Latch có các chức năng như sau:

- al = latch sang phương thức con theo chữ viết hoa

- II = latch sang phương thức con chữ thường

- ml = latch sang phương thức con hỗn hợp

- pl = latch sang phương thức con chấm câu

Bộ các chức năng của latch và shift giới hạn luôn sẵn có trong mỗi phương thức con của nén văn bản. Các chức năng này được liệt kê trong Bảng 5. Bảng 7 biểu diễn việc chuyển giữa các phương thức con của nén văn bản; Hình 6 biểu diễn các chức năng này dưới dạng lược đồ.

CHÚ THÍCH: Tiếp theo phương thức con của latch có thể là phương thức con của latch hoặc shift khác; còn tiếp theo phương thức con của shift có thể không phải là phương thức của con shift hoặc latch.

Bảng 7 - Bảng chuyển phương thức con của nén văn bản

Phương thức con gốc

Phương thức con đích

Alpha

Lower

Hỗn hợp

Chấm câu

Alpha

 

II

ml

ps

Lower

as

 

ml

ps

Hỗn hp

al

II

 

ps

pl

Chấm câu

al

 

 

 

Hình 6 - Chuyển phương thức con của nén văn bản

5.4.2.4. Cơ chế sử dụng lớp đệm trong phương thức nén văn bản

Nếu chuỗi kí tự nén văn bản không có kết quả là một số chẵn các giá trị của base 30, thì phải bổ sung ở cuối chuỗi kí tự một lớp đệm. Bảng 6 nêu ví dụ được minh họa. Khi không có các chức năng vô hiệu trong phương thức nén văn bản thì phương thức con của shift và latch phải được sử dụng theo các cơ chế xác định trong các trường hợp sau đây:

a) Nếu chuỗi kí tự tiếp tục xuất hiện đến cuối dữ liệu hoặc chuỗi kí tự của phương thức nén văn bản được theo sau bằng cách chốt phương thức nén khác, khi đó lớp đệm có thể là bất kì shift hay latch của phương thức con nào.

b) Nếu chuỗi kí tự của phương thức nén văn bản được theo sau bởi shift byte (từ mã 913) để mã hóa kí tự của phương thức nén byte đơn, hai cơ chế có thể được sử dụng phụ thuộc vào phương thức con của nén văn bản đang được sử dụng trước shift nén byte:

1) Nếu phương thức con của nén văn bản không phải là chấm câu, thì giá trị 29 (ps) của base 30 phải được sử dụng nếu việc mã hóa được nhằm để trở lại phương thức con của nén văn bản giống như vậy. Bộ giải mã ngay lập tức bỏ qua ps trước từ mã 913.

2) Nếu phương thức con của nén văn bản là chấm câu, thì giá trị 29 (al) của base 30 phải được sử dụng. Bộ giải mã không bỏ qua (al), do đó sẽ không quay lại phương thức con Alpha.

5.4.2.5. Chuyển từ phương thức nén văn bản

Phương thức nén văn bản có thể được kết thúc ở cuối mã vạch, hoặc bởi bất kì từ mã nào sau đây:

- 900 (latch của phương thức nén văn bản)

- 901 (latch của phương thức nén byte)

- 902 (latch của phương thức nén số)

- 924 (latch của phương thức nén byte)

- 928 (phần đầu của khối kiểm soát Macro PDF417)

- 923 (phần đầu của trường tùy chọn Macro PDF417)

- 922 (ký tự kết thúc Macro PFD417)

Ba từ mã cuối cùng chỉ xuất hiện trong khối kiểm soát Macro PDF417 của mã vạch Macro PDF417 (xem 5.13.1). Phương thức nén văn bản cũng bị ảnh hưởng bởi sự xuất hiện của từ mã dự trữ (xem 5.4.6).

Nếu bộ giải mã có trong phương thức nén văn bản và gặp từ mã 913 (shift của phương thức nén byte), thì nó giải mã từ mã theo sau từ mã 913 như một byte nhị phân đơn và sau đó quay về phương thức nén văn bản. Phương thức con mà bộ giải mã quay về là phương thức con được latch gần đây nhất có hiệu quả trước từ mã 913; một shift của phương thức con ps ngay lập tức bị bỏ qua trước từ mã 913.

Nếu bộ giả mã có trong phương thức nén văn bản và gặp từ mã 900 (latch của phương thức nén văn bản), thì bộ giải mã sẽ khởi tạo lại phương thức con Alpha.

5.4.3. Phương thức nén byte

Phương thức nén byte cho phép một chuỗi các byte 8 bit được mã hóa thành chuỗi các từ mã. Điều này được thực hiện bởi bộ chuyển đổi Base 256 thành Base 900, trong đó đạt được tỉ lệ nén của sáu byte trên năm từ mã (1,2 : 1).

Tất c kí tự và giá trị của chúng (0 đến 256) được quy định trong Phụ lục B. Điều này được coi như một diễn dịch kí tự kiểm soát và diễn dịch đồ họa mặc định. Khi các ECI được gọi ra (xem 5.5) thì diễn dịch này được xác định là ECI 000003 (xem 5.5.2).

CHÚ THÍCH: Trong các quy định kĩ thuật về PDF417 trước đây, bộ kí tự mặc định tương đương với ECI (trang mã về hệ điều hành MS-DOS). Diễn dịch về các giá trị kí tự byte dưới 128 là không đổi, thao tác của thiết bị in và quét mã vạch PDF417 là vô hiệu. Các ứng dụng mới sử dụng các giá trị kí tự byte trên 127 phải thừa nhận diễn dịch mặc định ECI 000003 về tính tương hợp rõ nét nhất với các hệ thống hiện hành. Các ứng dụng hiện có sử dụng các giá trị ở trên 127 có thể tiếp tục mã hóa và xử lý dữ liệu như trước. Các ứng dụng dựa vào diễn dịch mặc định các giá trị trên 127 trước đó có thể mã hóa ECI 000002 rõ ràng nếu chúng muốn chuyển bằng tín hiệu diễn dịch này.

5.4.3.1. Chuyển sang phương thức nén byte

Trong phương thức nén số hoặc văn bản, để chuyển sang phương thức nén byte cần sử dụng một trong các từ mã sau đây:

- Mode latch 924 được sử dụng khi tổng số kí tự nén byte được mã hóa là bội số của 6

- Mode latch 901 được sử dụng khi tổng số kí tự nén byte được mã hóa không phải là bội số của 6

- Mode shift 913 có thể được sử dụng thay cho từ mã 901 khi kí tự nén byte đơn phải được mã hóa

5.4.3.2. Quy tắc nén để mã hóa kí tự nén byte đơn (sử dụng mode shift 913)

Để mã hóa kí tự nén byte đơn, từ mã phải là giá trị thập phân (0 đến 255) của kí tự như đã quy định trong Phụ lục B.

5.4.3.3. Quy tắc nén để mã hóa các chuỗi kí tự nén byte dài hơn (sử dụng Mode latch 924 hoặc 901)

Quy trình sau đây được sử dụng để mã hóa dữ liệu kí tự nén byte

1) Thiết lập tổng số kí tự nén byte.

2) Nếu là bội số của 6 thì mode latch 924 và 901 phải được sử dụng.

3) Chia nhỏ số kí tự nén byte thành chuỗi 6 ký tự, từ trái qua phải (từ các kí tự quan trọng nhất đến ít quan trọng nhất).

4) Gán các giá trị thập phân 6 byte dữ liệu được mã hóa trong phương thức nén byte b5 đến b0 (trong đó b5 là byte dữ liệu đầu tiên).

5) Thực hiện bộ chuyển đổi từ base 256 thành base 900 để tạo một chuỗi gồm 5 từ mã. Phụ lục C xác định thuật toán và minh họa ví dụ.

6) Nhắc lại từ Bước 3 nếu cần thiết.

7) Với các kí tự nén byte còn lại khi sử dụng mode latch 901, (ví dụ: khi nhóm cuối cùng ít hơn 6 kí tự nén byte) (các) từ mã phải là (các) giá trị thập phân (0 đến 255) của (các) kí tự đã quy định trong Phụ lục B, theo thứ tự từ quan trọng nhất đến ít quan trọng nhất.

CHÚ THÍCH: Phương thức nén byte sau Mode latch 901 thừa nhận rằng tổng số byte được mã hóa không phải là bội số của 6. Nếu số byte được mã trong phương thức nén byte là bội số nguyên của 6 thì 901 hoặc 924 sẽ được mã hóa, và được đặt ở bất kì điểm nào trong mã vạch nhằm tạo ra một mã hóa chính xác theo các quy tắc mã hóa này. Ví dụ, từ mã 924 là từ mã thứ nht hoặc thứ hai có thể phân định hàng từ mã sau đây của phương thức nén byte khi mã hóa số byte là bội của 6. Như một sự lựa chọn, từ mã 901 có thể được đặt ở bất kỳ vị trí nào trong dòng từ mã của phương thức nén byte nhằm phân chia dòng thành hai đoạn, cả hai đoạn này đều không mã hóa số byte là bội của 6.

Nếu có yêu cầu về mã hóa bổ sung trong các phương thức nén số hoặc văn bản thì các kí tự latch thích hợp phải được sử dụng (xem 5.4.1.1).

5.4.3.4. Chuyển từ nén byte

Phương thức nén byte có thể kết thúc ở cuối mã vạch hoặc bất kì các từ mã sau đây:

- 900 (latch của phương thức nén văn bản)

- 901 (latch của phương thức nén byte)

- 902 (latch của phương thức nén số)

- 924 (latch của phương thức nén byte)

- 928 (phần đầu của khối kiểm soát Macro PDF417)

- 923 (phần đầu của trường tùy chọn Macro PDF417)

- 922 (ký tự kết thúc Macro PFD417)

Ba từ mã cuối cùng chỉ xuất hiện trong khối kiểm soát Marcro PDF417 của mã vạch Macro PDF417 (xem 5.13.1). Phương thức nén byte cũng bị ảnh hưởng bởi sự có mặt của từ mã dự trữ (xem 5.4.6).

Việc gọi lại phương thức nén byte (bằng cách sử dụng từ mã 901 hoặc 924 trong phương thức nén byte) để hoàn thành nhóm 6 ký tự nén byte của phương thức nén byte trước đó như đã mô tả trong điều 5.4.3.3, và sau đó bắt đầu một nhóm mới. Quy trình này có thể cần thiết khi số gán ECI cần được mã hóa (xem 5.5.3.2).

Đối với phương thức nén văn bản, trong suốt quá trình giải mã, việc xử lý nhóm các từ mã cuối cùng khác nhau phụ thuộc vào liệu phương thức nén byte được gọi ra với từ mã 901 hoặc 924 hay không.

Nếu phương thức nén byte được gọi ra với từ mã 924, tổng số từ mã trong phương thức nén phải là bội số của năm. Nếu không phải như vậy thì mã vạch không hợp lệ. Tất cả các nhóm 5 từ mã được giải mã thành các nhóm 6 byte.

Nếu phương thức nén byte được gọi ra với từ mã 901 thì nhóm các từ mã cuối cùng được diễn dịch trực tiếp là một byte mỗi từ mã, mà không cần nén. Do đó, nếu nhóm cuối cùng gồm năm từ mã thì nhóm được diễn dịch là 5 byte hơn là 6.

5.4.4. Phương thức nén số

Phương thức nén số là phương pháp nén dữ liệu từ base 10 đến base 900 và phải được sử dụng để mã hóa các chuỗi số liên tiếp. Phương thức bén số mã hóa trên 2,93 chữ số mỗi từ mã.

5.4.4.1. Latch sang phương thức nén số

Phương thức bén số có thể được gọi khi trong các phương thức nén văn bản hoặc nén byte sử dụng mode latch 902.

5.4.4.2. Quy tắc nén để mã hóa các chuỗi số liên tiếp

Quy trình sau đây được sử dụng để nén dữ liệu số:

1) Chia chuỗi số thành các nhóm 44 chữ số, ngoại trừ nhóm cuối cùng, nhóm này có thể chứa ít chữ số hơn.

2) Với mỗi nhóm, bổ sung chữ số 1 vào vị trí quan trọng nhất để ngăn ngừa sự mất mát các số 0 ở đầu

VÍ DỤ

dữ liệu gốc

00246812345678

sau bước 2

1 00246812345678

CHÚ THÍCH: Chữ số đầu 1 được rời đi trong thuật toán giải mã

3) Biểu diễn việc chuyển đổi base 10 đến base 900. Phụ lục D quy định thuật toán về việc chuyển đổi này và minh họa ví dụ.

4) Nhắc lại từ Bước 2 khi cần.

Các quy tắc sau đây có thể được sử dụng để xác định số từ mã chính xác trong phương thức nén số:

- Các nhóm 44 chữ số nén 15 từ mã

- Đối với các nhóm chuỗi số ngắn hơn, số từ mã có thể được tính như sau:

Các từ mã = INT(số các chữ số / 3) + 1

VÍ DỤ: Đối với chuỗi 28 số

INT (28/3) + 1 = 9 + 1 = 10 từ mã

5.4.4.3. Chuyển từ phương thức nén số

Phương thức nén số có thể được kết thức ở cuối mã vạch, hoặc bất kì từ mã sau đây:

- 900 (latch của phương thức nén văn bản)

- 901 (latch của phương thức nén byte)

- 902 (latch của phương thức nén số)

- 924 (latch của phương thức nén byte)

- 928 (phần đầu của khối kiểm soát Macro PDF417)

- 923 (phần đầu của trường tùy chọn Macro PDF417)

- 922 (ký tự kết thúc Macro PFD417)

Ba từ mã cuối cùng chỉ xuất hiện trong khối kiểm soát Macro PDF417 của mã vạch Macro PDF417 (xem 5.13.1). Phương thức nén số cũng bị ảnh hưởng bởi sự có mặt từ mã dự trữ (xem 5.4.6).

Việc gọi lại phương thức nén số (bằng cách sử dụng từ mã 902 trong phương thức nén số) để kết thúc nhóm trong phương thức nén số hiện hành như đã mô tả trong điều 5.4.2.2, và sau đó bắt đầu một nhóm mới. Quy trình này có thể cần thiết khi số gán ECI cần được mã hóa (xem 5.5.3.4).

Đối với phương thức nén số, trong suốt quá trình giải mã, việc chuyển đổi base 900 thành base 10 phải có kết quả là một số có chữ số quan trọng nhất là “1”. Nếu việc chuyển đổi này không có kết quả là một số bắt đầu với “1", thì mã vạch sẽ không hợp lệ. Chữ số đầu “1" được rời đi để tạo số gốc.

5.4.5. Lời khuyên về việc lựa chọn phương thức nén thích hợp

Tất cả các việc thực hiện cơ bản về in và quét các mã vạch PDF417 phải hỗ trợ ba phương thức: nén văn bản, nén byte, và nén số. Bộ ký tự mặc định về nén văn bản được đề cập trong Bảng 5; về nén byte được đề cập trong Phụ lục B. Phương thức nén văn bản hiệu quả hơn phương thức nén byte về việc mã hóa các tệp văn bản ASCII chuẩn bởi việc nén các giá trị ký tự ASCII 9, 10, 13 và 32 đến 126 tốt hơn.

Phương thức nén số phải được sử dụng cho các chuỗi số dài.

Lời khuyên về việc chuyển giữa các phương thức để giảm thiểu số từ mã được cung cấp như một thuật toán trong Phụ lục N.

5.4.6. Xử lý các từ mã dự trữ của PDF417

5.4.6.1. Tổng quan

Các mã vạch PDF417 sử dụng trong các hệ thống mở không được dùng bất kì từ mã dành riêng (xem 5.4.1) trong tiêu chuẩn này. Tuy nhiên, thiết bị giải mã phải hỗ trợ việc truyền các từ mã dự trữ sử dụng các chuỗi thoát như quy định trong 5.17.4. Thiết bị giải mã có thể cũng hỗ trợ lựa chọn xử lý các mã vạch như vậy là không hợp lệ, cũng như vậy khi hoạt động trong Phương thức Kênh Cơ sở.

Các hệ thống nhận phải xóa bỏ dữ liệu chứa các chuỗi thoát sử dụng các từ mã dự trữ, trừ phi hệ thống hiểu được định nghĩa mới về từ mã dự trữ trước.

5.4.6.2. Sử dụng các từ mã dự trữ trong tương lai

Bất kì từ mã chức năng mới được xác định trong các sửa đổi của tiêu chuẩn này phải có các quy tắc mã hóa được quy định phù hợp với thiết bị tồn tại trước đó. Đặc biệt là:

- Khi một từ mã báo hiệu mới (chống lại từ mã của phương thức nén mới) được mã hóa, nó được theo sau bởi latch của phương thức nén thích hp để các từ mã dữ liệu tiếp theo được diễn dịch và truyền như một hàng byte, hơn là chuỗi các từ mã thoát không diễn dịch. Phương pháp này sẽ cho các kết quả mong muốn với thiết bị giải mã phù hợp với cả tiêu chuẩn gốc và tiêu chuẩn này, không quan tâm liệu thiết bị có dùng giao thức truyền mới hay nguyên bản hay không.

- Tại hệ thống nhận, bộ giải mã ECI sẽ xử lý các ECI báo hiệu (ví dụ: Khối điều khiển Macro và các từ mã thoát không diễn dịch) trước các ECI có khả năng mã hóa (ví dụ như các bộ ký tự). Do đó, bộ mã hóa phải chú ý tới thứ tự các thao tác sau:

1) Nếu xuất hiện các ECI của khối kiểm soát Macro thì chúng sẽ được sử dụng để sắp xếp hàng byte theo thứ tự chính xác.

2) Các từ mã dữ liệu thoát được dịch bởi bộ giải mã ECI theo các quy tắc của phương thức nén mới hoặc ECI báo hiệu, và các byte dữ liệu kết quả sẽ được chèn vào vị trí thích hợp của chúng trong hàng byte.

3) Cuối cùng, bộ kí tự và các ECI có khả năng mã hóa khác sẽ được áp dụng cho hàng byte kết quả.

5.5. Diễn dịch Kênh Mở rộng

Giao thức diễn dịch kênh mở rộng (ECI) cho phép hàng dữ liệu xuất có các diễn dịch khác với diễn dịch của bộ ký tự mặc định. Giao thức ECI được xác định một cách nhất quán qua số mã vạch, bao gồm PDF417. Các ECI được ấn định bởi AIM Global, Inc (Hiệp hội thương mại xác thực tự động).

CHÚ THÍCH: Lược đồ về mã vạch gọi là Số phân định toàn cầu (GLIs) được xác định cho mã vạch PDF417. Việc mã hóa và giải mã các ECI giống với các yêu cầu kĩ thuật trước đây về các GLI của PDF417. Tuy nhiên, phương thức truyền các gói tin giải mã theo các yêu cầu kĩ thuật trước đây về PDF417 cho các GLI là khác với phương thức truyền các ECI. Cũng có nhiều điểm khác biệt trong việc sử dụng các ECI với Macro PDF417. Tiêu chuẩn này cho phép sử dụng các giao thức hiện hành và trước đây, theo cách này thiết bị mới và cũ có thể tiếp tục cùng tồn tại.

Có năm kiểu diễn dịch được hỗ trợ trong PDF417:

a) các bộ ký tự (hoặc các trang mã)

b) các diễn dịch theo mục đích chung như là mã hóa dữ liệu và nén dữ liệu (khác với các phương thức nén của mã vạch)

c) người sử dụng xác định các diễn dịch về các hệ thống đóng

d) truyền thông tin kiểm soát về Macro PDF417

e) truyền các từ mã không diễn dịch của PDF417

Việc truyền giao thức Diễn dịch Kênh mở rộng được quy định đầy đủ trong tiêu chuẩn quốc tế ITS/04-001 của AIM, Phần 1: Giao thức cung cấp phương pháp để quy định các diễn dịch riêng về các giá trị byte trước khi in và sau khi giải mã.

Diễn dịch Kênh Mở rộng (ECI) được phân định bởi số có 6 chữ số được mã hóa trong mã vạch PDF417 bởi một trong ba từ mã cụ thể theo sau bởi một hoặc hai từ mã (xem 5.5.1). ECI có thể bị gọi ra ở bất cứ đâu trong gói tin mã hóa theo các quy tắc của phương thức nén (xem 5.5.3).

Giao thức ECI chỉ có thể được sử dụng với các bộ giải mã cho phép truyền mã nhận dạng mã vạch (xem 5.17.5). Các bộ giải mã không được phép truyền số phân định mã vạch thì không thể chuyển các chuỗi thoát từ mã vạch chứa ECI.

5.5.1. Mã hóa số gán ECI

ECI có thể được gọi ra ở bất kỳ đâu trong hàng dữ liệu, tùy thuộc vào các điều kiện nêu trong điều 5.5.3. Trước đây, khi một ECI được gọi ra, quá trình chuyển có thể diễn ra ở mọi phương thức nén. Phương thức nén đã sử dụng được xác định hoàn toàn bởi các giá trị dữ liệu 8 bit đang được mã hóa và không phụ thuộc vào ECI hiện hành. Ví dụ, chuỗi các giá trị trong khoảng từ 48 đến 57 (thập phân) được mã hóa một cách hiệu quả nhất trong phương thức nén số thậm chí nếu chuỗi không được diễn dịch là các số.

Số gán ECI được mã hóa ở một trong ba chuỗi từ mã ECI, trong đó bắt đầu với các từ mã 927, 926 hoặc 925. Một trong hai từ mã bổ sung không được sử dụng để mã hóa số gán ECI. Các quy tắc mã hóa được quy định trong Bảng 8.

Bảng 8 - Mã hóa các số gán ECI

Số gán ECI

Chuỗi từ mã

Các từ mã

Các khoảng

000000 đến 000899

C0

927

 

 

C1

ECI_no

C1 = (0 đến 899)

000900 đến 810899

C0

926

 

 

C1

ECI_no div 900 - 1

C1 = (0 đến 899)

 

C2

ECI_no mod 900

C2 = (0 đến 899)

810900 đến 811799

C0

925

 

 

C1

ECI_no - 810 900

C1 = (0 đến 899)

Có 811 800 số gán ECI có sẵn trong mã vạch PDF417

CHÚ THÍCH: Phương pháp mã hóa giống với lược đồ GLI hợp nhất trong các yêu cầu kỹ thuật về PDF417 của AIM Mỹ (1994) và AIM Châu Âu (1994).

Ví dụ sau đây minh họa việc mã hóa:

VÍ DỤ: ECI = 013579

Các từ mã         = [926] [13 579 div 900] - 1] [13 579 mod 900]

= [926] [15-1] [79]

= [926] [14] [79]

5.5.2. Diễn dịch Kênh mở rộng mặc định và được gán trước

Các ECI từ ECI 000000 đến ECI 000003 được gán trước phù hợp với các yêu cầu kĩ thuật về mã vạch hiện có, bao gồm PDF417.

- ECI 000000 (ngang bằng với ECI 0 nguyên bản) biểu diễn lược đồ mã hóa mặc định của các bộ mã hóa tuân theo các tiêu chuẩn về PDF nguyên bản

- ECI 000001 (ngang bằng với GLI 1 nguyên bản) biểu diễn lược đồ mã hóa GLI của một số mã vạch với các ký tự từ 0 đến 127 giống với các kĩ tự đó trong ISO/IEC 646:1991, Phiên bản Tham chiếu Quốc tế (tương đương với ANSI X 3.4) và các ký tự từ 128 đến 255 giống với các giá trị đó trong ISO/IEC 8859-1.

CHÚ THÍCH: ECI 000000 (tương đương với GLI 0) và ECI 000001 (tương đương với GLI 1) yêu cầu một số logic 0 dạng return-to-GLI tại phần đầu mỗi mã vạch đã mã hóa của bộ mã vạch Macro PDF417. Giao thức này không chấp nhận các Diễn dịch Kênh Mở rộng khác.

- ECI 000002 có bảng mã tương đương với ECI 000000, mà không có số logic 0 dạng return-to-GLI

- ECI 000003 có bảng mã tương đương với ECI 000001, mà không có số logic 0 dạng return-to- GLI. ECI 000003 là lược đồ mã hóa mặc định về các bộ mã hóa hoàn toàn phù hợp với tiêu chuẩn này

ECI 000000 và ECI 000001 không được mã hóa trong cùng mã vạch PDF417 hoặc bộ mã vạch Macro PDF417 như các ECI khác, ngoại trừ các ECI do người sử dụng xác định. ECI 000002 và ECI cung cấp các lựa chọn thích hợp cho ECI 000000 và ECI 000001 tương ứng. ECI 000000 và ECI 000001 không được sử dụng trong các ứng dụng mới.

5.5.3. Mã hóa chuỗi ECI trong phương thức nén

Nguyên tắc mã hóa chung là: các ECI được áp dụng cho hàng byte dữ liệu nguồn (các diễn dịch báo hiệu khác nhau) tạo ra hàng byte đã sửa đổi được mã hóa thành các mã vạch PDF417 sử dụng các phương thức nén của mã vạch chi tính hiệu quả. Mã hóa ECI và nén mã vạch tạo thành hai lớp quá trình logic độc lập.

Mặc dù các số gán ECI và các phương thức nén có thể được hoà chung với nhau, nhưng một vài kết hợp có thể tạo ra sự tối nghĩa và không logic. Các điều sau đây quy định cách các ECI có thể hợp nhất với nhau một cách rõ ràng bằng cách quy định việc sắp xếp các chuỗi thoát ECI hợp lệ.

5.5.3.1. ECI và phương thức nén văn bản

Một chuỗi thoát ECI có thể được đặt tại bất kỳ đâu trong phương thức nén văn bản. Phương thức con gọi ra ngay trước chuỗi thoát ECI được lưu giữ cho việc mã hóa sau nó. Do đó, các latch và shift của phương thức con được lưu giữ qua chuỗi thoát ECI; và một shift của phương thức con ngay trước chuỗi thoát ECI không bị bỏ qua.

5.5.3.2. ECIs và phương thức nén byte sử dụng mode latch 924 và 901

Nếu mã hóa trong phương thức nén byte sử dụng mode latch 924, thì chuỗi thoát ECI có thể được định vị bởi bộ mã hóa theo ngay sau từ mã 924, hoặc ở ranh giới 5 từ mã sau đó. Cần phải cung cấp một vị trí rõ ràng trong hàng byte đã giải mã để cho bộ giải mã đặt chuỗi thoát.

Nếu bộ giải mã có trong phiên bản 924 của phương thức nén byte và tìm thấy chuỗi thoát ECI theo sau một nhóm 5 từ mã, nó sẽ cung cấp sáu byte dữ liệu liên quan đến các từ mã trước chuỗi thoát, cung cấp chuỗi thoát và sau đó tiếp tục thu thập các từ mã để giải mã trong phương thức nén byte. Nếu bộ giải mã bắt gặp một chuỗi thoát ECI khác với các vị trí quy định này thì mã vạch sẽ được xem là không hợp lệ.

Nếu việc mã hóa trong phương thức nén byte sử dụng mode latch 901, thì chuỗi thoát ECI có thể được định vị:

- theo ngay sau từ mã 901

- sau ngay bất kì bộ năm từ mã mã hóa sáu byte

- sau ngay bất kì các từ mã gồm byte đơn ở phần cuối của chuỗi

CHÚ THÍCH: Bộ giải mã không thể thừa nhận rằng, ch chuỗi thoát ECI theo sau một bộ gồm năm từ mã, năm từ mã mã hóa sáu byte, khi hàng nhập độ dài 6N + 5 (trong đó N là một số nguyên) có bộ năm từ mã cuối cùng ch mã hóa 5 byte, một byte mỗi từ mã. Do đó, bộ giải mã phải quét trước trong mã vạch qua chuỗi thoát ECI để xác định hai phương thức 901 kết thúc, như đã quy định trong điều 5.4.3.4. Dựa vào thông tin này, có thể xác định cách thức nhóm 5 từ mã được mã hóa.

Hình 7 minh họa các vị trí hợp lệ về các chuỗi thoát ECI khi mã hóa trong phương thức nén byte. Nếu bộ giải mã bt gặp một chuỗi thoát ECI trong nhóm 5 từ mã, thì mã vạch được xem là không hợp lệ.

Hình 7 - Vị trí hợp lệ về chuỗi thoát trong phương thức nén byte

5.5.3.3. ECI và phương thức nén byte sử dụng mode shift 913

Nếu mã hóa trong phương thức nén byte sử dụng mode shift 913, thì chuỗi thoát ECI có thể được đặt

- ngay trước từ mã 913

- ngay sau từ mã 913

- ngay sau và cách từ mã 913 một từ mã

Trong hai trường hợp đầu tiên, chuỗi thoát ECI được cung cấp trước byte đã mã hóa, trong khi ở trường hợp cuối chuỗi thoát được cung cấp sau byte đã mã hóa.

5.5.3.1. ECI và phương thức nén số

Một chuỗi thoát ECI không được đặt trong nhóm các từ mã đang được xử lý thông qua bộ chuyển đổi base 10 đến base 900 như đã quy định trong điều 5.4.4.2. Nó ch có thể được đặt trong phương thức nén số tại ranh giới giữa các nhóm 15 từ mã. Điều này là cần thiết để cung cấp một vị trí rõ ràng trong hàng chuỗi số đã được giải mã để bộ giải mã đặt chuỗi thoát.

Do đó, chuỗi thoát ECI chỉ có thể được đặt:

- ngay sau từ mã 902

- sau từ mã thứ 15

- sau từ mã thứ 30

- v.v.

Nếu bộ mã hóa cần đặt chuỗi thoát ECI tại vị trí mà không có kết quả là các từ mã là bội số của 15, thì nó sẽ coi khối số trước ECI là thực thể hoàn thiện, như đã quy định trong 5.4.4.2 bước 2. Bộ mã hóa sẽ gọi lại phương thức nén số bằng cách đặt từ mã 902 khác trong hàng được theo sau bởi chuỗi thoát ECI.

Nếu bộ giải mã tìm thấy chuỗi thoát ECI ở một trong các điểm ranh giới đã xác định ở trên, thì nó phải phát ra các byte dữ liệu liên quan đến từ mã trước chuỗi thoát (nếu có), sau đó phát ra chuỗi thoát và tiếp tục thu thập các từ mã về việc giải mã trong phương thức nén số. Nếu bộ giải mã bắt gặp một chuỗi thoát ECI tại vị trí khác với các vị trí quy định thì mã vạch được xem như không hợp lệ.

5.5.3.5. ECI liên kết

Hai hoặc nhiều chuỗi thoát ECI (ví dụ: các số gán) có thể được đặt ở mọi điểm mà một ECI có thể được định vị một cách có giá trị: với điều kiện không đặt giữa chúng từ mã nào khác với chúng được sử dụng để mã hóa chuỗi thoát ECI.

5.5.4. Giao thức giải mã trước

Giao thức về việc truyền dữ liệu ECI giống như đã quy định trong điều 5.17.2. Khi truyền các ECI, các số phân định (xem 5.17.5) phải được thực hiện đầy đủ và số phân định mã vạch thích hợp sẽ được truyền như một lời mở đầu.

5.6. Xác định chuỗi từ mã

Quá trình mã hóa sinh ra chuỗi các từ mã:

dn-1 ... d0

trong đó: d = từ mã dữ liệu bao gồm bộ tả Độ dài Mã vạch và tất cả các từ mã chức năng

n = tổng số từ mã dữ liệu (và bước đệm) bao gồm bộ Mô tả Độ dài Mã vạch, không tính các từ mã sửa lỗi.

Trong suốt quá trình mã hóa, các chuỗi từ mã sẽ được thiết lập. Giống như dữ liệu gốc, dữ liệu quan trọng nhất sẽ xuất hiện đầu tiên, ví dụ dữ liệu số và nguyên bản viết từ trái qua phải. Chuỗi các từ mã phải là chuỗi mà từ mã dữ liệu quan trọng nhất chứa dữ liệu đã mã hóa là từ mã ký hiệu dn - 2. Từ mã dữ liệu cuối cùng (bước đệm) là từ mã kí hiệu d0.

Quá trình được sử dụng để xác định ma trận hàng và cột của mã vạch (xem 5.9.2) yêu cầu bổ sung các từ mã đệm ở phần cuối của chuỗi từ mã dữ liệu.

5.7. Phát hiện lỗi và sửa

Mỗi mã vạch PDF417 chứa ít nhất hai từ mã sửa lỗi. Các từ mã sửa lỗi cung cấp khả năng phát hiện và sửa lỗi.

5.7.1. Mức sửa lỗi

Mức sửa lỗi cho mã vạch PDF417 có thể lựa chọn ở thời điểm tạo mã vạch. Bảng 9 biểu diễn số từ mã sửa lỗi cho mỗi mức sửa lỗi.

Bảng 9 - Mức sửa lỗi và từ mã sửa lỗi

Mức sửa lỗi

Tng số từ mã sửa lỗi

0

2

1

4

2

8

3

16

4

32

5

64

6

128

7

256

8

512

5.7.2. Khả năng sửa lỗi

Sửa lỗi có thể được sử dụng để bù đắp cho các lỗi trong nhãn và các hiểu nhầm trong suốt quy trình giải mã. Đối với bất kì mức sửa lỗi đưa ra, một số từ mã sửa lỗi được hợp nhất thành mã vạch PDF417. Thuật toán về từ mã sửa lỗi cho phép hai kiểu lỗi được khôi phục lại:

- vết xóa, đó là từ mã thiếu hoặc không thể giải mã ở v trí đã biết,

- lỗi thay thế, đó là từ mã được giải mã nhầm ở vị trí không xác định.

Lược đồ sửa lỗi yêu cầu một từ mã sửa lỗi để sửa vết xóa và hai từ mã điều chỉnh lỗi đ khôi phục lỗi thay thế. Do đó, mức điều chỉnh lỗi có thể sửa mọi kết hợp giữa các lỗi thay thế và các vết xóa thoả mãn các phương trình sau đây:

l + 2f ≤ 2s+1 - 2

trong đó: l, f và s được quy định trong 4.1.

Tuy nhiên, Nếu hầu hết khả năng sửa lỗi được sử dụng để điều chỉnh các vết xóa, thì có thể gia tăng các lỗi không phát hiện được. Với lý do này, bất cứ khi nào có ít hơn 4 lỗi được điều chỉnh (trừ khi s = 0), thì khả năng điều chỉnh lỗi nên được giảm như sau:

l + 2f ≤ 2s+1 - 3

trong đó: l, f và s được đề cập trong điều 4.1

VÍ DỤ: Mã vạch PDF417 mức sửa lỗi 3 có 16 từ mã điều chỉnh lỗi trong đó trên 14 từ mã có thể được sử dụng để sửa các lỗi và các vết xóa. Chúng có thể sửa trên 13 vết xóa và 7 lỗi thay thế, hoặc mọi kết hợp giữa các vết xóa l và các lỗi thay thế f tuân theo các phương trình ở trên. Bảng 10 quy định các kết hợp có thể xảy ra.

Bảng 10 - Các kết hợp sửa lỗi có thể xảy ra đối với mức sửa lỗi 13

Lỗi thay thế đã khôi phục

Vết xóa đã khôi phục

Phương trình xác định

0

13 hoặc ít hơn

l + 2f ≤ 2s+1 - 3

(số lỗi <>

1

11 hoặc ít hơn

2

9 hoặc ít hơn

3

7 hoặc ít hơn

4

6 hoặc ít hơn

l + 2f ≤ 2s+1 - 2

(số lỗi ≥ 4)

5

4 hoặc ít hơn

6

2 hoặc ít hơn

7

0

5.7.3. Xác định các từ mã sửa lỗi

Quá trình gồm hai giai đoạn phải được thực hiện để xác định các từ mã sửa lỗi:

1) Lựa chọn mức sửa lỗi. Người sử dụng hoặc ứng dụng xác định lựa chọn, điều này được quy định trong Phụ lục E.

2) Tạo ra các từ mã sửa lỗi. Điều này liên quan đến bộ quy tắc được đề cập trong điều 5.10. Các quy trình không được sử dụng cho đến khi tất cả các từ mã dữ liệu bao gồm các từ mã đệm (xem 5.9.2) được xác định

CHÚ THÍCH: Các quy trình được quy định trong các điều từ 5.3 đến 5.9, 5.13 và 5.14 là mối quan tâm hàng đầu của người sử dụng. Các quy trình nhiều kĩ thuật hơn được đề cập trong các điều 5.10, 5.11 và 5.15 có thể được hoàn tất và không cần các quyết định của người sử dụng.

5.8. Kích thước

Các mã vạch PDF417 tuân theo các kích thước sau đây:

5.8.1. Độ rộng tối thiểu của một môđun (X)

Độ rộng tối thiểu của một môđun được xác định bởi quy định kĩ thuật, có liên quan đến tính sẵn có của thiết bị về việc tạo và đọc mã vạch và phù hợp với các yêu cầu chung của ứng dụng.

Kích thước X phải là một hằng số qua một mã vạch cho trước.

CHÚ THÍCH: Các tiêu chuẩn về phép đo chất lượng mã vạch hiện hành (ví dụ ISO/IEC 15415) không yêu cầu các phép đo kích thước tuyệt đối để đánh giá chất lượng mã vạch. Nếu không tuân theo bất kì kích thước tối thiểu nào thì đó là lý do không chấp thuận mã vạch trong các tiêu chuẩn này.

5.8.2. Độ cao hàng (Y)

Đối với các mã vạch với ít nhất mức sửa lỗi tối thiểu đã khuyến cáo:

Y 3 X

Đối với các mã vạch với ít hơn mức điều chỉnh lỗi tối thiểu đã khuyến cáo, chiều cao hàng có thể được tăng lên, cụ thể là khi giá trị X nhỏ. (Xem Phụ lục E để biết thêm chi tiết về mức điều chỉnh lỗi đã khuyến cáo).

5.8.3. Vùng trống

- Độ rộng tối thiểu của vùng trống nằm ngang (đến bên trái và phải của mã vạch PDF417): 2X

- Kích cỡ tối thiểu của vùng trống thẳng đứng (bên trên và phía dưới mã vạch PDF417): 2X

5.9. Xác định định dạng mã vạch

Ma trận mã vạch PDF417 và toàn bộ kích cỡ, hình dáng của mã vạch được xác định bởi:

1) độ rộng môđun và tỉ lệ bề mặt và,

2) số hàng và cột trong ma trận mã vạch.

Để tạo nên một mã vạch PDF417, các tham số này được lựa chọn qua sự kết hợp của các thiết bị nhập người sử dụng, quy định ứng dụng và cài đặt mặc định. Quá trình lựa chọn có thể lặp đi lặp lại cho đến khi người sử dụng hài lòng với định dạng kết quả.

5.9.1. Xác định tỉ lệ bề mặt của môđun

Tỉ lệ bề mặt của môđun in ra phải được xác định bởi hai kích thước:

- X kích thước mong muốn của vạch và khoảng trống hẹp nhất

- Y kích thước mong muốn của chiều dài mỗi hàng

Các tham số này được xác định bởi người sử dụng hoặc bởi ứng dụng. Các phần tử quan trọng mà xác định các giá trị của các tham số này là giải pháp của việc in và quét hệ thống được sử dụng trong ứng dụng. Các vấn đề này được nêu trong điều 5.14.

5.9.2. Xác định ma trận hàng và cột của mã vạch

Có một vài phần tử cần được xem xét để xác định ma trận mã vạch, ví dụ: số hàng r và số cột c:

- số lượng và kiểu dữ liệu được mã hóa

- các quy tắc cơ bản của mã vạch, ví dụ: xác định các giới hạn về số hàng và cột (xem 5.2.1 và 5.2.2)

- không gian vật lý sẵn có để in mã vạch

- trên thực tế các hàng dài hơn sẽ sử dụng mã vạch ở trên ít hơn (các ký tự bắt đầu và kết thúc, chỉ báo hàng và không gian về vùng trống)

- trên thực tế độ dài của hàng (bao gồm các vùng trống) phải ít hơn độ dài của dòng quét được quy định hoặc bao hàm bởi ứng dụng

- kiểu máy quét, trong đó xác định toàn bộ tỉ lệ bề mặt của mã vạch

- mức điều chỉnh lỗi đã chọn.

Đối với nhiều ứng dụng, độ rộng cho phép của mã vạch là một phần tử bắt buộc đầu tiên, và ma trận mã vạch có thể được xác định trực tiếp bằng cách ấn định lại số cột. Phụ lục O cung cấp các hướng dẫn chính xác hơn được sử dụng để xác định ma trận mã vạch.

Sau khi dữ liệu nguồn được mã hóa sử dụng các phương thức nén đã lựa chọn, số từ mã dữ liệu nguồn m (trước khi bổ sung bộ Mô tả độ dài mã vạch và các từ mã đệm) được biết. Khi số hàng, cột và mức sửa lỗi được lựa chọn thì tổng số từ mã dữ liệu n được tính như sau:

n = c x r - k

trong đó: c, k, n và r được quy định trong điều 4.1

Ma trận có thể đưa đến một tình huống mà số hàng và cột yêu cầu sử dụng các từ mã đệm (bằng cách chuyển đổi sử dụng giá trị 900). Điều này xảy ra khi:

n > m + 1

trong đó: m n được quy định trong điều 4.1

Bộ Mô tả độ dài mã vạch phải được đặt là giá trị n đã xác định ở trên:

dn-1 = n = c x r - k

Số các từ mã đệm yêu cầu là (n - m) - 1.

Các từ mã đệm phải có giá trị 900 và phải được đặt trong các vị trí ít quan trọng nhất của chuỗi từ mã dữ liệu, ví dụ: bên phải từ mã dữ liệu nguồn ít quan trọng nhưng trước Khối kiểm soát Macro PDF417, nếu có. Ví dụ về quá trình này được nêu dưới đây. Ngoại trừ việc chèn bộ Mô tả độ dài mã vạch và các từ mã đệm, chuỗi từ mã phải giống y hệt như cái được tạo lúc ban đầu khi mã hóa dữ liệu nguồn.

VÍ DỤ

để m = 246, c = 12, r = 24, và k = 32, thì n = (c x r) - k = (12 x 24) - 32 = 256.

CHÚ THÍCH: Kí hiệu như đã được nêu ở trên

Giá trị của bộ Mô tả độ dài mã vạch là n = 256.

Số từ mã đệm = (n - m) - 1 = 256 - 246 - 1 = 9. Trong ví dụ này, các từ mã dữ liệu (trước khi đệm) bắt đầu với một latch đến phương thức nén số (từ mã 902), và kết thúc với từ mã 423, và tất cả các bước đệm đều sử dụng từ mã 900. Việc bổ sung bộ Mô tả độ dài mã vạch và các bước đệm được biểu diễn dưới đây:

Chuỗi từ mã dữ liệu gốc            dm-1... d0

Các từ mã                                 902... 423

Chuỗi từ mã dữ liệu đã đệm      dn-1 dn-2 … d9 d8 … d0

Các từ mã                                 256    902... 423    900 ... 900

5.10. Tạo các từ mã sửa lỗi

Các từ mã sửa lỗi được tạo bằng cách sử dụng quy trình xác định dưới đây. Chúng được tính trên cơ sở các giá trị của tất cả từ mã dữ liệu bao gồm bộ Mô tả độ dài mã vạch và các từ mã đệm. Chuỗi từ mã được xác định như sau:

dn-1, dn-2, … d0

trong đó: dn-1 là bộ Mô tả độ dài mã vạch

Đa thức về dữ liệu mã vạch là:

d(x) = dn-1xn-1 + dn-2xn-2 + ... + d1x + d0

Đa thức sau đây mô tả cách các từ mã sửa lỗi được tính cho dòng dữ liệu và mức sửa lỗi đã chọn. Tất cả số học được thực hiện theo modulo 929.

Các từ mã sửa lỗi là phần bổ sung các hệ số của số dư từ việc chia đa thức dữ liệu mã vạch d(x) nhân với xk bởi đa thức tạo g(x). Các giá trị âm được ánh xạ thành trường Galois GF (929) bằng cách thêm 929 cho đến khi giá trị ≥ 0.

Đa thức tạo sau đây được sử dụng để tính các hệ số về các từ mã sửa lỗi k yêu cầu cho mức sửa lỗi:

gk(x) = (x - 3)(x - 32)(x - 33)...(x - 3k)

= a0 + a1x + a2x2 +...+ ak-1xk-1 + xk

trong đó

gk(x) = đa số tạo và x là biến số

k = tổng số từ mã điều chỉnh lỗi

aj = hệ số các lũy thừa x được đưa ra bởi đa thức tạo gk(x)

Ví dụ về việc tính các hệ số được có trong Phụ lục Q.

Phụ lục F chứa tất cả các giá trị hệ số cần thiết để mã hóa mã vạch PDF417 của mức điều chỉnh lỗi. Các từ mã sửa lỗi phải được tính theo thuật toán xác định dưới đây sử dụng kí hiệu sau:

di = từ mã dữ liệu dn-1 ... d0

Ej = từ mã điều chỉnh lỗi Ek-1 ... E0

aj = hệ số lũy thừa của x lấy từ đa thức tạo (xem giải thích ở trên và Phụ lục F)

t1, t2, t3 = các biến tạm thời

Thuật toán:

1. Nhận dạng chuỗi từ mã dữ liệu dn-1, dn-2, d0

2. Khởi tạo các từ mã sửa lỗi E0, …, Ek-1 đến giá trị 0

3. Với mỗi từ mã dữ liệu di = dn-1 ... d0

BEGIN

t1 = (di + Ek-1) mod 929

Với mỗi từ mã sửa lỗi Ej = Ek-1 … E1:

BEGIN

t2 = (t1 x aj) mod 929

t3 = 929 - t2

Ej = (Ej-1 + t3) mod 929

END

t2 = (t1 x a0) mod 929

t3 = 929 - t2

E0 = t3 mod 929

END

4. Đối với mỗi từ mã sửa lỗi, Ej = E0...Ek-1, tính phần bù:

BEGIN

if Ej không bằng 0

Ej = 929 - Ej

END

Một ví dụ về việc tính các từ mã sửa lỗi được quy định trong Phụ lục Q.

Một quy trình khác về việc tạo các t mã sửa lỗi, sử dụng mạch phân chia được quy định trong Phụ lục R.

5.11. Mã hóa mức thấp

Mã hóa mức thấp chuyển đổi các từ mã thành các kí tự mã vạch tương ứng của chúng (chuỗi vạch-khong trống) chỉ ra rằng ma trận mã vạch đã được ấn định.

Hình 8 minh họa dưới dạng lược đồ về mã vạch PDF417, vị trí tương ứng của mỗi từ mã dữ liệu, từ mã sửa lỗi và các chỉ báo hàng.

Hình 8 - Mã vạch PDF417 điển hình biểu diễn dưới dạng lược đồ vị trí các từ mã

trong đó:

Lr = ch báo hàng trái

Rr = ch báo hàng phải

Vùng tô bóng = vùng từ mã dữ liệu

Vùng không tô bóng phía dưới vùng t mã là các từ mã sửa lỗi

5.11.1. Các cụm

PDF417 sử dụng hệ thống hàng cục bộ để tìm ra các chuyển đổi hàng-hàng.

Bộ các từ mã được biểu diễn trong mỗi ba cụm. Các số cụm 0, 3 và 6 được sử dụng. Các chuỗi vạch-khoảng trống liên kết của mỗi ký tự mã vạch biểu diễn mỗi từ mã và cụm được quy định trong Phụ lục A.

Để mã hóa các chỉ báo hàng và từ mã, mỗi hàng phải chứa các ký tự mã vạch (dấu hiệu vạch- khoảng trống) chỉ của một cụm. Hàng 1 sử dụng các ký tự mã vạch từ cụm 0, hàng 2 sử dụng các ký tự mã vạch từ cụm 3, hàng 3 sử dụng các ký tự mã vạch từ cụm 6, hàng 4 sử dụng các ký tự mã vạch từ cụm 0 và v.v. Chuỗi cụm 0, 3, 6 lặp lại liên tục. Số cụm K cho mọi hàng có thể được tính:

K = [(số hàng - 1) mod 3] x 3

trong đó: các hàng được đánh số từ 1 đến r (như trong điều 4.1).

Do hai hàng liền nhau có các cụm khác nhau nên máy giải mã có thể sử dụng các tia quét đi qua các hàng trong khi gii mã mã vạch PDF417.

5.11.2. Xác định ma trận mã vạch

Ma trận các hàng và cột của mã vạch cuối cùng phải được xác định bởi các quy trình đã quy định trong điều 5.9.2. Điều này cung cấp các giá trị của r và c.

5.11.3. Xác định giá trị của các chỉ báo hàng trái và phải

Các chỉ báo hàng trong mã vạch PDF417 là các từ mã mã hoà một vài tham số chính: số hàng (F), số các hàng (r), số cột (c) và mức sửa lỗi (s). Thông tin được truyền qua ba hàng và vòng lặp phải nhắc lại liên tục. Số hàng (F) phải được mã hóa trong mỗi hàng.

5.11.3.1. Chỉ báo dòng trái

Các chỉ báo hàng bên được tính như sau:

Nếu KF = 0; LF = 30 x ((F - 1) div 3) + (r - 1) div 3

Nếu KF = 3; LF = 30 x ((F - 1) div 3) + (s x 3) + (r - 1) mod 3

Nếu KF = 6; LF = 30 x ((F - 1) div 3) + (c - 1)

trong đó: c, F, r, s và K được quy định trong điều 4.1

5.11.3.2. Ch báo hàng bên phải

Các chỉ báo hàng bên phải được tính như sau:

Nếu KF = 0; RF = 30 x ((F - 1) div 3) + (c - 1)

Nếu KF = 3; RF = 30 x ((F - 1) div 3) + (r - 1) div 3

Nếu KF = 6; RF = 30 x ((F - 1) div 3) + (s x 3) + (r - 1) mod 3

trong đó: c, F, r, s và K được quy định trong điều 4.1.

5.11.4. Mã hóa hàng

Trong mỗi hàng, các kí tự mã vạch sau đây tuân theo số cụm:

- chỉ báo hàng bên trái

- các kí tự mã vạch biểu diễn dữ liệu và/hoặc các từ mã sửa lỗi đến một số bng với số cột.

- chỉ báo dòng bên phải

Các kí tự bắt đầu và kết thúc là không thay đổi đối với tất cả các hàng.

Mã vạch được mã hóa theo từng hàng, lấy các từ mã c (số các cột) vào mỗi hàng. Hàng đầu tiên bao gồm bộ Mô tả độ dài mã vạch trong cột đầu tiên. Dòng cuối cùng bao gồm một số hoặc tất cả từ mã sửa lỗi.

5.12. PDF417 nén

Các mã vạch PDF417 nén là một lựa chọn có sẵn. Nếu được sử dụng, PDP417 nén phải phù hợp với Phụ lục G.

5.13. Macro PDF417

Macro PDF417 cung cấp một cơ chế về dữ liệu trong tệp được chia thành các khối và được biểu diễn ở nơi có từ hai mã vạch PDF417 trở lên. Cơ chế này tương tự với đặc tính gn kết cấu trúc trong các mã vạch khác.

Mỗi mã vạch Macro PDF417 chứa thông tin kiểm soát bổ sung để giúp cho tệp dữ liệu gốc được thiết kế lại một cách thích đáng, không kể đến chuỗi mà các mã vạch PDF417 riêng lẻ được quét và giải mã.

Trên 99 999 mã vạch PDF417 riêng lẻ có thể được sử dụng để mã hóa dữ liệu trong Macro PDF417.

Các chi tiết đầy đủ về quy trình của Macro PDF417 được quy định trong Phụ lục H.

5.13.1. Các phương thức nén và Macro PDF417

Khối Kiểm soát Macro PDF417 có phương thức mã hóa định trước, vì vậy từ mã 928 là nguyên nhân của sự kết thúc chuỗi phương thức nén trong thân mã vạch. Trường chỉ số từng phần (Segment Index) được mã hóa trong phương thức nén số. Mỗi trường tùy chọn của Macro PDF417 xác định có một phương thức nén lúc đầu và một phương thức con cụ thể, phần đầu của trường tùy chọn mới kết thúc phương thức nén từ trường trước đó (xem Phụ lục H.2.3) và khởi đầu phương thức mặc định của nó. Cụ thể là, nếu hai trường tùy chọn liên tiếp cùng sử dụng phương thức nén văn bản thì phương thức con Alpha được sắp xếp lại khi gặp từ mã 923.

5.13.2. ECI và Macro PDF417

Tùy thuộc vào các quy định trong điều 5.5.2, các ECI có thể xuất hiện ở gói tin đã mã hóa trong bộ mã vạch PDF417 đơn hoặc bộ các mã vạch Macro PDF417. Mọi ECI được gọi ra phải áp dụng cho đến khi kết thúc dữ liệu đã được mã hóa hoặc cho đến khi gặp ECI khác. Do đó, diễn dịch ECI có thể đứng giữa hai hay nhiều mã vạch.

(Các) diễn dịch ECI trong thân của dòng từ mã dữ liệu không mở rộng thành khối kiểm soát Macro PDF417 nhưng tự động lấy lại ở phần đầu của mã vạch tiếp theo. Dữ liệu của khối kiểm soát được diễn dịch bằng cách sử dụng ECI (000003) mặc định, trừ khi chuỗi thoát ECI được mã hóa trong trường tùy chọn ở khối kiểm soát; hiệu quả của ECI này được tự kết thúc ở phần cuối của trường nơi nó xuất hiện.

CHÚ THÍCH: Khi thực hiện các GLI theo yêu cầu kỹ thuật trước đó (ví dụ: các yêu cầu kỹ thuật về PDF417 của AIM Mỹ (1994) và của AIM Châu Âu (1994)), việc mã hóa bao gồm một phản hồi đến GLI 0 (tương đương với ECI 000000) ở lúc bắt đầu mỗi mã vạch. Nếu GLI 1 có trong mã vạch tiếp theo thì GLI 1 phải được mã hóa tại lúc bắt đầu của mã vạch tiếp theo này. Khi các máy mã hóa phù hợp với các tiêu chuẩn có trước này được sử dụng thì sẽ có li khuyên về cách thức phù hợp với yêu cầu kĩ thuật này trong điều 5.17.6.

5.14. Hướng dẫn cho người sử dụng

5.14.1. Diễn dịch người đọc

Các mã vạch PDF417 có khả năng mã hóa số lượng lớn dữ liệu, có nghĩa là diễn dịch người đọc của các kí tự dữ liệu có thể không thực tế. Nói cách khác, văn bản mô tả có thể liên kết mã vạch hơn là văn bản thuần túy. Gói tin có thể được in ở bất kì đâu xung quanh mã vạch, nhưng không được gây trở ngại cho mã vạch hoặc các vùng trống. Phông chữ hoặc kích cỡ kí tự không được quy định trong tiêu chuẩn này, nhưng có thể được quy định trong các tiêu chuẩn ứng dụng.

5.14.2. Khả năng tự động phân biệt

PDF417 có thể được sử dụng trong môi trường tự động phân biệt với một số mã vạch khác (xem Phụ lục S.1).

5.14.3. Các tham số ứng dụng do người sử dụng quy định

Các tiêu chuẩn ứng dụng xác định các tham số của mã vạch PDF417 đã quy định trong tiêu chuẩn này như sau:

5.14.3.1. Mã vạch và các đặc tính về kích thước

Các tiêu chuẩn ứng dụng quy định dữ liệu, mã vạch và các tham số về kích thước sau đây:

a) Lựa chọn và sử dụng các diễn dịch kênh mở rộng, nếu được yêu cầu, để mở rộng mã hóa dữ liệu ngoài diễn dịch mặc định của phương thức cơ bản.

b) Khối lượng dữ liệu trong mã vạch, có thể là cố định, biến đổi hoặc biến đổi tới một lượng tối đa xác định.

c) Lựa chọn mức sửa lỗi

d) Khoảng kích thước X

e) Khoảng kích thước Y

f) Các tham số mã vạch: Khoảng tỷ lệ bề mặt cho phép và/hoặc độ dài và rộng mã vạch có kích cỡ tối đa

CHÚ THÍCH: Các phần tử bổ sung có thể được tính đến khi quy định về các ứng dụng PDF417 được quy định trong Phụ lục O và S.

5.14.3.2. Kiểm tra yêu cầu kĩ thuật

Các tham số để đánh giá mã vạch được xác định bằng cách quy định cấp chất lượng theo ISO/IEC 15415 trong tiêu chuẩn ứng dụng.

Cấp này được trình bày theo dạng:

Cấp kí hiệu tổng thể / số tham chiếu của lỗ đo /bước sóng hưởng ứng đỉnh

Ví dụ sau đây minh họa các kiểu giá trị cần được trình bày:

1,5/10/660

trong đó:

1,5 là cp chất lượng tổng thể của mã vạch

10 số tham chiếu của lỗ đo (trong ví dụ này: đường kính 0,25mm)

660 là bước sóng hưởng ứng đỉnh theo nanomet

CHÚ THÍCH: ISO/IEC 15415 đưa ra hướng dẫn về việc lựa chọn các thông số phân cp trong các yêu cầu kĩ thuật về ứng dụng. Các giá trị dành riêng cho ứng dụng sẽ được đề cập đến trong tiêu chuẩn về ứng dụng.

5.14.4. Cht lượng mã vạch PDF417

Các mã vạch PDF417 phải được đánh giá chất lượng bằng việc sử dụng các hướng dẫn về chất lượng in mã vạch 2D quy định trong ISO/IEC 15415 về các mã vạch nhiều hàng với khả năng quét hàng chéo.

5.15. Thuật toán giải mã tham chiếu

Thuật toán mã hóa tham chiếu về PDF417 được quy định trong Phụ lục J. Thuật toán giải mã tham chiếu này là cơ sở để đánh giá chất lượng in theo ISO/IEC 15415.

5.16. Phát hiện lỗi và quy trình sửa lỗi

Như một phần của quy trình giải mã, có thể thiết kế lại mã vạch cho các vết xóa và lỗi thay thế trong khả năng sửa lỗi của mã vạch. Điều này có thể được thực hiện bằng cách sử dụng quy trình nêu trong Phụ lục K.

5.17. Dữ liệu truyền đi

5.17.1. Dữ liệu truyền đi trong diễn dịch (mặc định) cơ bản

Tất cả các từ mã dữ liệu được thông dịch thành dữ liệu người sử dụng và được truyền như các byte 8 bit, liệu dữ liệu này có được mã hóa trong phương thức nén văn bản, nén byte hay nén số hay không. Các ký tự bắt đầu và kết thúc, các chỉ báo hàng, bộ Mô tả độ dài mã vạch, các từ mã chuyển phương thức, các từ mã đệm và các từ mã sửa lỗi không được truyền đi.

5.17.2. Giao thức truyền đối với diễn dịch kênh mở rộng (ECI)

Trong các hệ thống mà ECI được hỗ trợ, một tiền tố về số phân định mã vạch được sử dụng với mỗi bộ truyền (xem 4.17.5 và Phụ lục L). Các khối kiểm soát Macro PDF417 (nếu được truyền) được xem như một phần của bộ kiểm soát các chuỗi thoát trong đó hoạt động cùng với giao thức truyền ECI (xem 5.17.3 và Phụ lục H).

Ba từ mã (925, 926 và 927) báo hiệu việc mã hóa của giá trị ECI và được giải mã là các giá trị byte như sau:

1) Nếu chuỗi ECI bắt đầu với từ mã 927:

i. Từ mã 927 được truyền như ký tự thoát 92, biểu diễn dấu nghịch (\), hoặc gạch chéo ngược trong mã hóa mặc định

ii. Từ mã tiếp theo được chuyển thành giá trị 6 số, bằng cách đặt các số 0 trước từ mã. Giá trị 6 số được truyền như 6 giá trị byte tương ứng trong khoảng từ 48 đến 57.

VÍ DỤ:

Mã vạch mã hóa: [927] [123]

Truyền dữ liệu (byte): 92, 48, 48, 48, 49, 50, 51

Diễn dịch ASCII: \000123

2) Nếu chuỗi ECI bắt đầu với từ mã 926:

i. Từ mã 926 được truyền như ký tự thoát 92.

ii. Hai từ mã tiếp theo được chuyển thành giá trị 6 số với các số 0 ở đầu nếu được yêu cầu, sử dụng công thức sau đây:

([từ mã đầu tiên] + 1) x 900 + [từ mã thứ hai]

Giá trị 6 số được truyền như sáu giá trị byte tương ứng trong khoảng từ 48 đến 57.

VÍ DỤ

Mã vạch mã hoá: [926] [136] [156]

Truyền dữ liệu (các byte): 92, 49, 50, 51, 52, 53, 54

Diễn dịch ASCIl:\123456

3) Nếu chuỗi ECI bắt đầu với từ mã 925:

i. Từ mã 925 được truyền như ký tự thoát 92.

ii. Từ mã tiếp theo được chuyển thành giá trị 6 số bằng cách bổ sung giá trị 810 900 cho nó. Giá trị 6 số được truyền như sáu giá trị byte tương ứng trong khoảng từ 48 đến 57.

VÍ DỤ

Mã vạch mã hóa [925] [456]

Truyền dữ liệu (byte): 92, 56,49, 49, 52, 53, 54

Diễn dịch ASCII:\811356

Quy trình được lặp lại với mỗi lần xuất hiện của ECI.

Phần mềm ứng dụng thừa nhận chuỗi thoát 7 byte của kí tự thoát 92 theo sau bởi sáu byte (mỗi byte trong khoảng 48 đến 57) diễn dịch tất cả các kí tự theo sau đến cuối dữ liệu mã hóa hoặc đến khi byte đơn 92 khác bị bắt gặp, đến từ ECI được xác định bởi chuỗi sáu số.

Nếu dấu ngược, hoặc kí tự khác được biểu diễn bởi byte 92 cần được sử dụng như dữ liệu mã hóa, thì việc truyền như sau. Bất cứ khi nào byte 92 xuất hiện như dữ liệu, thì hai byte của giá trị đó phải được truyền; do đó một lần xuất hiện đơn luôn luôn là ký tự thoát và lần xuất hiện kép cho biết dữ liệu thực.

Ví DỤ:

Dữ liệu mã hóa: A\\B\C

Sự truyền:         A\\\\B\\C

5.17.3. Dữ liệu truyền đối với Macro PDF417

Giao thức cho dữ liệu truyền đối với Macro PDF417 có trong H.6.

5.17.4. Truyền từ mã dự trữ sử dụng giao thức ECI

Khi hoạt động theo giao thức truyền ECI, các bộ giải mã PDF417 phải truyền chuỗi thoát sáu byte của từ mã dự trữ (diễn dịch là\CnnnC’), biểu diễn ký tự thoát (92) theo sau bởi ’C’(67), ba số biểu diễn giá trị thập phân của từ mã dự trữ, theo sau bởi C’ khác, kết thúc chuỗi thoát theo cách độc lập. Các từ mã dữ liệu theo sau từ mã dự trữ không được diễn dịch bởi bộ giải mã theo bất kỳ phương thức nén nào, nhưng thay vào đó được truyền như một loạt chuỗi thoát biểu diễn các từ mã sử dụng cùng chuỗi thoát sáu byte đã nêu ở phần đầu đoạn văn bản này. Tất cả các từ mã dữ liệu còn lại được truyền theo cách này cho đến khi đạt được một trong các điều sau đây:

- phần cuối của dữ liệu mã hóa trong mã vạch

- một latch của phương thức nén được thừa nhận

- từ mã chức năng của Khối Kiểm soát Macro PDF417 (928, 923, hoặc 922)

Từ mã 913 (Byte shift) chỉ được thừa nhận từ phương thức nén văn bản, do đó không phải là một phần của dòng từ mã trong quá trình gửi các từ mã không được diễn dịch và thoát này.

CHÚ THÍCH: Giao thức này có thể truyền một cách thích đáng cú pháp gói tin của mọi từ mã dự trữ mà định nghĩa của nó nhằm mục đích cung cấp chức năng báo hiệu hoặc để biểu diễn một phương thức nén mới.

5.17.5. Số phân định mã vạch

Khi cấu trúc của dữ liệu (dưới dạng Macro PDF417, ECI, v.v) được phân định, số phân định mã vạch phù hợp được bổ sung như một lời mở đầu cho dữ liệu được truyền bởi bộ giải mã. Xem Phụ lục L về các số phân định mã vạch áp dụng PDF417.

5.17.6. Quá trình truyền sử dụng các giao thức cũ

Giới thiệu về hệ thống Diễn dịch Kênh Mở rộng, chung cho một số mã vạch có tác động đến các mã vạch hiện có bao gồm PDF417. Các quy tắc giải mã và mã hóa cơ bn còn lại trong tiêu chuẩn này giống với các quy tắc trong các yêu cầu kỹ thuật về PDF417 của AIM Mỹ (1994) và AIM Châu Âu (1994). Trong định dạng quá trình truyền các ECI và Macro PDF417 là khác nhau, nhưng truyền tải cùng thông tin.

Tất cả phần mềm và thiết bị giải mã PDF417 mới phải tuân theo tiêu chuẩn này. Tuy nhiên, thiết bị phù hợp với tiêu chuẩn trước đây sẽ vẫn tồn tại trong một vài năm nữa. Phụ lục M xác định các quy tắc phải làm theo khi sử dụng phần mềm và thiết bị giải mã không có khả năng tuân theo các mã vạch Macro PDF417 và ECI hiện hành. Theo cách này, thiết bị giải mã cũ và mới có thể tiếp tục cùng tồn tại.

 

Phụ lục A

(quy định)

Bảng mã hóa/ giải mã chuỗi vạch-khoảng trống của mã vạch PDF417

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

0

31111136

51111125

21111155

 

26

31113251

31112612

61113221

1

41111144

61111133

31111163

 

27

11113334

31113125

11113262

2

51111152

41111216

11111246

 

28

21113342

41113133

51113312

3

31111235

51111224

21111254

 

29

11114144

51113141

11113361

4

41111243

61111232

31111262

 

30

21114152

21113216

51113411

5

51111251

41111315

11111345

 

31

11114243

31113224

41114114

6

21111326

51111323

21111353

 

32

21114251

41113232

51114122

7

31111334

61111331

31111361

 

33

11115152

21113315

41114213

8

21111425

41111414

11111444

 

34

51116111

31113323

51114221

9

11111516

51111422

21111452

 

35

31121135

41113331

41114312

10

21111524

41111513

11111543

 

36

41121143

21113414

41114411

11

11111615

51111521

61112114

 

37

51121151

31113422

31115114

12

21112136

41111612

11112155

 

38

21121226

21113513

41115122

13

31112144

41112125

21112163

 

39

31121234

31113521

31115213

14

41112152

51112133

61112213

 

40

41121242

21113612

41115221

15

21112235

61112141

11112254

 

41

21121325

21114125

31115312

16

31112243

31112216

21112262

 

42

31121333

31114133

31115411

17

41112251

41112224

61112312

 

43

11121416

41114141

21116114

18

11112326

51112232

11112353

 

44

21121424

11114216

31116122

19

21112334

31112315

21112361

 

45

31121432

21114224

21116213

20

11112425

41112323

61112411

 

46

11121515

31114232

31116221

21

11113136

51112331

11112452

 

47

21121523

11114315

21116312

22

21113144

31112414

51113114

 

48

11121614

21114323

11121146

23

31113152

41112422

61113122

 

49

21122135

31114331

21121154

24

11113235

31112513

11113163

 

50

31122143

11114414

31121162

25

21113243

41112521

51113213

 

51

41122151

21114422

11121245

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

52

11122226

11114513

21121253

 

83

11131613

51122231

31126121

53

21122234

21114521

31121261

 

84

11132126

31122314

21126212

54

31122242

11115125

11121344

 

85

21132134

41122322

21126311

55

11122325

21115133

21121352

 

86

31132142

31122413

11131145

56

21122333

31115141

11121443

 

87

11132225

41122421

21131153

57

31122341

11115224

21121451

 

88

21132233

31122512

31131161

58

11122424

21115232

11121542

 

89

31132241

31122611

11131244

59

21122432

11115323

61122113

 

90

11132324

21123116

21131252

60

11123135

21115331

11122154

 

91

21132332

31123124

11131343

61

21123143

11115422

21122162

 

92

11132423

41123132

21131351

62

31123151

11116133

61122212

 

93

11132522

21123215

11131442

63

11123234

21116141

11122253

 

94

11133134

31123223

11131541

64

21123242

11116232

21122261

 

95

21133142

41123231

61132112

65

11123333

11116331

61122311

 

96

11133233

21123314

11132153

66

21123341

41121116

11122352

 

97

21133241

31123322

21132161

67

11124143

51121124

11122451

 

98

11133332

21123413

61132211

68

21124151

61121132

51123113

 

99

11134142

31123421

11132252

69

11124242

41121215

61123121

 

100

21141125

21123512

11132351

70

11124341

51121223

11123162

 

101

31141133

21123611

51133112

71

21131126

61121231

51123212

 

102

41141141

11124116

11133161

72

31131134

41121314

11123261

 

103

11141216

21124124

51133211

73

41131142

51121322

51123311

 

104

21141224

31124132

41134112

74

21131225

41121413

41124113

 

105

31141232

11124215

41134211

75

31131233

51121421

51124121

 

106

11141315

21124223

31135112

76

41131241

41121512

41124212

 

107

21141323

31124231

31135211

77

11131316

41121611

41124311

 

108

31141331

11124314

21136112

78

21131324

31122116

31125113

 

109

11141414

21124322

21136211

79

31131332

41122124

41125121

 

110

21141422

11124413

11141144

80

11131415

51122132

31125212

 

111

11141513

21124421

21141152

81

21131423

31122215

31125311

 

112

21141521

11124512

11141243

82

11131514

41122223

21126113

 

113

11142125

11125124

21141251

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

114

21142133

21125132

11141342

 

145

52111151

31133321

22112261

115

31142141

11125223

11141441

 

146

22111226

21133412

62112311

116

11142224

21125231

61142111

 

147

32111234

21133511

12112352

117

21142232

11125322

11142152

 

148

42111242

11134115

12112451

118

11142323

11125421

11142251

 

149

22111325

21134123

52113113

119

21142331

11126132

51143111

 

150

32111333

31134131

62113121

120

11142422

11126231

41144111

 

151

42111341

11134214

12113162

121

11142521

41131115

31145111

 

152

12111416

21134222

52113212

122

21143141

51131123

11151143

 

153

22111424

11134313

12113261

123

11143331

61131131

21151151

 

154

12111515

21134321

52113311

124

11151116

41131214

11151242

 

155

22112135

11134412

42114113

125

21151124

51131222

11151341

 

156

32112143

11134511

52114121

126

31151132

41131313

11152151

 

157

42112151

11135123

42114212

127

11151215

51131321

11161142

 

158

12112226

21135131

42114311

128

21151223

41131412

11161241

 

159

22112234

11135222

32115113

129

31151231

41131511

12111146

 

160

32112242

11135321

42115121

130

11151314

31132115

22111154

 

161

12112325

11136131

32115212

131

21151322

41132123

32111162

 

162

22112333

41141114

32115311

132

11151413

51132131

12111245

 

163

12112424

51141122

22116113

133

21151421

31132214

22111253

 

164

12112523

41141213

32116121

134

11151512

41132222

32111261

 

165

12113135

51141221

22116212

135

11152124

31132313

12111344

 

166

22113143

41141312

22116311

136

11152223

41132321

22111352

 

167

32113151

41141411

21211145

137

11152322

31132412

12111443

 

168

12113234

31142114

31211153

138

11161115

31132511

22111451

 

169

22113242

41142122

41211161

139

31161131

21133115

12111542

 

170

12113333

31142213

11211236

140

21161222

31133123

62112113

 

171

12113432

41142221

21211244

141

21161321

41133131

12112154

 

172

12114143

31142312

31211252

142

11161511

21133214

22112162

 

173

22114151

31142411

11211335

143

32111135

31133222

62112212

 

174

12114242

21143114

21211343

144

42111143

21133313

12112253

 

175

12115151

31143122

31211351

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

176

31211126

21143213

11211434

 

207

12122126

31162211

12123161

177

41211134

31143221

21211442

 

208

22122134

21163112

51214112

178

51211142

21143312

11211533

 

209

32122142

21163211

52123211

179

31211225

21143411

21211541

 

210

11213126

42111116

11214161

180

41211233

11144114

11211632

 

211

12122225

52111124

51214211

181

51211241

21144122

12121145

 

212

22122233

62111132

42124112

182

21211316

11144213

22121153

 

213

32122241

42111215

41215112

183

31211324

21144221

32121161

 

214

11213225

52111223

42124211

184

41211332

11144312

11212145

 

215

21213233

62111231

41215211

185

21211415

11144411

12121244

 

216

31213241

42111314

32125112

186

31211423

11145122

22121252

 

217

11213324

52111322

31216112

187

41211431

11145221

11212244

 

218

12122423

42111413

32125211

188

21211514

41151113

21212252

 

219

11213423

52111421

31216211

189

31211522

51151121

22121351

 

220

12123134

42111512

22126112

190

22121126

41151212

11212343

 

221

22123142

42111611

22126211

191

32121134

41151311

12121442

 

222

11214134

32112116

11221136

192

42121142

31152113

11212442

 

223

12123233

42112124

21221144

193

21212126

41152121

12121541

 

224

22123241

52112132

31221152

194

22121225

31152212

11212541

 

225

11214233

32112215

11221235

195

32121233

31152311

62122112

 

226

21214241

42112223

21221243

196

42121241

21153113

12122153

 

227

11214332

52112231

31221251

197

21212225

31153121

22122161

 

228

12124142

32112314

11221334

198

31212233

21153212

61213112

 

229

11215142

42112322

21221342

199

41212241

21153311

62122211

 

230

12124241

32112413

11221433

200

11212316

11154113

11213153

 

231

11215241

42112421

21221441

201

12121415

21154121

12122252

 

232

31221125

32112512

11221532

202

22121423

11154212

61213211

 

233

41221133

32112611

11221631

203

32121431

11154311

11213252

 

234

51221141

22113116

12131144

204

11212415

41161112

12122351

 

235

21221216

32113124

22131152

205

21212423

41161211

11213351

 

236

31221224

42113132

11222144

206

11212514

31162112

52123112

 

237

41221232

22113215

12131243

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

238

21221315

32113223

22131251

 

269

21223232

61211222

12141242

239

31221323

42113231

11222243

 

270

22132331

11211263

11232242

240

41221331

22113314

21222251

 

271

11223323

51211313

12141341

241

21221414

32113322

11222342

 

272

12132422

61211321

11232341

242

31221422

22113413

12131441

 

273

12132521

11211362

12142151

243

21221513

32113421

11222441

 

274

12133133

51211412

11233151

244

21221612

22113512

62132111

 

275

22133141

51211511

11241134

245

22131125

22113611

12132152

 

276

11224133

42121115

21241142

246

32131133

12114116

61223111

 

277

12133232

52121123

11241233

247

42131141

22114124

11223152

 

278

11224232

62121131

21241241

248

21222125

32114132

12132251

 

279

12133331

41212115

11241332

249

22131224

12114215

11223251

 

280

11224331

42121214

11241431

250

32131232

22114223

52133111

 

281

11225141

61212131

12151142

251

11222216

32114231

51224111

 

282

21231116

41212214

11242142

252

12131315

12114314

42134111

 

283

31231124

51212222

12151241

253

31222232

22114322

41225111

 

284

41231132

52121321

11242241

254

32131331

12114413

32135111

 

285

21231215

41212313

11251133

255

11222315

22114421

31226111

 

286

31231223

42121412

21251141

256

12131414

12114512

22136111

 

287

41231231

41212412

11251232

257

22131422

12115124

11231135

 

288

21231314

42121511

11251331

258

11222414

22115132

21231143

 

289

31231322

41212511

12161141

259

21222422

12115223

31231151

 

290

21231413

32122115

11252141

260

22131521

22115231

11231234

 

291

31231421

42122123

11261132

261

12131612

12115322

21231242

 

292

21231512

52122131

11261231

262

12132125

12115421

11231333

 

293

21231611

31213115

13111145

263

22132133

12116132

21231341

 

294

12141116

32122214

23111153

264

32132141

12116231

11231432

 

295

22141124

42122222

33111161

265

11223125

51211115

11231531

 

296

32141132

31213214

13111244

266

12132224

61211123

12141143

 

297

11232116

41213222

23111252

267

22132232

11211164

22141151

 

298

12141215

42122321

13111343

268

11223224

51211214

11232143

 

299

22141223

31213313

23111351

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

300

32141231

32122412

13111442

 

331

12151115

12125123

12212144

301

11232215

31213412

13111541

 

332

22151123

22125131

13121243

302

21232223

32122511

63112112

 

333

32151131

11216123

23121251

303

31232231

31213511

13112153

 

334

11242115

12125222

12212243

304

11232314

22123115

23112161

 

335

12151214

11216222

22212251

305

12141413

32123123

63112211

 

336

22151222

12125321

12212342

306

22141421

42123131

13112252

 

337

11242214

11216321

13121441

307

11232413

21214115

13112351

 

338

21242222

12126131

12212441

308

21232421

22123214

53113112

 

339

22151321

51221114

63122111

309

11232512

32123222

13113161

 

340

11242313

61221122

13122152

310

12142124

21214214

53113211

 

341

12151412

11221163

62213111

311

22142132

31214222

43114112

 

342

11242412

51221213

12213152

312

11233124

32123321

43114211

 

343

12151511

61221221

13122251

313

12142223

21214313

33115112

 

344

12152123

11221262

12213251

314

22142231

22123412

33115211

 

345

11243123

51221312

53123111

315

11233223

21214412

23116112

 

346

11243222

11221361

52214111

316

21233231

22123511

23116211

 

347

11243321

51221411

43124111

317

11233322

21214511

12211136

 

348

31251122

42131114

42215111

318

12142421

12124115

22211144

 

349

31251221

52131122

33125111

319

11233421

22124123

32211152

 

350

21251411

41222114

32216111

320

11234132

32124131

12211235

 

351

22161122

42131213

23126111

321

11234231

11215115

22211243

 

352

12161213

52131221

21311135

322

21241115

12124214

32211251

 

353

11252213

41222213

31311143

323

31241123

22124222

12211334

 

354

11252312

51222221

41311151

324

41241131

11215214

22211342

 

355

11252411

41222312

11311226

325

21241214

21215222

12211433

 

356

23111126

42131411

21311234

326

31241222

22124321

22211441

 

357

33111134

41222411

31311242

327

21241313

11215313

12211532

 

358

43111142

32132114

11311325

328

31241321

12124412

12211631

 

359

23111225

42132122

21311333

329

21241412

11215412

13121144

 

360

33111233

31223114

31311341

330

21241511

12124511

23121152

 

361

13111316

32132213

11311424

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

362

23111324

42132221

21311432

 

393

42211331

61231121

11321126

363

33111332

31223213

11311523

 

394

22211414

11231162

21321134

364

13111415

41223221

21311531

 

395

32211422

51231212

31321142

365

23111423

31223312

11311622

 

396

22211513

11231261

11321225

366

13111514

32132411

12221135

 

397

32211521

51231311

21321233

367

13111613

31223411

22221143

 

398

23121125

42141113

31321241

368

13112126

22133114

32221151

 

399

33121133

52141121

11321324

369

23112134

32133122

11312135

 

400

43121141

41232113

21321332

370

33112142

21224114

12221234

 

401

22212125

51232121

11321423

371

13112225

22133213

22221242

 

402

23121224

41232212

21321431

372

23112233

32133221

11312234

 

403

33121232

42141311

11321522

373

33112241

21224213

21312242

 

404

12212216

41232311

11321621

374

13112324

31224221

22221341

 

405

13121315

32142113

12231134

375

23112332

21224312

11312333

 

406

32212232

42142121

22231142

376

13112423

22133411

12221432

 

407

33121331

31233113

11322134

377

13112522

21224411

11312432

 

408

12212315

32142212

12231233

378

13113134

12134114

12221531

 

409

22212323

31233212

22231241

379

23113142

22134122

11312531

 

410

23121422

32142311

11322233

380

13113233

11225114

13131143

 

411

12212414

31233311

21322241

381

23113241

12134213

23131151

 

412

13121513

22143113

11322332

382

13113332

22134221

12222143

 

413

12212513

32143121

12231431

383

13114142

11225213

13131242

 

414

13122125

21234113

11322431

384

13114241

21225221

11313143

 

415

23122133

31234121

13141142

385

32211125

11225312

12222242

 

416

33122141

21234212

12232142

386

42211133

12134411

13131341

 

417

12213125

22143311

13141241

387

52211141

11225411

11313242

 

418

13122224

21234311

11323142

388

22211216

12135122

12222341

 

419

32213141

12144113

12232241

389

32211224

11226122

11313341

 

420

12213224

22144121

11323241

390

42211232

12135221

13132151

 

421

22213232

11235113

11331125

391

22211315

11226221

12223151

 

422

23122331

12144212

21331133

392

32211323

51231113

11314151

 

423

12213323

11235212

31331141

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

424

13122422

12144311

11331224

 

455

21312314

53111123

11352131

425

12213422

11235311

21331232

 

456

22221413

63111131

11361122

426

13123133

12145121

11331323

 

457

32221421

43111214

11361221

427

23123141

11236121

21331331

 

458

21312413

53111222

14111144

428

12214133

51241112

11331422

 

459

31312421

43111313

24111152

429

13123232

11241161

11331521

 

460

22221611

53111321

14111243

430

12214232

51241211

12241133

 

461

13131116

43111412

24111251

431

13123331

42151112

22241141

 

462

23131124

43111511

14111342

432

13124141

41242112

11332133

 

463

33131132

33112115

14111441

433

12215141

42151211

12241232

 

464

12222116

43112123

14112152

434

31311116

41242211

11332232

 

465

13131215

53112131

14112251

435

41311124

32152112

12241331

 

466

23131223

33112214

54113111

436

51311132

31243112

11332331

 

467

33131231

43112222

44114111

437

31311215

32152211

13151141

 

468

11313116

33112313

34115111

438

41311223

31243211

12242141

 

469

12222215

43112321

24116111

439

51311231

22153112

11333141

 

470

22222223

33112412

13211135

440

31311314

21244112

11341124

 

471

32222231

33112511

23211143

441

41311322

22153211

21341132

 

472

11313215

23113115

33211151

442

31311413

21244211

11341223

 

473

21313223

33113123

13211234

443

41311421

12154112

21341231

 

474

31313231

43113131

23211242

444

31311512

11245112

11341322

 

475

23131421

23113214

13211333

445

22221116

12154211

11341421

 

476

11313314

33113222

23211341

446

32221124

11245211

12251132

 

477

12222413

23113313

13211432

447

42221132

51251111

11342132

 

478

22222421

33113321

13211531

448

21312116

42161111

12251231

 

479

11313413

23113412

14121143

449

22221215

41252111

11342231

 

480

13131611

23113511

24121151

450

41312132

32162111

11351123

 

481

13132124

13114115

13212143

451

42221231

31253111

21351131

 

482

23132132

23114123

14121242

452

21312215

22163111

11351222

 

483

12223124

33114131

13212242

453

31312223

21254111

11351321

 

484

13132223

13114214

14121341

454

41312231

43111115

12261131

 

485

23132231

23114222

13212341

 

Từ mã

Chuỗi vạch - khoảng trống

 

Từ mã

Chuỗi vạch - khoảng trống

Cụm 0

Cụm 3

Cụm 6

 

Cụm 0

Cụm 3

Cụm 6

BSBSBSBS

BSBSBSBS

BSBSBSBS

 

BSBSBSBS

BSBSBSBS

BSBSBSBS

486

11314124

13114313

14122151

 

517

22231412

33122213

31411133

487

12223223

23114321

13213151

 

518

21322412

43122221

41411141

488

22223231

13114412

12311126

 

519

22231511

32213213

11411216

489

11314223

13114511

22311134

 

520

21322511

42213221

21411224

490

21314231

13115123

32311142

 

521

13141115

32213312

31411232

491

13132421

23115131

12311225

 

522

23141123

33122411

11411315

492

12223421

13115222

22311233

 

523

33141131

32213411

21411323

493

13133132

13115321

32311241

 

524

12232115

23123114

31411331

494

12224132

13116131

12311324

 

525

13141214

33123122

11411414

495

13133231

52211114

22311332

 

526

23141222

22214114

21411422

496

11315132

62211122

12311423

 

527

11323115

23123213

11411513

497

12224231

12211163

22311431

 

528

12232214

33123221

21411521

498

31321115

52211213

12311522

 

529

22232222

22214213

11411612

499

41321123

62211221

12311621

 

530

23141321

32214221

12321125

500

51321131

12211262

13221134

 

531

11323214

22214312

22321133

501

31321214

52211312

23221142

 

532

21323222

23123411

32321141

502

41321222

12211361

12312134

 

533

13141412

22214411

11412125

503

31321313

52211411

13221233

 

534

11323313

13124114