EDA技术基础设计.docx
- 文档编号:3364223
- 上传时间:2022-11-22
- 格式:DOCX
- 页数:11
- 大小:58.04KB
EDA技术基础设计.docx
《EDA技术基础设计.docx》由会员分享,可在线阅读,更多相关《EDA技术基础设计.docx(11页珍藏版)》请在冰豆网上搜索。
EDA技术基础设计
EDA技术基础
音乐播放器
设计性实验
电子信息科学与技术
一、任务解析:
以前用51单片机制作了一个可演奏的电子琴,学习了EDA技术之后,感觉FPGA与单片机有许多类似的地方。
于是,启发我用FPGA做一个可随意演奏的音乐播放器。
设计低、中、高21个音,几乎能够实现一般歌曲的演奏。
要实现该功能,就必须考虑到一首歌曲的产生应该考虑的两个因素:
音符的产生频率和音的节拍(即声音持续的时间)。
只要控制输出到扬声器的激励信号频率的高低和持续的时间,就可以使扬声器发声产生优美的歌曲。
2、方案论证:
1、音调的控制:
频率的高低决定了音调的高低。
通过查阅资料,得到下面的音符名与频率的关系表:
音符名
频率/hz
音符名
频率/hz
音符名
频率/hz
低音1
262
中音1
523
高音1
1046
低音2
294
中音2
587
高音2
1175
低音3
330
中音3
659
高音3
1318
低音4
349
中音4
698
高音4
1397
低音5
392
中音5
784
高音5
1568
低音6
440
中音6
880
高音6
1760
低音7
494
中音7
988
高音7
1976
分频比预置数的计算:
分频比就是从6Mhz基准频率通过二分频得到的3Mhz频率基础上计算得到的。
对于乐曲中的休止符,只需将其分频系数设为0,将分频预置数设为16383即可。
例如:
低音3的频率为330hz,分频比为3M/330hz=3000000/330=9091,则其分频预置数为:
16383-9091=7292。
其他的音符对应的分频比和分频比预置数均按此法计算可得到。
依次计算出低、中、高3X7=21个音的预置数。
各音阶对应的预置数如下表:
音符名
预置数
音符名
预置数
音符名
预置数
低音1
4933
中音1
10647
高音1
13515
低音2
6179
中音2
11272
高音2
13830
低音3
7292
中音3
11831
高音3
14107
低音4
7787
中音4
12085
高音4
14236
低音5
8730
中音5
12556
高音5
14470
低音6
9565
中音6
12974
高音6
14678
低音7
10310
中音7
13347
高音7
14858
2、音长的控制:
音符的持续时间必须根据乐曲的速度及每个音符的节拍数来确定。
本试验中,设定最短的音符为4分音符,若将全音符的持续时间设为1s的话,则需要提供一个4Hz的时钟频率即可产生4分音符的时间,每1/4个节拍的时间为0.25s,一个完整的节拍为1s。
以上即为音乐播放器的原理框图。
控制音调通过设置计数器的预置数来实现,预置不同的数可以使计数器产生不同频率的信号,从而产生不同的音调。
控制音长则是通过控制计数器预置数的停留时间来实现的,预置数停留的时间越长,则该音符演奏的时间越长。
每个音符的演奏时间都是0.25s的整数倍,对于节拍较长的音符,例如2分音符,占了2/4个节拍,在记谱的时候将其连续记录2次即可。
3、实验步骤:
1、分频产生6Mz的基准频率:
modulediv_clk6mhz(clk24m,clk6m);
inputclk24m;
outputclk6m;
regclk6m;
regcnt;
always@(posedgeclk24m)
if(cnt<1)cnt=cnt+1;//(24m/6m=4分频,cnt<[4/2-1=1]即可)
elsebegincnt=0;clk6m=!
clk6m;end
endmodule
由于此分频电路简单,就不在这里给出仿真波形了。
2、分频产生4hz的节拍控制频率:
modulediv_clk4hz(clk24m,clk4);
inputclk24m;
outputclk4;
regclk4;
reg[21:
0]cnt;
always@(posedgeclk24m)
if(cnt<2999999)cnt=cnt+1;//(24m/4hz=6000000,cnt<[6000000/2-1=2999999])
elsebegincnt=0;clk4=!
clk4;end
endmodule
此分频电路也很简单,就不在这里给出仿真波形了。
3、乐曲产生模块:
核心模块就在这里,这里:
(1)首先罗列了低、中、高21个音的分频比预置数(还有休止符的预置数16383),通过6Mhz的基准频率,在其上升沿的时候,计数器累加,当计满到16383之后就取反speaker(speaker<=~speaker非阻塞赋值),产生对应音符的频率,这里和单片机的定时计数器溢出中断差不多。
(2)产生了21个音调之后,我们要产生流畅的歌曲,还必须根据歌曲的谱子,调用相应音符并且根据节拍控制其持续的时间,例如:
若一个音持续4个1/4节拍,则在clk_4hz的上升沿,连续调用4次它的音符就可以了。
用counter来计数,计满了(何时计满取决于歌曲长度)就将counter返回为0,这样就可以实现循环演奏了。
代码如下:
modulesong(clk_6mhz,clk_4hz,speaker);
inputclk_6mhz,clk_4hz;
outputspeaker;
reg[3:
0]high,med,low;
reg[13:
0]divider,origin;
reg[7:
0]counter;
regspeaker;
wirecarry;
assigncarry=(divider==16383);
always@(posedgeclk_6mhz)
beginif(carry)divider<=origin;
elsedivider<=divider+1;
end
always@(posedgecarry)
beginspeaker<=~speaker;end
always@(posedgeclk_4hz)
begin
case({high,med,low})
'b1:
origin<=4933;
'b0:
origin<=6179;
'b1:
origin<=7292;
'b0:
origin<=7787;
'b1:
origin<=8730;
'b0:
origin<=9565;
'b1:
origin<=10310;
'b0:
origin<=10647;
'b0:
origin<=11272;
'b0:
origin<=11831;
'b0:
origin<=12085;
'b0:
origin<=12556;
'b0:
origin<=12974;
'b0:
origin<=13347;
'b0:
origin<=13515;
'b0:
origin<=13830;
'b0:
origin<=14107;
'b0:
origin<=14236;
'b0:
origin<=14470;
'b0:
origin<=14678;
'b0:
origin<=14858;
'b0:
origin<=16383;
endcase
end
always@(posedgeclk_4hz)
begin
if(counter==113)counter<=0;
elsecounter=counter+1;
case(counter)
0:
{high,med,low}<='b1;
1:
{high,med,low}<='b1;//
2:
{high,med,low}<='b0;
3:
{high,med,low}<='b0;//
4:
{high,med,low}<='b1;
5:
{high,med,low}<='b1;//
6:
{high,med,low}<='b0;
7:
{high,med,low}<='b0;//
8:
{high,med,low}<='b0;
9:
{high,med,low}<='b0;
10:
{high,med,low}<='b0;
11:
{high,med,low}<='b0;//
12:
{high,med,low}<='b0;
13:
{high,med,low}<='b0;//
14:
{high,med,low}<='b0;
15:
{high,med,low}<='b0;//
16:
{high,med,low}<='b0;
17:
{high,med,low}<='b0;//
18:
{high,med,low}<='b0;
19:
{high,med,low}<='b0;//
20:
{high,med,low}<='b0;
21:
{high,med,low}<='b0;
22:
{high,med,low}<='b0;
23:
{high,med,low}<='b0;//
24:
{high,med,low}<='b0;
25:
{high,med,low}<='b0;//
26:
{high,med,low}<='b0;
27:
{high,med,low}<='b0;//
28:
{high,med,low}<='b0;
29:
{high,med,low}<='b0;//
30:
{high,med,low}<='b0;
31:
{high,med,low}<='b0;//
32:
{high,med,low}<='b0;
33:
{high,med,low}<='b0;//
34:
{high,med,low}<='b0;
35:
{high,med,low}<='b0;//
36:
{high,med,low}<='b0;
37:
{high,med,low}<='b0;//
38:
{high,med,low}<='b0;
39:
{high,med,low}<='b0;//
40:
{high,med,low}<='b0;
41:
{high,med,low}<='b0;//
42:
{high,med,low}<='b0;
43:
{high,med,low}<='b0;//
44:
{high,med,low}<='b0;
45:
{high,med,low}<='b0;
46:
{high,med,low}<='b0;
47:
{high,med,low}<='b0;
48:
{high,med,low}<='b0;
49:
{high,med,low}<='b0;///////祝你生日快乐,完毕。
50:
{high,med,low}<='b1;/////////梁祝,开始
51:
{high,med,low}<='b1;
52:
{high,med,low}<='b1;
53:
{high,med,low}<='b1;
54:
{high,med,low}<='b1;
55:
{high,med,low}<='b1;
56:
{high,med,low}<='b1;
57:
{high,med,low}<='b0;
58:
{high,med,low}<='b0;
59:
{high,med,low}<='b0;
60:
{high,med,low}<='b0;
61:
{high,med,low}<='b0;
62:
{high,med,low}<='b0;
63:
{high,med,low}<='b0;
64:
{high,med,low}<='b1;
65:
{high,med,low}<='b1;
66:
{high,med,low}<='b0;
67:
{high,med,low}<='b0;
68:
{high,med,low}<='b0;
69:
{high,med,low}<='b0;
70:
{high,med,low}<='b0;
71:
{high,med,low}<='b0;
72:
{high,med,low}<='b0;
73:
{high,med,low}<='b0;
74:
{high,med,low}<='b0;
75:
{high,med,low}<='b0;
76:
{high,med,low}<='b0;
77:
{high,med,low}<='b0;
78:
{high,med,low}<='b0;
79:
{high,med,low}<='b0;
80:
{high,med,low}<='b0;
81:
{high,med,low}<='b0;
82:
{high,med,low}<='b0;
83:
{high,med,low}<='b0;
84:
{high,med,low}<='b0;
85:
{high,med,low}<='b0;
86:
{high,med,low}<='b1;
87:
{high,med,low}<='b1;
88:
{high,med,low}<='b0;
89:
{high,med,low}<='b0;
90:
{high,med,low}<='b1;
91:
{high,med,low}<='b1;
92:
{high,med,low}<='b1;
93:
{high,med,low}<='b0;
94:
{high,med,low}<='b0;
95:
{high,med,low}<='b0;
96:
{high,med,low}<='b0;
97:
{high,med,low}<='b0;
98:
{high,med,low}<='b1;
99:
{high,med,low}<='b1;
100:
{high,med,low}<='b0;
101:
{high,med,low}<='b0;
102:
{high,med,low}<='b0;
103:
{high,med,low}<='b1;
104:
{high,med,low}<='b0;
105:
{high,med,low}<='b0;
106:
{high,med,low}<='b1;
107:
{high,med,low}<='b1;
108:
{high,med,low}<='b1;
109:
{high,med,low}<='b1;
110:
{high,med,low}<='b1;
111:
{high,med,low}<='b1;
112:
{high,med,low}<='b1;
113:
{high,med,low}<='b1;
endcase
end
endmodule
4、三个模块都完成之后,生成相应的电路原理图,并连接起来,组成一个完整的音乐播放器电路,如下:
5、完成以上步骤之后,分配引脚到试验箱上的芯片,连接好引脚到扬声器等,并且接好相应的短路帽。
然后烧写程序到芯片中去,测试音乐播放器是否可以产生预期已经谱好了曲子的歌曲。
经过硬件测试,能够产生《梁祝》和《祝你生日快乐》,在这里我只写了2首简单的歌曲。
4、实验分析
1、所有不同频率的信号都是从同一个基准频率分频得到。
由于音阶频率多为分整数,而分频比又不能为小数,故必须将计算得到的分频数四舍五入取整。
如果基准频率过低,则如果分频比太小,四舍五入取整后的误差较大。
若基准频率过高,虽然误差小,但分频数将会变大。
设计时,综合考虑,在尽量减小频率误差的前提下取合适的基准频率。
我在这里就选取了6Mhz的时钟频率。
2、由于最大分频预置数为16383(休止符),2的14次方=16384>16383,故只需取14bit即可,14位的二进制计数器可满足要求。
分频比都是从6Mhz频率二分频得到3Mhz频率基础上计算得到。
3、如何分频得到想要的频率?
总结了下,如果想由已知频率得到N分频的频率,计数器count<(N/2-1)为分界线,将要得到的频率在分界线处取反即可。
比如:
上面要从24Mhz得到4hz的频率,N=24000000/4=6000000,则cnt<(6000000/2-1)即cnt<2999999即可。
5、实验总结;
其实,音乐播放器用FPGA来实现是很简单的。
核心部分就是抓住了乐曲的两个要点:
音调的控制和音长的控制。
因此,涉及到两个频率,一个用来控制产生相应的音调,一个是用来控制该音调持续的时间(即节拍)。
我做的这个简易音乐播放器,硬件电路也很简单。
其实,可以做的完善和人性化一点,因为声音不只21个音,还有升半调#和降调b,可以加些按键控制,选中某一首歌曲播放。
或者还可以通过按键调整模式,可以有自己弹奏乐曲的模式,和音乐自动播放模式,两种模式进行切换。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- EDA 技术 基础 设计