久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1364|回復: 0
收起左側

51單片機檢測4~20mA PT100傳感器程序

[復制鏈接]
ID:731890 發表于 2024-1-1 20:37 | 顯示全部樓層 |閱讀模式
本例程采用宏晶的STC8G1K08單片機來檢測輸出類型為4~20mA PT100傳感器的程序,在檢測中使用XPT2046作為AD的檢測芯片,XPT2046具有4路12位的AD檢測輸入端,因此最大可檢測4路傳感器,本例程中我們只使用了其中1路。檢測時使用了中值濾波算法。先看一下XPT2046的驅動程序:

/****************************************************************************
*函數名:SPI_Write
*輸  入:dat:寫入數據
*輸  出:無
*功  能:使用SPI寫入數據
****************************************************************************/

void SPI_Write(uchar dat)
{
        uchar i;
        CLK = 0;
        delay_us(2);
        for(i=0; i<8; i++)
        {
                DIN = dat >> 7;          //放置最高位
                dat <<= 1;
                CLK = 0;                        //上升沿放置數據
                delay_us(2);
                CLK = 1;
    delay_us(2);
        }
}
/****************************************************************************
*函數名:SPI_Read
*輸  入:無
*輸  出:dat:讀取 到的數據
*功  能:使用SPI讀取數據
****************************************************************************/

uint SPI_Read(void)
{
        uint i, dat=0;
        CLK = 0;
        delay_us(2);
        for(i=0; i<12; i++)                //接收12位數據
        {
                dat <<= 1;
                CLK = 1;
                delay_us(2);
                CLK = 0;
    delay_us(2);
                dat|= DOUT;

        }
        return dat;        
}

/****************************************************************************
*函數名:Read_AD_Data
*輸  入:cmd:讀取的X或者Y
*輸  出:endValue:最終信號處理后返回的值
*功  能:讀取觸摸數據
****************************************************************************/
uint Read_AD_Data(uchar cmd)
{
        uint AD_Value;
        CS  = 0;
        delay_us(2);
        CLK = 0;
        delay_us(2);
        SPI_Write(cmd);
        delay_us(6);//延時等待轉換結果        
        CLK = 1;          //發送一個時鐘周期,清除BUSY
        delay_us(2);
        CLK = 0;
        delay_us(2);
        AD_Value=SPI_Read();
        CS = 1;
        return AD_Value;        
}

下面是它的頭文件:
#ifndef          __XPT2046_H_
#define   __XPT2046_H_

#include        "STC8G.H"
#include "delay.h"
#include<intrins.h>


//---定義使用的IO口---//
sbit DOUT = P1^0;          //輸出
sbit CLK  = P3^4;          //時鐘
sbit DIN  = P3^6;          //輸入
sbit CS   = P3^5;          //片選

uint Read_AD_Data(uchar cmd);
uint SPI_Read(void);
void SPI_Write(uchar dat);

#endif


以下是主程序:
#include "STC8G.H"
#include "delay.h"
#include "uart1.h"
#include "XPT2046.h"

#define voltage 5.00
#define ncnt   127                             //采集次數必須為奇數

float sum=0;                                                                //浮點型溫度值
float val=0;                                                                //AD采集到的電壓值
unsigned int temd;                                                                                //排序中間轉換變量
unsigned int temp;                                                                                //用取取緩存中的中間值
xdata unsigned int value_buf[ncnt];                          //AD采集存儲緩存
int wendu;                                                                   //整數型溫度變量
char count, i,j;                                                //排序計數變量
unsigned char puf[6];


void main()
{

        P_SW1 = 0x10;//RXD/P3.0, TXD/P3.1
        Uart1_Init();
  P1M0 = 0x00;                 //設置為準雙向口
        P1M1 = 0X00;
        P3M0 = 0x70;                 //設置為推挽輸出
        P3M1 = 0X00;

  while(1)
        {
                //temp = Read_AD_Data(0x94);//AIN0
                //temp = Read_AD_Data(0xD4);//AIN1
                //temp = Read_AD_Data(0xA4);//AIN2
                //temp = Read_AD_Data(0xE4);//AIN3
               
                for (count=0; count<ncnt; count++)                                                                    //連續采集ncnt次
                {
                 value_buf[count]= Read_AD_Data(0x94);             //將采集到的數據存到value_buf中
                }
                        for (j=0;j<ncnt-1;j++)                                                                                                     //將采集到的數據從小到大排列
                        {
                                for (i=0;i<ncnt-j;i++)                                                        //通過for循環排列數據
                                {
                                        if (value_buf[ i] > value_buf[i+1])                                          //如果前一個元素大于后一個元素
                                        {
                                                temd = value_buf[ i];                                                      //則將大的元素賦值給temd
                                                value_buf[ i] = value_buf[i+1];                                            //將小值賦給前一個元素
                                                value_buf[i+1] = temd;                                                    //將大值賦給后一個元素
                                        }
                                }
                        }
                        
                temp=value_buf[(ncnt-1)/2];                                                                                                   //取緩存中的中間值        
                val=temp*voltage/4096.0;                                                                                                   //算出當前電壓,5.01是AD基準值,跟據實際電壓自行修改
                sum=((250.00*val)/2.40)-112.50;                                                                     //根據公式計算出當前溫度,公式: T=(250/2.4)*V-112.5
                wendu=(int)(sum*10);                                                                                                                          //將浮點數*10轉換為整數型數據
               
                if(wendu&0x8000)                                                                                                                                    //如果溫度為負值
                {
                        wendu=((~wendu)&0x7fff)+1;                                                                                          //則取反加1
                        puf[0]='-';                                                                                                                                 //加上負數標志位'-'
                }        
                else if((wendu/1000)==0){
                        puf[0]=' ';
                }else puf[0]=wendu/1000+0x30;
               
                if(((wendu/1000)==0)&&((wendu%1000/100)==0))                          //如果最高兩位都為0
                        puf[1]=' ';                                                                                                                                                    //則不顯示
                else puf[1]=wendu%1000/100+0x30;                                                        //否則正常顯示數
               
                puf[2]=wendu%1000%100/10+0x30;
                puf[3]='.';
                puf[4]=wendu%1000%100%10+0x30;
   // Uart1_SendString(puf);
               
                //Uart1_SendChar(temp/256);
                //Uart1_SendChar(temp%256);
                delay_ms(300);
                }
}

原理圖: 無
仿真: 無
Keil代碼: PT00串口.7z (29.44 KB, 下載次數: 25)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲一区二区三区在线播放 | 性高湖久久久久久久久3小时 | 一区二区视频在线 | 亚洲激精日韩激精欧美精品 | 在线成人一区 | 日韩国产一区二区三区 | 日本亚洲欧美 | 久久综合狠狠综合久久综合88 | 日本精品在线观看 | 日韩在线视频一区二区三区 | 国产一级毛片精品完整视频版 | 欧美一级淫片免费视频黄 | 国产精品一区三区 | 欧美乱人伦视频 | 中文字幕一级毛片 | 国产大学生情侣呻吟视频 | 中文字幕视频在线观看 | 天天插天天搞 | 国产美女久久久 | 成人一区av偷拍 | 欧美极品在线视频 | 91在线电影 | 三级视频在线观看电影 | 黄色a级一级片 | 欧洲国产精品视频 | 午夜爱爱网| 国产精品免费一区二区三区四区 | 精品一二三区在线观看 | 羞视频在线观看 | 麻豆av在线 | 久久国产精品精品国产色婷婷 | 九色在线视频 | 国产一级片免费视频 | 国产精品一区二区日韩 | 91成人精品 | 国产激情在线观看 | 精品国产乱码 | 人人人人人爽 | 欧美精品在线播放 | 亚洲九九 | 成人免费小视频 |