欢迎来到天天文库
浏览记录
ID:56758754
大小:443.50 KB
页数:10页
时间:2020-07-07
《实验六VHDL有限状态机设计(ADC0809).doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、本科学生综合性实验报告学号114090315姓名李开斌学院物电学院专业、班级11电子实验课程名称电子设计自动化(EDA实验)教师及职称罗永道副教授开课学期2013至2014学年下学期填报时间2014年5月30日云南师范大学教务处编印实验序号6实验名称VHDL有限状态机设计实验时间2014年5月30日实验室同析楼114一.实验预习1.实验目的:学习用状态机对A/D转换器ADC0809的采样控制电路的实现。2.实验原理、实验流程或装置示意图:ADC0809是CMOS的8位A/D转换器,片内有8路模拟开关,可控制8个模拟量中的一个进入转换器中。ADC0809的分辨率为8位,转换时间约100us,含锁
2、存控制的8路多路开关,输出有三态缓冲器控制,单5V电源供电。主要控制信号说明:如图1所示,START是转换启动信号,高电平有效;ALE是3位通道选择地址(ADDC、ADDB、ADDA)信号的锁存信号。当模拟量送至某一输入端(如IN1或IN2等),由3位地址信号选择,而地址信号由ALE锁存;EOC是转换情况状态信号(类似于AD574的STATUS),当启动转换约100us后,EOC产生一个负脉冲,以示转换结束;在EOC的上升沿后,若使输出使能信号OE为高电平,则控制打开三态缓冲器,把转换好的8位数据结果输至数据总线。至此ADC0809的一次转换结束了。图13.实验设备及材料电脑一台,Quartu
3、sII实验平台,EDA实验箱2.实验方法步骤及注意事项用VHDL 设计的状态机的一般结构有以下几部分组成:1. 说明部分说明部分中有新数据类型TYPE 的定义及其状态类型(状态名)和在此新数据类型下定义的状态变量。状态类型一般用枚举类型,其中每一个状态名可任意选取。但为了便于辨认和含义明确,状态名最好有明显的解释性意义。状态变量应定义为信号,便于信息传递。说明部分一般放在ARCHITECTURE 和BEGIN之间。2. 主控时序进程:状态机是随外部时钟信号以同步时序方式工作的,因此状态机中必须包含一个对工作时钟信号敏感的进程作为状态机的“驱动泵”。当时钟发生有效跳变时,状态机的状态
4、才发生变化。状态机的下一状态(包括再次进入本状态)仅仅取决于时钟信号的到来。一般地,主控时序进程不负责进入的下一状态的具体状态取值。当时钟的有效跳变到来时,时序进程只是机械地将代表下一状态的信号next_state 中的内容送入代表本状态的信current_state 中,而信号next_state 中的内容完全由其它的进程根据实际情况来决定。当然此进程中也可以放置一些同步或异步清零、置位方面的控制信号。总体来说,主控时序进程的设计比较固定、单一和简单。3. 主控组合进程:主控组合进程的任务是根据外部输入的控制信号(包括来自状态机外部的信号和来自状态机内部其它非主控的组合或时序进程的信号
5、),或(和)当前状态的状态值确定下一状态(next_state)的取向,即next_state的取值内容,以及确定对外输出或对内部其它组合或时序进程输出控制信号的内容。4. 普通组合进程用于配合状态机工作的其它组合进程,如为了完成某种算法的进程。5. 普通时序进程用于配合状态机工作的其它时序进程,如为了稳定输出设置的数据锁存器等。一个状态机的最简结构应至少由两个进程构成(也有单进程状态机,但并不常用)即一个主控时序进程和一个主控组合进程,一个进程作“驱动泵”,描述时序逻辑,包括状态寄存器的工作和寄存器状态的输出;另一个进程描述组合逻辑,包括进程间状态值的传递逻辑以及状态转换值的输出
6、。当然必要时还可以引入第3 个和第4 个进程,以完成其它的逻辑功能。图2为一般状态机结构图。图2 一般状态机结构框图工作示意图图3和图4为控制ADC0809采样状态机结构图和状态转换图图3 采样状态机结构框图设计提示:设目标器件是EP1C6Q240C8,建议选择实验电路结构图No.5(即结构图No.5A,附图1-14,由该图可见,ADC0809的转换时钟CLK已经事先接有750KHz的频率),将实验系统左下角选择插针处的“转换结束”和“A/D使能”用跳线帽短接。下载目标文件后,可用螺丝刀旋转实验系统左下角的电位器,以便为ADC0809提供变化的待测模拟信号,这时数码管8和7将显示ADC0
7、809采样输出并被锁存的数字值(16进制)。图4 控制ADC0809采样状态图图5 控制ADC0809采样时序图二.实验内容1.实验现象与结果(1)ADC0809VHDL语言程序如下:LIBRARYieee;USEieee.std_logic_1164.all;ENTITYadcISPORT(CLK:INSTD_LOGIC;RESET:INSTD_LOGIC:='0';EOC:INSTD_LO
此文档下载收益归作者所有