- 1、本文档共15页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于FPGA的高低位数字测温计
数字电路课程设计报告
课题:基于FPGA的高低位数字测温计
学院:机电工程学院
专业:自动化
班级:
姓名:
学号:
指导老师:
2014年10月14日星期二
一、引言
课题确定过程:最初在网上搜过不少课题,如自动售货机、3层电梯控制器、声控电子锁等,但每一个的信号采集模块的设计以我现在的水平而言都很复杂,于是在尝试了一段时间后就放弃了。后来我觉得自己必须先了解点关于FPGA、EDA、VHDL的一些基础知识,于是到图书馆借阅了一些相关书籍,同时想到平时生活里测物体温度时因为导热不均匀使得两端极的温度有较大的不同,于是就有了做高低位数字测温计的想法。
系统总体介绍:系统由FPGA器件实现数字测温,利用温度传感器AD590采集温度信号,产生的温度信号经调零、放大处理后,利用A/D转换器ADC0809将模拟信号转换成分高低位的数字信号,最后将高4位和低4位的数字信号分别连接到7段共阴极数码显示管上输出温度大小(以十六进制的形式)。
二、硬件描述
2.1系统组成框图
2.2测温模块(采集电路)
温度传感器AD590简介
AD590是美国ANALOG DEVICES公司的单片集成两端感温电流源AD590适用于150°C以下、目前采用传统电气温度传感器的任何温度检测应用。低成本的单芯片集成电路及无需支持电路的特点,使它成为许多温度测量应用的一种很有吸引力的备选方案。
2.3模数转换模块
A/D转换器ADC0809简介
ADC0809是美国国家半导体公司生产的CMOS工艺8通道,8位逐次逼近式A/D模数转换器。其内部有一个8通道多路开关,它可以根据地址码锁存译码后的信号,只选通8路模拟输入信号中的一个进行A/D转换。
本系统采集到的温度与数字输出量的关系
温度(摄氏度) 4位二进制输出 15 0000 15 0001 20 0010 25 0011 30 0100 35 0101 40 0110 45 0111 50 1000 55 1001 60 1010 65 1011 70 1100 75 1101 80 1110 80 1111
2.4七段数码管显示模块(执行电路)
数码管的一种是半导体发光器件,数码管可分为七段数码管和八段数码管,区别在于八段数码管比七段数码管多一个用于显示小数点的发光二极管单元DP(decimal point),其基本单元是发光二极管。
3.1.1VHDL语言描述
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
ENTITY ADC0809 IS
PORT(CLK:IN STD_LOGIC;--时钟信号
EOC:IN STD_LOGIC;--转换结束信号
DIN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);--采集温度信号
ALE:OUT STD_LOGIC;--地址锁存允许信号
START:OUT STD_LOGIC;-- A/D转换启动脉冲输入端 OE:OUT STD_LOGIC;--数据输出允许信号
LOCK0:OUT STD_LOGIC;--观察数据锁存信号
ADDA:OUT STD_LOGIC;--3条地址输入线
ADDB:OUT STD_LOGIC;
ADDC:OUT STD_LOGIC;
DOUT:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));--输出8位数字信号
END ADC0809;
ARCHITECTURE BEHAV OF ADC0809 IS
TYPE STATE IS (S0,S1,S2,S3,S4);
SIGNAL CURRENT_STATE,NEXT_STATE:STATE:=S0;
SIGNAL REGL:STD_LOGIC_VECTOR(7 DOWNTO 0);
SIGNAL LOCK:STD_LOGIC;
BEGIN
ADDA=0; --进入通道1
ADDB=0;
ADDC=0;
DOUT=REGL;
LOCK0=LOCK; --转换后输出锁存信号
COM:PROCESS(CURRENT_STATE,EOC)
BEGIN
CASE CURRENT_STATE IS --5个状态
WHEN S0=ALE=0; --初始化
START=0;
文档评论(0)