- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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;
P2process(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为超前滞后判断模块。
您可能关注的文档
最近下载
- 2025年无人机驾驶员执照飞行环境评估之城市楼宇信号屏蔽效应评估专题试卷及解析.pdf VIP
- 2025年项目管理专业偏差管理决策分析专题试卷及解析.pdf VIP
- 医院耗材SPD解决方案(技术方案).doc
- SOP标准作业指导书模版.xls VIP
- 中国共产党党支部工作条例解读1.pptx VIP
- (党课)2025民兵政治教育微课堂PPT课件.pptx VIP
- 2025年浙江特殊教育职业学院单招笔试语文试题库含答案解析.docx VIP
- 网评原创网评文章.docx VIP
- Twilight+《暮光之城》电影中英对照剧本.pdf VIP
- 卡通宪法宣传教育宪法主题班会通用PPT模板.pptx VIP
原创力文档


文档评论(0)