基于FPGA的音乐播放控制电路设计

发布者:浅唱清风最新更新时间:2010-11-18 来源: 现代电子技术关键字:乐曲  FPGA  控制  编码 手机看文章 扫描二维码
随时随地手机看文章

  随着电子技术发展,电子电路的形式趋向复杂化,面对这一状况,人们已经清醒地认识到,要分析和设计复杂的电子系统人工的方法已不适用。依靠传统的实验教学已远不能满足社会对高新技术人才的培养需要。本文就一个综合性的实例“音乐播放控制电路”的设计过程具体说明了FPGA在电子电路设计中所起的作用。

  1 总体方案的设计

  设计一个具有3个八度音程的电子音乐自动循环播放电路,具体曲目可以由设计者自由编辑,以简谱的二进制编码形式存放在ROM的数据文件中。

  设计要求如下:

  (1)采用5位二进制码表示音高信息,曲谱码存储器的地址由时值计数器控制,计数频率按乐曲的演奏速度选择,每个脉冲周期是所选曲谱中最短音符的时值。存储器在时值计数脉冲作用下顺序输出音高码控制分频器。

  (2)采用20 Hz~20 kHz的音频脉冲信号控制蜂鸣器,可以使其根据控制信号频率发出不同的音调。

  音乐播放控制电路设计方案原理框图如图1所示。

  

音乐播放控制电路设计方案原理框图 www.elecfans.com


 

  2 设计任务分析

  2.1 音高编码和分频控制

  计数器模值控制的方法很多,改变预置数控制模值是比较简单的一种。分频计数器的预置数与分频率和计数方式、预置方式有关。当采用减计数器、并以计数器的溢出信号(Carry Out)实现异步预置控制时,计数器的模(分频率)等于预置数。比如,当计数脉冲频率为10 MHz时,若希望产生音高“5”,并考虑占空比整形的二分频作用,分频系数(计数器的模)应该是3 188.9,四舍五入后的计数器预置数应该是3 189。其溢出信号的频率为3 135.8 Hz,控制蜂鸣器的信号频率为1 567.9 Hz,满足音高频率要求。若采用同步预置方式,则计数器的预置数应该是模减1,为3 188。由于计数器的溢出信号可能出现冒险干扰,采用同步预置的方法比较安全。

  分析表1可见,表中3个不同音程相同音名(同一行)的信号频率都相差一倍。

  

 

  即音程升、降8度时,频率增加或减小一倍。所以,若分频计数器的计数脉冲频率降低一倍时,蜂鸣器发出的音调降低8度。比如,当分频率仍为3 189,但计数脉冲频率为5 MHz时,控制蜂鸣器的信号频率为784 Hz,为中音“5”。

  因此若采用模值和输入脉冲频率都可控的计数器实现信号分频,可根据音程码选择分频计数器的输入脉冲频率fs、根据音名码控制分频计数器的模值N,如图2所示。

  

 

  这样,分频系数表只需考虑7个音高。由于计数脉冲只能分频降低,所以表中应该存储高音程7个不同音名对应的计数器预置值,其他两个音程可通过降低分频计数器的脉冲频率实现。

  3个8度音程的21个音高至少需要5位二进制码表示。为了控制方便,考虑将音名和音程分别编码:7个音名和休止符采用3位二进制码表示,控制分频器计数器的预置数实现模值N修改;3个音程用2位二进制码表示,控制分频器的计数脉冲频率fs。

  2.2 音长控制

  曲谱存储单元的数据输出时间是时值计数脉冲的一个周期,决定了该单元音符的持续时间。所以,与计数脉冲周期相同时值的音符为音长的度量单位,其音符码占1个存储单元。其他音符根据其时值长短占据不同数量的存储单元。比如,若以8分音符的时值作为存储器地址计数器的脉冲周期,则8分音符码占1个存储单元,4分音符占2个存储单元,2分音符占4个存储单元,以此类推。

  因此,可以所选曲谱的最短音符作为时值的度量单位。比如,图3所示的《梁祝》曲谱中最短的音符为8分音,若其编码存放1个存储单元,则时值计数脉冲周期为一个8分音长时间,可选O.5 s。曲谱中的四分音符码需要存放2个单元,一拍延长音也需要2个单元。该段曲谱有8个音节,每个音节是一个全音(8个8分音),演奏总时值为8×8个8分音。所以,存储曲谱编码的存储器需要64个存储单元。

  

 

  2.3 音强控制

  音的强度也称音的力度,体现了乐曲的情感元素。由于本设计实现的是简单的电子音乐播放,无法表现音强的不同。而且,参考方案还不能区别相同音高的音符连续与否。比如,两个八分音符“11”的总时值与一个四分音符“1”的时值相同,但体现的乐声是不同的。前者是两个强8分音,而后者可以认为是一个强8分音和一个弱8分音构成。为了解决这个问题,可以在连续的相同强音间加一个极短促的间断区别两者的不同,间断时间可以是几个毫秒。这样,在音符编码中应该有一位码控制。

  如果间断音码单独占1个存储单元,可设置间断音标志,控制时值计数器状态为间断信息单元地址时计数频率改变,使间断码输出的时间为间断音长;如果间断音码与强音码存放同一单元,可触发数字单稳态电路产生问断控制信号EN。

  2.4 乐曲的循环播放控制

  为了实现乐曲的循环播放,应该在乐曲结束时使曲谱表的查表地址回到初始值。可在曲谱表的最后一个单元中存放一个结束符,结束符的编码可以利用音程码的冗余码。电路采用逻辑门对音程码进行判断,当出现结束符码时控制时值计数器复位,乐曲重新开始演奏。

  2.5 曲谱编码举例

  设音符的6位二进制编码中,最高位为间断音控制,中间2位为音程码,最低3位为音名码。每个8分音存放于1个存储单元,四分音符码占2个存储单元。若音名码用其简谱数符对应的二进制码表示,而低、中、高三个音程分别用"01”,“00",“10”三组码表示,“11”为结束符码,则图3曲谱码存储表如表2所示。表中6位二进制音符码用2位八进制数表示。

  

 

  3 电路的实现

  根据设计电路原理框图,曲谱码以分频数编码,音高信号分频由一个可预置的模N计数器实现。分频系数表和曲谱表都存储在ROM中。若希望控制蜂鸣器的信号占空比为50%,分频器的输出信号采用二分频电路实现占空比整形,但注意信号频率被降低一半。电路原理框图中M分频器的作用是产生合适的时值计数脉冲频率。电路的顶层原理图如图4所示。

  

 

  4 结语

  FPGA技术已成为电子系统设计领域现代化的标志。本文将FPGA用于电子技术课程设计,取得了较好的效果。通过本设计激发了学生学习的兴趣,拓宽了学生的思路,为学生今后的毕业设计和从事电子技术方面的科研、开发工作打下了良好的基础。

关键字:乐曲  FPGA  控制  编码 引用地址:基于FPGA的音乐播放控制电路设计

上一篇:瑞萨电子推出内置2.5MB SRAM的SuperH微控制器
下一篇:基于CAN总线智能窗户系统的设计实现

推荐阅读最新更新时间:2024-03-16 12:30

汽车电子中的自动编码及测试自动化技术
汽车制造商们一直致力于将工业自动化不断推向新的高度。现在,他们在设计进程自动化领域更花功夫。随着软件复杂性的增强,他们将致力于在不牺牲稳定性的前提下,将研发重心向自动代码生成(ACG)和缩短量产时间转移。 在现在这个时代,最复杂的汽车可能拥有超过100个微处理器、超过1亿的编码行数(LOC)。而且目前我们还没看到任何迹象表明:这种不断增长的软件发展势头未来会受到遏制。令人惊讶地是,甚至许多资金短缺的公司,也在试图用机器而不是人类来解决这项技术挑战。其实自动代码生成很久以前就应用于这个行业了,现在看来,它正处于迫切需要突破的临界点。自动代码生成工具,有利于使设计原形进入量产。它们创造了易于维护的编码,也有助于工程师创建复合系统,快速
[嵌入式]
特斯拉申请新型集成座椅温度控制系统专利
据外媒报道,特斯拉(Tesla)为其车辆座椅申请了一项新的集成温度控制系统专利。 图片来源:特斯拉 在专利申请中,特斯拉列出了当前座椅温度控制不足的几个方面。对于乘员而言,通过座椅泡沫提供空气通风通常无法扩散多余热量以提供舒适环境。此外,传统的加热系统体积庞大,会占用座椅(较厚)空间。不仅如此,由于热量通常必须穿过多层并会加热乘客不接触的座椅区域,所以传统加热系统对于座椅的加热效率较低。因此需要改进汽车座椅的温度控制系统。 特斯拉的解决方案是创建一个温度控制系统,将流体泵入整个汽车座椅。该温度控制系统包括一个基层和一个与基层相邻设置的中间层。中间层允许流体通过。该温度控制系统还包括与中间层相邻配置的覆盖层。此外,该系
[汽车电子]
特斯拉申请新型集成座椅温度<font color='red'>控制</font>系统专利
简单人工智能的温度控制电路设计
  介绍一种具有简单人工智能的温度控制电路,使用该电路进行温度控制时,只需将开关打在2的位置,通过设定控制温度,并通过3位半数显表头所显示的温度值,即可精确地控制温度,使得温控操作变得十分方便。LM35是一种内部电路已校准的集成温度传感器,其输出电压与摄氏温度成正比,线性度好,灵敏度高,精度适中.其输出灵敏度为10.0MV/℃,精度达 0.5℃.其测量范围为-55—150℃。在静止温度中自热效应低.工作电压较宽,可在4——20V的供电电压范围内正常工作,且耗电极省,工作电流一般小于60uA.输出阻抗低,在1MA负载时为0.1Ω。根据LM35的输出特性可知,当温度在0—150℃之间变换时,其输出端对应的电压为0—150V,此电压经电
[电源管理]
简单人工智能的温度<font color='red'>控制</font>电路设计
6通道增量式编码器在智控型纺织机的应用
智控型纺织机的纺织机构的平衡对提高部件工作的可靠性,降低振动,特别是降低纺织生产中的噪音具有重要意义。在纺织机中除了应用与一般机械制造业上应用的零件外,还广泛应用着一系列具有不平衡质量的特殊部件和机构,这些带不平衡质量的工件在大多数情况下乃是纺织机中的主要机构,而且仅是纺织机上固有的。电机就是一个智控型纺织机的固有部件,对电机轴的监控是重要的技术,深圳世强代理的Rep-Avago的48mm的6通道增量式编码器可以满足纺织行业的应用。 6通道增量式编码器是以高精度计量光栅作为检测元件,通过光电转换技术,将输入的角度位置信息转换成相应的脉冲或数字代码的检测装置。 增量式编码器由LED光源、光栅副、光电接收器、主轴、电子处理电路等
[嵌入式]
ESP8266+51单片机WIFI控制多路遥控开关程序设计
这是一个基于单片机WIFI多路遥控开关设计,里面有文档,程序,图片等资料 制作出来的实物图如下: 电路原理图如下: Wifi开关元件清单 1) 9*15万用板 2) STC89C52单片机 3) 40脚IC座 4) 11.0592MHz晶振 5) 30pF瓷片电容*2 6) 10uF电解电容 7) ESP8266模块 8) 2*4P排母 9) 2P排母*2 10) 3.3V稳压模块 11) 2P接线端子*3 12) 继电器*3 13) 3MM LED灯*3(红、绿、蓝) 14) 8550三极管*3 15) 按键 16) 1k电阻*6 17) 10k电阻 18) 自锁开关 19) DC电
[单片机]
ESP8266+51单片机WIFI<font color='red'>控制</font>多路遥控开关程序设计
基于单片机中风机温度控制系统的设计
   0.引言    风机为通用机械,它广泛地使用在国民经济的各个部门中。风机广泛用在工厂、矿井、车辆、建筑物、家用电器等的通风、排尘和冷却;谷物的烘干和选送;风洞风源和气垫船的充气和推进等。另外,在一些对环境温度有特殊要求的场所,要求温度变化在1℃以下,这就需要一种可以根据外界环境温度来确定风机的转动与停止的风机温控系统。    本文设计的风机微小温控系统,可使温度检测精度达到0.01℃,并可手动设定温度上下限,且具有自动声光报警功能。    1.设计要求    本系统采用PT1000温度传感器 检测环境温度(温度检测精度0.01℃),根据环境温度变化控制风机降温,并具备按键手动设定温度上下限、声光报警等功能
[单片机]
基于单片机中风机温度<font color='red'>控制</font>系统的设计
理想L7魔毯空气悬挂2.0,配自研XCU中央域控制
理想L7 ( 参数 | 询价 ) 是理想汽车集团推出的一款重磅车型,它在运动化方面进行了进一步加强,其中最引人注目的亮点就是魔毯空气悬挂2.0。这项技术的优势在于它采用了全自研的XCU中央域控制器和创智能的控制算法,配合OTA可成长性,为驾乘者带来了更出色的悬挂性能。 魔毯空气悬挂2.0采用了4个车身高度传感器、前轴两个加速度传感器以及一个六轴陀螺仪传感器,能够实时监控路况和车辆动态,以毫秒级的阻尼调节来提升舒适性和稳定性。这项技术的另一个亮点在于它摆脱了技术封锁,用户可以根据自己的使用需求和路况环境自行设定标准和优化算法,只需通过OTA升级就能享受到完全不同的驾驶体验。 魔毯空气悬挂2.0的特点之一是定制的空气弹簧更薄,
[汽车电子]
理想L7魔毯空气悬挂2.0,配自研XCU中央域<font color='red'>控制</font>器
LMS自适应滤波器在激波报靶系统中的应用
0 前言 由空气动力学原理,当超音速运动的物体,由于运动速度大于局部声速时会产生激波,弹道声波是超声速弹丸飞行时冲击空气分子所形成的激波( Shock waves)。采用激波原理进行报靶是一项具有挑战性的技术,它利用激波信号进行超音速飞行体探测,是一种新的目标探测方法。本文研究对象为移动靶车,该遥控自动装置自带电源和动力装置,能在 25Km/h内无级调速,但是,由于其工作环境比较恶劣,自身振动、风吹、发电机和电动机的巨大干扰,严重影响了自动报靶系统的报靶精度。为了适应现代化*训练的需要,本文采用 FPGA和自适应滤波技术,利用硬件电路来实现 LMS自适应滤波器,完成对强背景噪声环境下激波信号的滤波,在满足实时数据处理前提下
[工业控制]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • 学习ARM开发(16)
    ARM有很多东西要学习,那么中断,就肯定是需要学习的东西。自从CPU引入中断以来,才真正地进入多任务系统工作,并且大大提高了工作效率。采 ...
  • 学习ARM开发(17)
    因为嵌入式系统里全部要使用中断的,那么我的S3C44B0怎么样中断流程呢?那我就需要了解整个流程了。要深入了解,最好的方法,就是去写程序 ...
  • 学习ARM开发(18)
    上一次已经了解ARM的中断处理过程,并且可以设置中断函数,那么它这样就可以工作了吗?答案是否定的。因为S3C44B0还有好几个寄存器是控制中 ...
  • 嵌入式系统调试仿真工具
    嵌入式硬件系统设计出来后就要进行调试,不管是硬件调试还是软件调试或者程序固化,都需要用到调试仿真工具。 随着处理器新品种、新 ...
  • 最近困扰在心中的一个小疑问终于解惑了~~
    最近在驱动方面一直在概念上不能很好的理解 有时候结合别人写的一点usb的例子能有点感觉,但是因为arm体系里面没有像单片机那样直接讲解引脚 ...
  • 学习ARM开发(1)
  • 学习ARM开发(2)
  • 学习ARM开发(4)
  • 学习ARM开发(6)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved