EDA技术培训 百文网手机站

EDA技术与应用课后习题答案(5)

时间:2022-03-18 16:19:46 EDA技术培训

EDA技术与应用课后习题答案

  CLK: IN STD_LOGIC; --状态机工作时钟

  EOC: IN STD_LOGIC; --转换状态指示,低电平表示正在转换

  ALE:OUT STD_LOGIC; --8个模拟信号通道地址锁存信号

  START:OUT STD_LOGIC; --转换开始信号

  OE:OUT STD_LOGIC; --数据输出三态控制信号

  ADDA:OUT STD_LOGIC; --信号通道最低位控制信号

  LOCK0:OUT STD_LOGIC; --观察数据锁存时钟

  Q:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)); --8位数据输出

  END ADCINT;

  ARCHITECTURE behav OF ADCINT IS

  TYPE states IS(st0,st1,St2,st3,st4); --定义各状态子类型

  SIGNAL current_state,next_state: states:=st0;

  SIGNAL REGL: STD_LOGIC_VECTOR(7 DOWNTO 0);

  SIGNAL LOCK: STD_LOGIC;--转换后数据输出锁存时钟信号

  BEGIN

  ADDA<='1';--当ADDA<='0',模拟信号进入通道IN0;当ADDA<='1',则进入通道INI

  Q<=REGL;LOCK0<=LOCK;

  COM: PROCESS(current_state,EOC) BEGIN --规定各状态转换方式

  CASE current_state IS

  WHEN st0=> ALE<='0';START<='0';LOCK<='0';OE<='0';

  next_state<=st1; --0809初始化

  WHEN st1=> ALE<='1';START<='1';LOCK<='0';OE<='0';

  next_state<=st2 ;--启动采样

  WHEN st2=> ALE<='0';START<='0';LOCK<='0'; OE<='0';

  IF(EOC='1') THEN next_state<=st3;--EOC=1表明转换结束

  ELSE next_state<=st2; END IF; --转换未结束,继续等待

  WHEN st3=> ALE<='0';START<='0';LOCK<='0';OE<='1';

  next_state<=st4;--开启OE,输出转换好的数据

  WHEN st4=> ALE<='0';START<='0';LOCK<='1';OE<='1';next_state<=st0;

  WHEN OTHERS=>next_state<=st0;

  END CASE;

  END PROCESS COM;

  REG:PROCESS(CLK)

  BEGIN

  IF(CLK'EVENT AND CLK='1') THEN current_state<=next_state; END IF;

  END PROCESS REG; --由信号current_state将当前状态值带出此进程:REG

  LATCH1: PROCESS(LOCK) --此进程中,在LOCK的上升沿,将转换好的数据锁入

  BEGIN

  IF LOCK='1' AND LOCK'EVENT THEN REGL<=D; END IF;

  END PROCESS LATCH1;

  END behav;

  8-5在不改变原代码功能的条件下用两种方法改写例8-2,使其输出的控制信号(ALE、START、OE、LOCK)没有毛刺。方法1:将输出信号锁存后输出;方法2:使用状态码直接输出型状态机,并比较这三种状态机的特点。

  -- 解:"【例8-2】根据图8-6状态图,采用Moore型状态机,设计ADC0809采样控制器" 方法1(将输出控制信号锁存后输出)的VHDL程序代码如下:

  LIBRARY IEEE;

  USE IEEE.STD_LOGIC_1164.ALL;

  ENTITY ADCINT IS

  PORT(D: IN STD_LOGIC_VECTOR(7 DOWNTO 0); --来自0809转换好的8位数据

  CLK: IN STD_LOGIC; --状态机工作时钟

  EOC: IN STD_LOGIC; --转换状态指示,低电平表示正在转换

  ALE: OUT STD_LOGIC; --8个模拟信号通道地址锁存信号

  START: OUT STD_LOGIC; --转换开始信号

  OE: OUT STD_LOGIC; --数据输出三态控制信号

  ADDA: OUT STD_LOGIC; --信号通道最低位控制信号

  LOCK0: OUT STD_LOGIC; --观察数据锁存时钟

  Q: OUT STD_LOGIC_VECTOR(7 DOWNTO 0)); --8位数据输出

  END ADCINT;

  ARCHITECTURE behav OF ADCINT IS

  TYPE states IS(st0,st1,St2,st3,st4); --定义各状态子类型

  SIGNAL current_state,next_state: states:=st0;

  SIGNAL REGL: STD_LOGIC_VECTOR(7 DOWNTO 0);

  SIGNAL LOCK: STD_LOGIC;--转换后数据输出锁存时钟信号

  SIGNAL ALE0: STD_LOGIC; --8个模拟信号通道地址锁存信号

  SIGNAL START0: STD_LOGIC; --转换开始信号

  SIGNAL OE0: STD_LOGIC; --数据输出三态控制信号

  BEGIN

  ADDA<='1';--当ADDA<='0',模拟信号进入通道IN0;当ADDA<='1',则进入通道INI

  Q<=REGL; --LOCK0<=LOCK;

  COM: PROCESS(current_state,EOC,CLK) BEGIN --规定各状态转换方式

  CASE current_state IS

  WHEN st0=> ALE0<='0';START0<='0';LOCK<='0';OE0<='0';

  next_state<=st1; --0809初始化

  WHEN st1=> ALE0<='1';START0<='1';LOCK<='0';OE0<='0';

  next_state<=st2 ;--启动采样

  WHEN st2=> ALE0<='0';START0<='0';LOCK<='0'; OE0<='0';

  IF(EOC='1') THEN next_state<=st3;--EOC=1表明转换结束

  ELSE next_state<=st2; END IF; --转换未结束,继续等待

  WHEN st3=> ALE0<='0';START0<='0';LOCK<='0';OE0<='1';

  next_state<=st4;--开启OE,输出转换好的数据