- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
(数字逻辑课程设计之电子琴
数字逻辑课程设计之电子琴实验内容:设计一个八音电子琴,能通过八个键进行手动控制音响,也可以通过自动控制有效自动播放一段音乐。实验设计:本实验分为四个模块:一个模块是主程序,一个模块是自动播放音乐部分,一个模块是音调发生器部分,一个模块是数控分频部分。通过接口和结构体component的定义将各个模块连接起来。本程序总的有11个输入,1个输出,2个输入为时钟脉冲,1个输入是控制电子琴自动演奏或者手动演奏的使能端,8个输入端为电子琴的八个键,1个输出为扬声器输出音乐。在音调发生器部分中,需要按照模=50000/频率的方法进行分频,但是要达到提高音量使占空比为50%的效果还需要再对信号进行二分频,因此最后得到的音调发生器进行分频预置值如下:音符 (C)1234567i频率(Hz)262294330349392440494523模9585757163565047当某位音符电平输入有效时,对应不同的分频预置值,将分频预置值输出并作为数控分频部分的输入,分频预置值控制对主频的分频。在数控分频部分,将输入的分频预置值和时钟脉冲作为输入,最后输出直接连接扬声器。这一部分一共包含了两个进程,第一个进程是根据不同音符的不同频率进行在主频下进行分频,得到音符的相应频率,第二个进程是为了提高音量使占空比为50%而进行二分频。在自动播放部分,1个时钟脉冲输入,1个自动播放的使能端输入,还有8个音符的键为输入,输出为音符对应的8位高低电平,输出连接到音调发生器的8位输入,如果自动播放的使能端(auto)无效则进行手动操作,在手动操作下,该模块的输出直接为输入。如果自动播放的使能端输入有效,则播放事先存储的一段音乐,首先将主频50KHZ进行10000分频,因此一个脉冲为0.2秒,每来一个脉冲进行计数并播放一个音符。直到设置的音符全部播放完毕,计数器回0。源代码:主模块部分:定义了结构体和各模块函数library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity piano is port(clk0,clk1:in std_logic; auto:in std_logic; inplay:in std_logic_vector(7 downto 0); play:out std_logic); end piano;architecture run of piano is component autoplay is --自动播放部分 port(A:in std_logic_vector(7 downto 0); B,C:in std_logic; D:out std_logic_vector(7 downto 0)); end component; component tone is --音调发生器部分 port(A:in std_logic_vector(7 downto 0); B:out integer range 0 to 170); end component; component control is --数控分频部分 port(A:in std_logic; B:in integer range 0 to 170; C:out std_logic); end component; signal sw0:std_logic_vector(7 downto 0);--自动播放部分的输出和音调发生器的输入,表示八个音符 signal tone0:integer range 0 to 170; --音调发生器的输出和数控分频部分的输入,表示音符的频率begin ――在这个进程中把各个部分连接起来 G1:autoplay port map(A=inplay,B=auto,C=clk0,D=sw0); G2:tone port map(A=sw0,B=tone0); G3:control port map(A=clk1,B=tone0,C=play);end run;自动播放模块:library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ieee.std_logic_unsigned.all;entity autoplay is port(A:in std_logic_vector(7 downto 0); --A=inplay,B=auto,C=clk0,D=sw0 B,C:in std_logic; D:out std_logic_vector(7 downto 0));end autoplay;architect
您可能关注的文档
- (餐饮各种宴席的服务标准.doc
- (数值分析历年考题.doc
- (农村中小学现代远程教育概述2.ppt
- (餐饮品牌如何打造.doc
- (数值分析原理课件第一章.doc
- (餐饮垃圾.doc
- (3D裸眼显示的光学设计3.doc
- (数值分析在材料研究中的应用.doc
- (小学二年级上册语文试卷1.doc
- (餐饮培训计划.docx
- 2025年吉林省中考地理试卷(含解析).pdf
- 2025年陕西省中考道德与法治试卷(含解析).docx
- 第四单元比应用专项5篇-2025年五升六年级数学暑假衔接应用专项(解析版)人教版.docx
- 07【小升初专项训练】 繁分数.docx
- 第四单元小数的意义和性质应用专项14篇-2025年四升五年级数学暑假衔接应用专项(原卷版)人教版.docx
- 第四单元小数的意义和性质应用专项14篇-2025年四升五年级数学暑假衔接应用专项(解析版)人教版.docx
- 不做“扫兴式父母”,构建良好亲子关系.docx
- 控制迷局:父母过度干预对青少年心理发展的深层影响.docx
- 零散建筑工程施工方案(3篇).docx
- 青蓝工程公开课实施方案(3篇).docx
文档评论(0)