欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 1992|回復(fù): 4
打印 上一主題 下一主題
收起左側(cè)

仿真通不過自己也找不出錯(cuò)誤,用PT100做的數(shù)字溫度計(jì) 單片機(jī)程序求助

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:540185 發(fā)表于 2019-5-23 22:50 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
仿真通不過自己也找不出錯(cuò)誤,用PT100做的數(shù)字溫度計(jì),ADC0808的基準(zhǔn)電壓為0.7V和5V,程序如下
#include <reg51.h>
#include <math.h>
#define uchar unsigned char

sbit START = P2^4;        //        高電平時(shí)開始轉(zhuǎn)換
sbit EOC = P2^6;        //        轉(zhuǎn)換標(biāo)志位,高電平時(shí)標(biāo)志轉(zhuǎn)換結(jié)束。
sbit CLOCK = P2^5;        //        單片機(jī)輸出脈沖信號(hào)作為轉(zhuǎn)換器的工作頻率
sbit OE = P2^7;        //        輸出使能 高電平標(biāo)志轉(zhuǎn)換結(jié)束可以開始輸出
sbit P20 = P2^0;
sbit P21 = P2^1;
sbit P22 = P2^2;
sbit P23 = P2^3;

uchar getdata;
double change;
long int temp;
uchar dispbuf[6];
uchar code table1[] = {0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};//無小數(shù)點(diǎn)0~9
uchar code table2[] = {0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,0x87,0xff,0xef};//帶小數(shù)點(diǎn)0~9

void TimeInitial()
{
        TMOD = 0x10;//定時(shí)器1選擇2^16
        TH1 = (65536-200)%256;
        EA = 1;
        ET1 = 1;
        TR1 = 1;//開定時(shí)器
}
void Delay(uchar i)
{
        unsigned int j;
        for(;i>0;i--){
                for(j = 0;j<125;j++){
                ;}
        }
}
void t1(void) interrupt 3 using 0//選用0組工作寄存器
{
        TH1 = (65536-200)/256;
        TL1 = (65536-200)%256;
        CLOCK = ~CLOCK;//取反,0.2ms給ADC0808 一個(gè)時(shí)鐘脈沖
}
void Display()//數(shù)碼管顯示程序
{
        P0 = table1[dispbuf[3]];//顯示百位
        P20 = 0;
        P21 = 1;
        P22 = 1;
        P23 = 1;
        Delay(8);
        P0 = 0x00;

        P0 = table1[dispbuf[2]];//顯示十位
        P20 = 1;
        P21 = 0;
        P22 = 1;
        P23 = 1;
        Delay(8);
        P0 = 0x00;

        P0 = table2[dispbuf[1]];//顯示個(gè)位
        P20 = 1;
        P21 = 1;
        P22 = 0;
        P23 = 1;
        Delay(8);
        P0 = 0x00;

        P0 = table1[dispbuf[0]];//顯示小數(shù)位
        P20 = 1;
        P21 = 1;
        P22 = 1;
        P23 = 0;
        Delay(8);
        P0 = 0x00;
}
void PT100(){
        double PR,aveT,aT,deal,U,aR;                //電阻值 ,溫度對(duì)電阻的變化量,溫度變化量,結(jié)果,電壓,電阻變化量
        U = 4.3/255.0*getdata;                //計(jì)算某一刻電壓值
        aR = (4.3/255*getdata)/(4.3/142.29);                //計(jì)算某一刻電阻值
        PR = 149.29-aR;                //計(jì)算電阻變化量,110度阻值為142.29
        aveT = 42.29/110.0;                //一度等于42.29/110歐姆
        aT = PR/aveT;                //溫度變化量
        deal = 10*(110.0-aT);                //所得溫度×10
        temp = (long int)deal;                //最終溫度取整(實(shí)際值乘十倍)
        if(U<5&&U>3.56){//計(jì)算-50~0的溫度
                aveT = (100.0-80.31)/50;
                PR = 100.0-aR;
                aT = 10*(PR/aveT);
                temp = (long int)aT;
                dispbuf[0] = temp%10;//計(jì)算小數(shù)位
                dispbuf[1] = temp/10%10;//計(jì)算個(gè)位
                dispbuf[2] = temp/100%10;//計(jì)算十位
                dispbuf[3] = temp%10;//顯示符號(hào)
                }
        else{
                dispbuf[0] = temp%10;
                dispbuf[1] = temp/10%10;
                dispbuf[2] = temp/100%10;
                   dispbuf[3] = temp/1000%10;//百位
                }
                Display();
}
void main(void)
{
        TimeInitial();
        while(1){
                START = 0;//關(guān)閉轉(zhuǎn)換
                OE = 0;//關(guān)閉輸出
                START = 1;//開始轉(zhuǎn)換
                START = 0;//開始輸出
                while(EOC==0){
                        OE = 1;//開啟數(shù)據(jù)輸出允許
                        Delay(10);//延時(shí)
                        getdata = P1;//模數(shù)轉(zhuǎn)換后的值給getdata
                        OE = 0;
                        PT100();//計(jì)算溫度
                }
        }
}
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:96682 發(fā)表于 2019-5-24 12:30 | 只看該作者
缺少 PT100 的溫度阻值轉(zhuǎn)換表
回復(fù)

使用道具 舉報(bào)

板凳
ID:540185 發(fā)表于 2019-5-24 15:40 | 只看該作者
wc86110 發(fā)表于 2019-5-24 12:30
缺少 PT100 的溫度阻值轉(zhuǎn)換表

是要把表加入到工程中嗎?我不太明白我已經(jīng)計(jì)算轉(zhuǎn)換后的溫度賦值給變量了啊
回復(fù)

使用道具 舉報(bào)

地板
ID:93224 發(fā)表于 2019-5-24 18:28 | 只看該作者
缺少轉(zhuǎn)換的,你可以用DS18B20精度更好
回復(fù)

使用道具 舉報(bào)

5#
ID:650126 發(fā)表于 2019-11-26 22:05 來自觸屏版 | 只看該作者
樓主,我也在做pt100,能交流下嗎
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表