找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3117|回复: 2
打印 上一主题 下一主题
收起左侧

51单片机+MAX6675 TCK 8路测温程序Proteus仿真 学习总结

[复制链接]
跳转到指定楼层
楼主
51单片机制作的MAX6675,TCK 8路测温,学习总结。。。。
网上没有找到MAX6675详细的读温度程序代码,只有不完整的时序图。。。。
从仿真中得出结论。。。。
想成功,读出一个温度,需要32个时钟脉冲。。。而不是16时钟脉冲。。。
首先CS片选为低电平时,16个连续时钟脉冲,MAX6675把TCK模拟转化一个0x0~0xfff
的数,高位添加1位,低位添加3位,形成我们需要读取的16位数字信号。。。。。
转化完成后,CS无论高电平还是低电平,再有16个连续时钟脉冲,SO就会输出16位数字信号。。
如果,多路循环测温。MAX6675把16位数字信号转化好后。把CS置1,同时把下一路MAX6675 CS置0.。
再来16个连续时钟脉冲。读取数据同时,又把下一路的16位数字信号转化好了。。。


仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. #include "read_temp.h"


  2. uint tem_convert(uint tem)
  3. {
  4.         if(tem<7)                                                //0
  5.                 return 0;
  6.         else if(tem<11)                                //1
  7.                 return 1;
  8.         else if(tem<15)                                //2
  9.                 return 2;
  10.         else if(tem<19)                                //3
  11.                 return 3;
  12.         else if(tem <= 648)                  //<=162
  13.                 return tem/4;
  14.         else if(tem <= 718)                         //<=180
  15.                 return (uint)(tem/4.0+0.5);
  16.         else if(tem <= 784)                  //<=197
  17.                 return tem/4+1;
  18.         else if(tem <= 968)                  //<=244
  19.                 return tem/4+2;
  20.         else if(tem<=1223)                        //<=308
  21.                 return tem/4+3;
  22.         else if(tem <= 1467)                        //<=368
  23.                 return tem/4+2;
  24.         else if(tem <= 1627)                        //<=407
  25.                 return tem/4+1;
  26.         else if(tem <= 1763)                        //<=440
  27.                 return tem/4;
  28.         else if(tem <= 1883)                        //<=469
  29.                 return tem/4-1;
  30.         else if(tem <= 1999)                 //<=497
  31.                 return tem/4-2;
  32.         else if(tem <= 2111)                        //<=524
  33.                 return tem/4-3;
  34.         else if(tem <= 2223)                        //<=551
  35.                 return tem/4-4;
  36.         else if(tem <= 2339)                        //<=579
  37.                 return tem/4-5;
  38.         else if(tem <= 2459)                        //<=608
  39.                 return tem/4-6;
  40.         else if(tem <= 2591)                        //<=640
  41.                 return tem/4-7;
  42.         else if(tem <= 2747)                        //<=678
  43.                 return tem/4-8;
  44.         else if(tem <= 2983)                         //<=736
  45.                 return tem/4-9;
  46.         else if(tem <= 3392)                         //<=838
  47.                 return tem/4-10;
  48.         else if(tem <= 3604)                         //<=892
  49.                 return tem/4-9;
  50.         else if(tem <= 3736)                         //<=926
  51.                 return tem/4-8;
  52.         else if(tem <= 3840)                         //<=953
  53.                 return tem/4-7;
  54.         else if(tem <= 3928)                         //<=976
  55.                 return tem/4-6;
  56.         else if(tem <= 4008)                         //<=997
  57.                 return tem/4-5;
  58.         else if(tem <= 4080)                         //<=1016
  59.                 return tem/4-4;
  60.         else                                                                 //最大量程1020
  61.                 return tem/4-3;
  62. }

  63. void max6675_ADcnve(uchar cs)
  64. {
  65.         uchar i=0;
  66.         cs |= 0xf0;
  67.         CSp2 |= 0x0f;
  68.         SCK=0;
  69.         _nop_();_nop_();
  70.         CSp2&=cs;
  71.         for(i=0;i<16;i++)
  72.         {
  73.                 _nop_();_nop_();
  74.                 SCK=1;
  75.                 _nop_();_nop_();_nop_();
  76.                 SCK=0;
  77.                 _nop_();
  78.         }
  79. }
  80. uint read_tem(uchar tck)
  81. {
  82.         uchar i;
  83.         uint Temp=0;
  84.          
  85.         //tck=(tck==7)? 0 : tck+1;
  86.         max6675_ADcnve(tck);
  87.        
  88.         tck|=0xf0;
  89.         CSp2 |= 0x0f;
  90.         SCK=0;
  91.         _nop_();_nop_();
  92.         //CSp2&=tck;
  93.         for(i=0;i<16;i++)
  94.         {
  95.                 Temp<<=1;
  96.                 _nop_();
  97.                 SCK=1;
  98. ……………………

  99. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载(仿真程序):
MAX6675_AD转换.rar (88.13 KB, 下载次数: 80)


评分

参与人数 1黑币 +80 收起 理由
admin + 80 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏2 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:328014 发表于 2020-11-6 17:32 | 只看该作者
好资料,51黑有你更精彩!!!
回复

使用道具 举报

板凳
ID:417092 发表于 2020-11-21 01:24 | 只看该作者
51hei团团 发表于 2020-11-6 17:32
好资料,51黑有你更精彩!!!

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表