亚洲春色中文字幕久久久-三上亚,一吻二脱三床四吻胸,国产真实伦对白视频全集,在线毛片观看,精品成品入口黄网,国产毛aⅴ片久久久,亚洲AV色香蕉一区二区三区老师,萧皇后A级艳片,色情日本视频更新,99久久亚洲精品日本无码
標題:
ADC中值平均濾波得到的值不正確。
[打印本頁]
作者:
samxon
時間:
2024-12-16 19:22
標題:
ADC中值平均濾波得到的值不正確。
代碼采用ADC中斷式, ,ADC值抖動的更厲害了,請高手幫忙檢查一下代碼是否有問題。謝謝大家。
#define N 12 //取中值
typedef unsigned char BYTE;
typedef unsigned int WORD;
WORD ADCx,ADCbg,bandgap,ADCx10filter,ADCx11filter;
WORD VoltageBuf[N],CurrentBuf[N];
// 初始化ADC
void InitADC() {
P1ASF = 0x03;// (1 << ADC_CHANNEL); // 設置P1.0,P1.1為ADC輸入
ADC_RES = 0;ADC_RESL = 0; // 清除ADC結果寄存器
CLK_DIV = 0x20;
ADC_CONTR = 0x88|0x01;//ADC_POWER | ADC_SPEEDLL | ADC_CHANNEL; // 使能ADC,設置速度為最快
Delay20ms(); // 等待ADC穩定
EADC = 1;
}
//中值濾波法(去掉最大,最小值,取平均值)
void filter(char channel)
{
char i,j,count;
int crtemp,votemp,sum=0;
if(channel==0){
for(j=0;j<(N-1);j++)
{
for(i=0;i<(N-j);i++)
{
if(CurrentBuf[i]>CurrentBuf[i+1])
{
crtemp = CurrentBuf[i];
CurrentBuf[i]= CurrentBuf[i+1];
CurrentBuf[i+1]= crtemp;
}
}
}
for(count =1;count<N-1;count++) sum += CurrentBuf[count];
ADCx10filter=sum/(N-2);
}
if(channel==1){
for(j=0;j<(N-1);j++)
{
for(i=0;i<(N-j);i++)
{
if(VoltageBuf[i]>VoltageBuf[i+1])
{
votemp = VoltageBuf[i];
VoltageBuf[i] = VoltageBuf[i+1];
VoltageBuf[i+1] = votemp;
}
}
}
for(count =1;count<N-1;count++) sum += VoltageBuf[count];
ADCx11filter=sum/(N-2);
}
}
//ADC中斷函數
void adc_isr()interrupt 5 using 1
{
static char vo=0,cr=0,ch=0;
// ADC_CONTR &= !0x10; //CLOSE ADC ADC_FLAG復位
ADC_CONTR &= ~ADC_FLAG;
if(ch==0)
{
CurrentBuf[cr] = (ADC_RES*256+ADC_RESL);
cr++;
if(cr==N){
cr=0;
filter(0);
}
}
if(ch==1)
{
VoltageBuf[vo] = (ADC_RES*256+ADC_RESL);
vo++;
if(vo==N){
vo=0;
filter(1);
}
}
ch++;
if(ch>1)ch=0;
ADC_CONTR = 0x88|ch; //ADC_POWER | ADC_SPEEDLL | 0x02 | ADC_START;
}
復制代碼
作者:
T0m
時間:
2024-12-17 10:08
我簡單看下你好像用的是均值濾波,直接排序后取中值是不是容易許多?
void array_sort(uint32_t* arr, uint8_t len) {
uint8_t i, j, k;
uint32_t temp = 0;
for (i = 0; i < len - 1; i++) {
k = i;
for (j = i + 1; j < len; j++) {
if (arr[k] > arr[j]) {
k = j;
}
}
if (k != i) {
temp = arr[k];
arr[k] = arr[i];
arr[i] = temp;
}
}
}
假設調用函數是是buf[11],那么使用函數array_sort(&buf,11); 之后buf[5]就是中值
作者:
WL0123
時間:
2024-12-17 13:43
這代碼出現ADC值不穩定的主要原因不在于采用了什么濾波方式,而是不合理的使用ADC中斷及中斷函數代碼。ADC中斷函數不斷在兩個通道之間切換?创a應該是使用的STC系列1T單片機,由于ADC轉換速度非?欤敲碅DC中斷周期必然很短。如此快速切換通道,ADC模塊內濾波電容來不及充放電,造成取樣不準。獲取的ADC結果更新速度又遠大于數據處理速度(濾波函數運行一次的過程中ADC中斷可能已運行多次)。最終的結果必然不穩定。需要設置一個標志,在數據處理完成后才允許執行下一次ADC采樣。
作者:
samxon
時間:
2024-12-17 20:07
T0m 發表于 2024-12-17 10:08
我簡單看下你好像用的是均值濾波,直接排序后取中值是不是容易許多?
void array_sort(uint32_t* arr, uin ...
用了過濾器后抖動的更厲害了。調低了ADC的采樣速度才有改善。謝謝大家回顧。
作者:
月沙
時間:
2024-12-18 00:20
可能是因為中斷服務例程中的處理時間過長,導致ADC采樣不連續或者錯過了一些樣本?梢試L試減少中斷服務例程中的處理時間,只存儲ADC值,然后在主循環中進行濾波處理。
歡迎光臨 (http://www.denmoz.com/bbs/)
Powered by Discuz! X3.1