蘋果充電線里面有個貼片場效應管,導通電流4A蠻大的,如圖
51hei圖片20210521095233.jpg (24.6 KB, 下載次數: 86)
下載附件
2021-5-21 10:02 上傳
于是找來個6W3R9的水泥電阻做負載(4.2/3.9=1安電流左右),用個7805適應寬電壓工作(6v-36v),如果只用5v供電還可以取消7805使電路更簡單
51hei圖片20210521095225.jpg (137.12 KB, 下載次數: 76)
下載附件
2021-5-21 10:02 上傳
測試電池內阻為0.527歐(隨便測一兩個丟久了的18650,下次測量個0.01以下的會上圖),不放電池顯示9999
51hei圖片20210521095213.jpg (133.97 KB, 下載次數: 75)
下載附件
2021-5-21 10:02 上傳
51hei圖片20210521095204.jpg (152.68 KB, 下載次數: 81)
下載附件
2021-5-21 10:02 上傳
51hei圖片20210521095505.png (38.42 KB, 下載次數: 74)
下載附件
2021-5-21 10:02 上傳
最后是單片機程序了
- #include<reg51.h>//內部晶振大約5.5mhz
- #define u8 unsigned char
- #define u16 unsigned int
- sbit w1=P3^2;sbit w2=P3^3;sbit w3=P3^4;sbit w4=P3^5; //4個數碼管
- sbit a=P3^0;sbit b=P3^1;sbit c=P1^2;sbit d=P1^3;sbit e=P1^4;
- sbit f=P1^5;sbit g=P1^6;sbit dp=P1^7;//共陽數碼管8段
- u8 time,shu,i;bit F_1s,F_ad;u16 t;sbit open=P3^7;
- /*聲明與ADC有關的寄存器*/
- sfr ADC_CONTR = 0xc5; //ADC控制寄存器
- sfr ADC_DATA = 0xc6; //ADC轉換結果寄存器 高8位
- sfr ADC_LOW2 = 0xBE; //ADC轉換結果寄存器 低8位
- sfr P1M0 = 0x91; //P1口模式控制寄存器0
- sfr P1M1 = 0x92; //P1口模式控制寄存器1
- sfr P3M0 = 0xb1;
- sfr P3M1 = 0xb2;
- /*定義ADC控制寄存器里的操作常量*/
- #define ADC_POWER 0X80 //ADC電源控制位
- #define ADC_FLAG 0X10 //ADC轉換結束標志位
- #define ADC_START 0x08 //ADC開始控制位
- void Delay(u16 n){while(--n);}//stc12內晶振約5.5MHZ 時間us=n*1.17
- //1=3us;10=13us;100=118us;1000=1.169ms;10000=11.678ms;
- void disp()
- {Delay(2000);//調節數碼管亮度
- for(i=0;i<4;i++){if(i==0){w1=1;shu=t/1000;}if(i==1){w2=1;shu=t%1000/100;}
- if(i==2){w3=1;shu=t%100/10;}if(i==3){w4=1;shu=t%10;}dp=1;
- switch(shu) //我數碼管沒有小數點,所以dp都=1,最大顯示9999毫毆
- {case 0:a=0;b=0;c=0;d=0;e=0;f=0;g=1;break; //0
- case 1:a=1;b=0;c=0;d=1;e=1;f=1;g=1;break; //1
- case 2:a=0;b=0;c=1;d=0;e=0;f=1;g=0;break;//2
- case 3:a=0;b=0;c=0;d=0;e=1;f=1;g=0;break;//3
- case 4:a=1;b=0;c=0;d=1;e=1;f=0;g=0;break;//4
- case 5:a=0;b=1;c=0;d=0;e=1;f=0;g=0;break;//5
- case 6:a=0;b=1;c=0;d=0;e=0;f=0;g=0;break;//6
- case 7:a=0;b=0;c=0;d=1;e=1;f=1;g=1;break;//7
- case 8:a=0;b=0;c=0;d=0;e=0;f=0;g=0;break;//8
- case 9:a=0;b=0;c=0;d=0;e=1;f=0;g=0;break; //9
- default:break;}
- Delay(200);//段位接IO腳可以任意改對接數碼管
- w1=0;w2=0;w3=0;w4=0;a=1;b=1;c=1;d=1;e=1;f=1;g=1;}}
- /*****初始化ADC寄存器*****/
- void ADint()
- {
- ADC_DATA = 0; //清除以前的結果
- ADC_CONTR = ADC_POWER;
- Delay(10000);//等待AD上電完成
- }
- /****獲取ADC轉換結果*****/
- u8 ADget(u8 ch2)
- {ADC_CONTR=ADC_POWER|ADC_START|ch2; //配置初始化
- Delay(1);
- while(!(ADC_CONTR&ADC_FLAG)); //等待轉換完成
- ADC_CONTR &= ~ADC_FLAG; //關閉ADC
- return ADC_DATA; //返回ADC轉換結果
- }
- void t0int() //定時器T0初始化
- {TMOD=0x01;TH0=0x00; TL0=0x00;EA=1; //開總中斷
- ET0 = 1; //開定時器中斷
- TR0 = 1; //啟動定時器T0;
- }//用內部5.5晶振,所以時間=65536*12/5.5=142987us約=143ms一周
- void main()
- {u16 s0,s1,s2;bit F_s,F_r,ch=0;u8 i,j,temp,n=0,buf[11];//2秒一次,采樣11次取中數
- P1M0=0x03;P1M1=0;
- P3M0=0;P3M1=0xbc;
- open=1;w1=0;w2=0;w3=0;w4=0;
- t0int(); //定時=定時*12/晶振(5.5)
- ADint(); //初始化ADC寄存器
- ADget(0); //調用ADC采集函數
- ADget(1); //采兩次不用
- while(1){if((!open)||(F_s)){buf[n]=ADget(ch);//采樣11個值到數組
- n++;if(n==11){n=0;F_ad=1;if(ch){open=1;F_s=1;}}}
- if(F_ad){F_ad=0;for(j=0;j<6;j++)//比較11個數后取中數
- {for(i=0;i<10-j;i++)
- {if(buf[i]>buf[i+1])
- {temp=buf[i];
- buf[i]=buf[i+1];
- buf[i+1]=temp;}
- }}//比較兩數的大小,如果大就往后排
- ch=~ch;if((ch)&&(F_s)){F_r=1;F_s=0;ch=0;s0=buf[5];
- s0=s0<<2|ADC_LOW2;}else if(ch){s1=buf[5];
- s1=s1<<2|ADC_LOW2;}else{s2=buf[5];s2=s2<<2|ADC_LOW2;}
- ADC_DATA=0;ADC_LOW2=0;}//比較10次大小后,中數已經在buf[5]
- //順序采三次DATA:負載電池兩端(P1.0采)到電阻兩端(P1.1采)到空載電池兩端(P1.0采)
- if(F_1s){F_1s=0;open=0;}//幾秒后開負載
- if(F_r){F_r=0;s0-=s1;t=(float)(s0*3.9/s2*1.0+0.0005)*1000;
- if(t>9999)t=9999;}
- //10位公式:ADC_DATA<<2|ADC_LOW2=1024*Vin/Vcc
- //化簡公式后內阻=(空載電池兩端ADC_DATA-負載電池兩端ADC_DATA)*
- //3R9(負載電阻)/負載電阻上兩端ADC_DATA
- disp();}
- }
- void timer_0() interrupt 1
- {TH0=0;TL0=0;time++;
- if(time==50) //一周約143ms.50*143=7秒
- {time=0;F_1s=1;}
- }
復制代碼
51hei.png (2.09 KB, 下載次數: 74)
下載附件
2021-5-21 21:48 上傳
以上代碼下載(就是這網頁上的一模一樣的):
650.rar
(1.93 KB, 下載次數: 72)
2021-5-21 10:26 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
|