首页
|
新闻
|
新品
|
文库
|
方案
|
视频
|
下载
|
商城
|
开发板
|
数据中心
|
座谈新版
|
培训
|
工具
|
博客
|
论坛
|
百科
|
GEC
|
活动
|
主题月
|
电子展
注册
登录
论坛
博客
搜索
帮助
导航
默认风格
uchome
discuz6
GreenM
»
工业控制
» 单总线温度传感器的EDA控制方法
返回列表
回复
发帖
发新话题
发布投票
发布悬赏
发布辩论
发布活动
发布视频
发布商品
单总线温度传感器的EDA控制方法
发短消息
加为好友
forsuccess
当前离线
UID
871057
帖子
6281
精华
0
积分
3141
阅读权限
90
在线时间
282 小时
注册时间
2012-2-21
最后登录
2015-6-23
论坛元老
UID
871057
性别
男
1
#
打印
字体大小:
t
T
forsuccess
发表于 2013-5-25 01:29
|
只看该作者
单总线温度传感器的EDA控制方法
温度传感器
,
接口
1 硬件接口电路
DS18B20是单总线
数字温度传感器
,测量温度范围从-55℃到125℃,测量精度为±0.5℃,通过单总线可直接输出所测温度的二进制数据,数字量的输出位数可通过编程控制,在9位至12位(含符号位)之间选择。该器件有三个端口,分别是电源端、地端、单总线数据端,在使用时将
FPGA
的I/O口和DS18B20的单总线连接,通过单总线实现FPGA与DS18B20之间的数据收发,接口电路如图1所示。
2 软件控制程序
控制DS18B20进行温度测量和读取主要包括三个步骤:器件初始化、发送写寄存器命令和发送读寄存器命令,该功能代码写在核心控制模块中,软件流程如图2所示。其中初始化是通过FPGA向总线发送低电平复位信号,持续时间为480-600us,然后FPGA释放总线,单总线经过上拉电阻会被拉至高电平,当DS18B20检测到上升沿之后,等待15-60us后将发出60-256us的低电平存在脉冲作为响应,如果FPGA检测到响应脉冲则初始化成功。
初始化成功后,FPGA通过向总线发送命令来控制传感器的温度采集,程序中用到的主要命令如下:0XCC为跳过ROM检测命令;0X44为启动温度转换命令;0XBE为从DS18B20读取温度测量数值。
在顶层代码中除了核心控制模块外,还包括包括分频模块和显示模块。
其中,分频模块将实验板上50M Hz时钟转换为1MHz输出到核心控制模块,用于控制FPGA对单总线的读、写时序。
显示模块用于将读取到的温度数据转换为十进制数据,并通过数码管进行动态显示。由于温度寄存器默认采用12位二进制数据来存储,最高位为符号位,温度分辨率为0.0625℃,如图3所示。当温度为正数时符号位为0;当温度为负数时符号位为1,且数据位采用补码的形式。因此,将温度转换成十进制数据时,首先判断符号位,当符号位为1时,先由二进制数据求出原码,再转换为十进制,最后乘以温度分辨率0.0625得到实测温度;当符号位为0时,直接将二进制转换为十进制,再乘以温度分辨率。
3 系统顶层文件
将编译好的sof程序下载到实验板中运行,能够实现环境温度的测量和显示,实际效果如图5所示。基于以上方法的温度控制系统硬件电路简单,实时性强,能够进行多路温度监控,应用范围广泛。
收藏
分享
评分
回复
引用
订阅
TOP
返回列表
电商论坛
Pine A64
资料下载
方案分享
FAQ
行业应用
消费电子
便携式设备
医疗电子
汽车电子
工业控制
热门技术
智能可穿戴
3D打印
智能家居
综合设计
示波器技术
存储器
电子制造
计算机和外设
软件开发
分立器件
传感器技术
无源元件
资料共享
PCB综合技术
综合技术交流
EDA
MCU 单片机技术
ST MCU
Freescale MCU
NXP MCU
新唐 MCU
MIPS
X86
ARM
PowerPC
DSP技术
嵌入式技术
FPGA/CPLD可编程逻辑
模拟电路
数字电路
富士通半导体FRAM 铁电存储器“免费样片”使用心得
电源与功率管理
LED技术
测试测量
通信技术
3G
无线技术
微波在线
综合交流区
职场驿站
活动专区
在线座谈交流区
紧缺人才培训课程交流区
意见和建议