设计系统软件时运用VHDL语言,可将系统分为频率计、分频.docVIP

设计系统软件时运用VHDL语言,可将系统分为频率计、分频.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
设计系统软件时运用VHDL语言,可将系统分为频率计、分频

设计系统软件时运用VHDL语言,可将系统分为频率计、分频器、相位计数器3个子模块,现对其分别进行描述: (1)频率计 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; entity fcounter is port(sig:in std_logic; --输入信号 clk:in std_logic; --0.5Hz的闸门信号,可由晶振分频得到 counter:out std_logic_vector(19 downto 0)); --计数输出 end; architecture data of fcounter is signal temp:std_logic_vector(19 downto 0); begin P1:process(sig) begin if sig'event and sig=‘1’then if clk=‘1’ then temp<=temp+1; --在闸门的高电平时段计数 else temp<=“00000000000000000000”  --在闸门的低电平时段清零 end if; end if; end process P1; P2process(clk) begin if clk′event and clk=′0′ then counter<=temp;在闸门的下降沿将数据读出 end if; end process P2; end; 由于闸门采用的是0.5Hz的方波,因此输出数值即为频率值。 (2) 分频模块 通过此模块可对频率计得到的频率进行分频,也可在异或后再分频得到频率为0.5Hz的矩形波。 library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; entity fen is port(qin:in std_logic vector(19 downto 0);--连接频率计输出的频率值 qout:out std_logic); end; architecture data of fen is signal temp:std_logic_vector(19 downto 0); signal a:std_logic; begin process(temp) begin if temp<qin then temp<=temp+1; else temp<=“00000000000000000000”; a<=not a; end if; qout<=a;  --进行2f倍分频 end process; end; 3相位测量 该模块将分频模块得到的信号作为闸门,然后利用外部晶振进行计数,其设计原理与频率计相同。由于相异或的一个周期对应输入的两路方波信号的半个周期(180°),而且只能测量到最大180°的相位差,因此还须判断超前或滞后,才能测量出大于180°的相位差,具体程序如下: library ieee; use ieee.std_logic_1164.all; entity pre_lag is port(s1,s2:in std_ ogic;  --两输入信号 pre:out std_logic);  --判断结果输出 end; architecture data of pre_lag is begin lag:process(s1) begin if s1′event and s1=′1′ then if s2=′0′then pre<=′1′; --若s1超前s2,输出为 ′1′,否则输出′0′; else pre<=′0′; end if; end if; end process lag; end; (4) 模块的组合 HYPERLINK /Technic/technic/2007/3/info/images/iie/200404/7c.gif 图3 ??? 在Max+PlusII中,采用原理图输入方式可将上述各模块组合成一个软件系统,然后将其综合下载到CPLD即可完成相位测量仪的设计,其具体设计图见图3所示。 图3中, A、B为输入信号a、b经过整形得到的方波信号。Fcounter为频率计模块,Fen为分频器,Phasecounter为相位测量计数器,Pre-lag为超前滞后判断模块。

文档评论(0)

181****2553 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档