一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>可編程邏輯>陪兒子做作業(yè),我用上了C語言和Verilog資料下載

陪兒子做作業(yè),我用上了C語言和Verilog資料下載

2021-03-28 | pdf | 258.83KB | 次下載 | 2積分

資料介紹

前幾天和同事聊天,他說他上初中的兒子做出了一道很難的數(shù)學(xué)題,想考考我們這些大學(xué)生看能不能做得出來?

題目很簡單:

數(shù)學(xué)題目

大家先嘗試做一下?我沒想出怎么算的,只是用排除法確定了a和b的范圍,然后再逐個(gè)嘗試。

1.對4361進(jìn)行開方計(jì)算,得到結(jié)果最大為66,則a,b的值均小于等于66。

2.對4361/2進(jìn)行開方計(jì)算,則得到結(jié)果為46,則a,b兩者,一個(gè)是1-46,一個(gè)是46-66之間的數(shù)。

3.由平方和4361末尾為1,再根據(jù)整數(shù)平方和的幾種可能,計(jì)算出僅有0+1和5+6這兩種可能,而且平方之后的個(gè)位數(shù)為0/1/5/6,這樣就進(jìn)一步縮小了范圍,通過多次計(jì)算嘗試可以得出結(jié)果。

不過我懶得算了,就簡單寫了個(gè)C語言程序,計(jì)算出了結(jié)果:

#include? #include? #include? int?main(void) {
????int?num;?????
????int?a,?b,?n;
????int?result;
????int?sqr;

????printf("please?enter?a?number:");//4361 ????scanf("%d",?&num);
????printf("input?num:?%d\n",?num);

????sqr?=?sqrt(num);
????for(a?=?1;?a?<=?sqr;?a++)????????//可以設(shè)置1-46 ????{
????????for(b?=?1;?b?<=?sqr;?b++)????//可以設(shè)置46-66 ????????{
????????????result?=?pow(a,?2)?+?pow(b,?2);
????????????if(result?==?num)
????????????{
????????????????printf("a?=?%2d,?b?=?%2d,?a?+?b?=?%d\n",?a,?b,?a+b);
????????????????n++;
????????????}
????????}
????}
????if(n?==?0)
????????printf("There?is?no?answer!\n");

????return?0;
}

其實(shí)可以設(shè)置一個(gè)數(shù)的循環(huán)范圍是:1-46,一個(gè)數(shù)的循環(huán)范圍是46-66,這樣會減少循環(huán)次數(shù)。

運(yùn)行結(jié)果:

運(yùn)行結(jié)果

而且這種方式還適用于解的個(gè)數(shù)不唯一的情況,比如7605:

運(yùn)行結(jié)果

作為一個(gè)野生FPGA開發(fā)者,我在想能不能用FPGA的編程思想來實(shí)現(xiàn)呢?也就是如何用Verilog來實(shí)現(xiàn)兩個(gè)循環(huán)的嵌套呢?抄起鍵盤就是干!

抄起鍵盤就是干

verilog源文件fpga_math.v:

module?fpga_math(
????//inputs ????input?clk,
????input?rst_n,

????//outputs ????output?reg?[13:0]?a,?b,
????output?reg?[14:0]?result,
????output?ok
);

parameter?SUM?=?4361;
parameter?SQR?=?67;???????//sqrt(SUM); reg?[13:0]?tmp_a;
reg?[13:0]?tmp_b;
reg?flag;

assign?ok?=?(tmp_a*tmp_a?+?tmp_b*tmp_b?==?SUM);

always?@?(posedge?clk) begin
????if(!rst_n) ????????tmp_b?<=?0;
????else?if(tmp_b?==?SQR)
????????tmp_b?<=?0;
????else?if(tmp_a?!=?SQR)
????????tmp_b?<=?tmp_b?+?1;
end

always?@?(posedge?clk) begin
????if(!rst_n) ????????flag?<=?0;
????else?if(tmp_b?==?SQR)
????????flag?<=?1;
????else?
????????flag?<=?0;
end

always?@?(posedge?clk) begin
????if(!rst_n) ????????tmp_a?<=?0;
????else?if((tmp_a?!=?SQR)?&?flag)
????????tmp_a?<=?tmp_a?+?1;
end

always?@?(posedge?clk) begin
????if(!rst_n) ????begin
????????a?<=?0;
????????b?<=?0;
????????result?<=?0;
????end
????else?if(ok) ????begin
????????a?<=?tmp_a;
????????b?<=?tmp_b;
????????result?=?tmp_a?+?tmp_b;
????end
end

endmodule

為了驗(yàn)證這個(gè)模塊的正確性,我們需要對這個(gè)模塊進(jìn)行仿真,即給一個(gè)激勵(lì)輸入信號,看輸出是否正確。

新建testbench文件fpga_math_tb.v:

`timescale?1ns/100ps module?fpga_math_tb;

parameter?SUM?=?4361;
parameter?SQR?=?67;?????//sqrt(4361) parameter?SYSCLK_PERIOD?=?10;//?100MHZ wire?[13:0]?a,?b;
wire?[14:0]?result;

reg?SYSCLK;
reg?NSYSRESET;

initial
begin
????SYSCLK?=?1'b0;
????NSYSRESET?=?1'b0;

????#(SYSCLK_PERIOD?*?10?)
????????NSYSRESET?=?1'b1;
????#(SYSCLK_PERIOD?*?(SQR*SQR+500)?)
????????$stop;
end /*generate?clock*/ always?@(SYSCLK)
????#(SYSCLK_PERIOD?/?2.0)?SYSCLK?<=?!SYSCLK;??????? /*instance?module*/ fpga_math?#(
????.SUM(SUM),
????.SQR(SQR)
)fpga_math_0(
????//inputs ????.clk(SYSCLK),
????.rst_n(NSYSRESET),

????//outputs ????.a(a),
????.b(b),
????.result(result),
????.ok(ok)
);

endmodule

ModelSim仿真波形:

仿真波形

仿真工具除了使用各大FPGA廠商IDE帶的ModelSim等,也可以使用小巧開源的全平臺仿真工具:iverilog+gtkwave,使用方法可以參考:

如果使用iverilog進(jìn)行仿真,需要在TB文件中添加以下幾行語句:

/*iverilog?*/
initial
begin????????????
????$dumpfile("wave.vcd");????????//生成的vcd文件名稱
????$dumpvars(0,?fpga_math_tb);???//tb模塊名稱
end
/*iverilog?*

首先對Verilog源文件進(jìn)行編譯,檢查是否有語法錯(cuò)誤,這會在當(dāng)前目錄生成wave目標(biāo)文件:

iverilog?-o?wave?*.v

然后通過vvp指令,產(chǎn)生仿真的wave.vcd波形文件:

vvp?-n?wave?-lxt2

使用gtkwave打開波形文件:

gtkwave?wave.vcd

當(dāng)然以上命令也可以寫成批處理文件:

echo?"開始編譯" iverilog?-o?wave?*.v echo?"編譯完成" echo?"生成波形文件" vvp?-n?wave?-lxt2 echo?"打開波形文件" gtkwave?wave.vcd

以文本方式存儲為build.bat文件即可,雙擊即可自動完成編譯、生成波形文件、打開波形文件操作。

仿真波形:

仿真波形

可以看出,和使用ModelSim仿真是一樣的結(jié)果。

總結(jié)

從仿真波形圖中,可以得到計(jì)算的結(jié)果,a+b的值為91,如果要在真實(shí)的FPGA芯片硬件上實(shí)現(xiàn),還需要添加其他功能模塊,把結(jié)果通過串口輸出,或者在數(shù)碼管等顯示屏上進(jìn)行顯示,這里只是簡單介紹使用FPGA計(jì)算方法的實(shí)現(xiàn)。作為純數(shù)字電路的FPGA,實(shí)現(xiàn)平方根是比較復(fù)雜的,這里采用直接人為輸入平方根結(jié)果的方式,而不是像C語言那樣調(diào)用sqrt函數(shù)自動計(jì)算平方根。FPGA中不僅有觸發(fā)器和查找表,而且還有乘法器、除法器等硬核IP,所以在涉及到乘除法、平方根運(yùn)算時(shí),不要直接使用*/等運(yùn)算符,而是要使用FPGA自帶的IP核,這樣就不會占用大量的邏輯資源,像Xilinx的基于Cordic算法的Cordic IP核,不僅能實(shí)現(xiàn)平方根計(jì)算,而且還有sin/cos/tan/arctan等三角函數(shù)。

(mbbeetchina)
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1DC電源插座圖紙
  2. 0.67 MB   |  3次下載  |  免費(fèi)
  3. 2AN-1267: 使用ADSP-CM408F ADC控制器的電機(jī)控制反饋采樣時(shí)序
  4. 1.41MB   |  3次下載  |  免費(fèi)
  5. 3AN158 GD32VW553 Wi-Fi開發(fā)指南
  6. 1.51MB   |  2次下載  |  免費(fèi)
  7. 4AN148 GD32VW553射頻硬件開發(fā)指南
  8. 2.07MB   |  1次下載  |  免費(fèi)
  9. 5AN111-LTC3219用戶指南
  10. 84.32KB   |  次下載  |  免費(fèi)
  11. 6AN153-用于電源系統(tǒng)管理的Linduino
  12. 1.38MB   |  次下載  |  免費(fèi)
  13. 7AN-283: Σ-Δ型ADC和DAC[中文版]
  14. 677.86KB   |  次下載  |  免費(fèi)
  15. 8SM2018E 支持可控硅調(diào)光線性恒流控制芯片
  16. 402.24 KB  |  次下載  |  免費(fèi)

本月

  1. 1ADI高性能電源管理解決方案
  2. 2.43 MB   |  450次下載  |  免費(fèi)
  3. 2免費(fèi)開源CC3D飛控資料(電路圖&PCB源文件、BOM、
  4. 5.67 MB   |  138次下載  |  1 積分
  5. 3基于STM32單片機(jī)智能手環(huán)心率計(jì)步器體溫顯示設(shè)計(jì)
  6. 0.10 MB   |  130次下載  |  免費(fèi)
  7. 4使用單片機(jī)實(shí)現(xiàn)七人表決器的程序和仿真資料免費(fèi)下載
  8. 2.96 MB   |  44次下載  |  免費(fèi)
  9. 5美的電磁爐維修手冊大全
  10. 1.56 MB   |  24次下載  |  5 積分
  11. 6如何正確測試電源的紋波
  12. 0.36 MB   |  18次下載  |  免費(fèi)
  13. 7感應(yīng)筆電路圖
  14. 0.06 MB   |  10次下載  |  免費(fèi)
  15. 8萬用表UT58A原理圖
  16. 0.09 MB   |  9次下載  |  5 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935121次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
  4. 1.48MB  |  420062次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費(fèi)下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費(fèi)下載
  14. 0.02 MB  |  73810次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分