找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 879|回復: 2
收起左側(cè)

單片機里自然對數(shù)如何寫

[復制鏈接]
ID:1045846 發(fā)表于 2024-7-21 20:47 | 顯示全部樓層 |閱讀模式

要計算兩路電壓的dB差,不在規(guī)格值時報警。
下面這種寫法,編譯沒有報錯,數(shù)碼管上也沒有數(shù)字顯示出來。

高手幫忙看看問題出在哪。
感謝!
  1. //測量VR電壓\dB程序
  2. void Voltage_VR(void)
  3. {
  4.         P1M0=0x32;P1M1=0x09;   //P1.1、P1.4、P1.5推挽(測試兩端),P1.0、P1.3為高阻
  5.         ADCA=0;ADCC=0;ADCB=0;ADCD=1;ADCE=1;//AL、BL、CL、OH,P1.5
  6.         ADKA=0;ADKB=0;//aL、bL、cL
  7.         Delay500us();          //延時等待穩(wěn)定
  8.         VinA=ADC_V(0x00);     //讀取第0通道,R2層電壓,1-2端
  9.         Delay500us();          //延時等待穩(wěn)定
  10.         VinB=ADC_V(0x03);     //讀取第0通道,R1層電壓,1-2端
  11.        
  12.         // 判斷電壓,進行dB計算
  13.               dBA=(float)20*log(VinA/VCC);
  14.               dBB=(float)20*log(VinB/VCC);
  15.               dB=dBA-dBB;
  16.               if(dB>=-2.9 && VinA<=5100)
  17.                                 {
  18.                                         count=0; //計數(shù)清0
  19.                                 }
  20.                                 else if(dB<=2.9 && VinA<=5100)//else if(Vin>=4950 && Vin<=5000)
  21.                                 {
  22.                                         count=0; //計數(shù)清0
  23.                                 }
  24.                                 else //以上各分支條件都不成立,說明產(chǎn)品有缺陷
  25.                                 {
  26.                                         count++;
  27.                                         if(count>=2)//當?shù)竭_10ms
  28.                                         {
  29.                                                 LEDG=1;           //綠燈熄
  30.                                                 LEDR=0;           //紅燈亮
  31.                                                 alarm=1;
  32.                                                 while(alarm & RST)//取下VR或按RST鍵退出死循環(huán),但報錯發(fā)生在不取下VR的情況下按RST鍵復檢當前檔位
  33.                                                 {
  34.                                                         VR=exist_VR(0x05); //第5通道測量VR存在
  35.                                                         if(VR>=4000)alarm=0;//判斷VR沒有裝,退出死循環(huán)

  36.                                                         if(count2==0)//閃爍周期250ms
  37.                                                         {
  38.                                              dis_buf[0]=~(table[dB%10]);
  39.                                  dis_buf[1]=~(table[dB/10%10]|0x80);
  40.                                        dis_buf[2]=~(table[25]);//'U'
  41.                                        dis_buf[3]=~(table[VinA/10%10]);
  42.                                        dis_buf[4]=~(table[VinA/100%10]);
  43.                                        dis_buf[5]=~(table[VinA/1000%10]|0x80);//加小數(shù)點
  44.                                                          dis_buf[6]=~(table[25]);//'U'
  45.                                        dis_buf[7]=~(table[VinB/10%10]);
  46.                                        dis_buf[8]=~(table[VinB/100%10]);
  47.                                        dis_buf[9]=~(table[VinB/1000%10]|0x80);//加小數(shù)點

  48.                                                                 DisplayScan();
  49.                                                         }
  50.                                                         if(count2==125)
  51.                                                         {
  52.                                                                 dis_buf[0]=~(table[16]);//不顯示
  53.                                                                 dis_buf[1]=~(table[16]);
  54.                                                                 dis_buf[2]=~(table[16]);
  55.                                                                 dis_buf[3]=~(table[16]);
  56.                                                                 dis_buf[4]=~(table[16]);
  57.                                                                 dis_buf[5]=~(table[16]);
  58.                                                                 dis_buf[6]=~(table[16]);
  59.                                                                 dis_buf[7]=~(table[16]);
  60.                                                                 dis_buf[8]=~(table[16]);
  61.                                                                 dis_buf[9]=~(table[16]);
  62.                                                                 DisplayScan();
  63.                                                         }
  64.                                                         Delay_ms(1);
  65.                                                         count2=++count2%250;
  66.                                                 }
  67.                                                 count2=0;
  68.                                         }
  69.                                 }
  70.                                 LEDG=0;           //綠燈亮
  71.                                 LEDR=1;           //紅燈熄
  72.                           dis_buf[0]=~(table[dB%10]);
  73.                           dis_buf[1]=~(table[dB/10%10]|0x80);
  74.                                 dis_buf[2]=~(table[25]);//'U'
  75.                                 dis_buf[3]=~(table[VinA/10%10]);
  76.                                 dis_buf[4]=~(table[VinA/100%10]);
  77.                                 dis_buf[5]=~(table[VinA/1000%10]|0x80);//加小數(shù)點
  78.                                 dis_buf[6]=~(table[25]);//'U'
  79.                                 dis_buf[7]=~(table[VinB/10%10]);
  80.                                 dis_buf[8]=~(table[VinB/100%10]);
  81.                                 dis_buf[9]=~(table[VinB/1000%10]|0x80);//加小數(shù)點
  82.                                 DisplayScan();           //顯示電壓值
  83.                         }
復制代碼




回復

使用道具 舉報

ID:344848 發(fā)表于 2024-7-22 11:56 | 顯示全部樓層
普通單片機乘除運算能力較差,別說自然對數(shù)了,建議將自然對數(shù)轉(zhuǎn)化為表格形式,直接查表即可。這需要FLASH容量很大,才能確保精度!
回復

使用道具 舉報

ID:1045846 發(fā)表于 2024-7-27 16:19 | 顯示全部樓層
donglw 發(fā)表于 2024-7-22 11:56
普通單片機乘除運算能力較差,別說自然對數(shù)了,建議將自然對數(shù)轉(zhuǎn)化為表格形式,直接查表即可。這需要FLASH ...

感謝提供方法。
只是本人初學,這種方法實施起來有難度。
回復

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復 返回頂部 返回列表