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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 9945|回復: 11
打印 上一主題 下一主題
收起左側

單片機NTC熱敏電阻測溫 溫度一直對不上

  [復制鏈接]
回帖獎勵 50 黑幣 回復本帖可獲得 5 黑幣獎勵! 每人限 1 次
跳轉到指定樓層
樓主
ID:217640 發表于 2017-7-10 21:34 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式

求各位大佬幫忙看看哪里出錯了 ,這個是NTC熱敏電阻查表法測溫,但是溫度一直對不上,求大佬幫助幫助,最好請大佬幫我改一下發過來
用protues仿真一下,拜謝!809417210@qq.com

  1. #include <reg52.h>           
  2. #include <intrins.h>
  3. #include <math.h>

  4. typedef unsigned char uchar;
  5. typedef unsigned int  uint;
  6. code        uint VOL[]={   31.11,29.57,28.12,26.74,25.45,24.22,23.06,21.96,20.92,
  7.                      19.93,19.00,18.11,17.28,16.48,15.73,15.01,14.33,13.69,13.08,
  8.                                   12.50,11.94,11.42,10.92,10.45,10.00,9.57,9.16,8.77,8.40,
  9.                                  8.05,7.71,7.39,7.09,6.79,6.52,6.25,6.00,5.76,5.53,
  10.                                  5.31,5.10,4.90,4.71,4.53,4.35,4.18,4.02,3.87,3.72,3.58,
  11.                                  3.45,3.32,3.20,3.08,2.97,2.86,2.76,2.66,2.56,2.47,
  12.                                  2.38,2.30,2.22,2.14,2.07,1.99,1.93,1.86,1.80,1.74,
  13.                                  1.68,1.62,1.57,1.52,1.47,1.42,1.37,1.33,1.28,1.24,
  14.                                  1.20,1.16,1.13,1.09,1.06,1.02,0.99,0.96,0.93,0.90,
  15.                                  0.88,0.85,0.82,0.80,0.78,0.75,0.73,0.71,0.69,0.67,};

  16. code        uint Temper[]={            100,             200,        300,        400,         500,               
  17.                                                                     600,            700,        800,            900,                1000,        
  18.                                                                     1100,                1200,        1300,                1400,                1500,               
  19.                                                         1600,                1700,        1800,                1900,                2000,        
  20.                                                         2100,                2200,        2300,                2400,            2500,        
  21.                                                         2600,                2700,        2800,                2900,            3000,
  22.                                                         3100,                3200,        3300,                3400,           3500,        
  23.                                                         3600,                3700,        3800,                3900,           4000,
  24.                                                         4100,                4200,        4300,                4400,            4500,        
  25.                                                         4600,                4700,        4800,                4900,            5000,
  26.                                                         5100,       5200,        5300,            5400,            5500,        
  27.                                                         5600,            5700,        5800,            5900,            6000,
  28.                                                         6100,                6200,   6300,            6400,            6500,
  29.                                                     6600,       6700,        6800,            6900,            7000,        
  30.                                                         7100,                7200,   7300,            7400,            7500,
  31.                                                     7600,            7700,        7800,            7900,           8000,        
  32.                                                         8100,                8200,   8300,            8400,            8500,
  33.                                                         8600,            8700,        8800,            8900,            9000,        
  34.                                                         9100,            9200,        9300,            9400,            9500,
  35.                                                         9600,            9700,        9800,            9900,            10000};
  36. sbit EOC   = P1^4;  
  37. sbit CLOCK = P1^3;  
  38. sbit CS    = P1^2;  
  39. sbit DIN   = P1^1;
  40. sbit DOUT  = P1^0;


  41. sbit RS=P1^5 ;
  42. sbit RW=P1^6 ;
  43. sbit EN=P1^7 ;           

  44. void delay_ms(uint z)
  45. {
  46.         uint x,y;
  47.         for(x=z;x>0;x--)
  48.                 for(y=110;y>0;y--);
  49. }

  50. unsigned int read2543(uchar port)
  51. {
  52. uint ad,i;
  53. ad=0;
  54. CLOCK =0;
  55. CS =0;
  56. port=port<<4;

  57. for(i=0;i<12;i++)
  58. {
  59.   if(DOUT)
  60.   ad|=0x01;
  61.   DIN =(bit)(port&0x80);
  62.   CLOCK=1;
  63.   CLOCK=0;
  64.   port=port<<1;
  65.   ad<<=1;
  66. }
  67. CS = 1;
  68. ad =ad>>1;
  69. return(ad);
  70. }
  71. /*** D′êy¾Y***/
  72. void w_dat(unsigned char dat)
  73. {
  74.         RS = 1;
  75.         //EN = 0;
  76.         P2 = dat;
  77.         delay_ms(5);
  78.         RW = 0;
  79.         EN = 1;
  80.         EN = 0;
  81. }
  82. /*** D′Ãüáî***/
  83. void w_cmd(unsigned char cmd)
  84. {
  85.         RS = 0;
  86. //        EN = 0;
  87.         P2 = cmd;
  88.         delay_ms(5);
  89.         RW = 0;
  90.         EN = 1;
  91.         EN = 0;
  92. }                        
  93. /***
  94. 求各位大佬幫忙看看哪里出錯了 ,這個是NTC熱敏電阻查表法測溫,但是溫度一直對不上,求大佬幫助幫助,最好請大佬幫我改一下發過來
  95. 用protues仿真一下,拜謝!***/
  96. void w_string(unsigned char addr_start, unsigned char *p)
  97. {
  98.         unsigned char *pp;
  99.         
  100.         pp = p;
  101.         w_cmd(addr_start);
  102.         while (*pp != '\0')
  103.         {
  104.                 w_dat(*pp++);
  105.         }
  106. }           


  107. void Init_LCD1602(void)
  108. {
  109.         EN = 0;
  110.         w_cmd(0x38);  
  111.         w_cmd(0x0C);
  112.         w_cmd(0x06);
  113.         w_cmd(0x01);  
  114. }
  115. void process(uint date,uchar add)
  116. {
  117.         uchar A[7];
  118.         A[0]=date/1000%10+'0';
  119.         A[1]=date/100%10+'0';
  120.         A[2]='.';        
  121.         A[3]=date/10%10+'0';
  122.         A[4]=date%10+'0';
  123.         A[5]='C';                        
  124.         w_string(add,A);
  125. }         
  126. void main()
  127. {

  128.         uchar i,flag=0;
  129.         uint result,temp1,temp2;
  130.         float        res;

  131.         Init_LCD1602();
  132.          
  133.         w_string(0x80,"Temper:");
  134.         
  135.         while (1)
  136.         {
  137.                  res=(read2543());
  138.                  result=(uint)((10*4096/res)-10);
  139.                  
  140.                  temp1=abs(result-VOL[0]);
  141.                  for(i=1;i<101;i++)
  142.                  {
  143.                          temp2=abs(result-VOL[i]);
  144.                         if(temp1>=temp2)
  145.                         {
  146.                                 temp1=temp2;
  147.                                 flag=i;
  148.                         }
  149.                                 
  150.                  }
  151.                  process(Temper[flag],0x80+7);
  152.         }
  153. }
復制代碼

NTC熱敏電阻測溫度.zip

176.12 KB, 下載次數: 66

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂1 踩
回復

使用道具 舉報

來自 2#
ID:591703 發表于 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;
}


回復

使用道具 舉報

板凳
ID:213173 發表于 2017-7-11 05:55 | 只看該作者
本帖最后由 wulin 于 2017-7-11 14:26 編輯

見過查表數組都是10進制整數或16進制表示的
回復

使用道具 舉報

地板
ID:213173 發表于 2017-7-11 06:30 | 只看該作者
unsigned int為無符號整型數據(0-65535),數組中用的是小數。
回復

使用道具 舉報

5#
ID:217640 發表于 2017-7-11 16:20 | 只看該作者
但是怎么查表,插值法運算求電阻
回復

使用道具 舉報

6#
ID:218901 發表于 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
};
回復

使用道具 舉報

7#
ID:96072 發表于 2017-7-11 20:16 | 只看該作者
插值法運算求電阻
回復

使用道具 舉報

8#
ID:438000 發表于 2019-4-24 21:10 | 只看該作者
vcc是多少v
回復

使用道具 舉報

9#
ID:576074 發表于 2019-7-3 10:30 | 只看該作者
謝謝作者~
回復

使用道具 舉報

10#
ID:577503 發表于 2019-7-4 16:32 | 只看該作者
是不是硬件電路的問題,我看這個程序應該沒問題啊,再看看接線和電阻,希望對你有幫助
回復

使用道具 舉報

11#
ID:427818 發表于 2019-7-22 21:53 | 只看該作者
樓主解決了嗎?
回復

使用道具 舉報

12#
ID:511461 發表于 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 ;  
  
}  
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 免费看国产一级特黄aaaa大片 | 欧美日韩在线一区 | 久久精品国产亚洲 | 狠狠躁18三区二区一区 | 极品国产视频 | 国产精品久久国产精品99 gif | 日韩在线视频一区二区三区 | 欧美中文字幕在线观看 | 国产精品成人69xxx免费视频 | 精品亚洲视频在线 | 日韩毛片在线免费观看 | 国产视频一二三区 | 中文字幕国产高清 | 久久伊人亚洲 | 国产精品久久久久久久久久久久冷 | 亚洲精品久久久久久久久久久久久 | 91久久视频 | 久久久久久久国产 | 91久久精品一区二区二区 | 国产免费一区二区三区免费视频 | www.婷婷| 国产精久久久久久 | 一区二区影院 | 久草视频在线播放 | 91色综合| 欧美精品片 | 亚洲福利在线观看 | 一区二区久久 | 男女网站免费观看 | 欧美一区中文字幕 | 亚洲精品成人免费 | 日日操夜夜干 | 波多野结衣在线观看一区二区三区 | 免费国产视频在线观看 | av天天澡天天爽天天av | 欧美午夜激情在线 | 亚洲一区二区三区福利 | 日韩在线 | 日韩视频精品在线 | 久久久久久久久久久成人 | 你懂的国产 |