www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 電源 > 數字電源
[導讀]  卷積碼是廣泛應用于衛(wèi)星通信、無線通信等各種通信系統的信道編碼方式。Viterbi算法是一種最大似然譯碼算法。在碼的約束度較小時,它比其它概率譯碼算法效率更高、速度更

  卷積碼是廣泛應用于衛(wèi)星通信、無線通信等各種通信系統的信道編碼方式。Viterbi算法是一種最大似然譯碼算法。在碼的約束度較小時,它比其它概率譯碼算法效率更高、速度更快,譯碼器的硬件結構比較簡單。隨著可編程邏輯技術的不斷發(fā)展,其高密度、低功耗、使用靈活、設計快速、成本低廉、現場可編程和反復可編程等特性,使FPGA逐步成為Viterbi譯碼器設計的最佳方法。項目目的是用FPGA實現一個Viterbi譯碼器。

  一、譯碼器功能分析

  譯碼器是一種具有“翻譯”功能的邏輯電路,這種電路能將輸入二進制代碼的各種狀態(tài),按照其原意翻譯成對應的輸出信號。Viterbi譯碼器是以Viterbi算法為基礎設計的一種譯碼器,譯碼器主要由五部分組成:分支度量單元(Branch Metric Unit)、加比選單元(Add-Compare-Select Unit)、幸存路徑管理單元(Survivor Management Unit)、判輸出單元(Decide-Output Unit)和控制單元(Control Unit)。其整體結構如圖1。

  

 

  圖1 譯碼器結構框圖

  各單元之間的相互關系如下:接收到的輸入數據首先被送入各分支度量單元中計算出相應的分支路徑距離;加比選單元將舊的狀態(tài)路徑度量與相應的新產生的分支路徑距離相加,通過比較后選擇到達同一狀態(tài)的兩個路徑度量值中較小的分支來更新路徑度量;溢出處理防止加比選單元中的路徑度量累加值發(fā)生溢出;幸存路徑管理單元將加比選單元生成的路徑信息進行存儲管理;判決輸出單元根據加比選單元選擇的路徑度量,從中選擇一個最小值,并輸出該最小值對應的幸存路徑。所有這些單元都在控制單元的協調下工作。

  1 分支度量單元

  分支度量表征該分支接收到的碼元與期望碼元之間的差別。對于硬判決,這種差別指不同碼元的個數。硬判決分支度量值可以表示為:

  

(式1)

 

  其中,y為接收碼字,c為本地卷積碼輸出碼字。對于碼率為1/2硬判決譯碼方式,編碼器輸出信號可能為00、01、10、11,其路徑度量取值(漢明距離)只有0、1、2三種可能,因此需要用一個2bit的寄存器來存儲分支度量值。

  在本文中,采用了4個ACS單元(每個ACS單元有兩個累加器)并行計算,因此需要8個分支度量單元并行計算8個條支路的度量值,并將度量值送至ACS中的累加器。

  2 加比選單元

  ACS單元用來累加路徑度量值并比較和選擇進入某一狀態(tài)的兩條分支。本文中采用4個ACS單元并行計算,每16個狀態(tài)復用一個ACS結構,同時兼顧了面積和速度。

  

 

  圖 2 (2,1,7)卷積碼的狀態(tài)圖

  譯碼器的核心部分是ACS單元,傳統的譯碼器結構每產生一位譯碼需要進行2(n-1)次加比選運算,即2×2(n-1)=2n次加法運算和2(n-1)次比較選擇運算。對于(2,1,7)卷積碼來說,需要進行128加法運算和64次比較選擇運算,這將占用很多的資源并產生很大的功耗,因此,如果能夠通過改進ACS單元的結構來降低其規(guī)模和功耗,將會使整個譯碼器的硬件規(guī)模和功耗大大降低。

  從圖2所示的(2,1,7)卷積碼的狀態(tài)圖中可以看出:在T(i+1)時刻到達狀態(tài)S0和S1的是T(i)時刻的狀態(tài)S0和S32,……,在T(i+1)時刻到達狀態(tài)S62和S63的是T(i)時刻的狀態(tài)S31和S63。也就是說,T(i)時刻的狀態(tài)Sj和Sj+32會達到T(i+1)時刻的相鄰的兩個狀態(tài),并且這兩個狀態(tài)是S2j和S2j+1(31≥j≥0)。這也就是圖形單(ButterfllyUnit)。

  

 

  圖3 基二蝶形單元

  在圖3中,T(i)時刻的狀態(tài)Sj和Sj+32都是在輸入0的時候轉移到T(i+1)時刻的狀態(tài)S2j,在輸入1的時候轉移到T(i+1)時刻的狀態(tài)S2j+1。這也就意味著ACS單元中的比較器所比較的兩個路徑度量值(BM)來自數值上相差32的兩個狀態(tài)。路徑度量的計算就是分支度量加上與這條分支相連的前一時刻的狀態(tài)選擇的路徑度量,所以,新狀態(tài)的路徑度量為:

  

(式2)

 

  

(式3) [!--empirenews.page--]

 

  從以上的分析中我們可以得出一個很重要的結論:從T(i)時刻的狀態(tài)Sj(2(n-1)≥j≥0)生成的兩條支路,唯一不同的信息就是該時刻狀態(tài)Sj的輸入數據,Sj的上支路輸入的是0,下支路輸入的是1。因此,一個狀態(tài)可以只生成一條支路(上支路),另一條支路(下支路)的信息已經包括在這條支路中,要恢復出下支路只需要將上支路的輸入數據取反即可。圖4.2所示的ACS單元結構中的累加器可以減少一半的工作量,對于本文中的(2,1,7)卷積碼的譯碼器,即由每產生一位譯碼工作16個時鐘周期減少為8個時鐘周期(可將時鐘頻率降為原來的1/2),減少了復用次數,降低了ACS單元的復雜度和功耗。同時,由于ACS單元結構的優(yōu)化,每個狀態(tài)只需要生成一條路徑,存儲的幸存路徑數也由原來的128條減少為64條,也同樣使結構變得簡單,功耗有所降低。

  由式(2)和式(3)可知,輸入數據(datain)不同,卷積碼的輸出C0和C1也不同,因此,同一狀態(tài)上支路的輸出與下支路不同,上下支路狀態(tài)輸出及譯碼器的輸入數據之間的關系如表1所示:

  

 

  利用上下支路分支度量值的關系就可以從上支路路徑度量累加值中計算出下支路路徑度量累加值,用Verilog HDL語言描述為:

  case(up_branch_metric)

  2'b00: down_path_add_metric <= up_path_add_metric + 2'b10;

  2'b01: down_path_add_metric <= up_path_add_metric;

  2'b10: down_path_add_metric <= up_path_add_metric-2'b10;

  default: down_path_add_metric <= 7'bxxx_xxxx;

  endcase

  另外,ACS單元中的累加器可以用超前進位加法器實現,這將使累加器不會成為速度的瓶頸。由于累加器使用固定長度的寄存器(本文中采用7bit的寄存器),因此在不斷累加過程中可能會發(fā)生溢出,影響譯碼結果。解決溢出常用的方法是到達譯碼深度時從所有狀態(tài)的路徑度量值中減去最小度量值。

  3 幸存路徑管理單元

  幸存路徑管理單元用來完成對幸存路徑的記錄,處理ACSU輸出的信息,為輸出判決作準備。SMU的實現主要有Register Exchange (寄存器交換)和Trace Back(回溯)兩種算法。由于寄存器交換算法比回溯有更小的譯碼延時,RE法中幸存路徑寄存器記錄了幸存路徑所對應的解碼信息,也就是譯碼輸出。采用這種方法消除了根據當前狀態(tài)往前追蹤的必要,因此寄存器交換提供了一種速度很高的譯碼操作。

  4 判決輸出單元

  判決輸出單元(DOU)由兩部分組成:最小值選擇單元(MNSU:Minimum Number Select Unit)和譯碼輸出單元(DOU:Decode Output Unit)。最小值選擇單元是用來選出本文中前面4個ACS單元輸的路徑度量值中具有最小度量值的節(jié)點, 讀取該結點保存的幸存路徑,供譯碼輸出單元輸出譯碼值。判決輸出單元的結構如圖4所示:

  

 

  圖4 判決輸出單元結構圖

  5 控制單元

  控制單元(CU)產生控制各模塊的時鐘信號,是所有模塊的有序運行的基礎。各時鐘信號功能如下:clk_load用于讀取前一時刻各狀態(tài)寄存器的內容,并產生各狀態(tài)上支路的狀態(tài)輸出值;clk_BM用于計算各狀態(tài)上支路的分支度量值并讀取前一時刻各狀態(tài)的路徑度量值;clk_Add用于計算各狀態(tài)上支路的路徑度量值;clk_restore用于暫存各狀態(tài)上支路度量值并恢復相應狀態(tài)下支路的路徑度量值;clk_C_S用于比較并選擇達到同一狀態(tài)的兩支路的路徑度量值的較小者,并存儲各狀態(tài)選擇的幸存路徑;clk_MNS用于選擇各狀態(tài)存儲的路徑度量值中的最小值,并保存該最小值對應的狀態(tài);min_sel_1和min_sel_2分兩步選擇4個MNSU選擇結果的最小值,并選出最終的最小值對應的狀態(tài);Decode_Output用于讀取該最小值對應狀態(tài)存儲的幸存路徑,并輸出譯碼結果。

  二、項目實施方案

  Viterbi譯碼器大致可以分為四個部分:支路度量模塊(BMU)、加比選模塊(ACS)、幸存路徑管理模塊(SMU)和輸出產生模塊。其 中支路度量模塊用于完成譯碼器輸入信號與網格圖上的可能路徑信號的分支度量計算;加比選模塊主要把前一個狀態(tài)的路徑度量與當前輸入信號的分支度量相加,以得到該分支的路徑度量,然后比較不同分支路徑度量的大小,同時找出最小的度量值,并更新該狀態(tài)的度量值,最后輸出狀態(tài)轉移信息;路徑管理模塊可對加比選單 元輸出的狀態(tài)轉移信息進行處理,以便為輸出判決做準備。輸出模塊可根據幸存路徑管理單元的輸出進行輸出判決,最后輸出譯碼信息。Viterbi譯碼器基本原理框圖如下所示。

  

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

11萬+人次!5000+海外買家! 展會落幕,感恩同行!明年8月深圳再見! 深圳2025年9月1日 /美通社/ -- 據物聯網世界報道。 在AIoT(人工智能+物聯網)技術加速滲透、全球數字化轉型深化,以...

關鍵字: IoT 物聯網 TE IC

華盛頓2025年8月23日 /美通社/ -- CGTN America和CCTV UN發(fā)布《探索人工智能驅動的敘事未來》(Explore the Future of Storytelling with AI)。 人工智...

關鍵字: 人工智能 智能驅動 TV IC

在數字化浪潮席卷全球的今天,FPGA技術正成為驅動創(chuàng)新的核心引擎。2025年8月21日,深圳將迎來一場聚焦FPGA技術與產業(yè)應用的盛會——2025安路科技FPGA技術沙龍。本次沙龍以“定制未來 共建生態(tài)”為主題,匯聚行業(yè)...

關鍵字: FPGA 核心板 開發(fā)板

在現代電子系統中,現場可編程門陣列(FPGA)憑借其開發(fā)時間短、成本效益高以及靈活的現場重配置與升級等諸多優(yōu)點,被廣泛應用于各種產品領域。從通信設備到工業(yè)控制,從汽車電子到航空航天,FPGA 的身影無處不在。為了充分發(fā)揮...

關鍵字: 可編程門陣列 FPGA 數字電源

從顯示材料創(chuàng)新、光學技術融合到用于高科技微芯片的量測與檢測解決方案,默克結合先進材料、光學技術與AI洞察,助力新一代顯示技術、光學器件與半導體的發(fā)展 。 憑借在光學與電子材料領域的專長,默克為顯示面板制造商、半...

關鍵字: 光電 IC 光學 AI

上海2025年8月5日 /美通社/ -- 2025年7月30日,上海"2025思旗獎(AIflag Awards)"頒獎盛典上,FESCO Adecco外企德科上海公司憑借在人力資源管理與A...

關鍵字: ECC AI AD BSP

2025年8月4日 – 提供超豐富半導體和電子元器件?的業(yè)界知名新品引入 (NPI) 代理商貿澤電子 (Mouser Electronics) 即日起開售Altera?的Agilex? 3 FPGA C系列開發(fā)套件。此開...

關鍵字: FPGA 邊緣計算 嵌入式應用

上海2025年7月31日 /美通社/ -- 7月26日-29日,2025世界人工智能大會暨人工智能全球治理高級別會議(簡稱"WAIC 2025")在上海舉行。大會聚焦人工智能發(fā)展的關鍵命題,系統刻畫智...

關鍵字: IC AI 機器人 模型

上海2025年7月30日 /美通社/ -- 在剛剛落幕的2025世界人工智能大會(WAIC 2025)上,全球領先的AI數據服務提供商澳鵬Appen(中國)攜全新技術平臺矩陣及九大垂類數據服務解決方案精彩亮相,為人工智能...

關鍵字: 模型 矩陣 IC AI

上海2025年7月29日 /美通社/ -- 上海盛夏,科技熱浪奔涌不息,AI群星閃耀世界。 7月27日,2025年世界人工智能大會期間,一場"云擎智造 工賦新元"的圓桌論壇引爆AI+制造話題。中之杰...

關鍵字: AI IC 離散 智能體
關閉