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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

用STC12C5608AD單片機測量18650鋰電池內阻 附源程序

  [復制鏈接]
跳轉到指定樓層
樓主
蘋果充電線里面有個貼片場效應管,導通電流4A蠻大的,如圖



于是找來個6W3R9的水泥電阻做負載(4.2/3.9=1安電流左右),用個7805適應寬電壓工作(6v-36v),如果只用5v供電還可以取消7805使電路更簡單




測試電池內阻為0.527歐(隨便測一兩個丟久了的18650,下次測量個0.01以下的會上圖),不放電池顯示9999






最后是單片機程序了

  1. #include<reg51.h>//內部晶振大約5.5mhz
  2. #define u8 unsigned char
  3. #define u16 unsigned int
  4. sbit w1=P3^2;sbit w2=P3^3;sbit w3=P3^4;sbit w4=P3^5; //4個數碼管
  5. sbit a=P3^0;sbit b=P3^1;sbit c=P1^2;sbit d=P1^3;sbit e=P1^4;
  6. sbit f=P1^5;sbit g=P1^6;sbit dp=P1^7;//共陽數碼管8段
  7. u8 time,shu,i;bit F_1s,F_ad;u16 t;sbit open=P3^7;
  8. /*聲明與ADC有關的寄存器*/
  9. sfr ADC_CONTR = 0xc5; //ADC控制寄存器
  10. sfr ADC_DATA = 0xc6; //ADC轉換結果寄存器 高8位
  11. sfr ADC_LOW2 = 0xBE; //ADC轉換結果寄存器 低8位
  12. sfr P1M0 = 0x91; //P1口模式控制寄存器0
  13. sfr P1M1 = 0x92; //P1口模式控制寄存器1
  14. sfr P3M0 = 0xb1;
  15. sfr P3M1 = 0xb2;
  16. /*定義ADC控制寄存器里的操作常量*/
  17. #define ADC_POWER 0X80 //ADC電源控制位
  18. #define ADC_FLAG 0X10 //ADC轉換結束標志位
  19. #define ADC_START 0x08 //ADC開始控制位

  20. void Delay(u16 n){while(--n);}//stc12內晶振約5.5MHZ 時間us=n*1.17
  21. //1=3us;10=13us;100=118us;1000=1.169ms;10000=11.678ms;
  22. void disp()
  23. {Delay(2000);//調節數碼管亮度
  24. for(i=0;i<4;i++){if(i==0){w1=1;shu=t/1000;}if(i==1){w2=1;shu=t%1000/100;}
  25.      if(i==2){w3=1;shu=t%100/10;}if(i==3){w4=1;shu=t%10;}dp=1;
  26.      switch(shu)  //我數碼管沒有小數點,所以dp都=1,最大顯示9999毫毆
  27.      {case 0:a=0;b=0;c=0;d=0;e=0;f=0;g=1;break;        //0
  28.       case 1:a=1;b=0;c=0;d=1;e=1;f=1;g=1;break;        //1
  29.       case 2:a=0;b=0;c=1;d=0;e=0;f=1;g=0;break;//2
  30.       case 3:a=0;b=0;c=0;d=0;e=1;f=1;g=0;break;//3
  31.       case 4:a=1;b=0;c=0;d=1;e=1;f=0;g=0;break;//4
  32.       case 5:a=0;b=1;c=0;d=0;e=1;f=0;g=0;break;//5
  33.           case 6:a=0;b=1;c=0;d=0;e=0;f=0;g=0;break;//6
  34.       case 7:a=0;b=0;c=0;d=1;e=1;f=1;g=1;break;//7
  35.       case 8:a=0;b=0;c=0;d=0;e=0;f=0;g=0;break;//8
  36.       case 9:a=0;b=0;c=0;d=0;e=1;f=0;g=0;break;        //9
  37.       default:break;}
  38.   Delay(200);//段位接IO腳可以任意改對接數碼管
  39.    w1=0;w2=0;w3=0;w4=0;a=1;b=1;c=1;d=1;e=1;f=1;g=1;}}

  40. /*****初始化ADC寄存器*****/
  41. void ADint()
  42. {
  43. ADC_DATA = 0; //清除以前的結果
  44. ADC_CONTR = ADC_POWER;
  45. Delay(10000);//等待AD上電完成
  46. }

  47. /****獲取ADC轉換結果*****/
  48. u8 ADget(u8 ch2)
  49. {ADC_CONTR=ADC_POWER|ADC_START|ch2; //配置初始化
  50. Delay(1);
  51. while(!(ADC_CONTR&ADC_FLAG)); //等待轉換完成
  52. ADC_CONTR &= ~ADC_FLAG; //關閉ADC
  53. return ADC_DATA; //返回ADC轉換結果
  54. }

  55. void t0int() //定時器T0初始化
  56. {TMOD=0x01;TH0=0x00; TL0=0x00;EA=1; //開總中斷
  57. ET0 = 1; //開定時器中斷
  58. TR0 = 1; //啟動定時器T0;
  59. }//用內部5.5晶振,所以時間=65536*12/5.5=142987us約=143ms一周                                          

  60. void main()
  61. {u16 s0,s1,s2;bit F_s,F_r,ch=0;u8 i,j,temp,n=0,buf[11];//2秒一次,采樣11次取中數
  62. P1M0=0x03;P1M1=0;
  63. P3M0=0;P3M1=0xbc;
  64. open=1;w1=0;w2=0;w3=0;w4=0;
  65. t0int(); //定時=定時*12/晶振(5.5)
  66. ADint(); //初始化ADC寄存器
  67. ADget(0); //調用ADC采集函數
  68. ADget(1); //采兩次不用
  69. while(1){if((!open)||(F_s)){buf[n]=ADget(ch);//采樣11個值到數組
  70.      n++;if(n==11){n=0;F_ad=1;if(ch){open=1;F_s=1;}}}
  71.      if(F_ad){F_ad=0;for(j=0;j<6;j++)//比較11個數后取中數
  72.                          {for(i=0;i<10-j;i++)
  73.                              {if(buf[i]>buf[i+1])
  74.                                  {temp=buf[i];
  75.                                   buf[i]=buf[i+1];
  76.                                   buf[i+1]=temp;}
  77.                                                           }}//比較兩數的大小,如果大就往后排
  78.                                 ch=~ch;if((ch)&&(F_s)){F_r=1;F_s=0;ch=0;s0=buf[5];
  79.                                 s0=s0<<2|ADC_LOW2;}else if(ch){s1=buf[5];
  80.                                 s1=s1<<2|ADC_LOW2;}else{s2=buf[5];s2=s2<<2|ADC_LOW2;}
  81.                                 ADC_DATA=0;ADC_LOW2=0;}//比較10次大小后,中數已經在buf[5]
  82. //順序采三次DATA:負載電池兩端(P1.0采)到電阻兩端(P1.1采)到空載電池兩端(P1.0采)
  83.    if(F_1s){F_1s=0;open=0;}//幾秒后開負載                                
  84.    if(F_r){F_r=0;s0-=s1;t=(float)(s0*3.9/s2*1.0+0.0005)*1000;
  85.       if(t>9999)t=9999;}
  86.    //10位公式:ADC_DATA<<2|ADC_LOW2=1024*Vin/Vcc
  87.   //化簡公式后內阻=(空載電池兩端ADC_DATA-負載電池兩端ADC_DATA)*
  88.   //3R9(負載電阻)/負載電阻上兩端ADC_DATA
  89.   disp();}
  90. }

  91. void timer_0() interrupt 1
  92. {TH0=0;TL0=0;time++;
  93. if(time==50) //一周約143ms.50*143=7秒
  94. {time=0;F_1s=1;}
  95. }
復制代碼



以上代碼下載(就是這網頁上的一模一樣的):
650.rar (1.93 KB, 下載次數: 72)

評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:961710 發表于 2021-8-30 17:52 | 只看該作者
你好!接線圖有沒有沒有?最好能發一張,謝謝
回復

使用道具 舉報

板凳
ID:961710 發表于 2021-8-30 18:05 | 只看該作者
您好接線圖發一下,謝謝
回復

使用道具 舉報

地板
ID:72088 發表于 2021-8-30 19:19 | 只看該作者
測內阻要恒流放電,你這簡單一個大功率電阻,誤差很大的,沒有參考意義
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 高清一区二区 | 一道本视频 | 神马福利 | 国产欧美日韩在线播放 | 亚洲精品视频一区 | 国产欧美一区二区精品久导航 | aa级毛片毛片免费观看久 | 99热.com | 国产农村妇女毛片精品久久麻豆 | 天天射网站 | 久久亚洲一区二区三区四区 | 亚洲美女一区二区三区 | 久久久久久久久久久成人 | 午夜视频网站 | 91精品亚洲 | 亚洲一区二区三区观看 | 亚洲精品视频免费观看 | 成人久久久| 日韩av在线一区 | www国产成人免费观看视频 | 91在线电影 | 国产成人综合在线 | 欧美一级毛片免费观看 | 国产传媒毛片精品视频第一次 | 亚洲日韩中文字幕一区 | 一区二区三区四区在线视频 | 亚洲三级av| 在线观看视频h | 日韩中文字幕在线观看 | 欧美在线综合 | 超碰91在线| av乱码 | www.av7788.com| 91社影院在线观看 | 欧美性视频在线播放 | 日韩中出 | 99久久免费精品视频 | 国产99久久精品一区二区永久免费 | 婷婷久久五月天 | www日日日| 国产视频久久久久 |