基于FPGA简易数控电源(2)

2019-07-31 09:31

数字电路课程设计报告

仿真结果分析:输入CLK的F0=50MHZ,(即T0=20ns)而输出FOUT的T1=20ms, (即F1=50HZ)则次分频器设计符合要求。

(2)200万分频器DVF的设计 源程序如下: LIBRARY IEEE;

USE IEEE.STD_LOGIC_1164.ALL;

USE IEEE.STD_LOGIC_UNSIGNED.ALL; ENTITY DVF1 IS

PORT(CLK:IN STD_LOGIC; FOUT:OUT STD_LOGIC); END;

ARCHITECTURE ONE OF DVF1 IS BEGIN

PROCESS(CLK)

VARIABLE CNT:INTEGER RANGE 0 TO 1000000; VARIABLE X:STD_LOGIC; BEGIN

IF CLK'EVENT AND CLK='1' THEN IF CNT<1000000 THEN CNT:=CNT+1; ELSE

CNT:=0; X:=NOT X; END IF; END IF; FOUT<=X; END PROCESS ; END ONE;

生成的电路模块如下

图2-6

仿真波形图如下:

数字电路课程设计报告

图2-7(缩小波形图)

图2-8(放大波形图)

仿真结果分析:输入CLK的F0=50MHZ,(即T0=20ns)而输出FOUT的T1=40ms, (即F1=25HZ)则次分频器设计符合要求。

2.1.2键盘输入模块设计

源程序如下:

LIBRARY IEEE;

USE IEEE.STD_LOGIC_1164.ALL;

USE IEEE.STD_LOGIC_UNSIGNED.ALL; USE IEEE.STD_LOGIC_ARITH.ALL; ENTITY KEY IS

PORT( UP:IN STD_LOGIC; DOWN:IN STD_LOGIC; CLK:IN STD_LOGIC; CLK1:IN STD_LOGIC; UP0:OUT STD_LOGIC; DOWN0:OUT STD_LOGIC); END KEY;

ARCHITECTURE ONE OF KEY IS

SIGNAL UPT1,UPT2,UPT3,DOWNT1,DOWNT2,DOWNT3:STD_LOGIC; BEGIN

PROCESS(CLK1) BEGIN

if(CLK1'EVENT AND CLK1='1') THEN UPT1<=UP; UPT2<= UPT1; DOWNT1<=DOWN; DOWNT2<=DOWNT1; END IF;

数字电路课程设计报告

END PROCESS;

UPT3 <=NOT UPT2; DOWNT3 <=NOT DOWNT2; PROCESS(CLK) BEGIN

IF(CLK'EVENT AND CLK='1') THEN UP0 <=CLK1 AND UPT1 AND UPT3;

DOWN0 <=CLK1 AND DOWNT1 AND DOWNT3; END IF; END PROCESS; END ONE;

生成的电路模块如下:

图2-9

仿真波形如下:

图2-10

仿真结果分析:经过抖动处理,按键的输出脉冲均变为一个CLK1时钟周期的宽度,因开关及外界一系列因素引起的电平抖动的干扰脉冲信号全被滤掉。则此键盘模块符合设计要求。

2.1.3可逆100进制计数器模块设计

源程序如下: LIBRARY IEEE;

USE IEEE.STD_LOGIC_1164.ALL;

USE IEEE.STD_LOGIC_UNSIGNED.ALL;

数字电路课程设计报告

ENTITY CNT100 IS

PORT ( CLK:IN STD_LOGIC;

UP,DOWN:IN STD_LOGIC;

Q1,Q2:OUT STD_LOGIC_VECTOR(3 DOWNTO 0)); END CNT100;

ARCHITECTURE ONE OF CNT100 IS

SIGNAL COUT2,COUT1:STD_LOGIC_VECTOR(3 DOWNTO 0); BEGIN

PROCESS(CLK,UP,DOWN) BEGIN

IF(CLK'EVENT AND CLK='1') THEN IF(UP='0' AND DOWN='1') THEN

IF (COUT2=9 AND COUT1=9) THEN COUT2<=\ ELSE

IF (COUT1=9) THEN

COUT2<=COUT2+1; COUT1<=\ ELSE

COUT2<=COUT2; COUT1<=COUT1+1; END IF; END IF;

ELSIF(DOWN='0' AND UP='1') THEN IF (COUT2=0 AND COUT1=0) THEN COUT2<=\ ELSE

IF (COUT1=0) THEN

COUT2<=COUT2-1; COUT1<=\ ELSE

COUT2<=COUT2; COUT1<=COUT1-1; END IF; END IF;

ELSIF(DOWN='1' AND UP='1') THEN COUT1<=\ END IF; END IF; END PROCESS;

Q1<=COUT1;Q2<=COUT2; END ONE;

生成的电路模块如下:

数字电路课程设计报告

图2-11

仿真波形如下:

图2-12

图2-13

分析结果:由波形可知,当UP=0,DOWN=1时,每当CLK的上升沿来临时,则计数器加1,当计数到99时,就不会再增计数,将一直保持在99;当UP=1,DOWN=0时,每当CLK的上升沿来临时,则计数器数值减1,当计数到00时,就不会再减计数,将一直保持在00;而当UP=1,DOWN=1时,计数器被置在66,符合预置的电压值。综上所述,则此模块符合设计要求。

2.1.4数据选择器模块设计

源程序如下: LIBRARY IEEE;

USE IEEE.STD_LOGIC_1164.ALL; ENTITY MUX21 IS


基于FPGA简易数控电源(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:宁夏回族自治区咨询工程师考试分析与评价巩固题每日一讲(1月20

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: