25M时钟的梁祝演奏

module liangzhu(clk_50M,rst,speaker);
input clk_50M,rst;
output speaker;
reg speaker;

//分频计数器
parameter wide=15;
reg[7:0] cnt; //音名数
reg[3:0] cnt1; //5MHz基频
reg[23:0] cnt2;//节拍频率5Hz
reg[wide-1:0] origin;//预置数寄存器
reg[wide-1:0] drive;
reg[1:0] count;
reg carrier;
//分频产生5MHz和5Hz的频率
always @(posedge clk_50M,negedge rst)
begin
if(!rst)
begin
cnt1<=4‘d0;
cnt2<=24‘d0;
end
else
begin
cnt1<=cnt1+1‘b1;
cnt2<=cnt2+1‘b1;
if(cnt1==4‘d4)
cnt1<=4‘d0;
if(cnt2==4999999)
cnt2<=24‘d0;
end
end
always @(posedge clk_50M,negedge rst)
begin
if(!rst)
drive<=15‘h0;
else if(cnt1==4‘d4)
begin
if(drive==15‘h3fff)
begin
drive<=origin;
carrier<=1‘b1;
end
else begin drive<=drive+1‘b1;carrier<=1‘b0; end
end
end

//carrier的频率是每个音阶的频率  音乐里面的节拍

always @(posedge carrier)
begin
count<=count+1‘b1;
if(count==4‘d0)
speaker<=1‘b1;
else speaker<=1‘b0;

end
always @(posedge clk_50M,negedge rst)
begin
if(!rst)
begin
origin<=15‘h0;
cnt<=8‘d0;
end
else if(cnt2==24‘h98967F/2)
begin
if(cnt==8‘d139)
cnt<=8‘d0;
else
cnt<=cnt+1‘b1;

case (cnt)
8‘d0:origin<=15‘h625F/2; //中音3,4个节拍
8‘d1:origin<=15‘h625F/2;
8‘d2:origin<=15‘h625F/2;
8‘d3:origin<=15‘h625F/2;
8‘d4:origin<=15‘h6715/2; //中音5,3个节拍
8‘d5:origin<=15‘h6715/2;
8‘d6:origin<=15‘h6715/2;
8‘d7:origin<=15‘h69cd/2;//中音6
8‘d8:origin<=15‘h6d55/2; //高音1,3个节拍
8‘d9:origin<=15‘h6d55/2;
8‘d10:origin<=15‘h6d55/2;

8‘d11:origin<=15‘h6f5f/2; //高音2
8‘d12:origin<=15‘h69cd/2; //中音6
8‘d13:origin<=15‘h6d55/2; //高音1
8‘d14:origin<=15‘h6715/2; //中音5
8‘d15:origin<=15‘h6715/2;
8‘d16:origin<=15‘h738a/2; //高音5
8‘d17:origin<=15‘h738a/2;
8‘d18:origin<=15‘h738a/2;
8‘d19:origin<=15‘h76aa/2; //倍高音1
8‘d20:origin<=15‘h69cd/2; //高音6

8‘d21:origin<=15‘h6715/2;//高音5
8‘d22:origin<=15‘h712f/2;//高音3
8‘d23:origin<=15‘h6715/2;//高音5
8‘d24:origin<=15‘h6f5f/2; //高音2
8‘d25:origin<=15‘h6f5f/2;
8‘d26:origin<=15‘h6f5f/2;
8‘d27:origin<=15‘h6f5f/2;
8‘d28:origin<=15‘h6f5f/2;
8‘d29:origin<=15‘h6f5f/2;
8‘d30:origin<=15‘h6f5f/2;
8‘d31:origin<=15‘h6f5f/2;
8‘d32:origin<=15‘h6f5f/2;
8‘d33:origin<=15‘h6f5f/2;
8‘d34:origin<=15‘h6f5f/2;
8‘d35:origin<=15‘h712f/2;//高音3
8‘d36:origin<=15‘h6c39/2; //中音7
8‘d37:origin<=15‘h6c39/2;
8‘d38:origin<=15‘h69cd/2;//中音6
8‘d39:origin<=15‘h69cd/2;
8‘d40:origin<=15‘h6715/2; //中音5
8‘d41:origin<=15‘h6715/2;
8‘d42:origin<=15‘h6715/2;
8‘d43:origin<=15‘h69cd/2;//中音6
8‘d44:origin<=15‘h6d55/2;//高音1

8‘d45:origin<=15‘h6d55;
8‘d46:origin<=15‘h6f5f/2;//高音2
8‘d47:origin<=15‘h6f5f/2;
8‘d48:origin<=15‘h625f/2;//中音3
8‘d49:origin<=15‘h625f/2;
8‘d50:origin<=15‘h6d55/2; //高音1
8‘d51:origin<=15‘h6d55/2;

8‘d52:origin<=15‘h69cd/2;//中音6
8‘d53:origin<=15‘h6715/2;//中音5
8‘d54:origin<=15‘h69cd/2; //中音6
8‘d55:origin<=15‘h6d55/2;//高音1
8‘d56:origin<=15‘h6715/2;//中音5
8‘d57:origin<=15‘h6715/2;
8‘d58:origin<=15‘h6715/2;
8‘d59:origin<=15‘h6715/2;
8‘d60:origin<=15‘h6715/2;
8‘d61:origin<=15‘h6715/2;
8‘d62:origin<=15‘h6715/2;
8‘d63:origin<=15‘h6715/2;
8‘d64:origin<=15‘h712f/2;//高音3
8‘d65:origin<=15‘h712f/2;
8‘d66:origin<=15‘h712f/2;
8‘d67:origin<=15‘h738a/2;//高音5
8‘d68:origin<=15‘h6c39/2;//中音7
8‘d69:origin<=15‘h6c39/2;
8‘d70:origin<=15‘h6f5f/2;//高音2
8‘d71:origin<=15‘h6f5f/2;

8‘d72:origin<=15‘h69cd/2; //中音6
8‘d73:origin<=15‘h6d55/2;//高音1
8‘d74:origin<=15‘h6715/2;//中音5
8‘d75:origin<=15‘h6715/2;
8‘d76:origin<=15‘h6715/2;
8‘d77:origin<=15‘h6715/2;
8‘d78:origin<=15‘h6715/2;

8‘d79:origin<=15‘h6715;
8‘d80:origin<=15‘h625f/2; //中音3

8‘d81:origin<=15‘h6715/2;//中音5
8‘d82:origin<=15‘h625f/2;//中音3
8‘d83:origin<=15‘h625f/2;
8‘d84:origin<=15‘h6715/2;//中音5
8‘d85:origin<=15‘h69cd/2;//中音6
8‘d86:origin<=15‘h6c39/2;//中音7
8‘d87:origin<=15‘h6f5f/2;//高音2
8‘d88:origin<=15‘h69cd/2;//中音6
8‘d89:origin<=15‘h69cd/2;
8‘d90:origin<=15‘h69cd/2;
8‘d91:origin<=15‘h69cd/2;
8‘d92:origin<=15‘h69cd/2;
8‘d93:origin<=15‘h69cd/2;
8‘d94:origin<=15‘h6715/2;//中音5
8‘d95:origin<=15‘h69cd/2;//中音6
8‘d96:origin<=15‘h6d55/2;//高音1
8‘d97:origin<=15‘h6d55/2;
8‘d98:origin<=15‘h6d55/2;
8‘d99:origin<=15‘h6f5f/2;////高音2
8‘d100:origin<=15‘h738a/2; //高音5
8‘d101:origin<=15‘h738a/2;
8‘d102:origin<=15‘h738a/2;
8‘d103:origin<=15‘h712f/2;//高音3
8‘d104:origin<=15‘h6f5f/2;//高音2
8‘d105:origin<=15‘h6f5f/2;
8‘d106:origin<=15‘h712f/2;//高音3
8‘d107:origin<=15‘h6f5f/2;//高音2
8‘d108:origin<=15‘h6d55/2;//高音1
8‘d109:origin<=15‘h6d55/2;
8‘d110:origin<=15‘h69cd/2;//中音6

8‘d111:origin<=15‘h6715/2;//中音5
8‘d112:origin<=15‘h625f/2;//中音3

8‘d113:origin<=15‘h625f;
8‘d114:origin<=15‘h625f/2;
8‘d115:origin<=15‘h625f/2;
8‘d116:origin<=15‘h6d55/2;//高音1
8‘d117:origin<=15‘h6d55/2;
8‘d118:origin<=15‘h69cd/2;//中音6
8‘d119:origin<=15‘h6d55/2;//高音1
8‘d120:origin<=15‘h69cd/2;//中音6

8‘d121:origin<=15‘h625f/2;//中音3
8‘d122:origin<=15‘h625f/2;
8‘d123:origin<=15‘h6f5f/2;//高音2
8‘d124:origin<=15‘h625f/2;//中音3
8‘d125:origin<=15‘h6715/2;//中音5
8‘d126:origin<=15‘h69cd/2;//中音6
8‘d127:origin<=15‘h6d55/2;//高音1
8‘d128:origin<=15‘h6715/2;//中音5
8‘d129:origin<=15‘h6715/2;
8‘d130:origin<=15‘h6715/2;
8‘d131:origin<=15‘h6715/2;
8‘d132:origin<=15‘h6715/2;
8‘d133:origin<=15‘h6715/2;
8‘d134:origin<=15‘h6715/2;
8‘d135:origin<=15‘h6715/2;
8‘d136:origin<=15‘h3fff/2;
8‘d137:origin<=15‘h3fff/2;
8‘d138:origin<=15‘h3fff/2;
8‘d139:origin<=15‘h3fff/2;
default:origin<=15‘h3fff/2;
endcase
end
end
endmodule

时间: 2024-12-21 13:33:54

25M时钟的梁祝演奏的相关文章

关于VGA显示实验的问题

今天做了一个关于VGA的显示实验,但是由于产生的25M时钟不正确所以一直没有图像产生.刚开始的程序如下 虽然仿真的时候出现了时序,但是在下载到硬件的时候不正确. 后来改成 结果就正确了. 另外之前关于分频时用边沿触发和用电平触发的结果是不一样的. 下面是VGA实验使用到了ADV7123在DE115平台进行的实验.640*480*25M水平同步信号和场同步信号可以 根据VGA的时序图进行计算. 顶层文件://THIS IS ABOUT VGA TEST 实验结果整个屏幕是红色 module VGA

基于FPGA的飞机的小游戏

基于FPGA的飞机的小游戏 实验原理 ????该实验主要分为4个模块,采用至上而下的设计方法进行设计.由50M的晶振电路提供时钟源,VGA显示控制模块.图形显示控制模块.移动模块的时钟为25M,由时钟分频电路产生获得.时钟分频模块采用PLL进行设计,由50M时钟进行2分频获得25M时钟. ????移动模块,控制我方飞机和敌方飞机.子弹的移动,移动的速度可以通过时钟的频率进行控制,操作我方飞机的移动和子弹的发射由外部按键进行控制,控制的方式有发射子弹.左移.右移. ????图像显示控制模块,用于控

S5PV210开发系列五_sd卡驱动实现

S5PV210开发系列五 sd卡驱动实现 象棋小子    1048272975 SD卡(Secure Digital Memory Card)具有体积小.容量大.数据传输快.可插拔.安全性好等优点,被广泛应用于便携式设备上.例如作为数码相机的存储卡,作为手机.平板多媒体扩展卡用的TF卡(micro sd).笔者此处就S5PV210的 sd卡驱动实现作一个简单的介绍. 1. sd卡概述 sd卡技术是在MMC卡的基础上发展起来的,其尺寸与MMC卡一样,只是比MMC卡厚了0.7mm,因此sd设备可以识

FPGA学习之蜂鸣器演奏乐曲

参考链接:http://www.cnblogs.com/kongtiao/archive/2011/07/20/2111581.html 一.实验目的:学习驱动FPGA之IO引脚来控制蜂鸣器演奏音乐.二.实验环境:FPGA开发板AX301,Quartus ii三.实验介绍: 我们都知道,乐曲由音调和音长组成,只要将音调和音长控制好就能演奏出动听的乐曲.下面将用Verilog HDL 硬件描述语言完成乐曲演奏的设计. 1.音调的控制 频率的高低决定了音调的高低.图1.1是音调和音律之间的关系. 图

v3学院带你学习《驱动蜂鸣器演奏歌曲》

此文章为原创出自 V3学院 www.v3edu.org,FPGA培训专家 一.实验背景(一)蜂鸣器的介绍1.蜂鸣器的作用蜂鸣器是一种一体化结构的电子讯响器,采用直流电压供电,广泛应用于计算机.打印机.复印机.报警器.电子玩具.汽车电子设备.电话机.定时器等电子产品中作发声器件.2.蜂鸣器的分类蜂鸣器主要分为压电式蜂鸣器和电磁式蜂鸣器两种类型.3.蜂鸣器的电路图形符号蜂鸣器在电路中用字母"H"或"HA"(旧标准用"FM"."LB"

【转】OAL之系统时钟

1. 系统时钟与内核的关系 WinCE 5.0采用基于时间片的抢占式多任务的实时内核,而且每个线程可以根据需要自行设定线程时间片的大小(参考CeSetThreadQuantum函数),默认为100ms,这个默认值dwDefaultThreadQuantum也可以在OEMInit()时自行设定.在内核源文件中,与单词Quantum有关的变量名一般是指时间片,WinCE内核定义了几个与时钟有关的全局变量,他们也是内核与OAL接口的一部分: 1) dwReschedTime,这个变量在内核的调度程序中

STM32F2系列系统时钟默认配置

新到一家公司后,有个项目要用到STM32F207Vx单片机,找到网上的例子照猫画虎的写了几个例子,比如ADC,可是到了ADC多通道转换的时候就有点傻眼了,这里面的时钟跑的到底是多少M呢?单片机外挂的时钟是25M,由于该单片机时钟系统较为复杂,有内部高/低.外部高/低 .PLL锁相环时钟,又有AHB总线时钟.APB1/2时钟,而例子中很少讲到系统时钟的默认配置是怎么配置呢?那么就发点时间研究下这个单片机内部的复杂时钟系统吧. 下图是STM32F2系列的时钟树结构图: 1.内部高速时钟HSI.外部高

第15章 RCC—使用HSE/HSI配置时钟

本章参考资料:<STM32F7xx参考手册>RCC章节. 学习本章时,配合<STM32F7xx参考手册>RCC章节一起阅读,效果会更佳,特别是涉及到寄存器说明的部分. RCC :reset clock control  复位和时钟控制器.本章我们主要讲解时钟部分,特别是要着重理解时钟树,理解了时钟树,F767的一切时钟的来龙去脉都会了如指掌. 15.1  RCC主要作用-时钟部分 设置系统时钟SYSCLK.设置AHB分频因子(决定HCLK等于多少).设置APB2分频因子(决定PCL

RCC—使用HSE/HSI配置时钟

1.1 RCC主要作用—时钟部分 设置系统时钟SYSCLK.设置AHB分频因子(决定HCLK等于多少).设置APB2分频因子(决定PCLK2等于多少).设置APB1分频因子(决定PCLK1等于多少).设置各个外设的分频因子:控制AHB.APB2和APB1这三条总线时钟的开启.控制每个外设的时钟的开启.对于SYSCLK.HCLK.PCLK2.PCLK1这四个时钟的配置一般是:HCLK = SYSCLK=PLLCLK = 180M,PCLK2=HCLK/2 = 90M,PCLK1=HCLK/4 =