原創(chuàng)聲明:
本原創(chuàng)教程由芯驛電子科技(上海)有限公司(ALINX)創(chuàng)作,版權(quán)歸本公司所有,如需轉(zhuǎn)載,需授權(quán)并注明出處。
適用于板卡型號:
AXU2CGA/AXU2CGB/AXU3EG/AXU4EV-E/AXU4EV-P/AXU5EV-E/AXU5EV-P /AXU9EG/AXU15EG
實(shí)驗(yàn)Vivado工程為“pwm_led”。
本文主要講解使用PWM控制LED,實(shí)現(xiàn)呼吸燈的效果。
1.實(shí)驗(yàn)原理
如下圖所示,用一個N比特的計(jì)數(shù)器,最大值可以表示為2的N次方,最小值0,計(jì)數(shù)器以“period”為步進(jìn)值累加,加到最大值后會溢出,進(jìn)入下一個累加周期。當(dāng)計(jì)數(shù)器值大于“duty”時,脈沖輸出高,否則輸出低,這樣就可以完成圖中紅色線所示的脈沖占空比可調(diào)的脈沖輸出,同時“period”可以調(diào)節(jié)脈沖頻率,可以理解為計(jì)數(shù)器的步進(jìn)值。
![pIYBAGAKLtSAOU6CAAANXx_V_tQ811.jpg](https://file.elecfans.com//web1/M00/DC/2D/pIYBAGAKLtSAOU6CAAANXx_V_tQ811.jpg)
不同的脈沖占空比的方波輸出后加在LED上,LED燈就會顯示不同的亮度,通過不斷地調(diào)節(jié)方波的占空比,從而實(shí)現(xiàn)LED燈亮度的調(diào)節(jié)。
2. 實(shí)驗(yàn)設(shè)計(jì)
PWM模塊設(shè)計(jì)非常簡單,在上面的原理中已經(jīng)講到,這里不再說原理。
信號名稱 | 方向 | 說明 |
clk | in | 時鐘輸入 |
rst | in | 異步復(fù)位輸入,高復(fù)位 |
period | in | PWM脈寬周期(頻率)控制。period = PWM輸出頻率 * (2 的N次方) / 系統(tǒng)時鐘頻率。顯然N越大,頻率精度越高。 |
duty | in | 占空比控制,占空比 = duty / (2的N次方)* 100% |
PWM模塊(ax_pwm)端口
`timescale1ns/1psmoduleax_pwm#( parameterN=16//pwmbitwidth )(inputclk,inputrst,input[N-1:0]period, //pwmstepvalueinput[N-1:0]duty, //dutyvalueoutputpwm_out //pwmoutput);reg[N-1:0]period_r; //periodregisterreg[N-1:0]duty_r; //dutyregisterreg[N-1:0]period_cnt; //periodcounterregpwm_r;assignpwm_out=pwm_r;always@(posedgeclkorposedgerst)beginif(rst==1)begin period_r<={?N?{1'b0}}; ????????duty_r?<={?N?{1'b0}};endelsebegin ????????period_r?<=?period; ????????duty_r???<=?duty;endend//period?counter,?step?is?period?valuealways@(posedge?clk?orposedge?rst)beginif(rst==1) ????????period_cnt?<={?N?{1'b0}};else ????????period_cnt?<=?period_cnt?+?period_r;endalways@(posedge?clk?orposedge?rst)beginif(rst==1)begin ????????pwm_r?<=1'b0;endelsebeginif(period_cnt?>=duty_r) //ifperiodcounterisbiggerorequalstodutyvalue,thensetpwmvaluetohighpwm_r<=1'b1;else ????????????pwm_r?<=1'b0;endend
那么如何實(shí)現(xiàn)呼吸燈的效果呢?我們知道呼吸燈效果是由暗不斷的變亮,再由亮不斷的變暗的過程,而亮暗效果是由占空比來調(diào)節(jié)的,因此我們主要來控制占空比,也就是控制duty的值。
在下面的測試代碼中,通過設(shè)置period的值,設(shè)定PWM的頻率為200Hz,PWM_PLUS狀態(tài)即是增加duty值,如果增加到最大值,將pwm_flag置1,并開始將duty值減少,待減少到最小的值,則開始增加duty值,不斷循環(huán)。其中PWM_GAP狀態(tài)為調(diào)整間隔,時間為100us。
`timescale1ns/1psmodulepwm_test(input clk, //25MHzinput rst_n, //lowactive output led //high-off,low-on); localparamCLK_FREQ=25; //25MHzlocalparamUS_COUNT=CLK_FREQ; //1uscounterlocalparamMS_COUNT=CLK_FREQ*1000; //1mscounterlocalparamDUTY_STEP =32'd100000; //dutysteplocalparamDUTY_MIN_VALUE=32'h6fffffff; //dutyminimumvaluelocalparamDUTY_MAX_VALUE=32'hffffffff; //dutymaximumvalue localparamIDLE =0; //IDLEstatelocalparamPWM_PLUS =1;//PWMdutyplusstatelocalparamPWM_MINUS =2;//PWMdutyminusstatelocalparamPWM_GAP =3;//PWMdutyadjustmentgapwire pwm_out; //pwmoutputreg[31:0] period; //pwmstepvaluereg[31:0] duty; //dutyvaluereg pwm_flag; //dutyvalueplusandminusflag,0:plus;1:minusreg[3:0] state;reg[31:0] timer; //dutyadjustmentcounterassignled=~pwm_out;//ledlowactivealways@(posedgeclkornegedgerst_n)begin if(rst_n==1'b0) begin period <=32'd0; timer? <=32'd0; duty? <=32'd0; pwm_flag? <=1'b0; state? <=?IDLE; end else case(state) IDLE: begin period? <=32'd17179;//The?pwm?step?value,?pwm?200Hz(period?=?200*2^32/50000000) state?? <=?PWM_PLUS; duty??? <=?DUTY_MIN_VALUE; end PWM_PLUS?: begin if(duty?>DUTY_MAX_VALUE-DUTY_STEP) //ifdutyisbiggerthanDUTYMAXVALUEminusDUTY_STEP,begintominusdutyvalue begin pwm_flag <=1'b1; duty??? <=?duty?-?DUTY_STEP?; end else begin pwm_flag? <=1'b0; duty??? <=?duty?+?DUTY_STEP?; end state?? <=?PWM_GAP?; end PWM_MINUS?: begin if(duty?=US_COUNT*100)//adjustmentgapis100us begin if(pwm_flag) state<=?PWM_MINUS?; else state?<=?PWM_PLUS?; timer?<=32'd0; end else begin timer?<=?timer?+32'd1; end end default: begin state?<=?IDLE; end endcaseend//Instantiate?pwm?moduleax_pwm#(.N(32))ax_pwm_m0(.clk??????(clk),.rst??????(~rst_n),.period???(period),.duty?????(duty),.pwm_out??(pwm_out)); endmodule
3. 下載驗(yàn)證
生成bitstream,并下載bit文件,可以看到PL LED1燈產(chǎn)生呼吸燈效果。PWM是比較常用的模塊,比如風(fēng)扇轉(zhuǎn)速控制,電機(jī)轉(zhuǎn)速控制等等。
-
FPGA
+關(guān)注
關(guān)注
1631文章
21806瀏覽量
606637 -
PWM
+關(guān)注
關(guān)注
114文章
5203瀏覽量
215078 -
Zynq
+關(guān)注
關(guān)注
10文章
610瀏覽量
47356 -
MPSoC
+關(guān)注
關(guān)注
0文章
199瀏覽量
24346 -
呼吸燈
+關(guān)注
關(guān)注
10文章
111瀏覽量
42829
發(fā)布評論請先 登錄
相關(guān)推薦
基于FPGA的呼吸燈設(shè)計(jì)(附源工程)
![基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>呼吸</b><b class='flag-5'>燈</b>設(shè)計(jì)(附源工程)](https://file1.elecfans.com/web3/M00/06/28/wKgZPGeIauuAXqGPAAAj9lKATnA650.png)
Zynq UltraScale+ MPSoC數(shù)據(jù)手冊
《DNESP32S3使用指南-IDF版_V1.6》第十章 LED實(shí)驗(yàn)
AMD/Xilinx Zynq? UltraScale+ ? MPSoC ZCU102 評估套件
![AMD/Xilinx <b class='flag-5'>Zynq</b>? <b class='flag-5'>UltraScale+</b> ? <b class='flag-5'>MPSoC</b> ZCU102 評估套件](http://m.xsypw.cn/images/chaijie_default.png)
在米爾電子MPSOC實(shí)現(xiàn)12G SDI視頻采集H.265壓縮SGMII萬兆以太網(wǎng)推流
迅為iTOP-RK3568開發(fā)板驅(qū)動開發(fā)指南-第十八篇 PWM
在米爾電子MPSOC實(shí)現(xiàn)12G SDI視頻采集H.265壓縮SGMII萬兆以太網(wǎng)推流
《DNK210使用指南 -CanMV版 V1.0》第十章 板卡信息實(shí)驗(yàn)
使用TPS65086x PMIC為Xilinx Zynq UltraScale MPSoC供電
![使用TPS65086x PMIC為Xilinx <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale</b> <b class='flag-5'>MPSoC</b>供電](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
ALINX FPGA+GPU異架構(gòu)視頻圖像處理開發(fā)平臺介紹
一個更適合工程師和研究僧的FPGA提升課程
AMD推出全新Spartan UltraScale+ FPGA系列
![AMD推出全新Spartan <b class='flag-5'>UltraScale+</b> <b class='flag-5'>FPGA</b>系列](https://file1.elecfans.com/web2/M00/C4/B9/wKgZomX3qe2ARWOqAAA1_slJx3U488.png)
AMD推出Spartan UltraScale+ FPGA系列產(chǎn)品
AMD推出全新Spartan UltraScale+ FPGA系列
在FPGA上為FPGA設(shè)計(jì)PCB的步驟詳解
![在<b class='flag-5'>FPGA</b>上為<b class='flag-5'>FPGA</b>設(shè)計(jì)PCB的步驟詳解](https://file1.elecfans.com/web2/M00/C1/DD/wKgaomXb5BiAMx_hAAA1KoqZlSo148.png)
評論