- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
五邑大学物理实验报告
实验三:基于自定义 二、实验要求PWM的乐曲演奏实验 1、理解PWM设计原理 2、设计PWM自定义组件 3、利用SOPCBuilder构建乐曲演奏电路的微处理器系统 4、构建硬件设计电路 5、编写乐曲C语言程序 6、用niosII软件下载程序,调试 三、实验原理 1、PWM的基本原理 PWM即脉冲宽度调制,是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术。 脉冲宽度调制是一种对模拟信号电平进行数字编码的方法。通过高分辨率计数器的使用,方波的占空比被调制用来对一个具体模拟信号的电平进行编码。PWM信号仍然是数字的,因为在给定的任何时刻,满幅值的直流供电要么完全有(ON),要么完全无(OFF)。电压或电流源是以一种通(ON)或断(OFF)的重复脉冲序列被加到模拟负载上去的。通的时候即是直流供电被加到负载上的时候,断的时候即是供电被断开的时候。只要带宽足够,任何模拟值都可以使用PWM进行编码。多数负载(无论是电感性负载还是电容性负载)需要的调制频率高于10Hz,通常调制频率为1kHz到200kHz之间。 2、乐曲演奏原理 用niosII软件控制组件,实现PWM控制蜂鸣器的输入信号的频率,改变蜂鸣器鸣叫的音的长短、响度等。 3、乐曲演奏电路的微处理器系统微处理系统如图1所示: NiosllRAM AVALON_MM JtagUartsysid CYCLONEII DE2_70 图1乐曲演奏电路的微处理器系统 四、实验过程 1、用HDL设计带avalonslave接口的PWM控制器 PWM自定义组件的设计,如下: 1)clk:PWM输入时钟; 2)reset:PWM复位信号; 3)chipselect:PWM使能信号; 4)address:PWM寄存器地址信号; 5)write:PWM写信号; 6)writedata:PWM写数据; 7)read:PWM读信号; 8)byteenable:字节使能信号; 9)readdata:PWM读出数据; 10)PWM_out:PWM输出信号。 程序如下: modulemypwm(clk,reset_n,chipselect,address,write,writedata,read,readdata,byteenable,pwm_out); inputclk; inputreset_n; inputchipselect; inputwrite; inputread; input[31:0]writedata; output[31:0]readdata; input[3:0]byteenable; input[1:0]address; outputpwm_out; reg[31:0]clock_divide_reg;//PWM输出一个周期中包含的时钟周期数reg[31:0]duty_cycle_reg; regcontrol_reg; regclock_divide_reg_selected; regduty_cycle_reg_selected; regcontrol_reg_selected; reg[31:0]pwm_counter;//PWM计数值 reg[31:0]readdata; regpwm_out; wirepwm_enable; //addressdecode always@(address) begin clock_divide_reg_selected=0; duty_cycle_reg_selected=0; control_reg_selected=0; case(address) 0:clock_divide_reg_selected=1; 1:duty_cycle_reg_selected=1; 2:control_reg_selected=1; default: begin clock_divide_reg_selected=0; duty_cycle_reg_selected=0; control_reg_selected=0; end endcase end //写PWM输出周期的时钟数寄存器 always@(posedgeclkornegedgereset_n) begin if(!reset_n) begin clock_divide_reg=0; end else begin if(writ
您可能关注的文档
最近下载
- 吉林省中药软片炮制规范.pptx VIP
- 名著阅读《湘行散记》七年级语文上册部编版(共9页).docx VIP
- 《白洋淀纪事》阅读测试题含答案(推荐).docx VIP
- 必考名著《白洋淀纪事》导读+知识点汇总.pdf VIP
- CQJZDE-2008 重庆市建筑工程计价定额.docx VIP
- 人教部编版七年级语文上册名著选读《湘行散记》导读.doc VIP
- 重庆市建筑工程计价定额CQJZDE-2008.doc
- 部编版七上语文名著导读《朝花夕拾》、《白洋淀纪事》、《湘行散记》知识点练习(含答案).docx VIP
- 超星尔雅学习通《大学生劳动教育》章节测试含答案.docx VIP
- 七年级上册名著《湘行散记》知识点+习题(共12页).docx VIP
文档评论(0)