久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费
標題:
單片機NTC熱敏電阻測溫 溫度一直對不上
[打印本頁]
作者:
zyq123456789
時間:
2017-7-10 21:34
標題:
單片機NTC熱敏電阻測溫 溫度一直對不上
求各位大佬幫忙看看哪里出錯了 ,這個是NTC熱敏電阻查表法測溫,但是溫度一直對不上,求大佬幫助幫助,最好請大佬幫我改一下發過來
用protues仿真一下,拜謝!
809417210@qq.com
#include <reg52.h>
#include <intrins.h>
#include <math.h>
typedef unsigned char uchar;
typedef unsigned int uint;
code uint VOL[]={ 31.11,29.57,28.12,26.74,25.45,24.22,23.06,21.96,20.92,
19.93,19.00,18.11,17.28,16.48,15.73,15.01,14.33,13.69,13.08,
12.50,11.94,11.42,10.92,10.45,10.00,9.57,9.16,8.77,8.40,
8.05,7.71,7.39,7.09,6.79,6.52,6.25,6.00,5.76,5.53,
5.31,5.10,4.90,4.71,4.53,4.35,4.18,4.02,3.87,3.72,3.58,
3.45,3.32,3.20,3.08,2.97,2.86,2.76,2.66,2.56,2.47,
2.38,2.30,2.22,2.14,2.07,1.99,1.93,1.86,1.80,1.74,
1.68,1.62,1.57,1.52,1.47,1.42,1.37,1.33,1.28,1.24,
1.20,1.16,1.13,1.09,1.06,1.02,0.99,0.96,0.93,0.90,
0.88,0.85,0.82,0.80,0.78,0.75,0.73,0.71,0.69,0.67,};
code uint Temper[]={ 100, 200, 300, 400, 500,
600, 700, 800, 900, 1000,
1100, 1200, 1300, 1400, 1500,
1600, 1700, 1800, 1900, 2000,
2100, 2200, 2300, 2400, 2500,
2600, 2700, 2800, 2900, 3000,
3100, 3200, 3300, 3400, 3500,
3600, 3700, 3800, 3900, 4000,
4100, 4200, 4300, 4400, 4500,
4600, 4700, 4800, 4900, 5000,
5100, 5200, 5300, 5400, 5500,
5600, 5700, 5800, 5900, 6000,
6100, 6200, 6300, 6400, 6500,
6600, 6700, 6800, 6900, 7000,
7100, 7200, 7300, 7400, 7500,
7600, 7700, 7800, 7900, 8000,
8100, 8200, 8300, 8400, 8500,
8600, 8700, 8800, 8900, 9000,
9100, 9200, 9300, 9400, 9500,
9600, 9700, 9800, 9900, 10000};
sbit EOC = P1^4;
sbit CLOCK = P1^3;
sbit CS = P1^2;
sbit DIN = P1^1;
sbit DOUT = P1^0;
sbit RS=P1^5 ;
sbit RW=P1^6 ;
sbit EN=P1^7 ;
void delay_ms(uint z)
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
unsigned int read2543(uchar port)
{
uint ad,i;
ad=0;
CLOCK =0;
CS =0;
port=port<<4;
for(i=0;i<12;i++)
{
if(DOUT)
ad|=0x01;
DIN =(bit)(port&0x80);
CLOCK=1;
CLOCK=0;
port=port<<1;
ad<<=1;
}
CS = 1;
ad =ad>>1;
return(ad);
}
/*** D′êy¾Y***/
void w_dat(unsigned char dat)
{
RS = 1;
//EN = 0;
P2 = dat;
delay_ms(5);
RW = 0;
EN = 1;
EN = 0;
}
/*** D′Ãüáî***/
void w_cmd(unsigned char cmd)
{
RS = 0;
// EN = 0;
P2 = cmd;
delay_ms(5);
RW = 0;
EN = 1;
EN = 0;
}
/***
求各位大佬幫忙看看哪里出錯了 ,這個是NTC熱敏電阻查表法測溫,但是溫度一直對不上,求大佬幫助幫助,最好請大佬幫我改一下發過來
用protues仿真一下,拜謝!***/
void w_string(unsigned char addr_start, unsigned char *p)
{
unsigned char *pp;
pp = p;
w_cmd(addr_start);
while (*pp != '\0')
{
w_dat(*pp++);
}
}
void Init_LCD1602(void)
{
EN = 0;
w_cmd(0x38);
w_cmd(0x0C);
w_cmd(0x06);
w_cmd(0x01);
}
void process(uint date,uchar add)
{
uchar A[7];
A[0]=date/1000%10+'0';
A[1]=date/100%10+'0';
A[2]='.';
A[3]=date/10%10+'0';
A[4]=date%10+'0';
A[5]='C';
w_string(add,A);
}
void main()
{
uchar i,flag=0;
uint result,temp1,temp2;
float res;
Init_LCD1602();
w_string(0x80,"Temper:");
while (1)
{
res=(read2543());
result=(uint)((10*4096/res)-10);
temp1=abs(result-VOL[0]);
for(i=1;i<101;i++)
{
temp2=abs(result-VOL[i]);
if(temp1>=temp2)
{
temp1=temp2;
flag=i;
}
}
process(Temper[flag],0x80+7);
}
}
復制代碼
NTC熱敏電阻測溫度.zip
2017-7-10 21:33 上傳
點擊文件名下載附件
176.12 KB, 下載次數: 66
作者:
wulin
時間:
2017-7-11 05:55
本帖最后由 wulin 于 2017-7-11 14:26 編輯
見過查表數組都是10進制整數或16進制表示的
作者:
wulin
時間:
2017-7-11 06:30
unsigned int為無符號整型數據(0-65535),數組中用的是小數。
作者:
zyq123456789
時間:
2017-7-11 16:20
但是怎么查表,插值法運算求電阻
作者:
jmpxwh
時間:
2017-7-11 17:43
我做過的一個是這樣的數組:
//NTC使用MF52-103/3435;10K±1%精度;B值:3435±1%
/*************************************
NTC阻值與溫度關系表
Vcc---NTC(±1%)---R(10K±1%)---GND
|
ADC端子
**************************************/
unsigned int code NTCcode[] = {
/*ADC采樣值****溫度值*******電阻值**********/
0x033, // -40.00 190.5562
0x034, // -39.00 183.4132
0x037, // -38.00 175.6740
0x039, // -37.00 167.6467
0x03c, // -36.00 159.5647
0x03f, // -35.00 151.5975
0x042, // -34.00 143.8624
0x045, // -33.00 136.4361
0x049, // -32.00 129.3641
0x04d, // -31.00 122.6678
0x050, // -30.00 116.3519
0x054, // -29.00 110.4098
0x059, // -28.00 104.8272
0x05d, // -27.00 99.5847
0x061, // -26.00 94.6608
0x066, // -25.00 90.0326
0x06a, // -24.00 85.6778
0x06f, // -23.00 81.5747
0x074, // -22.00 77.7031
0x079, // -21.00 74.0442
0x07e, // -20.00 70.5811
0x084, // -19.00 67.2987
0x089, // -18.00 64.1834
0x08f, // -17.00 61.2233
0x095, // -16.00 58.4080
0x09b, // -15.00 55.7284
0x0a1, // -14.00 53.1766
0x0a8, // -13.00 50.7456
0x0af, // -12.00 48.4294
0x0b5, // -11.00 46.2224
0x0bd, // -10.00 44.1201
0x0c4, // -9.00 42.1180
0x0cb, // -8.00 40.2121
0x0d3, // -7.00 38.3988
0x0db, // -6.00 36.6746
0x0e3, // -5.00 35.0362
0x0eb, // -4.00 33.4802
0x0f3, // -3.00 32.0035
0x0fb, // -2.00 30.6028
0x0104, // -1.00 29.2750
0x010d, // 0.00 28.0170
0x0115, // 1.00 26.8255
0x011e, // 2.00 25.6972
0x0127, // 3.00 24.6290
0x0130, // 4.00 23.6176
0x0139, // 5.00 22.6597
0x0142, // 6.00 21.7522
0x014b, // 7.00 20.8916
0x0154, // 8.00 20.0749
0x015d, // 9.00 19.2988
0x0166, // 10.00 18.5600
0x0167, // 11.00 18.4818
0x016b, // 12.00 18.1489
0x0172, // 13.00 17.6316
0x017b, // 14.00 16.9917
0x0185, // 15.00 16.2797
0x0190, // 16.00 15.5350
0x019c, // 17.00 14.7867
0x01a9, // 18.00 14.0551
0x01b6, // 19.00 13.3536
0x01c2, // 20.00 12.6900
0x01cf, // 21.00 12.0684
0x01dc, // 22.00 11.4900
0x01e8, // 23.00 10.9539
0x01f4, // 24.00 10.4582
0x01ff, // 25.00 10.0000
0x020a, // 26.00 9.5762
0x0215, // 27.00 9.1835
0x021f, // 28.00 8.8186
0x0229, // 29.00 8.4784
0x0233, // 30.00 8.1600
0x023c, // 31.00 7.8608
0x0245, // 32.00 7.5785
0x024e, // 33.00 7.3109
0x0257, // 34.00 7.0564
0x0260, // 35.00 6.8133
0x0268, // 36.00 6.5806
0x0271, // 37.00 6.3570
0x0279, // 38.00 6.1418
0x0282, // 39.00 5.9343
0x028a, // 40.00 5.7340
0x0292, // 41.00 5.5405
0x029a, // 42.00 5.3534
0x02a2, // 43.00 5.1725
0x02aa, // 44.00 4.9976
0x02b1, // 45.00 4.8286
0x02b9, // 46.00 4.6652
0x02c1, // 47.00 4.5073
0x02c8, // 48.00 4.3548
0x02d0, // 49.00 4.2075
0x02d7, // 50.00 4.0650
0x02de, // 51.00 3.9271
0x02e5, // 52.00 3.7936
0x02ec, // 53.00 3.6639
0x02f3, // 54.00 3.5377
0x02fa, // 55.00 3.4146
0x0301, // 56.00 3.2939
0x0308, // 57.00 3.1752
0x030f, // 58.00 3.0579
0x0316, // 59.00 2.9414
0x031d, // 60.00 2.8250
0x0320, // 61.00 2.7762
0x0324, // 62.00 2.7179
0x0328, // 63.00 2.6523
0x032d, // 64.00 2.5817
0x0331, // 65.00 2.5076
0x0336, // 66.00 2.4319
0x033b, // 67.00 2.3557
0x0341, // 68.00 2.2803
0x0346, // 69.00 2.2065
0x034b, // 70.00 2.1350
0x034f, // 71.00 2.0661
0x0354, // 72.00 2.0004
0x0358, // 73.00 1.9378
0x035d, // 74.00 1.8785
0x0361, // 75.00 1.8225
0x0365, // 76.00 1.7696
0x0368, // 77.00 1.7197
0x036c, // 78.00 1.6727
0x036f, // 79.00 1.6282
0x0372, // 80.00 1.5860
0x0376, // 81.00 1.5458
0x0378, // 82.00 1.5075
0x037b, // 83.00 1.4707
0x037e, // 84.00 1.4352
0x0381, // 85.00 1.4006
0x0383, // 86.00 1.3669
0x0386, // 87.00 1.3337
0x0389, // 88.00 1.3009
0x038b, // 89.00 1.2684
0x038e, // 90.00 1.2360
0x0391, // 91.00 1.2037
0x0393, // 92.00 1.1714
0x0396, // 93.00 1.1390
0x0399, // 94.00 1.1067
0x039b, // 95.00 1.0744
0x039e, // 96.00 1.0422
0x03a1, // 97.00 1.0104
0x03a3, // 98.00 0.9789
0x03a6, // 99.00 0.9481
0x03a8, // 100.00 0.9180
0x03ab, // 101.00 0.8889
0x03ad, // 102.00 0.8610
0x03b0, // 103.00 0.8346
0x03b2, // 104.00 0.8099
0x03b4, // 105.00 0.7870
0x03b6, // 106.00 0.7665
0x03b7, // 107.00 0.7485
0x03b9, // 108.00 0.7334
0x03ba, // 109.00 0.7214
0x03ba // 110.00 0.7130
};
作者:
HEIZI555
時間:
2017-7-11 20:16
插值法運算求電阻
作者:
qqq112
時間:
2019-4-24 21:10
vcc是多少v
作者:
123lht
時間:
2019-7-3 10:30
謝謝作者~
作者:
zfddfer741
時間:
2019-7-4 16:32
是不是硬件電路的問題,我看這個程序應該沒問題啊,再看看接線和電阻,希望對你有幫助
作者:
jyk
時間:
2019-7-22 21:53
樓主解決了嗎?
作者:
天空618
時間:
2019-7-29 18:29
//ad值最大4096
//下偏rntc=(4096*上偏電阻)/4096-ad
//上偏ntc=(4096-ad)*上偏電阻/ad
查表法 放阻值表
tmp[50]={,,,,,10000,,,,,,};//0~49度
//1000對應25度
//輸人電阻值返回溫度
//返回值為三位整數,方便數碼管顯示
u16 get_Temperature(u16 ntc)
{
u16 i,tmpL,tmpH;
u16 t,ftmp; //溫度整數和小數
if(ntc<10000)//如果小于25度向前查
for(i=25;i>0;i--)//25是數組下標表示25度
{
if(ntc>tmp[i])
{
tmpL=tmp[i];//實測阻值的前后溫度
tmpH=tmp[i+1];//用于計算小數點位
t=i; //得到對應溫度
i=0;//退出循環否則i--為0
}
// ftmp=(ntc- tmpL) *10/( tmpH- tmpL);
}
else //向后查
for(i=25;i<50;i++)
{
if( ntc<tmp[i])
{
tmpH=tmp[i];//注意哪個是高
tmpL=tmp[i-1];
t=i;
i=50;//退出循環
}
}
//計算小數 *10取整數
ftmp=(ntc- tmpL) *10/( tmpH- tmpL);
t=t*10+ftmp;
return t;
}
作者:
aaaaaa。
時間:
2019-7-29 19:19
建議二分查找法
#define TempSize 100 //定義表長度
//溫度值對應的AD值的表的定義
const int16 TabNtc_100K[TempSize]={0xf00,0xe00,oxd00,......};
int16 *pTmp ; //定義一個字長的指針
pTmp = TabNtc_100K ; //指向要溫度表的地址
CuTemp = FineTab(pTmp,TempSize,R_NTCAD); //查表得出溫度 R_NTCAD為NTC分壓得出的AD值
********************************************/
//*************************************
// 函數名稱:FineTab 二分查找算法 ->查溫度表
// 函數功能:查找數據在表中對應的位置 表中數據從大到小
// 入口參數:表地址、表長度、要查找的數據
// 出口參數:無
// 返 回 值:數據在表中的位置
//*************************************
uint8 FineTab(uint16 *a,uint8 TabLong,uint16 data)//表中數據從大到小
{
uint8 st,ed,m ;
uint8 i ;
st = 0 ;
ed = TabLong-1 ;
i = 0 ;
if(data >= a[st]) return st ;
else if(data <= a[ed]) return ed ;
while(st < ed)
{
m = (st+ed)/2 ;
if(data == a[m] ) break ;
if(data < a[m] && data > a[m+1]) break ;
if(data > a[m]) ed = m ;
else st = m ;
if(i++ > TabLong) break ;
}
if(st > ed ) return 0 ;
return m ;
}
//*************************************
// 函數名稱:FineTab 二分查找算法 ->查溫度表
// 函數功能:查找數據在表中對應的位置 表中數據從小到大
// 入口參數:表地址、表長度、要查找的數據
// 出口參數:無
// 返 回 值:數據在表中的位置
//***************************************
uint8 FineTab(uint16 *a,uint8 TabLong,uint16 dat)//表中數據從小到大
{
uint8 st,ed,m ;
uint8 i ;
st = 0 ;
ed = TabLong-1 ;
i = 0 ;
if(dat >= a[ed]) return ed ;
else if(dat <= a[st]) return st ;
while(st < ed)
{
m = (st+ed)/2 ;
if(dat == a[m] ) break ;
if(dat < a[m+1] && dat > a[m]) break ;
if(dat > a[m]) st = m ; //ed = m ;
else ed = m ;//st = m ;
if(i++ > TabLong) break ;
}
if(st > ed ) return 0 ;
return m ;
}
歡迎光臨 (http://www.zg4o1577.cn/bbs/)
Powered by Discuz! X3.1
主站蜘蛛池模板:
久久精品亚洲精品国产欧美
|
天天色综
|
亚洲一区二区综合
|
九色av
|
午夜电影福利
|
欧美日韩综合一区
|
91天堂网
|
91新视频
|
一区二区三区免费
|
在线观看国产www
|
一区二区三区国产好
|
国产aⅴ爽av久久久久久久
|
99精品国产成人一区二区
|
中文字幕在线一区
|
日韩欧美一区二区三区免费观看
|
夜夜草
|
黄色网址免费在线观看
|
国产乱码精品一区二区三区五月婷
|
亚洲一区二区中文字幕
|
中文字幕亚洲一区二区va在线
|
国产最好的av国产大片
|
一级欧美视频
|
欧美日韩久久
|
91久久伊人
|
中文字幕在线免费观看
|
午夜男人的天堂
|
日韩和的一区二在线
|
亚洲欧美在线一区
|
羞羞涩涩在线观看
|
一区二区三区视频
|
久久久资源
|
国产精品久久亚洲
|
日韩精品久久一区二区三区
|
国产a视频
|
成人欧美日韩一区二区三区
|
五月婷婷激情
|
精品在线一区二区三区
|
蜜桃官网
|
精精国产xxxx视频在线播放7
|
精品国产乱码久久久久久牛牛
|
日韩精品在线一区
|