chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

FPGA如何使用RAM分區(qū)循環(huán)移位法實(shí)現(xiàn)解交織器

FPGA設(shè)計(jì)論壇 ? 來源:電子設(shè)計(jì)應(yīng)用 ? 作者:fengfeng ? 2021-09-28 17:53 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本文分析了卷積交織和解交織的基本原理,然后采用AlteraFPGA器件,用RAM分區(qū)循環(huán)移位法來實(shí)現(xiàn)解交織器。無論從理論上,還是從計(jì)算機(jī)仿真和綜合結(jié)果上來分析,都可以看出用這種方法來實(shí)現(xiàn)DVB-C解交織器能有效地節(jié)省硬件資源。

卷積交織和解交織原理簡介

在DVB-C系統(tǒng)當(dāng)中,實(shí)際信道中的突發(fā)錯(cuò)誤往往是由脈沖干擾、多徑衰落引起的,在統(tǒng)計(jì)上是相關(guān)的,所以一旦出現(xiàn)不能糾正的錯(cuò)誤時(shí),這種錯(cuò)誤將連續(xù)存在。因此在DVB-C系統(tǒng)里,采用了卷積交織來解決這種問題。它以一定規(guī)律擾亂源符號數(shù)據(jù)的時(shí)間順序,使其相關(guān)性減弱,然后將其送入信道,解交織器按相反規(guī)律恢復(fù)出源符號數(shù)據(jù)。

DVB-C的卷積交織和解交織原理為:交織由I=12(I為交織深度)個(gè)分支構(gòu)成。每個(gè)分支的延時(shí)逐漸遞增,遞增的單元數(shù)M=n/I=204/12=17(M為交織基數(shù))。這里的數(shù)據(jù)單位為字節(jié)。0支路無延時(shí),1支路延時(shí)17個(gè)符號周期,11支路則延時(shí)l7×11個(gè)符號周期。輸入端有一開關(guān)隨著時(shí)間推移依次連接各個(gè)延時(shí)支路,輸出端有一開關(guān)與輸入端一一對應(yīng),同步連接各延時(shí)支路。

解交織器的實(shí)現(xiàn)

解交織器的FPGA實(shí)現(xiàn)原理

本文采用RAM分區(qū)循環(huán)移位法來實(shí)現(xiàn),因?yàn)镽AM里面暫存一位數(shù)據(jù),只需要用一個(gè)邏輯門大小的資源,比基本寄存器暫存一位數(shù)據(jù)需要12個(gè)邏輯門大小的資源要優(yōu)化很多。用RAM分區(qū)循環(huán)移位法來實(shí)現(xiàn)解交織器,就是把RAM分成11個(gè)區(qū)。每個(gè)區(qū)的大小為(單位為字節(jié)):

Ni=M*(I-i-1)(i=0,1,2, …,(I-1))

這里i為RAM所分區(qū)的區(qū)號。

因?yàn)?1支路不需要延時(shí),所以 RAM的11分區(qū)大小即N11為0。本文在RAM前面設(shè)置一個(gè)地址控制器,這是解交織器關(guān)鍵的一步。RAM每區(qū)有一個(gè)首地址和區(qū)內(nèi)偏移地址,分別用一個(gè)寄存器來存儲。在地址控制器里產(chǎn)生每區(qū)的首地址和區(qū)內(nèi)偏移地址,從而進(jìn)一步產(chǎn)生RAM的讀寫地址。

解交織器的FPGA實(shí)現(xiàn)

把解交織器的深度I和基數(shù)M設(shè)成參數(shù),以增強(qiáng)程序的通用性。如果以后設(shè)計(jì)的解交織器的系數(shù)I和M需要改動(dòng),只要把參數(shù)值重新設(shè)置一下就可以了,不需要改動(dòng)程序。由前面的計(jì)算可知,解交織器總共需要延時(shí)的比特?cái)?shù),也就是RAM的大小應(yīng)該為8976比特。

可以用下面一段程序?qū)崿F(xiàn)首地址的初始化:

FirstAddr[0]=0;

for(i=1;i《(i-1);i=i+1)《 span=“”》

FirstAddr[i]=(I-i)*M+FirstAddr[i-1];

也就是說0~11支路的首地址在RAM中分別為0,187,357,510,646,765,867,952,1020,1071,1105。

RAM每區(qū)的字節(jié)數(shù)可以由參數(shù)來表示,即為(I-i-1)*M,i為分支號。

每區(qū)內(nèi)偏移地址SectAddr[i]初始化為0,每寫入一個(gè)數(shù)據(jù),遞增1并與由參數(shù)表示的每區(qū)的字節(jié)數(shù)進(jìn)行比較,若兩數(shù)相等,則SectAddr[i]重新設(shè)為零,保證區(qū)內(nèi)偏移地址在每區(qū)內(nèi)循環(huán)移動(dòng)。

由上可知,RAM每區(qū)的讀寫地址為:FirstAddr[i]+SectAddr[i](i為RAM分區(qū)號)

RAM每區(qū)的讀寫地址相同,也就是先讀出給定地址單元的數(shù)據(jù)后,再寫入新的數(shù)據(jù)。這里要同時(shí)發(fā)生讀寫操作,所以要使用雙口RAM。每隔一個(gè)時(shí)鐘周期,RAM讀寫指針就跳到下一個(gè)RAM區(qū),這樣讀寫指針在RAM的11個(gè)區(qū)循環(huán)移動(dòng),實(shí)現(xiàn)解交織。

Clk為時(shí)鐘信號,Reset為異步復(fù)位信號,ClkEn為時(shí)鐘使能信號,高電平有效,F(xiàn)rameFirstIn為幀同步信號,高電平有效。DeinterleaverIn為輸入數(shù)據(jù)。設(shè)計(jì)時(shí)要注意數(shù)據(jù)同步問題,要不然會造成數(shù)據(jù)錯(cuò)位,導(dǎo)致設(shè)計(jì)的失敗。DeinterleaverIn為了在selector模塊輸入時(shí)和RAM的輸出數(shù)據(jù)q保持同步,要作相應(yīng)的延時(shí),同步延時(shí)后DataIn4,同理,對應(yīng)地RAM的輸入數(shù)據(jù)DataIn1,selector模塊的使能信號ClkEn4等也是經(jīng)過同步處理得到。Flag為selector模塊的選擇控制信號,當(dāng)Flag信號為0~10時(shí),選擇RAM的輸出數(shù)據(jù)q作為輸出,而當(dāng)Flag=11時(shí),則選擇DeinterleaverIn經(jīng)過同步處理后的數(shù)據(jù)DataIn4作為輸出,從而保證在解交織器的11支路實(shí)現(xiàn)無延時(shí)輸出。在解交織器的最前面輸出的字節(jié)有些是無效的,加一個(gè)DataEffect模塊是為了等全部字節(jié)都有效時(shí),才把FrameFirstOut信號置高,告訴后面的模塊數(shù)據(jù)開始全部有效。

從資源利用方面考慮,使用RAM分區(qū)循環(huán)移位法來實(shí)現(xiàn)DVB-C解交織器比全部用基本寄存器或用配置FIFO的方法來實(shí)現(xiàn)要優(yōu)化得多。

為了更好地驗(yàn)證,本文把設(shè)計(jì)在synopsys 公司的synplify pro軟件環(huán)境下進(jìn)行綜合,選用Altera公司的Cyclone EP1C12Q240C8器件。因?yàn)槭褂昧塑浐薎P,所以再把生成的*.vqm文件導(dǎo)入synopsys公司的QuartusII 軟件進(jìn)行再綜合,選擇同樣的器件類型和型號,結(jié)果說明采用雙口RAM設(shè)計(jì)所使用的邏輯單元較少,而且使用的8976比特RAM資源占用了Cyclone器件中的3個(gè)M4K,只有全部存儲資源的3%。

結(jié)語

雖然采用卷積交織會在剛開始傳輸數(shù)據(jù)的時(shí)候輸出一些無效數(shù)據(jù),在系統(tǒng)中引入一定的延時(shí),但是它能把突發(fā)干擾造成的突發(fā)錯(cuò)誤分散成隨機(jī)錯(cuò)誤,利于RS糾錯(cuò),這樣一權(quán)衡,有延時(shí)也是很值得的。本文利用EDA工具完成解交織器的設(shè)計(jì),并且采用Verilog和原理圖協(xié)同輸入的設(shè)計(jì)方法,大大提高了設(shè)計(jì)效率。這里設(shè)計(jì)的解交織器具有通用性,如果要用不同深度I和基數(shù)M的解交織器,只要重設(shè)程序里的參數(shù)值就可以了,非常方便。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1659

    文章

    22364

    瀏覽量

    632978
  • RAM
    RAM
    +關(guān)注

    關(guān)注

    8

    文章

    1399

    瀏覽量

    120088
  • 交織器
    +關(guān)注

    關(guān)注

    0

    文章

    5

    瀏覽量

    7844

原文標(biāo)題:用RAM分區(qū)循環(huán)移位法來實(shí)現(xiàn)解交織器

文章出處:【微信號:gh_9d70b445f494,微信公眾號:FPGA設(shè)計(jì)論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    AES加解密算法邏輯實(shí)現(xiàn)及其在蜂鳥E203SoC上的應(yīng)用介紹

    這次分享我們會簡要介紹AES加解密算法的邏輯實(shí)現(xiàn),以及如何將AES算法做成硬件協(xié)處理集成在蜂鳥E203 SoC上。 AES算法介紹 AES算法屬于對稱密碼算法中的分組密碼,其明文/密文分組長度為
    發(fā)表于 10-29 07:29

    ram ip核的使用

    ram ,通過對這些bram存儲模塊進(jìn)行配置,可以實(shí)現(xiàn)ram移位寄存器、rom以及fifo緩沖
    發(fā)表于 10-23 07:33

    如何利用Verilog HDL在FPGA實(shí)現(xiàn)SRAM的讀寫測試

    本篇將詳細(xì)介紹如何利用Verilog HDL在FPGA實(shí)現(xiàn)SRAM的讀寫測試。SRAM是一種非易失性存儲,具有高速讀取和寫入的特點(diǎn)。在FPGA
    的頭像 發(fā)表于 10-22 17:21 ?4202次閱讀
    如何利用Verilog HDL在<b class='flag-5'>FPGA</b>上<b class='flag-5'>實(shí)現(xiàn)</b>SRAM的讀寫測試

    SN74HCT165 8位并行輸入移位寄存器技術(shù)解析

    Texas Instruments SN74HCT165/SN74HCT165-Q1并聯(lián)負(fù)載移位寄存器是一款并聯(lián)或串聯(lián)輸入、串聯(lián)輸出8位移位寄存器。借助八個(gè)獨(dú)立的直接數(shù)據(jù) (A-H) 輸入并行訪問
    的頭像 發(fā)表于 09-19 14:39 ?736次閱讀
    SN74HCT165 8位并行輸入<b class='flag-5'>移位寄存器</b>技術(shù)解析

    服務(wù)數(shù)據(jù)恢復(fù)—重裝系統(tǒng)后OceanStor存儲上的分區(qū)數(shù)據(jù)丟失這樣恢復(fù)

    服務(wù)存儲數(shù)據(jù)恢復(fù)環(huán)境: 華為OceanStor某型號存儲+擴(kuò)展盤柜,存儲中的硬盤組建了raid5磁盤陣列,上層分配了1個(gè)lun。 linux操作系統(tǒng),劃分了兩個(gè)分區(qū),分區(qū)一通過lvm擴(kuò)容,
    的頭像 發(fā)表于 09-02 15:32 ?591次閱讀
    服務(wù)<b class='flag-5'>器</b>數(shù)據(jù)恢復(fù)—重裝系統(tǒng)后OceanStor存儲上的<b class='flag-5'>分區(qū)</b>數(shù)據(jù)丟失這樣恢復(fù)

    ?TLC6C5816-Q1 16位移位寄存器LED驅(qū)動(dòng)技術(shù)文檔總結(jié)

    錯(cuò)誤故障意味著通道已配置為 LED 診斷,但寄存寫入命令同時(shí)打開了該通道。該器件提供循環(huán)冗余校驗(yàn),以驗(yàn)證移位寄存器中的寄存值。在回讀模式下,器件提供 6 位 CRC 余數(shù)。MCU可
    的頭像 發(fā)表于 08-25 18:13 ?863次閱讀
    ?TLC6C5816-Q1 16位<b class='flag-5'>移位寄存器</b>LED驅(qū)動(dòng)<b class='flag-5'>器</b>技術(shù)文檔總結(jié)

    生態(tài)循環(huán)園區(qū)環(huán)網(wǎng)箱局放傳感:脈沖電流的綠色守護(hù)

    的波動(dòng)性沖擊,電氣設(shè)備絕緣劣化風(fēng)險(xiǎn)顯著增加。局部放電作為絕緣故障的早期征兆,其監(jiān)測技術(shù)成為保障園區(qū)電力安全的關(guān)鍵手段。本文聚焦基于脈沖電流的環(huán)網(wǎng)箱局放傳感,解
    的頭像 發(fā)表于 08-25 11:51 ?584次閱讀
    生態(tài)<b class='flag-5'>循環(huán)</b>園區(qū)環(huán)網(wǎng)箱局放傳感<b class='flag-5'>器</b>:脈沖電流<b class='flag-5'>法</b>的綠色守護(hù)

    無位置傳感無刷直流電機(jī)的+FPGA+控制實(shí)現(xiàn)

    硬件方案,同時(shí)通過算法優(yōu)化,避免了乘法和除法運(yùn)算,大大減少了 FPGA 邏輯資源消耗,并在一片低端現(xiàn)場可編程門陣列中得到了具體驗(yàn)證和實(shí)現(xiàn)。該方案充分運(yùn)用 FPGA豐富的邏輯資源,靈活運(yùn)用 Verilog
    發(fā)表于 07-10 16:35

    Linux系統(tǒng)中磁盤分區(qū)與掛載詳解

    磁盤分區(qū)是將物理硬盤劃分為不同的邏輯部分,每個(gè)分區(qū)都可以被視為一個(gè)獨(dú)立的存儲設(shè)備。通過磁盤分區(qū),我們可以更好地管理磁盤空間,實(shí)現(xiàn)數(shù)據(jù)的組織和隔離。
    的頭像 發(fā)表于 06-17 15:08 ?2320次閱讀
    Linux系統(tǒng)中磁盤<b class='flag-5'>分區(qū)</b>與掛載詳解

    服務(wù)數(shù)據(jù)恢復(fù)—重裝系統(tǒng)導(dǎo)致XFS文件系統(tǒng)分區(qū)丟失的數(shù)據(jù)恢復(fù)案例

    服務(wù)數(shù)據(jù)恢復(fù)環(huán)境&故障: 一臺服務(wù)上通過磁盤柜+RAID卡組建的riad5磁盤陣列,服務(wù)上層安裝Linux操作系統(tǒng),搭建XFS文件系統(tǒng)。服務(wù)上層分配一個(gè)LUN,并劃分了兩個(gè)
    的頭像 發(fā)表于 06-12 11:20 ?720次閱讀
    服務(wù)<b class='flag-5'>器</b>數(shù)據(jù)恢復(fù)—重裝系統(tǒng)導(dǎo)致XFS文件系統(tǒng)<b class='flag-5'>分區(qū)</b>丟失的數(shù)據(jù)恢復(fù)案例

    服務(wù)數(shù)據(jù)恢復(fù)—服務(wù)器重裝系統(tǒng)導(dǎo)致分區(qū)消失的數(shù)據(jù)恢復(fù)案例

    服務(wù)上有一組由raid卡組建的raid5磁盤陣列。上層安裝linux才做系統(tǒng),采用XFS文件系統(tǒng),劃分了3個(gè)分區(qū)。 管理員將服務(wù)的操作系統(tǒng)重裝后,發(fā)現(xiàn)服務(wù)上的
    的頭像 發(fā)表于 05-14 10:13 ?507次閱讀
    服務(wù)<b class='flag-5'>器</b>數(shù)據(jù)恢復(fù)—服務(wù)器重裝系統(tǒng)導(dǎo)致<b class='flag-5'>分區(qū)</b>消失的數(shù)據(jù)恢復(fù)案例

    Xilinx Shift RAM IP概述和主要功能

    Xilinx Shift RAM IP 是 AMD Xilinx 提供的一個(gè) LogiCORE IP 核,用于在 FPGA實(shí)現(xiàn)高效的移位寄存器(Shift Register)。該
    的頭像 發(fā)表于 05-14 09:36 ?951次閱讀

    FPGA從0到1學(xué)習(xí)資料集錦

    種類更多,而不僅僅是原來的簡單邏輯單元(LE)。早期的 FPGA 相對比較簡單, 所有的功能單元僅僅由管腳、內(nèi)部 buffer、LE、RAM 構(gòu)建而成,LE 由 LUT(查找表)和 D 觸發(fā)構(gòu)成
    發(fā)表于 05-13 15:41

    labview FPGA模塊如何實(shí)現(xiàn)0步長?

    哪位大佬施以援手,labview FPGA模塊如何實(shí)現(xiàn)0?步長(0.01)到1后又從1-步長(0.01)到0,如此往復(fù)循環(huán),現(xiàn)在實(shí)現(xiàn)了0自累加到1與1自累減到0,但是二者沒法聯(lián)立起來建
    發(fā)表于 04-04 13:09

    磁盤分區(qū)工具parted的使用方法

    傳統(tǒng)的MBR分區(qū)表格式,僅支持最大四個(gè)主分區(qū),而且不可以格式化2TB以上的磁盤,因此,大磁盤更適合使用parted工具進(jìn)行GPT的分區(qū)格式。
    的頭像 發(fā)表于 03-03 09:39 ?2227次閱讀