uint32_t ozone_oneCycleSample(void) { uint32_t sum=0,samples=100; uint16_t pre_adc_value,AD_value; int16_t diff; int16_t k; uint16_t adc_min,adc_max; double db_temp; while(TMR6!=100 && !i2c_rec_end); //if i2c recieved i2c data,quite synchronization //while(TMR6!=100); //if i2c recieved i2c data,quite synchronization cnt_10ms=0; pre_adc_value=0; //memset(&buff[0],0,1000); //GIE=0; adc_min=0xffff; adc_max=0; // LATA2=1; for(samples=0;cnt_10ms<2;) //for(samples_n=0;samples_n<1000;samples_n++) { AD_value=adc_oneSample(); diff=AD_value-pre_adc_value; if(diff>3 || diff<-3) { if(samples!=0) { sum+=pre_adc_value; samples++; } } else { sum+=AD_value; samples++; } pre_adc_value=AD_value; if(adc_max<AD_value)adc_max=AD_value; if(adc_min>AD_value)adc_min=AD_value; if(samples>250 && i2c_rec_end)break; } //rms // db_temp=adc_max-adc_min; // db_temp=db_temp*0.423; // sum=adc_min+db_temp; // samples=1; //mean if(samples==0)samples=1; sum=sum/samples; //GIE=1; // LATA2=0; return sum; }
时间: 2024-04-20 07:25:56 浏览: 83
C实现与 uint64_t 相同功能的类
这段代码是一个函数定义,名为`ozone_oneCycleSample`,返回一个无符号32位整数类型的值。
函数首先声明了一些变量,包括`sum`、`samples`、`pre_adc_value`、`AD_value`、`diff`、`k`、`adc_min`、`adc_max`和`db_temp`。
然后,在一个循环中,函数等待计时器TMR6的值为100,并且`i2c_rec_end`为假。这是为了在接收到I2C数据时,确保与I2C数据同步。
接下来,将变量`cnt_10ms`的值设置为0,将变量`pre_adc_value`的值设置为0。
然后,初始化变量`adc_min`为最大可能值0xffff,初始化变量`adc_max`为0。
接下来,进入一个循环,循环条件是在计时器TMR6的值小于100并且变量`cnt_10ms`小于2的情况下。在循环中,首先调用函数`adc_oneSample()`获取一个ADC采样值,并将其保存在变量`AD_value`中。
然后,计算变量`diff`的值,即当前采样值与上一次采样值之间的差异。
接下来,根据差异的大小判断是否需要将当前采样值加入到求和变量`sum`中。如果差异大于3或小于-3,则将上一次的采样值加入到`sum`中;否则,将当前的采样值加入到`sum`中。
每次更新完`sum`后,将当前采样值保存到`pre_adc_value`中,并更新最大值`adc_max`和最小值`adc_min`。
在循环中,如果`samples`大于250并且`i2c_rec_end`为真,则跳出循环。
接下来,计算均值。如果`samples`为0,则将`samples`设置为1,以避免除以0的错误。然后,将`sum`除以`samples`得到均值。
最后,返回均值`sum`作为函数的结果。
阅读全文