雙網(wǎng)傳真機的編譯碼電路設計與實(shí)現
2.2 步進(jìn)電機控制
在傳真機硬件系統中,步進(jìn)電機的主要作用是根據當前工作狀態(tài),驅動(dòng)掃描或打印夾紙的滾軸。步進(jìn)電機的時(shí)鐘周期為10 ms,滿(mǎn)足系統要求。掃描時(shí)步進(jìn)電機反轉,打印時(shí)正轉。通過(guò)控制寄存器,可以實(shí)現標準和精細兩種掃描模式。
2.3 打印器件
設計所用的熱敏打印器件系統采用SHECHA216-UH,其接口時(shí)序如圖3所示(data表示數據在鎖存信號有效后輸出)。其中,heater_clk為打印頭時(shí)鐘,1 MHz,50 %占空比;heater_latch_n為打印頭鎖存信號,低電平有效,每隔10ms鎖存一次;heater_trobe[3:0]為打印頭加熱段選信號,在10 ms內,這四個(gè)信號依次低有效一次。本文引用地址:http://dyxdggzs.com/article/191102.htm
3 編碼電路單元設計
對一個(gè)二值傳真信源來(lái)說(shuō),一副傳真圖像是由掃描線(xiàn)上的像素組成的,而每一掃描線(xiàn)又總是由一些連續的黑像素和白像素組成,連續發(fā)生的黑像素為連‘1’,白像素為連‘0’,也稱(chēng)之為黑游程和白游程。連‘1’的個(gè)數稱(chēng)為黑游程長(cháng)度,連‘0’的個(gè)數稱(chēng)為自游程長(cháng)度。黑白游程總是交替出現的。游程長(cháng)度就等于一條掃描線(xiàn)上的像素總數,A4幅面一般為1 728。本項目使用的圖像二值化方法是固定閾值法,即將A/D轉化后的8 b數據和閾值做比較,得到‘0’或‘1’(白點(diǎn)或黑點(diǎn))。當總線(xiàn)地址為01H時(shí),讀取32位編碼寄存器。
無(wú)失真的信源編碼方式中,使用最多的是變長(cháng)碼,其中最優(yōu)的編碼是Huffman碼,改進(jìn)的Huffman碼(MHC)是三類(lèi)傳真機信源編碼的標準。MHC所做的主要改進(jìn)是將碼字分為終止碼和形成碼,能夠用較短的編碼來(lái)表示較長(cháng)的連續黑點(diǎn)或自點(diǎn)。0~63的游程長(cháng)度用終止碼表示,64整數倍的游程長(cháng)度由形成碼表示,任意游程長(cháng)度大于63的碼字表示為“形成碼+終止碼”。例如,當白游程長(cháng)度為131 b(128+3)時(shí),編碼表示為‘100101000’,即,白游程長(cháng)度128 b的形成碼‘10010’加上白游程長(cháng)度為3 b的終止碼‘1000’。行同步碼EOL的格式為‘0000000000 01’。WRLC為白游程長(cháng)度編碼,BRLC為黑游程長(cháng)度編碼。每一行的第一個(gè)游程長(cháng)度編碼為白碼字,黑白游程長(cháng)度碼字連續交替。收到連續的六個(gè)EOL后表示該頁(yè)結束。根據T.4的表述,一頁(yè)編碼后的傳真數據格式如表3所示。
在構建碼表時(shí),構建四個(gè)不同的碼表單元,即黑、白游程形成碼碼元單元和黑、白游程終止碼碼元單元。同時(shí)需要存儲黑白游程編碼碼元的長(cháng)度信息。終止碼碼表的地址是按游程長(cháng)度編寫(xiě)的,即0~63,而形成碼的碼表地址共有27個(gè)。這樣存儲可以通過(guò)黑白計數值直接找到地址,碼表所存儲的信息為17位,表4給出了MHC碼表的輸出說(shuō)明。
例如,編碼得到的碼元信息是‘0111’,這是白游程2所代表的碼元,則碼元的有效長(cháng)度為‘0100’(4位),碼元信息為‘011100000000 0’(13位)。在碼元黑白屬性發(fā)生改變時(shí),如果當前游程的計數長(cháng)度小于64,則取計數長(cháng)度的低6位為地址,查找對應碼表(終止碼表)中的17位數據;如果游程長(cháng)度大于或等于64,則取計數長(cháng)度的高5位為地址,查找對應碼表(形成碼表)中的17位數據。NiosⅡ處理器進(jìn)行數據交換,采用32位寄存器接口。每次查找完MHC碼表后,采用二級編碼電路對一級編碼電路得到的信息再進(jìn)行一次編碼,將17位編碼數據轉換成32位編碼數據。圖4給出了編碼狀態(tài)轉移圖。
評論