函数信号发生器设计(EDA大作业).docVIP

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
EDA课程设计大作业 设计题目: 函数信号发生器设计 学生姓名: 学 号: 专业班级: 20012年 05月 28日 函数信号发生器 1.设计背景和设计方案 1.1 设计背景 在电子工程、通信工程、自动控制、遥测控制、测量仪器、仪表和计算机等技术领域,经常需要用到各种各样的信号波形发生器。随着集成电路的迅速发展,用集成电路可很方便地构成各种信号波形发生器。用集成电路实现的信号波形发生器与其它信号波形发生器相比,其波形质量、幅度和频率稳定性等性能指标,都有了很大的提高。 函数信号发生器是一种在科研和生产中经常用到的基本波形发生器,随着大规模集成电路的迅速发展,多功能信号发生器已被制作成专用集成电路,例如ICL8038单片函数波形发生器,可以产生精度较高的正弦波、方波、矩形波、锯齿波等多种信号。 1.2 设计方案及实现 函数信号发生器由递增斜波(zeng),递减斜波产生模块(jian),方波产生模块(square),三角波产生模块(san),正弦波产生模块(sin)和输出波形选择模块(choice)组成。总体设计框图如图所示,图中输出q需要接到外部D/A转换的数据输入端,将数字信号转换为模拟信号,在D/A转换器的输出端即可得到各种不同的函数信号波形。如果输出脉冲波形边沿跳变不理想,可加低通滤波器来加以完善。 将各个模块分开来设计,先设计各个模块的程序,让后将程序生成对应的元件,然后再将这些元件链接到一起组成完整的硬件电路 1.3各模块程序及生成模块 1.3.1 递减斜波产生模块 模块程序如下:library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; entity jian is port(clk,reset:in std_logic; //定义输入输出端口 q:out std_logic_vector(7 downto 0)); //定义波形输出端口 end jian; architecture jian_arc of jian is begin process(clk,reset) //模块进程 variable tmp:std_logic_vector(7 downto 0); //定义7位逻辑位变量 begin if reset=0 then //复位有效 tmp: //为变量赋值全1 elsif clkevent and clk=1 then //时钟有效时 if tmpthen //当前变量值为全0时 tmp: //为变量赋值为全1 else tmp:=tmp-1; //不为全0时,当前变量值减1 end if; end if; q=tmp; //变量值赋给q end process; end jian_arc; 生成的元件图: 1.3.2 递增斜波产生模块 模块程序如下:library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; entity zeng is port(clk,reset:in std_logic; //定义时钟,复位端口 q:out std_logic_vector(7 downto 0)); //定义波形输出端口 end zeng; architecture zeng_arc of zeng is begin process(clk,reset) //模块进程 variable tmp:std_logic_vector(7 downto 0); //定义7位逻辑位变量 begin if reset=0 then //复位有效 tmp: //为变量赋值为全0 elsif clkevent and clk=1 then //时钟有效 if tmpthen

文档评论(0)

nnh91 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档