![基于FPGA的LZO實(shí)時(shí)無(wú)損壓縮的硬件設(shè)計(jì)_第1頁(yè)](http://file4.renrendoc.com/view/7d2f8bbc5e33440090f373b2db2f2f6e/7d2f8bbc5e33440090f373b2db2f2f6e1.gif)
![基于FPGA的LZO實(shí)時(shí)無(wú)損壓縮的硬件設(shè)計(jì)_第2頁(yè)](http://file4.renrendoc.com/view/7d2f8bbc5e33440090f373b2db2f2f6e/7d2f8bbc5e33440090f373b2db2f2f6e2.gif)
![基于FPGA的LZO實(shí)時(shí)無(wú)損壓縮的硬件設(shè)計(jì)_第3頁(yè)](http://file4.renrendoc.com/view/7d2f8bbc5e33440090f373b2db2f2f6e/7d2f8bbc5e33440090f373b2db2f2f6e3.gif)
![基于FPGA的LZO實(shí)時(shí)無(wú)損壓縮的硬件設(shè)計(jì)_第4頁(yè)](http://file4.renrendoc.com/view/7d2f8bbc5e33440090f373b2db2f2f6e/7d2f8bbc5e33440090f373b2db2f2f6e4.gif)
下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
基于FPGA的LZO實(shí)時(shí)無(wú)損壓縮的硬件設(shè)計(jì)本文通過(guò)對(duì)多種壓縮算法作進(jìn)一步研究對(duì)比后發(fā)現(xiàn),LZO壓縮算法是一種被稱為實(shí)時(shí)無(wú)損壓縮的算法,LZO壓縮算法在保證實(shí)時(shí)壓縮速率的優(yōu)點(diǎn)的同時(shí)提供適中的壓縮率。如圖1(A)給出了Linux操作系統(tǒng)下常見開源壓縮算法的壓縮速率的測(cè)試結(jié)果,LZO壓縮算法速率極快;如圖1(B)給出了Gzip壓縮算法和LZO壓縮算法的壓縮率測(cè)試結(jié)構(gòu),從圖中可以看出,LZO壓縮算法可以提供平均約50%的壓縮率。1LZO壓縮算法基本原理分析1.1LZO壓縮算法壓縮原理LZO壓縮算法采用(重復(fù)長(zhǎng)度L,指回距離D)代替當(dāng)前已經(jīng)在歷史字符串中出現(xiàn)過(guò)的字符串,其中,重復(fù)長(zhǎng)度是指,后出現(xiàn)的字符串與先出現(xiàn)的字符串中連續(xù)相同部分的長(zhǎng)度;指回距離是指,先后兩個(gè)相同字符串之間相隔的距離(每個(gè)字節(jié)為一個(gè)單位);如果沒出現(xiàn)過(guò)(定義為新字符),則首先輸出新字符的個(gè)數(shù),再輸出新字符。例如,待處理的字符串為“ABCDEFGHABCDEFJKLM”,壓縮算法逐個(gè)處理字符,處理ABCDEFGH時(shí)沒發(fā)現(xiàn)重復(fù)字符;處理到ABCDEF時(shí)發(fā)現(xiàn)這些字符在歷史字符串中已經(jīng)出現(xiàn)過(guò),計(jì)算重復(fù)長(zhǎng)度為6,指回距離(當(dāng)前A離歷史A的距離)為8,則用(6,8)代替ABCDEF;處理到JKLM時(shí)沒發(fā)現(xiàn)重復(fù)字符,字符串到此處理完畢,則整個(gè)字符串被壓縮成:(08)hABCDEFGH(6,8)(04)hJKLM,其中h表示16進(jìn)制。1.2LZO壓縮算法編碼LZO壓縮后的數(shù)據(jù)需要經(jīng)過(guò)特定的格式進(jìn)行編碼,如圖2所示,LZO壓縮算法這樣做的目的有兩方面:調(diào)整LZO壓縮率,使得LZO適合壓縮重復(fù)長(zhǎng)度短,但指回距離較長(zhǎng)的數(shù)據(jù);使得解壓縮過(guò)程更加簡(jiǎn)單,解壓縮速度更快,且不需要額外的內(nèi)存。2LZO壓縮算法硬件設(shè)計(jì)與加速方案2.1LZO壓縮算法硬件結(jié)構(gòu)如圖3(A)給出了一種LZO壓縮算法的硬件結(jié)構(gòu),其中輸入緩存模塊:用于緩存DMA傳輸?shù)拇龎嚎s數(shù)據(jù),為高速緩存模塊提供數(shù)據(jù)源用以進(jìn)行壓縮操作;高速緩存模塊:臨時(shí)緩存待壓縮數(shù)據(jù),為L(zhǎng)ZSS壓縮模塊提供待壓縮數(shù)據(jù),初始化時(shí)提前寫入一定量的數(shù)據(jù);LZSS模塊:對(duì)待壓縮數(shù)據(jù)進(jìn)行壓縮處理;字典模塊:存儲(chǔ)壓縮過(guò)程中產(chǎn)生的壓縮信息,例如歷史字符串的索引信息,這樣便可為后續(xù)數(shù)據(jù)壓縮提供歷史字符串信息;LZO編碼模塊:對(duì)LZSS壓縮后的數(shù)據(jù)按照LZO編碼格式進(jìn)行編碼,并將編碼數(shù)據(jù)組包成固定長(zhǎng)度的數(shù)據(jù)包,方便總線通訊;輸出緩存模塊:緩存編碼后的數(shù)據(jù),為DMA讀操作提供壓縮后的數(shù)據(jù)源;Avalon總線接口:按照Avalon總線規(guī)范對(duì)LZO壓縮算法模塊進(jìn)行封裝,為后續(xù)集成SOPC提供準(zhǔn)備。2.2LZO壓縮算法硬件加速方案(1)分離雙端口RAM為了加速LZO壓縮算法字符串的比對(duì)過(guò)程,本文提出如圖3(B)所示的分離雙端口RAM的結(jié)構(gòu),圖中的多路選擇器1用于將待壓縮數(shù)據(jù)交替式寫入雙端口RAM1和雙端口RAM2之一中,多路選擇器2用于將讀取的數(shù)據(jù)交替式輸出。例如,現(xiàn)有字符ABCDEFGHIJ要存入雙端口RAM中,具體如下:ABCD通過(guò)多路選擇器1被寫入RAM1中的data1處,EFGH通過(guò)多路選擇器1被寫入RAM2中的data2處,IJ通過(guò)多路選擇1被寫入data3,此時(shí)LZO壓縮算法模塊需要讀取字符串BCDE,則在讀取RAM1中data1處的BCD的同時(shí)讀取RAM2中data2處的E,即給RAM1讀地址的同時(shí)可以給RAM2讀地址,這樣同一時(shí)刻可以讀2處地址對(duì)應(yīng)的內(nèi)容。相比于一般性雙端口RAM結(jié)構(gòu),本結(jié)構(gòu)可以實(shí)現(xiàn)一次完成讀取操作。做進(jìn)一步擴(kuò)展可得出如下結(jié)論:若RAM的寬度為W,則讀取字符數(shù)在2W以內(nèi)時(shí),采用分離雙端口RAM結(jié)構(gòu)可以一次完成讀取操作;則讀取字符數(shù)在2~2W以內(nèi)時(shí),采用一般性雙端口RAM結(jié)構(gòu)可能要讀兩次。當(dāng)然,不僅RAM的寬度可以增加,RAM的個(gè)數(shù)也可以增加,當(dāng)RAM的寬度和RAM個(gè)數(shù)越大時(shí),完成讀操作只需一次的可能性就越大。(2)塊標(biāo)記LZO壓縮算法在壓縮每個(gè)數(shù)據(jù)塊之前都要對(duì)字典模塊進(jìn)行初始化為0的操作,即對(duì)RAM進(jìn)行寫0操作,然而寫0操作會(huì)耗費(fèi)若干個(gè)周期。若字典模塊深度為16K,即RAM的深度為16K,當(dāng)進(jìn)行寫0操作時(shí)至少花費(fèi)16K個(gè)周期。通常解決此類問(wèn)題的一種方法是采用乒乓操作的方式,即用兩個(gè)字典來(lái)交替處理。為了解決初始化帶來(lái)的時(shí)間花費(fèi)和資源消耗的問(wèn)題,本文提出一種如圖3(C)所示的塊標(biāo)記字典結(jié)構(gòu),該結(jié)構(gòu)主要包括:LZSS壓縮控制模塊,用于產(chǎn)生壓縮信息,即字符索引及字符所對(duì)應(yīng)的Hash值;flag產(chǎn)生模塊,用于產(chǎn)生0或者1兩種flag標(biāo)識(shí),表示是當(dāng)前數(shù)據(jù)塊還是歷史數(shù)據(jù)塊;信息合并模塊,用于將字符索引和flag標(biāo)識(shí)進(jìn)行合并,然后存入字典模塊。整個(gè)結(jié)構(gòu)的工作原理可歸納如下:flag標(biāo)識(shí)0或1表示是當(dāng)前數(shù)據(jù)塊或歷史數(shù)據(jù)塊,如壓縮第一個(gè)數(shù)據(jù)塊時(shí)標(biāo)識(shí)為0,壓縮第二個(gè)數(shù)據(jù)塊時(shí)標(biāo)識(shí)為1,壓縮第三個(gè)數(shù)據(jù)塊時(shí)標(biāo)識(shí)為0,壓縮第四個(gè)數(shù)據(jù)塊時(shí)標(biāo)識(shí)為1,如此進(jìn)行反復(fù);LZSS壓縮控制模塊產(chǎn)生字符索引然后與flag進(jìn)行合并共同存入通過(guò)字符計(jì)算出的Hash值對(duì)應(yīng)的地址處。例如,現(xiàn)假設(shè)已經(jīng)壓縮到第二個(gè)數(shù)據(jù)塊,則根據(jù)上面的工作原理可知,當(dāng)前的標(biāo)識(shí)應(yīng)該為1,在壓縮時(shí)取出字典中的信息并判斷第一個(gè)bit位,如果第一個(gè)bit位為0則說(shuō)明該壓縮信息是歷史數(shù)據(jù)塊,壓縮信息無(wú)效;如果第一個(gè)bit位為1則說(shuō)明可能是當(dāng)前數(shù)據(jù)塊(因?yàn)橐灿锌赡苁呛芫靡郧暗臄?shù)據(jù)塊),根據(jù)壓縮信息取出相應(yīng)字符進(jìn)行比對(duì)確認(rèn)。綜上所述,塊標(biāo)記字典結(jié)構(gòu)具有如下特點(diǎn):無(wú)需初始化操作,避免了初始化過(guò)程帶來(lái)的時(shí)間花費(fèi);摒棄了乒乓操作的思想,節(jié)省了乒乓操作帶來(lái)的大量資源的消耗;該結(jié)構(gòu)在片上資源緊缺的情況下是最優(yōu)的選擇。(3)字典分離軟件在實(shí)現(xiàn)LZO壓縮算法過(guò)程中,當(dāng)碰撞發(fā)生時(shí),LZO壓縮算法會(huì)進(jìn)行第二次Hash操作,該次Hash操作在第一次Hash操作的基礎(chǔ)上進(jìn)行偏移。為了提升LZO壓縮算法的壓縮率,本文提出一種如圖3(D)所示的字典分離的結(jié)構(gòu),當(dāng)Hash碰撞發(fā)生時(shí),LZO壓縮算法進(jìn)行第二次Hash操作,但第二次Hash操作對(duì)應(yīng)的字符串索引不再存入第一個(gè)字典中,而是單獨(dú)開辟一塊RAM空間進(jìn)行存儲(chǔ)。字典分離結(jié)構(gòu)的總存儲(chǔ)空間增加了字典2的大小,這樣在壓縮文件的過(guò)程中,文件的壓縮信息量也會(huì)增加??梢?,該結(jié)構(gòu)可以改進(jìn)LZO壓縮算法的壓縮率。3LZO壓縮系統(tǒng)集成與測(cè)試驗(yàn)證3.1LZO壓縮系統(tǒng)硬件結(jié)構(gòu)如圖4(A)為L(zhǎng)ZO壓縮系統(tǒng)SOPC硬件結(jié)構(gòu),內(nèi)層虛線表示FPGA,虛線內(nèi)的模塊有相應(yīng)的代碼或硬件電路構(gòu)成,外層虛線表示DE2開發(fā)板,開發(fā)板提供了相應(yīng)的資源。圖中:PC機(jī)通過(guò)下載線將待壓縮的數(shù)據(jù)傳送至DE2開發(fā)板上的SDRAM,數(shù)據(jù)經(jīng)壓縮后再經(jīng)下載線回傳至PC機(jī);NiosII處理器負(fù)責(zé)與用戶交互,對(duì)待壓縮數(shù)據(jù)進(jìn)行管理,控制整個(gè)SOPC的正常工作;JTAG-UART用于設(shè)計(jì)過(guò)程中的軟件和硬件調(diào)試;DMA控制器用于高速數(shù)據(jù)傳輸,它將片外SDRAM中的待壓縮數(shù)據(jù)傳送到LZO壓縮算法模塊,將LZO壓縮算法模塊中被壓縮后的數(shù)據(jù)傳送到片外SDRAM中;LZO壓縮算法模塊用于對(duì)用戶傳輸過(guò)來(lái)的數(shù)據(jù)進(jìn)行壓縮,它與片外SRAM進(jìn)行通訊;LCD控制器用于控制LCD的顯示,LCD可顯示LZO壓縮文件開始與結(jié)束,增加用戶交互的可視性,例如顯示待壓縮文件的大小,壓縮后的文件大小等;PIO控制LED指示燈的亮與滅,LED燈可用于指示LZO壓縮文件開始與結(jié)束,增加用戶交互的可視性;On-chipmemory用于存儲(chǔ)系統(tǒng)啟動(dòng)時(shí)的軟硬件配置等信息;SDRAM控制器用于控制SDRAM與系統(tǒng)數(shù)據(jù)的交換;SDRAM用于存儲(chǔ)指令和數(shù)據(jù);SRAM用于存儲(chǔ)LZO壓縮算法過(guò)程中產(chǎn)生的壓縮信息,在硬件設(shè)計(jì)中扮演字典的角色,采用片外SRAM的原因是考慮到FPGA片內(nèi)資源可能不夠使用;以上所有涉及到的模塊均采用Avalon總線規(guī)范進(jìn)行數(shù)據(jù)通信,它們共同掛載到數(shù)據(jù)總線上,Avalon總線具有自身的仲裁結(jié)構(gòu)、地址分析等功能,易于用戶集成開發(fā)。3.2開發(fā)板簡(jiǎn)介測(cè)試與驗(yàn)證平臺(tái)如圖4(B)所示的DE2開發(fā)板,該開發(fā)板上的核心芯片為Altera公司的CycloneIIEP2C35FPGA。選擇該開發(fā)板作為測(cè)試平臺(tái)主要基于以下考慮:擁有足夠的片外存儲(chǔ)資源(SDRAM8MB、SRAM512KB);擁有較豐富的片上邏輯資源(35KLEs);擁有豐富的可用于調(diào)試的外設(shè)(LCD、7-segment-displays);支持NiosII嵌入式軟核;成本較低。3.3測(cè)試結(jié)果及對(duì)比針對(duì)LZO壓縮算法模塊和集成后的系統(tǒng)進(jìn)行板級(jí)測(cè)試,一方面驗(yàn)證算法模塊及集成后的系統(tǒng)的功能正確性,另一方面測(cè)試分析算法模塊及集成后系統(tǒng)的性能。測(cè)試內(nèi)容包括:數(shù)據(jù)壓縮率(壓縮后的文件大小/壓縮前的
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2020-2025年中國(guó)減速器行業(yè)市場(chǎng)調(diào)研分析及投資戰(zhàn)略咨詢報(bào)告
- 2025年中國(guó)互聯(lián)網(wǎng)+服裝行業(yè)發(fā)展前景預(yù)測(cè)及投資規(guī)劃建議報(bào)告
- 提升復(fù)合型人才培養(yǎng)質(zhì)量的策略
- 中國(guó)石化購(gòu)油合同范本
- 2025年加油站安全管理及事故應(yīng)急預(yù)案合同
- epc內(nèi)部合同范例
- 個(gè)人網(wǎng)店店鋪轉(zhuǎn)讓合同范本
- 2020-2025年中國(guó)無(wú)人船行業(yè)市場(chǎng)調(diào)研分析及投資戰(zhàn)略咨詢報(bào)告
- 勞務(wù)廣告安裝合同范例
- 作品著作版權(quán)合同范例
- 部編人教版六年級(jí)下冊(cè)語(yǔ)文1-6單元作文課件
- 2024年駐寺工作總結(jié)
- 初三政治中考重要知識(shí)點(diǎn)歸納
- 派出所績(jī)效考核總結(jié)分析報(bào)告
- 智能型萬(wàn)能式斷路器框架開關(guān)RMW1、DW45-2000/3P-抽屜式1000A說(shuō)明
- 2023靜脈治療護(hù)理技術(shù)操作標(biāo)準(zhǔn)解讀
- 先天性腎上腺皮質(zhì)增生癥
- 2024年湖南鐵道職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試題庫(kù)及答案解析word版
- 新《安全生產(chǎn)法》全面解讀“三管三必須”
- 印刷包裝行業(yè)復(fù)工安全培訓(xùn)課件
- 蜜蜂的社會(huì)結(jié)構(gòu)和功能
評(píng)論
0/150
提交評(píng)論