久久午夜影院,91精品国产调教在线观看,日韩午夜免费,伊人久久大香线蕉av不卡

你的位置:首頁 > 互連技術 > 正文

利用FPGA進行基本運算及特殊函數定點運算

發布時間:2024-02-21 責任編輯:lina

【導讀】FPGA以擅長高速并行數據處理而聞名,從有線/無線通信到圖像處理中各種DSP算法,再到現今火爆的AI應用,都離不開卷積、濾波、變換等基本的數學運算。但由于FPGA的硬件結構和開發特性使得其對很多算法不友好,之前本人零散地總結和轉載了些基本的數學運算在FPGA中的實現方式,今天做一個系統的總結歸納。


一、前言


FPGA以擅長高速并行數據處理而聞名,從有線/無線通信到圖像處理中各種DSP算法,再到現今火爆的AI應用,都離不開卷積、濾波、變換等基本的數學運算。但由于FPGA的硬件結構和開發特性使得其對很多算法不友好,之前本人零散地總結和轉載了些基本的數學運算在FPGA中的實現方式,今天做一個系統的總結歸納。


二、FPGA中的加減乘除


1.硬件資源


Xilinx 7系列的FPGA中有DSP Slice ,叫做“DSP48E1”這一專用硬件資源,這是一個功能強大的計算單元,單就用于基本運算的部分有加減單元和乘法器。詳見參考文獻1.


利用FPGA進行基本運算及特殊函數定點運算


因此可以直接用HDL語言中的加、減、乘符號實現變量與常量間運算操作以及變量與變量間操作。而四則運算中的除法沒有基本的邏輯計算單元可以對應,因此計算除法需要調用除法器IP核。


2.確認數據的表示范圍


有符號數:(補碼)-2^(N-1) ~ 2^(N-1)-1 如N = 8,則表示范圍是:-128 ~ 127.

無符號數:0~2^N-1 如N = 8,則表示范圍是:0~255.

定點數:2Q13 范圍是:-4~4-2^(-13) 精度是:2^(-13)


3.結果有效位寬

  

首先討論結果位寬問題。在FPGA中往往采用定點運算替代浮點運算來降低硬件資源占用率和計算延遲,其中的精髓就是精度與資源的權衡。若按照保留計算結果的全部精度,N bit數與Mbit數相加結果需要N+1bit(N>M)。N bit數與M bit數相乘之積需要N+M bit。而減法可以轉化為加法,除法則轉換為乘法和加減法的組合。如果操作數是定點小數,則在滿足以上準則的前提下,A與B相加(A小數點位數>B小數點位數),結果小數點位數與A相同;A與B相乘(小數點位數分別為p和q),結果小數點位數是p+q。


4.定點運算步驟

  

然而(話鋒一轉),在大多數場合下,不需要以上這么多位來保留計算結果,因為我們在進行數學運算時,已經知道輸入數據的大致范圍,一個數除以1000和除以1結果數據所需最小位寬能一樣么?加減運算的操作步驟是先對齊小數點位數,后加減。而乘法是先計算后取小數點。這實際上與十進制運算一致,我們看看具體的計算步驟:

整數之間加減以及乘法的統一步驟:預估結果位寬N --> 按照結果位寬擴展操作數符號位以防止溢出 --> 運算取低N位。

定點小數加減運算步驟:預估結果位寬N --> 得到結果小數點后位數 --> 對齊操作數整數位和小數位,確定擴展位寬M(M≥N) --> 加減運算取低M位。

定點小數乘法運算步驟:預估結果位寬N --> 得到結果小數點后位數 --> 擴展操作數位寬 --> 相乘取低N位


5. 變量與常量運算化簡

  

以上討論的均是兩變量之間的運算規則,當然結果位寬及格式準則是適用的。變量與常量的運算的優勢在于,可以將乘除法轉換成加減以及移位運算實現,從而降低計算復雜度和延遲。當常數項C為2的整數次冪(C = 2^p),則乘C等于變量左移p位,除以C等于變量右移p位。幾個在書中看到的幾個簡單示例:A*16 = A <<4  A*20 = A<<4 + A<<2.  A除以2 = A >>1  A除以3 = A*(0.25+0.0625+0.0156) = A>>2+A>>4+A>>6  A除以5 = A*(0.125+0.0625+0.0156) = A>>3 + A>>4 + A>>6.其中乘法完全等價對應的移位相加操作,而除法的移位代替會損失精度。


三、如何計算特殊函數

  

FPGA內部的DSP Slice可以直接進行最基本的加法和乘法運算,但是對于其他比如對數、指數、三角函數、開根號等特殊函數就無能為力了。這時需要借助算法對這些特殊函數進行變換和簡化。FPGA實現復雜函數的常用手段一個是級數展開,再一個就是CORDIC算法。關于CORDIC的理論知識和具體內容詳見參考文獻2,這里主要闡述CORDIC的IP核調用以及應用示例。CORDIC算法就是通過一定的手段,將很多復雜的特殊函數變為相加移位運算,這一點對于硬件芯片實現來說非常友好。CORDIC分為旋轉模式和矢量模式,配合圓周坐標、線性坐標和雙曲線坐標會有六種組合,具體見下表:


利用FPGA進行基本運算及特殊函數定點運算


從表中發現,基本的乘


利用FPGA進行基本運算及特殊函數定點運算


除法、三角函數、反三角函數、雙曲函數、反雙曲函數、開根號都能夠直接求得,那其他函數怎么辦?


常見的函數計算需求基本都能滿足,雖上述變換式對自變量定義域有限制,但同樣可以分析輸入數據的取值范圍并利用簡單的數學變換得到想要的結果。Xilinx同時提供了浮點IP核以及CORDIC IP核,前者調用簡單但占用資源大,延遲高,因此利用CORDIC算法計算函數是個較好的選擇。


四、CORDIC計算e^x Demo


1. 算法仿真分析

  

要計算e^x數值需要讓CORDIC工作在雙曲坐標的旋轉模式下,通過e^x = sinhx+coshx關系式間接求得。首先看下sinh和cosh函數的曲線,有個直觀認識。


利用FPGA進行基本運算及特殊函數定點運算


我們用MATLAB毫不費力地驗證一下公式正確性:


利用FPGA進行基本運算及特殊函數定點運算


在設計后也同樣要借助MATLAB進行仿真驗證。


2. CORDIC IP核

  

現在通過查看user guide得知CORDIC IP核的接口及主要特性。


利用FPGA進行基本運算及特殊函數定點運算


接口包括輸入笛卡爾數據輸入通道、相位輸入通道、全局信號以及數據輸出通道。該IP核有兩種結構:串行和并行,可根據數據吞吐量需求選擇,并行結構可以每個時鐘輸出一個計算結果。如果計算sinh和cosh,要向phase通道輸入相位信息,X_OUT是cosh(phase),Y_OUT是sinh(phase).輸入phase必須滿足數據范圍,否則出現不可預計結果。輸出幀結構及數據范圍如下:


利用FPGA進行基本運算及特殊函數定點運算


 其中輸入數據格式為2QN,輸出則是1QN。由于均是有符號數,也就是輸入整數部分3bit,輸出整數部分2bit。接下來對IP核進行配置,重點是第一頁,此處將其配置為計算sinh和cosh模式,采用并行優化的流水線結構。相位以角度為單位,輸入輸出位寬設置成16bit。


利用FPGA進行基本運算及特殊函數定點運算


3.HDL代碼設計及仿真驗證

設計代碼:
`timescale 1ns / 1ps

module cordic_ex#(parameter DIN_W = 16,
DOUT_W = 16)
(
input clk,
input [DIN_W-1:0] din,//2Q13
input din_vld,

output reg [DOUT_W+1-1:0] dout = 0,//2Q14
output reg dout_vld = 0
);

wire [DOUT_W*2-1 : 0] m_axis_dout_tdata;
wire m_axis_dout_tvalid;
wire signed [DOUT_W-1:0] sinh,cosh;

// ex = sinhx + coshx <1Q14+1Q14 = 2Q14>
always @(posedge clk)begin
dout <= sinh + cosh;
end

assign sinh = m_axis_dout_tdata[DOUT_W*2-1 -:DOUT_W];
assign cosh = m_axis_dout_tdata[DOUT_W-1 -:DOUT_W];

always @(posedge clk)begin
if(m_axis_dout_tvalid)begin
dout_vld <= 1'b1;
end
else
dout_vld <= 0;
end

cordic_0 cordic_cosh_sinh (
.aclk(clk), // input wire aclk
.s_axis_phase_tvalid(din_vld), // input wire s_axis_phase_tvalid
.s_axis_phase_tdata(din), // input wire [15 : 0] s_axis_phase_tdata
.m_axis_dout_tvalid(m_axis_dout_tvalid), // output wire m_axis_dout_tvalid
.m_axis_dout_tdata(m_axis_dout_tdata) // output wire [31 : 0] m_axis_dout_tdata
);

endmodule

cordic_ex

用MATLAB產生兩組數據,并將角度值定點化后作為設計模塊數據激勵:


利用FPGA進行基本運算及特殊函數定點運算


testbench:
`timescale 1ns / 1ps

module cordic_ex_tb();

parameter CYC = 20;

reg clk;
reg [16-1:0] din;
reg din_vld;

wire signed [17-1:0] dout;
wire dout_vld;

cordic_ex#(.DIN_W(16),
.DOUT_W(16))
uut(
.clk (clk) ,
.din (din) ,//2Q13
.din_vld (din_vld) ,
.dout (dout) ,//2Q14
.dout_vld (dout_vld)
);

initial begin
clk = 1;
forever #(CYC/2) clk = ~clk;
end

initial begin
#1;
din = 0;
din_vld = 0;
#(CYC*10);

din_vld = 1;
din = 16'b0001010000011011;//pi * 1/5
#(CYC*1);
din = 16'b1110011011011110;//-pi * 1/4
#5;
$stop;
end

endmodule

cordic_ex_tb


仿真結果:


利用FPGA進行基本運算及特殊函數定點運算


仿真波形表明,計算結果與MATLAB浮點運算相近,滿足一般計算需求。若想提高精度,可以增加CORDIC輸出數據位寬。


免責聲明:本文為轉載文章,轉載此文目的在于傳遞更多信息,版權歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權問題,請聯系小編進行處理。


推薦閱讀:

電子峰會再來襲!讓智能網聯汽車跑出新速度

利用高度集成的處理器,在工廠自動化的過程中加快以太網的應用 

電子應用中的潛在熱源及各種熱管理方法

LLC拓撲結構設計要點:如何在更低負載下進入打嗝模式?

電源應用中,不同PWM頻率之間的同步設置


特別推薦
技術文章更多>>
技術白皮書下載更多>>
熱門搜索

關閉

?

關閉

久久午夜影院,91精品国产调教在线观看,日韩午夜免费,伊人久久大香线蕉av不卡
日韩成人一级| 岛国av在线播放| 精品一区二区男人吃奶| 国产精品中文字幕亚洲欧美 | 亚洲一区二区小说| 秋霞国产精品| 亚洲女人av| 亚洲欧美日本国产专区一区| 美国欧美日韩国产在线播放| 婷婷综合在线| 国产精品美女久久久久久不卡| 欧美中文日韩| 一区二区三区国产在线| 99精品在线免费在线观看| 婷婷综合福利| 欧美天堂一区| 蜜臀91精品一区二区三区| 国产精品天天看天天狠| 久久激情中文| 在线午夜精品| 国产欧美日韩在线观看视频| 国产一区二区三区不卡av | 午夜在线视频观看日韩17c| 国产精选在线| 欧洲毛片在线视频免费观看| 日本成人一区二区| 欧美激情一区| 久久久久久久久99精品大| 国产精品一区二区三区四区在线观看 | 国产女人18毛片水真多18精品| 久久香蕉网站| 国产一级一区二区| 亚洲黄色网址| 国产欧美日韩一级| 日本vs亚洲vs韩国一区三区二区| 成人亚洲精品| 手机精品视频在线观看| 国产传媒av在线| 欧洲一级精品| 国产综合婷婷| 欧美1区2区3| 午夜精品影院| sm久久捆绑调教精品一区| 久久国产日韩欧美精品| 视频一区二区三区在线| 国产一区二区三区日韩精品| 久久激五月天综合精品| 亚洲一区二区成人| 日韩在线视频精品| 国产精品一线| 日韩高清国产一区在线| 韩国久久久久久| 午夜日本精品| 国产v日韩v欧美v| 日本亚洲欧美天堂免费| 欧美一区二区三区高清视频| 国产极品嫩模在线观看91精品| 久久国产毛片| 亚洲啊v在线| 日韩高清在线不卡| 欧美日韩在线播放视频| 久久99久久人婷婷精品综合| 视频在线在亚洲| 欧洲在线一区| 日韩一区二区在线免费| 国产精品极品| 亚洲乱码视频| 中文精品电影| 中文无码日韩欧| 亚洲精品视频一二三区| 久久av一区| 欧美女激情福利| 欧美 日韩 国产一区二区在线视频 | 成人av二区| 国产成人免费| 日韩国产综合| 日韩88av| 欧美特黄一级大片| 欧美日韩在线观看首页| 首页亚洲欧美制服丝腿| 久久gogo国模啪啪裸体| 亚洲欧美专区| 亚洲涩涩av| 欧美日韩精品一区二区三区在线观看| 久久国产生活片100| 久久久久亚洲精品中文字幕| 国产亚洲在线| 国产精品theporn| 麻豆久久久久久| 亚洲欧美在线综合| 深夜福利亚洲| 国产精品激情电影| 久久精品国产久精国产| 欧美中文一区二区| 合欧美一区二区三区| 日韩视频在线一区二区三区| 中文无码久久精品| 在线日韩视频| 亚洲福利一区| 日韩欧美久久| 亚洲不卡视频| 亚洲精品麻豆| 喷白浆一区二区| 国产福利亚洲| 一本大道色婷婷在线| 久久天堂影院| 激情五月综合网| 国产精品最新自拍| 精品三区视频| 亚洲欧美日韩视频二区| 国产精品超碰| 亚洲欧美日韩专区| 亚洲尤物av| 久久伊人亚洲| 国产精品视频一区二区三区| 黄色aa久久| 亚洲v在线看| 麻豆成人91精品二区三区| 久久亚洲影院| 免费精品一区| 亚洲免费一区二区| 成人在线黄色| 日韩中文字幕区一区有砖一区| 麻豆中文一区二区| 亚洲精品网址| 久久精品理论片| 99久精品视频在线观看视频| 天堂久久av| 婷婷成人在线| 亚洲中午字幕| 精品中国亚洲| 亚洲成人国产| 日精品一区二区三区| 国产成人精品999在线观看| 天堂日韩电影| 日韩在线播放一区二区| 国产精品嫩草影院在线看| 天堂资源在线亚洲| 久久精品国产www456c0m| 福利一区和二区| 国产精品一国产精品| 国产一区日韩一区| 国产精品毛片久久| 亚洲欧美日韩视频二区| 国产成人精品三级高清久久91| 中文字幕一区二区三区在线视频| 亚洲另类av| 999国产精品永久免费视频app| 日韩动漫一区| bbw在线视频| 亚洲一区观看| 高潮久久久久久久久久久久久久| 中文无码久久精品| 999国产精品999久久久久久| 日韩高清在线一区| 精品免费av一区二区三区| 久久亚洲电影| 99久久99久久精品国产片果冰| 国产一区二区三区四区五区| 国产欧美日韩精品一区二区三区| 97精品久久| 日韩久久精品网| 视频一区中文字幕| 国产探花一区| 福利一区和二区| 国产成人精品一区二区三区免费| 免费不卡中文字幕在线| 99久久激情| 蜜臀a∨国产成人精品| 亚洲一区国产| 亚洲最新无码中文字幕久久| 正在播放日韩精品| 亚洲伦乱视频| 激情综合在线| 久久亚洲风情| www成人在线视频| 麻豆9191精品国产| 成人va天堂| 久久在线免费| 久久av网站| 高清不卡亚洲| 免费在线日韩av| 国产精品综合| 91偷拍一区二区三区精品| 精品欧美一区二区三区在线观看| 天堂久久一区| 97精品国产99久久久久久免费| 老司机免费视频一区二区| 国产精品亲子伦av一区二区三区| 日本视频一区二区| 国产成人免费精品| 999久久久免费精品国产| 午夜久久黄色| 极品裸体白嫩激情啪啪国产精品| 免费精品国产| 国产精品久久久久蜜臀| 日本成人在线一区| 97精品国产一区二区三区| 精品国产精品久久一区免费式 | 911精品国产|