欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOC文档下载  

    593638874《EDA技术》课程设计报告彩灯控制器.doc

    • 资源ID:4146235       资源大小:412KB        全文页数:17页
    • 资源格式: DOC        下载积分:8金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    593638874《EDA技术》课程设计报告彩灯控制器.doc

    EDA技术课程设计报告题 目: 彩灯控制器 专 业: 电子信息工程 班 级: 0702 姓 名: 指导教师: 二0一 0 年 6 月 24 日目 录1设计目的32设计题目描述和要求33设计原理33.1方案论证33.2模块设计43.3系统结构64总结75参考书目86附录一程序97附录二编译168附录三时序仿真171.设计目的 学习EDA开发软件和MAX+plus 的使用方法,熟悉可编程逻辑器件的使用,通过制作来了解彩灯控制系统。2.设计题目描述和要求1) 设计一个彩灯控制器,能使8个彩灯(LED管)能连续发出四六种以上不同的显示形式;2)随着彩灯显示图案的变化,发出不同的音响声。3.设计原理3.1 方案论证这次的彩灯设计采用的是分模块来完成的,包括分频器、计数器、选择器、彩灯控制器。其中彩灯控制器是用来输出不同的花样,彩灯控制器的输出则是用一个32进制的计数器来控制,扬声器的输出时用不同的频率来控制,所以用了一个集成分频器来使输入的频率被分为几种不同的频率,不同频率的选择性的输出则是用一个4选一的选择器来控制。基于上述的介绍本次的彩灯控制采用的模式6来进行显示。 图3-1-1 模式6结构图3.2 模块设计1)集成分频器模块设计要求显示不同的彩灯的时候要伴随不同的音乐,所以设计分频器来用不同的频率控制不同的音乐输出。模块说明:Rst:输入信号 复位信号 用来复位集成分频器的输出使输出为“0”,及没有音乐输出。Clk:输入信号 模块的功能即为分频输入的频率信号。Clk_4、clk_6、clk_8、clk_10:输出信号 即为分频模块对输入信号clk的分频,分别为1/4分频输出、1/6分频输出、1/8分频输出、1/10分频输出。 图3-2-1 集成分频器 2)32进制计数器模块32进制模块用来控制彩灯输出模块,即确定彩灯控制器的不同的输出。Rst:输入信号 复位信号 用来复位32进制使其输出为“00000”。Clk:输入信号 用来给模块提供工作频率。Count_out4.0:输出信号 即为32进制计数器的输出。 图3-2-2 32进制计数器3)彩灯控制模块彩灯控制模块用来直接控制彩灯的输出,使彩灯表现出不同的花样。Rst:输入信号 使彩灯控制模块的输出为“00000000”,即让彩灯无输出。Input4.0:输入信号 不同的输入使彩灯控制模块有不同的输出即彩灯显示出不同的花样。Output7.0:输出信号 直接与彩灯相连来控制彩灯。 图3-2-3 彩灯控制模块4) 4选1选择器模块Rst:输入信号 复位信号 使选择器的输出为“0”。In1、in2、in3、in4:输入信号 接分频器的输出。Inp1.0:输入信号 接4进制计数器的输出用来控制选择器的选择不同的输入选择不同的输出。Output:输出信号 直接接扬声器即输出的是不同的频率来控制扬声器播放音乐。 图3-2-4 4选1选择器 5)4进制计数器模块4进制计数器作为选择器的输入来控制选择器选择不同的频率作为输出控制扬声器工作。Clk:输入信号 来为计数器提供工作频率。Rst:输入信号 复位信号 使计数器的输出为“00”。 图3-2-5 4进制计数器3.3 系统结构 整个系统就是各个分模块组成来实现最后的彩灯控制功能,系统又两个时钟来控制一个是控制32进制计数器即控制彩灯控制模块来实现彩灯的不同输出,另一个时钟为分频器的输入来进行分频处理,最后用来控制扬声器发出不同的音乐,具体分频处理的时钟的频率比实现彩灯控制的时钟频率要高。 图 3-3-1 系统功能模块4.总结这次的EDA课程设计有一周的时间,在这一周的时间里我们充分合理的安排了自己的时间来使本次的课程设计能够顺利的完成,当然我们在本次的设计中并不是一帆风顺的,我们遇到了一些的问题,例如我们开始时用的文本的方式用一个总的程序来完成,可以在设计的过程中我们发现程序编到后面变量越到很容易搞混淆同时各个进程间的联系也越来越模糊以至于后面我们自己都不知道程序的整体框图是什么,导致后面不能够继续下去,后面我们再一次对我们这次的设计题目进行了分析和整理,最后我和我的同伴决定采用分模块的方式来完成本次的课题设计,当然最重要的是分析各个模块间的关系。最后我们采用上面分析的结构框图。最后我们的设计很成功,仿真和硬件测试都是正确的,实现了我们的设计要求和目的。在这次设计中我们收获了很多,首先最直接的收获就是我们巩固了这门课程所学过的知识,把它运用到了实践当中,并且学到了很多在书本撒和那个所没有学到的知识,通过查阅相关资料进一步加深了对EDA的了。总的来说,通过这次课程设计不仅锻炼了我们的动手和动脑能力,也使我懂得了理论与实际相结合的重要性,只有理论知识是远远不够的,要把所学的理论知识与实践相结合起来,才能提高自己的实际动手能力和独立思考的能力。在我们的共同努力和指导老师的指引下我们圆满的完成了彩灯控制器的设计,实现了设计目的。参考书目:1 赵伟军,Protel99se教程,北京,人民邮电出版社,1996年2 金西,VHDL与复杂数字系统设计,西安,西安电子科技大学出版社,20033 汉泽西,EDA技术及其应用,北京,北京航空航天大学出版社,20046附录一 程序:-分频器模块- MAX+plus II VHDL Template- Clearable loadable enablable counterLIBRARY ieee;USE ieee.std_logic_1164.all;ENTITY fenpinqi ISPORT(clk,rst: INstd_logic;clk_10,clk_4,clk_6,clk_8: OUT std_logic);END fenpinqi;ARCHITECTURE cd OF fenpinqi ISbeginp1:process(clk,rst) variable a:integer range 0 to 20; begin if rst='1' then clk_4<='0' - 复位信号控制部分 else if clk'event and clk='1'then if a>=3 then a:=0; clk_4<='1' else a:=a+1; clk_4<='0' end if; end if; end if;end process p1;p2:process(clk,rst) variable b:integer range 0 to 20; begin if rst='1' then clk_6<='0' - 复位信号控制部分 else if clk'event and clk='1'then if b>=5 then b:=0; clk_6<='1' else b:=b+1; clk_6<='0' end if; end if; end if;end process p2;p3:process(clk,rst) variable c:integer range 0 to 20; begin if rst='1' then clk_8<='0' - 复位信号控制部分 else if clk'event and clk='1'then if c>=7 then c:=0; clk_8<='1' else c:=c+1; clk_8<='0' end if; end if; end if;end process p3;p4:process(clk,rst) variable d:integer range 0 to 20; begin if rst='1' then clk_10<='0' - 复位信号控制部分 else if clk'event and clk='1'then if d>=9 then d:=0; clk_10<='1' else d:=d+1; clk_10<='0' end if; end if; end if;end process p4;end cd;-4选1选择器-LIBRARY ieee;USE ieee.std_logic_1164.all;ENTITY xzq4_1 ISPORT( rst:in std_logic; inp:in integer range 0 to 3;in1,in2,in3,in4: In std_logic;output: OUT std_logic);END xzq4_1;ARCHITECTURE a OF xzq4_1 ISBEGINPROCESS (rst,inp)BEGIN if(rst='1') then output<='0' else case inp is when 0=>output<=in1; when 1=>output<=in2; when 2=>output<=in3; when 3=>output<=in4; when others=>null; end case; end if;END PROCESS;END a;-彩灯控制模块-LIBRARY ieee;USE ieee.std_logic_1164.all;ENTITY caideng ISPORT(input: ININTEGER RANGE 0 TO 31; rst:in std_logic; output: OUT std_logic_vector(7 downto 0); sm :out std_logic_vector(6 downto 0);END caideng;ARCHITECTURE a OF caideng ISBEGINPROCESS (input)BEGIN if rst='1' then output<="00000000"sm<="0000000" else case input is when 0=>output<="10000000"sm<="0000110" when 1=>output<="01000000"sm<="0000110" when 2=>output<="00100000"sm<="0000110" when 3=>output<="00010000"sm<="0000110" when 4=>output<="00001000"sm<="0000110" when 5=>output<="00000100"sm<="0000110" when 6=>output<="00000010"sm<="0000110" when 7=>output<="00000001"sm<="0000110" when 8=>output<="00010000"sm<="0011011" when 9=>output<="00110000"sm<="0011011" when 10=>output<="00111000"sm<="0011011" when 11=>output<="01111000"sm<="0011011" when 12=>output<="01111100"sm<="0011011" when 13=>output<="01111110"sm<="0011011" when 14=>output<="11111110"sm<="0011011" when 15=>output<="11111111"sm<="0011011" when 16=>output<="10000001"sm<="1001111" when 17=>output<="11000001"sm<="1001111" when 18=>output<="11000011"sm<="1001111" when 19=>output<="11100011"sm<="0011011" when 20=>output<="11100111"sm<="1001111" when 21=>output<="11110111"sm<="1001111" when 22=>output<="11111111"sm<="1001111" when 23=>output<="00001000"sm<="1001111" when 24=>output<="00000001"sm<="0100110" when 25=>output<="00000010"sm<="0100110" when 26=>output<="00000100"sm<="0100110" when 27=>output<="00001000"sm<="0100110" when 28=>output<="00010000"sm<="0100110" when 29=>output<="00100000"sm<="0100110" when 30=>output<="01000000"sm<="0100110" when 31=>output<="10000000"sm<="0100110" when others=>null; end case; end if; end process; end a;-32进制计数器模块-LIBRARY ieee;USE ieee.std_logic_1164.all;ENTITY counter_32 ISPORT(clk,rst: INstd_logic;count_out: OUT integer range 0 to 31);END counter_32;ARCHITECTURE a OF counter_32 ISBEGINPROCESS (rst,clk) variable temp:integer range 0 to 32;BEGINIF rst='1' THEN temp:=0;ELSIF (clk'event and clk='1') THEN temp:=temp+1; if(temp=32) then temp:=0; end if;END IF; count_out<=temp;END PROCESS;END a;-4进制计数器模块-LIBRARY ieee;USE ieee.std_logic_1164.all;ENTITY counter_4 ISPORT(clk,rst: INstd_logic;count_out: OUT integer range 0 to 3);END counter_4;ARCHITECTURE a OF counter_4 ISBEGINPROCESS (rst,clk) variable temp:integer range 0 to 32;BEGINIF rst='1' THEN temp:=0;ELSIF (clk'event and clk='1') THEN temp:=temp+1; if(temp=4) then temp:=0; end if;END IF; count_out<=temp;END PROCESS;END a;7附录二 编译7附录三 时序仿真

    注意事项

    本文(593638874《EDA技术》课程设计报告彩灯控制器.doc)为本站会员(laozhun)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开