欢迎来到天天文库
浏览记录
ID:6722892
大小:912.50 KB
页数:10页
时间:2018-01-23
《eda期末大作业设计》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、宁波理工学院EDA课程设计报告题目简易电子琴组员王维婷(3110403128)郑雅亿(3110403131)专业班级电子信息工程112班X一、实验目的1.学习利用数控分频器、键盘实验。2.理解PS/2键盘的基本原理。二、实验原理本实验利用键盘的数字按键部分来控制电子琴的C调,DORA,MI,FA,SO,LA,SI,分别用0,1,2,3,4,5,6,7来进行控制。们使用了键盘的介入来进行控制。组成乐曲的每个音符的发音频率值及其持续的时间是乐曲能连续演奏所需的2个基本要素,首先让我们来了解音符与频率的关系。乐曲的12平均率规定:每2
2、个八度音(如简谱中的中音1与高音1)之间的频率相差1倍。在2个八度音之间,又可分为12个半音,每2个半音的频率比为。另外,音符A(简谱中的低音6)的频率为440Hz,音符B到C之间、E到F之间为半音,其余为全音。由此可以计算出简谱中从低音1至高音1之间每个音符的频率,如图所示。简谱中音符与频率的关系如图所示,为PS/2键盘的接口引脚图。下图为PS/2键盘的通信时序图。X主系统由4个模块组成:TOP是顶层设计文件,其内部有三个功能模块:Tone.VHD、Speaker.VHD、enc16_4.VHD.、PS2VHDL.VHD、cl
3、kdiv10.VHD、clkdiv50.VHD以及PULSE12.VHD模块TONE是音阶发生器,当4位发声控制输入INDEX中某一位为高电平时,则对应某一音阶的数值将从端口TONE输出,作为获得该音阶的分频预置值;同时由CODE输出对应该音阶简谱的显示数码,如‘5’,并由HIGH输出指示音阶高8度显示。由例6-28可见,其语句结构只是类似与真值表的纯组合电路描述,其中的音阶分频预置值,如Tone<=1290是根据产生该音阶频率所对应的分频比获得的。简易电子琴电路结构模块SPEAKER中的主要电路是一个数控分频器,它由一个初值可
4、预置的加法计数器构成,当模块SPEAKER由端口TONE获得一个2进制数后,将以此值为计数器的预置数,对端口CLK12MHZ输入的频率进行分频,之后由SPKOUT向扬声器输出发声。模块NOTETABS,用于控制音乐的暂停与播放,产生节拍控制(INDEX数据存留时间)和音阶选择信号,即在NOTETABS模块放置一个乐曲曲谱真值表,由一个计数器的计数值来控制此真值表的输出,而由此计数器的计数时钟信号作为乐曲节拍控制信号,从而可以设计出一个纯硬件的乐曲自动演奏电路。试完成此项设计,并在EDA实验系统上的FPGA目标器件中实现之。5、实
5、验内容:编译适配以上4个示例文件,给出仿真波形,最后进行下载和硬件测试实验。建议使用实验电路模式“3”,用短路帽选择“CLOCK9”的输入频率选择12MHz,此信号作为系统输入信号CLK12MHZ;CLK8HZ与clock2相接,接受4Hz频率;键盘按键0-7作为输入信号控制各音阶。一、实验代码enc16_4libraryieee;useieee.std_logic_1164.all;entityenc16_4isport(I:instd_logic_vector(7downto0);--输入的待编码信号Y:outstd_log
6、ic_vector(3downto0));--编码输出endenc16_4;architectureoneofenc16_4isSIGNALL:STD_LOGIC_VECTOR(7DOWNTO0);XbeginSearch:PROCESS(I)beginCASEIISWHEN"01101100"=>Y<="1000";WHEN"01110100"=>Y<="0111";WHEN"01110011"=>Y<="0110";WHEN"01101011"=>Y<="0101";WHEN"01111010"=>Y<="0100";WHE
7、N"01110010"=>Y<="0011";WHEN"01101001"=>Y<="0010";WHEN"01110000"=>Y<="0001";WHENOTHERS=>Y<="0000";ENDCASE;endprocess;endone;ToneLIBRARYIEEE;USEIEEE.STD_LOGIC_1164.ALL;USEIEEE.STD_LOGIC_ARITH.ALL;ENTITYToneISPORT(Index:INSTD_LOGIC_VECTOR(3DOWNTO0);CODE:OUTSTD_LOGIC_VEC
8、TOR(3DOWNTO0);HIGH:OUTSTD_LOGIC;Tone:OUTSTD_LOGIC_VECTOR(10DOWNTO0));END;ARCHITECTUREoneOFToneISBEGINSearch:PROCESS(Index)BEGINCASE
此文档下载收益归作者所有