国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

FPGA設計論壇 ? 來源:未知 ? 2023-07-19 14:25 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

wKgaomToD9qAYZlLAAADFPiCFw8514.pngwKgaomToD9qAdcLCAAAAuFYhST8844.png

點擊上方藍字關注我們

wKgaomToD9qAeOjPAAAC9hV8I20530.png

一、前言

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

二、FPGA中的加減乘除

1.硬件資源

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

wKgaomToD9qAQtK4AAAsQOBKNvM985.png

因此可以直接用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 >>1A除以3 = A*(0.25+0.0625+0.0156) = A>>2+A>>4+A>>6A除以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分為旋轉模式和矢量模式,配合圓周坐標、線性坐標和雙曲線坐標會有六種組合,具體見下表:

wKgaomToD9qAQAwJAALgSKHryco670.png

從表中發現,基本的乘

wKgaomToD9qAJl5xAAFcD_RjxdU100.png

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

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

四、CORDIC計算e^x Demo

1. 算法仿真分析

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

wKgaomToD9uAMmZLAAFF-6ZmYDg769.png

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

wKgaomToD9uAR5UmAADEaSP8HHM443.png

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

2. CORDIC IP核

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

wKgaomToD9uAftduAAEMutKZ7eI359.png

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

wKgaomToD9uAD8hwAACNA7RHLJU174.png

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

wKgaomToD9uAY256AADbDvWlbBs309.png

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產生兩組數據,并將角度值定點化后作為設計模塊數據激勵:

wKgaomToD9uAGEjaAAI96Vno27o189.png

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

仿真結果:

wKgaomToD9uASCbRAAChLlKdHqQ793.png

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

wKgaomToD9uAW6dsAAAJM7aZU1A388.png

有你想看的精彩 至芯科技-FPGA就業培訓來襲!你的選擇開啟你的高薪之路!7月12號北京中心開課、歡迎咨詢! 如何在FPGA中實現狀態機 基于FPGA的電子按鍵密碼鎖設計

wKgaomToD9yAQ4akAABUdafP6GM141.jpg

掃碼加微信邀請您加入FPGA學習交流群

wKgaomToD9yABZesAAACXWrmhKE308.png

歡迎加入至芯科技FPGA微信學習交流群,這里有一群優秀的FPGA工程師、學生、老師、這里FPGA技術交流學習氛圍濃厚、相互分享、相互幫助、叫上小伙伴一起加入吧!

點個在看你最好看


原文標題:利用FPGA進行基本運算及特殊函數定點運算

文章出處:【微信公眾號:FPGA設計論壇】歡迎添加關注!文章轉載請注明出處。


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1660

    文章

    22412

    瀏覽量

    636297

原文標題:利用FPGA進行基本運算及特殊函數定點運算

文章出處:【微信號:gh_9d70b445f494,微信公眾號:FPGA設計論壇】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    定點運算案例的程序

    定點運算(Fixed-Poin Arithmetic)在某些嵌入式系統中,浮點運算會較慢或不被支持。因此,使用固定點運算可以提供一種有
    發表于 12-12 06:35

    詳解FPGA定點數計算方法

    FPGA定點數計算在高效資源利用運算速度優勢、硬件可預測性和成本效益等方面發揮著重要作用。它能節省邏輯和存儲資源,實現更快速的運算和更高的
    的頭像 發表于 12-02 10:09 ?512次閱讀
    詳解<b class='flag-5'>FPGA</b><b class='flag-5'>定點</b>數計算方法

    C語言宏拼接運算符典型使用

    在C語言中,##運算符(稱為[size=16.002px]標記拼接運算符)用于宏定義中將兩個標記(token)拼接成一個新的標記。它在預處理階段處理,常用于動態生成變量名、函數名或類型名,以提高代碼
    發表于 11-20 08:27

    定點數表示實數的方法以及定點數在硬件上的運算驗證

    定點數要長許多。 相比之下,在數值范圍較小(相對于浮點數)、精度要求不那么高的運算中,可以利用定點數加速運算。 Q4精度小數
    發表于 10-28 08:13

    卷積運算分析

    卷積運算的基礎運算是乘加運算(MAC,Multiplication and Accumulation),本文設計了基本運算單元PE模塊來實現MAC
    發表于 10-28 07:31

    浮點數是如何實現開平方運算

    摘要: 本文主要描述浮點數是如何實現開平方運算的。 簡介 事實上,浮點數的開平方運算結構與定點數甚至整數的開平方運算結構是十分相似的,我們可以在對
    發表于 10-24 08:42

    Verilog實現使用Booth編碼和Wallace樹的定點補碼乘法器原理

    周期乘法器。乘法器,對于無符號乘法進行一位符號擴展后統一當作有符號數進行運算,因此需要17個迭代周期。為了改良乘法器性能,我們可以使用Booth編碼和Wallace樹的定點補碼乘法器,該乘法器生成
    發表于 10-23 08:01

    浮點運算單元的設計和優化

    普通的加減交替法,同樣對于無符號乘法進行一位符號擴展后統一當作有符號數進行運算,最終得到完全準確的除法結果,總共最多需要36個時鐘周期。 4.浮點指令擴展:計劃先完成單精度浮點指令集(F)的拓展,可以
    發表于 10-22 07:04

    使用Simulink自動生成浮點運算HDL代碼(Part 1)

    引言 想要實現浮點運算功能,如果自己寫Verilog代碼,需要花費較多的時間和精力。好在Simulink HDL Coder工具箱提供了自動代碼生成技術。下圖展示了HDL Coder如何生成浮點運算
    發表于 10-22 06:48

    優化boot4的乘法運算周期

    優化電路設計:在電路設計中,優化關鍵路徑和信號傳輸路線,使用更高速的邏輯單元和存儲器元件來降低延遲,從而縮短乘法器的運算周期。 利用流水線技術:使用流水線技術將乘法操作分成多個階段,使每個階段的操作
    發表于 10-21 13:17

    定點小數運算

    許多 MCU 芯片只支持整數運算,如果要在這些芯片上進行小數運算,定點運算應該是最佳選擇了;此外即使芯片支持浮點數,
    發表于 07-25 14:02

    功率分析儀運算原理 什么是同步源?有功功率運算

    橫河功率分析儀的通用運算原理則是首先檢測出指定信號的周期,并將檢測周期的整數倍時間設為測量區間,隨后對這段時間內采集到的數據進行平均運算,這一測量方式也被稱為“同步源周期平均法”,其中用于定義測量周期的輸入信號被稱為同步源。
    的頭像 發表于 06-30 15:30 ?1602次閱讀
    功率分析儀<b class='flag-5'>運算</b>原理 什么是同步源?有功功率<b class='flag-5'>運算</b>

    FPGA定點和浮點數學運算實例對比

    在創建 RTL 示例時,經常使用 VHDL 2008 附帶的 VHDL 包。它提供了出色的功能,可以高效地處理定點數,當然,它們也是可綜合的。該包的一些優點包括:
    的頭像 發表于 06-23 09:53 ?1027次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>定點</b>和浮點數學<b class='flag-5'>運算</b>實例對比

    CRC16-MODBUS+手算+移位運算+C程序+并行運算

    CRC16-MODBUS+手算+移位運算+C程序+并行運算
    發表于 04-22 18:23 ?0次下載

    從零開始學運算放大器筆記一 | 認識運算放大器

    )是一種模擬電路模塊,它采用差分電壓輸入,產生單端電壓輸出。它可以對輸入信號進行放大以及加、減、乘、除、微分、積分等數學運算,現多應用于信號放大功能。一個運算放大器至
    的頭像 發表于 03-24 19:32 ?4545次閱讀
    從零開始學<b class='flag-5'>運算</b>放大器筆記一 | 認識<b class='flag-5'>運算</b>放大器