PDF417二維條碼在嵌入式設備中的應用
根據SE923HS與微控制器的接口圖,軟件總體上可分為掃描頭工作函數和中斷函數,流程如圖5和圖6所示。
用SE923HS譯碼程序相對簡單。首先,設置好SE923HS與W77E58通信的波特率。然后,打開串口中斷,在需要掃描條碼時將P1.2置為低電平,進入3s的延時,掃描電機開始工作。在延時時間內,掃描頭一直處于工作狀態(tài),掃描頭譯碼后的數據輸入至單片機產生串口中斷,在中斷函數中存儲譯碼后的信息。一般來說,SE923HS掃描頭有效工作1s后可以將紙質的掃描譯碼完畢。P1.2置為高電平時,掃描電機停止工作。
對解碼后的數據進行后期處理,將這些數據和其它需要重新加密的數據重新二維條碼編碼和糾錯,得到加密后的數據。這些數據可以通過RS232、USB或者藍牙發(fā)送給上位機作相應的處理。
3.2 二維條碼編碼和糾錯
在實際應用中,考慮到在應用中投遞物品信息組成和單片機處理速度,投遞物品上的信息多用漢字表示,且文本字符和數字的數量較少,所以可以只用字節(jié)壓縮模式(BC)對其進行編碼。這樣可大大減小編譯碼的復雜性,并且對數據的壓縮率影響也不大。再有,由PDF417條碼標準規(guī)定,條碼符號的行數不超過90行,數據區(qū)列數不超過30列,所以最多可以編2700個碼字。糾錯碼最多512個,那么數據碼最多可編2188個。但是由于PDF417條碼標準規(guī)定數據區(qū)第一個碼字表示數據區(qū)碼字的個數,這就限制了數據區(qū)碼字最多不超過928個,也就是說譯碼最多只能譯 928個碼字,沒有用到編碼數量的極限。當要編碼的數據較多時,則可以作如下改動:采用2個碼字表示數據區(qū)碼字的個數,這樣就可以做到編碼個數的極限2188個碼字。因此在具體應用時,根據情況靈活地運用PDF417條碼標準是很重要的。
為統(tǒng)一起見,在編碼過程中只采用模式結構中的字節(jié)壓縮模式(BC)?,F簡要介紹如下:
字節(jié)壓縮模式通過基256至基900的轉換,將字節(jié)序列轉換為碼字序列。當所要表示的字節(jié)總數不是6的倍數時,用模式鎖定901;當所要表示的字節(jié)總數是6的倍數時,用模式鎖定924。在應用模式鎖定924的情況下,6個字節(jié)可通過基256至基900的轉換用5個碼字表示,從左到右進行轉換。在應用模式鎖定901的情況下,每前6個字節(jié)的轉換方法與上述方法相同,對被6整除所剩余的字節(jié)應每個字節(jié)對應一個碼字,逐字節(jié)用碼字表示。具體編碼流程如圖7所示。
四一七條碼采用Reed-Solomon錯誤控制算法(簡稱RS碼)對數據碼字進行糾錯編碼和譯碼。RS碼是一類可以糾正多個隨機錯誤的多進制循環(huán)碼。對于一組給定的數據碼字,根據不同的碼字個數采用相應的糾錯等級,錯誤糾正碼字根據Reed-Solomon錯誤控制碼算法計算。
對于一個給定的錯誤糾正等級,其錯誤糾正容量由下式確定:
式中: e-拒讀錯誤數目; t-替代錯誤數目;
s-錯誤糾正等級; d-錯誤糾正碼字數目。
錯誤糾正碼字的總數為2s+1。其中,兩個用于錯誤檢測。其余的錯誤糾正碼字用于錯誤糾正。用一個錯誤糾正碼字恢復一個拒讀錯誤,用兩個錯誤糾正碼字糾正一個替代錯誤。
當被糾正的替代錯誤數目小于4時(s=0除外),錯誤糾正容量由下式確定:
e+2t ≤ d-3
對于一組給定的數據碼字,錯誤糾正碼字根據RS錯誤控制碼算法計算。
(1)建立符號數據多項式
(2)建立糾正碼字的生成多項式
(3)產生錯誤糾正碼字
對一組給定的數據碼字和一選定的錯誤糾正等級,錯誤糾正碼字為符號數據多項式d(x)乘以xk,然后除以生成多項式g(x),所得為余式的各系數的補數。
注:解碼、編碼和糾錯程序見本刊網站www.dpj.com.cn。
圖7
4 結 論
本文提供了一種簡單可行的PDF417二維條碼譯碼和編碼的方案。利用PDF417二維條碼具有信息容量大、編碼范圍廣、容錯能力強、譯碼可靠性高、保密防偽性好、成本低、條碼形狀和尺寸可變等優(yōu)點,使SE923HS掃描頭和W77E58微控制器結合,成本低、可行性強。在小數據量(小于1000字節(jié))和較低糾錯級別(5級以下)時,編碼和糾錯時間在10s之內,處理速度優(yōu)勢明顯。
評論