色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

【ZYNQ Ultrascale+ MPSOC FPGA教程】第十章PWM呼吸燈實驗

FPGA技術專欄 ? 來源:芯驛電子科技 ? 作者:芯驛電子科技 ? 2021-01-23 11:18 ? 次閱讀

原創聲明:

本原創教程由芯驛電子科技(上海)有限公司(ALINX)創作,版權歸本公司所有,如需轉載,需授權并注明出處。

適用于板卡型號:

AXU2CGA/AXU2CGB/AXU3EG/AXU4EV-E/AXU4EV-P/AXU5EV-E/AXU5EV-P /AXU9EG/AXU15EG

實驗Vivado工程為“pwm_led”。

本文主要講解使用PWM控制LED,實現呼吸燈的效果。

1.實驗原理

如下圖所示,用一個N比特的計數器,最大值可以表示為2的N次方,最小值0,計數器以“period”為步進值累加,加到最大值后會溢出,進入下一個累加周期。當計數器值大于“duty”時,脈沖輸出高,否則輸出低,這樣就可以完成圖中紅色線所示的脈沖占空比可調的脈沖輸出,同時“period”可以調節脈沖頻率,可以理解為計數器的步進值。

pIYBAGAKLtSAOU6CAAANXx_V_tQ811.jpgPWM脈寬調制示意圖

不同的脈沖占空比的方波輸出后加在LED上,LED燈就會顯示不同的亮度,通過不斷地調節方波的占空比,從而實現LED燈亮度的調節。

2. 實驗設計

PWM模塊設計非常簡單,在上面的原理中已經講到,這里不再說原理。

信號名稱 方向 說明
clk in 時鐘輸入
rst in 異步復位輸入,高復位
period in PWM脈寬周期(頻率)控制。period = PWM輸出頻率 * (2 的N次方) / 系統時鐘頻率。顯然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

那么如何實現呼吸燈的效果呢?我們知道呼吸燈效果是由暗不斷的變亮,再由亮不斷的變暗的過程,而亮暗效果是由占空比來調節的,因此我們主要來控制占空比,也就是控制duty的值。

在下面的測試代碼中,通過設置period的值,設定PWM的頻率為200Hz,PWM_PLUS狀態即是增加duty值,如果增加到最大值,將pwm_flag置1,并開始將duty值減少,待減少到最小的值,則開始增加duty值,不斷循環。其中PWM_GAP狀態為調整間隔,時間為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. 下載驗證

生成bitstream,并下載bit文件,可以看到PL LED1燈產生呼吸燈效果。PWM是比較常用的模塊,比如風扇轉速控制,電機轉速控制等等。

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

    關注

    1630

    文章

    21796

    瀏覽量

    605171
  • PWM
    PWM
    +關注

    關注

    114

    文章

    5197

    瀏覽量

    214555
  • Zynq
    +關注

    關注

    10

    文章

    610

    瀏覽量

    47252
  • MPSoC
    +關注

    關注

    0

    文章

    199

    瀏覽量

    24312
  • 呼吸燈
    +關注

    關注

    10

    文章

    111

    瀏覽量

    42778
收藏 人收藏

    評論

    相關推薦

    基于FPGA呼吸設計(附源工程)

    ,起到一個通知提醒的作用。 設計原理 關于呼吸設計實現的理論主要是PWM有關知識。PWM(Pluse Width Modulation)脈沖寬度調制,是一種對模擬信號電平進行數字編碼
    的頭像 發表于 01-16 10:09 ?75次閱讀
    基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>呼吸</b><b class='flag-5'>燈</b>設計(附源工程)

    Zynq UltraScale+ MPSoC數據手冊

    電子發燒友網站提供《Zynq UltraScale+ MPSoC數據手冊.pdf》資料免費下載
    發表于 12-30 14:37 ?2次下載

    《DNESP32S3使用指南-IDF版_V1.6》第十章 LED實驗

    第十章LED實驗 本章將通過一個經典的點燈實驗,帶大家開啟ESP32-S3 IDF開發之旅。通過本章學習,我們將會學習到如何實現ESP32-S3的IO作為輸出功能。本章分為如下幾個小節:10.1
    發表于 12-07 09:33

    AMD/Xilinx Zynq? UltraScale+ ? MPSoC ZCU102 評估套件

    AMD/Xilinx Zynq? UltraScale+ ? MPSoC ZCU102 評估套件可快速啟動汽車、工業、視頻和通信應用設計。AMD/Xilinx MPSoC ZCU102
    的頭像 發表于 11-20 15:32 ?512次閱讀
    AMD/Xilinx <b class='flag-5'>Zynq</b>? <b class='flag-5'>UltraScale+</b> ? <b class='flag-5'>MPSoC</b> ZCU102 評估套件

    在米爾電子MPSOC實現12G SDI視頻采集H.265壓縮SGMII萬兆以太網推流

    4K UHD音視頻廣播領域的優勢 1.高性能與低功耗的結合:Zynq UltraScale+ MPSoC采用了16nm FinFET工藝,集成了多核處理器和可編程邏輯,能夠在提高性能的同時降低功耗,這對
    發表于 11-01 16:56

    迅為iTOP-RK3568開發板驅動開發指南-第十八篇 PWM

    APP 209.5 運行測試 209.5.1 編譯驅動程序 209.5.2 編譯應用程序 209.5.3 運行測試 209.6 呼吸實驗 第210 sysyfs操作
    發表于 10-29 10:13

    在米爾電子MPSOC實現12G SDI視頻采集H.265壓縮SGMII萬兆以太網推流

    在本設計中,我們使用Zynq UltraScale+ MPSoC平臺(具體型號為MYIR XCZU4EV),通過FPGA實現對SDI視頻的H265壓縮,并通過SGMII接口推送到萬兆
    發表于 10-14 17:42

    《DNK210使用指南 -CanMV版 V1.0》第十章 板卡信息實驗

    第十章 板卡信息實驗 本章實驗將介紹如何使用CanMV內置的board腳本來獲取板卡信息,方便后續實驗使用。通過本章的學習,讀者將學習到CanMV內置board腳本的使用。本章分為如下
    發表于 09-28 15:04

    使用TPS65086x PMIC為Xilinx Zynq UltraScale MPSoC供電

    電子發燒友網站提供《使用TPS65086x PMIC為Xilinx Zynq UltraScale MPSoC供電.pdf》資料免費下載
    發表于 09-21 11:11 ?0次下載
    使用TPS65086x PMIC為Xilinx <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale</b> <b class='flag-5'>MPSoC</b>供電

    ALINX FPGA+GPU異架構視頻圖像處理開發平臺介紹

    Alinx 最新發布的新品 Z19-M 是一款創新的 FPGA+GPU 異構架構視頻圖像處理開發平臺,它結合了 AMD Zynq UltraScale+ MPSoC
    的頭像 發表于 08-29 14:43 ?1263次閱讀

    一個更適合工程師和研究僧的FPGA提升課程

    Suite 1 設計 FPGA; 嵌入式設計課程 02 ● 設計 Zynq UltraScale+ RFSoC; ● 面向軟件開發者的Zynq
    發表于 06-05 10:09

    AMD推出全新Spartan UltraScale+ FPGA系列

    AMD 已經擁有 Zynq UltraScale+ 和 Artix UltraScale+ 系列,而 Spartan UltraScale+ FPG
    發表于 03-18 10:40 ?437次閱讀
    AMD推出全新Spartan <b class='flag-5'>UltraScale+</b> <b class='flag-5'>FPGA</b>系列

    AMD推出Spartan UltraScale+ FPGA系列產品

    AMD公司,全球知名的芯片巨頭,近日宣布推出全新的AMD Spartan UltraScale+ FPGA系列產品組合。這一新系列作為AMD成本優化型FPGA、自適應SoC產品家族的最新成員,特別針對成本敏感型邊緣應用進行了優化
    的頭像 發表于 03-07 10:15 ?751次閱讀

    AMD推出全新Spartan UltraScale+ FPGA系列

    AMD日前正式推出了全新的Spartan UltraScale+ FPGA系列,該系列作為AMD廣泛的成本優化型FPGA和自適應SoC產品組合的最新成員,專為邊緣端各種I/O密集型應用設計。
    的頭像 發表于 03-06 11:09 ?876次閱讀

    FPGA上為FPGA設計PCB的步驟詳解

    FPGA(Zynq? UltraScale+? MPSoC) 上的 Ubuntu 22.04 桌面映像上安裝了各種 EE 設計應用程序(包括 KiCad),并用它設計 PCB。
    的頭像 發表于 02-26 09:04 ?2054次閱讀
    在<b class='flag-5'>FPGA</b>上為<b class='flag-5'>FPGA</b>設計PCB的步驟詳解
    主站蜘蛛池模板: 国产强奷糟蹋漂亮邻居在线观看 | 日本精品久久无码影院 | 美女爽到嗷嗷嗷叫 | 老司机试看午夜 | 被免费网站在线视频 | 精品一区二区三区四区五区六区 | 午夜精品久久久久久久99蜜桃 | xxx军人3p大gay | 年轻的老师5理伦片 | 青草在线观看视频 | 女性性纵欲派对 | 在线综合 亚洲 欧美 | 偷柏自拍亚洲综合在线 | 国产又粗又猛又爽又黄的免费视频 | 在线 日韩 欧美 国产 社区 | 青青久在线 | 免费一级毛片在线观看 | 国产成+人欧美+综合在线观看 | 欧美午夜理伦三级在线观看 | 97伦理97伦理2018最新 | 午夜国产精品影院在线观看 | 黑人猛挺进小莹的体内视频 | 亚洲不卡一卡2卡三卡4卡5卡 | MD传媒在线观看佳片 | 国产午夜精品一区二区 | 国内精品自线在拍2020不卡 | 一本之道高清视频在线观看 | 免费毛片在线视频 | 女教师二十三歳 | 国产69精品久久久久乱码韩国 | 日本 一二三 不卡 免费 | 贵妃高h荡肉呻吟np杨玉环 | 极品少妇粉嫩小泬啪啪AV | 全免费午夜一级毛片 | 7723日本高清完整版在线观看 | 伊人久久大香线蕉综合网站 | 国产小视频国产精品 | 欧美一区二区三区不卡免费 | 国产视频精品在线偷拍 | 欧美大片免费 | 阿离被扒开双腿疯狂输出 |