版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、简易电子琴的设计孙凡 (大连理工大学 信息工程学院)摘 要 本课程设计主要采用eda技术设计了一个简易的八音符电子琴,它可通过按键输入来控制音响从而演奏出已存入的乐曲。在课程设计中,系统开发平台为windows xp,程序设计采用vhdl语言1,程序运行平台为quartus6.0。然后编写程序实现电子琴的各项功能,使不同的音阶对应不同频率的正弦波,按下不同的键时发出对应频率的声音。程序通过调试运行,时序仿真,电路功能验证,顺利地实现了设计目标。关键词 电子琴;eda;vhdl;音阶;频率design of a simple electronic organsun yang (college o
2、f information engineering ,dalian university)abstract the main use of this curriculum design eda technology to design a simple eight-note organ, it can be key to control the audio input so as to have been deposited in a concert of music. in the course design, system development platform for windows
3、xp, the procedures vhdl design language1, platform for running quartus6.0. and then program to achieve the various functions of the organ, so that different scale corresponds to a different frequency sine wave, press different keys when the voice of the corresponding frequency. running through the d
4、ebugging process, timing simulation, functional verification circuit, successfully achieved the goal of the design.key words electronic organ; eda; vhdl; scale; frequency1. 引 言 随着信息科学的进步,现代电子产品的性能越来越高,复杂度越来越大,更新步伐也越来越快,电子技术的发展进入了划时代的阶段。其中电子技术的核心便是电子设计自动化eda2(electronic design automatic)技术。eda是指以计算机为
5、工作平台,融合了应用电子技术、计算机技术、智能化技术的最新成果而开发出的电子cad通用软件包,它根据硬件描述语言vhdl完成的设计文件,自动完成逻辑编译、化简、分割、综合、优化、布局布线及仿真,直至完成对于特定目标芯片的适配编译、逻辑映射和编程下载等工作。本课程设计就是采用eda技术描述语言vhdl编程实现简易电子琴的各项功能,是eda技术应用于实际的一个很好的例子。1.1 课程设计目的运用vhdl语言对简易电子琴的各个模块进行设计,并使用eda工具对各模块进行仿真验证。本设计包含如下三个模块:乐曲自动演奏模块,音调发生模块,数控分频模块,最后把各个模块整合后,通过电路的输入输出对应关系连接起
6、来。1.2 课程设计内容(1)设计一个简易的八音符电子琴,它可通过按键输入来控制音响。(2)演奏时可以选择是手演奏(键盘输入)或自动演奏已存入的乐曲,并且能自动重复演奏。1.3 课程设计原理 本课程设计目的在于灵活运用eda技术编程实现一个简易电子琴的乐曲演奏,它要求在实验箱上构造一个电子琴电路,不同的音阶对应不同频率的正弦波。按下每个代表不同音阶的按键时,能够发出对应频率的声音。由于设计分模块组成,每个单独的模块都是一个完整的源程序,分别实现不同性质的功能,但是每个模块又是紧密关联的,前一个模块的输出很可能是后一模块的输入。另外,时钟脉冲信号在本课程设计中用的最多,用处也最大,一般情况下时钟
7、信号处上升沿有效,判断和控制各个计数器计数多少。2. eda、vhdl简介 eda技术是以计算机为工作平台,融合了应用电子技术、计算机技术、信息处理及智能化技术的最新成果,进行电子产品的自动设计。eda可提供文本输入以及图形编辑的方法将设计者的意图用程序或者图形方式表达出来,而我们经常用到的vhdl语言便是用于编写源程序所需的最常见的硬件描述语言(hdl)之一。2.1 eda技术 eda是电子设计自动化(electronic design automation)缩写,是90年代初从cad、cam、cat和cae的概念发展而来的。eda技术是电子设计的发展趋势,利用eda工具可以代替设计者完成电
8、子系统设计中的大部分工作。eda工具从数字系统设计的单一领域,发展到今天,应用范围已涉及模拟、微波等多个领域,可以实现各个领域电子系统设计的测试、设计方针和布局布线等。现在对eda的概念或范畴用得很宽,包括在机械、电子、通信、航空航天、化工、矿产、生物、医学、军事等各个领域,都有eda的应用。目前eda主要辅助进行三个方面的设计工作:ic设计、电子电路设计和pcb设计。2.2 vhdl语言常用硬件描述语言有vhdl、verilog和abel语言,而vhdl主要用于描述数字系统的结构、行为、功能和接口。除了含有许多具有硬件特征的语句外,vhdl的结构特点是将设计实体的内部功能和算法完成部分。相对
9、于其他硬件语言,vhdl有许多优点。比如vhdl的行为描述能力更强,而且具有丰富的仿真语句和库函数,随时可对系统进行仿真模拟,使设计者对整个工程的结构和功能可行性做出判断;另外,由于具有类属描述语句和子程序调用等功能,对于完成的设计,在不改变源程序的条件下,只需改变类属参量和函数,就能轻易地改变设计的规模和结构。3. 简易电子琴的设计过程根据系统设计要求,系统该系统基于计算机中时钟分频器3的原理,设计采用自顶向下的设计方法,通过按键输入来控制音响或者自动演奏已存入的歌曲。它由乐曲自动演奏模块、音调发生模块和数控分频模块三部分组成。根据实验实际情况,这里只详细介绍数控分频模块。3.1 乐曲自动演
10、奏模块乐曲自动演奏模块的作用是产生8位发生控制输入信号。当进行自动演奏时,由存储在此模块的8位二进制数作为发声控制输入,从而自动演奏乐曲。该模块的vhdl源程序主要由3个工作进程组成,分别为pulse0,music和com1。该模块最主要的用途就是将输入二进制数转化为发声控制输入,是产生音符的重要步骤。3.2 音调发生模块音调发生模块的作用是产生音阶的分频预置值。当8位发声控制输入信号中的某一位为高电平时,则对应某一音阶的数值将输出,该数值即为该音阶的分频预置值,分频预置值控制数控分频模块进行分频,由此得到每个音阶对应的频率。该模块最主要的作用就是给音符输入预设频率值,因为,电子琴最终实现乐曲
11、演奏就是输出不同频率的正弦波,此模块就是将二进制发声信号转化为对应的频率。3.3 数控分频模块数控分频模块是对时基脉冲进行分频,得到与0、1、2、3、4、5、6、7八个音符相对应的频率。该模块主要由4个工作进程组成。首先,根据系统时钟信号的输入得到时基脉冲以及计数器的值,而时钟信号在auto模块中便已给出,两者之间的设置关系类似于auto模块中第一个工作进程的设置。第二个process是此模块的核心,即由时基脉冲值转化为音符的频率。源程序如下:library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_arith.all;use ie
12、ee.std_logic_unsigned.all;entity yinjie is port( clk : in std_logic; jian : in std_logic_vector(7 downto 0); speak_out : out std_logic - d : out std_logic_vector(7 downto 0);end yinjie;architecture jly of yinjie issignal count : std_logic_vector(7 downto 0);signal d : std_logic_vector(7 downto 0);be
13、gin process(jian) begin case jian is when 10000000=dddddddd=11111111; end case; -音节 end process; process( clk,d ) begin if clkevent and clk=1 then if count=d then count=00000000; else count=count+1; end if; - if count = 00111111 then speak_out=1; else speak_outother files-vector waveform file. (2)点击
14、空白处,点开insert-insert node,再点击-node finder-list,把元器件添加进去,得到其仿真波形图。本课程设计的仿真平台是quartus6.0,通过对vhdl源程序进行编译检错,然后创建波形文件,加入输入输出变量,选择适用的芯片(ep1c3t114c8)5以及设定仿真结束时间,设置好输入初值进行仿真,得到仿真波形图。 数控分频模块的仿真如图4-1所示。图4-1 数控分频模块的仿真图该图输入系统时钟信号clk1初值为0(各输出值都是在时钟信号的下降沿有效),音符分频系数tone1为00100000即1290hz,驱动扬声器的音频信号spks输出为1。4.2 电路功能验
15、证如果说前面的过程都是理论上进行软件设计制作,那么电路验证则是硬件产生实际结果的必要步骤,它是软件编程导入硬件系统得到最终设计目标的一个过程。硬件和软件系统相连接的枢纽就是芯片引脚和vhdl主程序中所有输入输出之间对应的关系。在选择好芯片以及设置引脚值后,下载源程序到此芯片上,确认编程器硬件是否已安装好。数控分频模块的引脚图如图4-2所示。图4-2 数控分频模块的引脚图4.3 问题分析在此次设计中,较成功的完成了简易的八音符电子琴设计,它可以通过按键输入来控制音响,系统演奏时可以选择是手动演奏(由键盘输入)还是自动演奏已存入的乐曲,且可重复演奏。通过仿真,验证结果正确。通过使用quartus6
16、.0和vhdl进行了简单的电子琴设计,成功完成预期效果,加深了我对课堂上所学理论知识的理解,给我提供了一个在学习生活中很难得的理论联系实际的机会,让我深刻体会到在设计遇到不同问题时,首先应该理解问题的关键所在,因为用语言编写程序需要以仔细认真的态度,一点点错误漏洞都将导致整个源程序无法编译运行,阻碍下一步工作的完成进度。5. 结束语通过这次vhdl课程设计,不仅增强了我们的实践动手能力,也让我们对课堂上所学到的理论知识的理解加深了许多,这给我们提供了一个在学习生活中很难得的理论联系实际的机会。能够借此机会了解到部分eda技术的知识和学习运用其中一种硬件描述语言vhdl编程实现各种常用器件的功能,这是在书本中得不到的一笔巨大财富。另一方面我们也发现了在平时学习过程中难于发现的许多缺点跟不足。比如实践机会过少,所学的理论知识不能灵活运用,在遇到实际的问题时无法正确处理;再者在课堂上获得的专业知识过于浅显,很多的有关基本操作原理、操作方法都理解不了;课外知识了解的也过少,导致在课程设计初期,面对完全陌生的设计课题无从下手,不知所措。这就提醒我们在平时的学习生活中不能一味埋头于面前的课本知识。当然
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 品管圈引流管护理缺陷
- 中国黄酒课程设计
- 幼儿园新生家长见面会方案计划
- 人教版初中数学总复习第三章函数及其图象第11课时反比例函数课件
- 新媒体对传统阅读习惯的影响计划
- 情绪管理在幼儿园教育中的应用计划
- 建筑防水工程招标合同三篇
- 医药采购合同三篇
- 质量保证承诺书范文锦集5篇
- 辅导员新学期工作计划13篇
- DB63-T 241-2021草地毒害草综合治理技术规范
- 中国传统文化十二生肖介绍PPT课件(带内容)
- DB22T 5016-2019 市政工程资料管理标准
- 山西省建筑工程工程施工资料管理规程
- 板蓝根颗粒工艺规程
- 医疗质量安全管理核心制度知识考核试题与答案
- 溶酶体介绍课件
- 铁路线路工胀轨跑道处理作业指导书
- 四年级上册数学期中试卷讲评教案
- 能源化学能量转换与储存
- 水上娱乐项目外包服务方案
评论
0/150
提交评论