日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > > 電子電路開發(fā)學(xué)習(xí)
[導(dǎo)讀]前幾天和同事聊天,他說他上初中的兒子做出了一道很難的數(shù)學(xué)題,想考考我們這些大學(xué)生看能不能做得出來?


前幾天和同事聊天,他說他上初中的兒子做出了一道很難的數(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,使用方法可以參考:

全平臺輕量開源verilog仿真工具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文件即可,雙擊即可自動(dòng)完成編譯、生成波形文件、打開波形文件操作。

仿真波形:

仿真波形

可以看出,和使用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ù)自動(dòng)計(jì)算平方根。FPGA中不僅有觸發(fā)器和查找表,而且還有乘法器、除法器等硬核IP,所以在涉及到乘除法、平方根運(yùn)算時(shí),不要直接使用*/等運(yùn)算符,而是要使用FPGA自帶的IP核,這樣就不會占用大量的邏輯資源,像Xilinx的基于Cordic算法的Cordic IP核,不僅能實(shí)現(xiàn)平方根計(jì)算,而且還有sin/cos/tan/arctan等三角函數(shù)。


免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

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

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉