思路:adc的DMA采集数据,将采集回来的数据存入数组中,通过冒泡排序的,找出最大值,将最大值显示在液晶上,不加这个冒泡排序的算法数据是正确的,可是一加上这个,怎么数据就成了0-1、20的数据了。这不科学啊。Mode是按键进行通道切换的,这样写的有问题吗?
[mw_shl_code=c,true]/****************************************************************************
* 名 称:ADCValueDisplay_MainLoop(void)
* 功 能:ADC采集数据输出函数,液晶显示函数
* LCD显示电压值主循环
* 入口参数:
* 出口参数:无
* 说 明:
* 调用方法:直接调用
****************************************************************************/
void ADCValueDisplay_MainLoop(u8 Mode_flag)
{
static u16 Mode;
static float uwVoltage =0, uwMVoltage=0;
static u32 i,j,k,value1=0,value2=0,temp1,temp2;
Mode=Mode_flag;
//把ADC采样值转换成电压值
if(1==Mode)
{
// GUI_DispDecAt(uwADC3ConvertedVoltage*3300/0xFFF,210,90,4);
for(i=0;i<N;i++)
{
ArrDataBuffer =uwADC3ConvertedVoltage*3300/0xFFF;
}
//采样由小到大排列,排序采样冒泡法
for(j=0;j<N-1;j++) //冒泡
{
for(k=0;k<N-1-j;k++)
{
if(ArrDataBuffer>ArrDataBuffer[i+1])
{
temp1=ArrDataBuffer;
ArrDataBuffer=ArrDataBuffer[i+1];
ArrDataBuffer[i+1]=temp1;
}
}
}
value1=(ArrDataBuffer[i+1]+ArrDataBuffer+ArrDataBuffer[i-1])/3;//3次平均
// printf("uwADC3ConvertedVoltage is: %d
",uwADC3ConvertedVoltage );
//uwVoltage = uwADC3ConvertedVoltage/1000.0;
GUI_SetFont(&GUI_Font24_1);
GUI_SetColor(GUI_YELLOW);
GUI_DispDecAt(value1,120,90,4); //实际电压值
// printf("PA3: %0.2f V
",uwVoltage);
}
if(2==Mode)
{
// GUI_DispDecAt(uhADC1ConvertedValue*3300/0xFFF,210,120,4);// mV
for(i=0;i<N;i++)
{
ArrDataBuffer1 =uhADC1ConvertedValue*3300/0xFFF;
}
//采样由小到大排列,排序采样冒泡法
for(j=0;j<N-1;j++) //冒泡
{
for(k=0;k<N-1-j;k++)
{
if(ArrDataBuffer1>ArrDataBuffer1[i+1])
{
temp2=ArrDataBuffer1;
ArrDataBuffer1=ArrDataBuffer1[i+1];
ArrDataBuffer1[i+1]=temp2;
}
}
}
value2=((ArrDataBuffer1[i+1]+ArrDataBuffer1+ArrDataBuffer1[i-1])*2)/3; //3次平均
// printf("uwADC1ConvertedVoltage is: %d
",uwADC1ConvertedVoltage );
// uwMVoltage = uwADC1ConvertedVoltage/1000.0;
GUI_SetFont(&GUI_Font24_1);
GUI_SetColor(GUI_YELLOW);
GUI_DispDecAt(value2,120,120,4); //实际电压值
// printf("PA6: %0.2f V
",uwMVoltage);
}
}[/mw_shl_code]
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
[mw_shl_code=c,true] [/mw_shl_code] [mw_shl_code=c,true] /**************************************************************************** * 名 称:ADCValueDisplay_MainLoop(void) * 功 能:ADC采集数据输出函数,液晶显示函数 * LCD显示电压值主循环 * 入口参数: * 出口参数:无 * 说 明: * 调用方法:直接调用 ****************************************************************************/ void ADCValueDisplay_MainLoop(u8 Mode_flag) { static u16 Mode; static u32 i,j,k,value,temp; static u32 ArrDataBuffer[N];//N个数据 Mode=Mode_flag; if(1==Mode) { value=GlideaverageValueFilter(uwADC3ConvertedVoltage*3300/0xFFF); // printf("uwADC3ConvertedVoltage is: %d ",uwADC3ConvertedVoltage ); GUI_SetFont(&GUI_Font24_1); GUI_SetColor(GUI_RED); GUI_DispStringAt("V",260,90); GUI_SetColor(GUI_YELLOW); GUI_DispDecAt(value,120,90,4); GUI_DispStringAt(".",220,90); GUI_DispDecAt(value/1000,210,90,1); GUI_DispDecAt((value%1000)/10,230,90,2); //实际电压值 // printf("PA3: %0.2f V ",uwVoltage); } if(2==Mode) { value=GlideaverageValueFilter(uwADC1ConvertedVoltage*3300/0xFFF)*2; // printf("uwADC1ConvertedVoltage is: %d ",uwADC1ConvertedVoltage ); GUI_SetFont(&GUI_Font24_1); GUI_SetColor(GUI_RED); GUI_DispStringAt("V",260,120); GUI_SetColor(GUI_YELLOW); GUI_DispDecAt(value,120,120,4); GUI_DispStringAt(".",220,120); GUI_DispDecAt(value/1000,210,120,1); GUI_DispDecAt((value%1000)/10,230,120,2); //实际电压值 // printf("PA6: %0.2f V ",uwMVoltage); } } /**************************************************************************** * 名 称:?void ADC_Key(void) * 功 能: 按键处理函数,设置ADC采集通道 * 入口参数: * 出口参数:无 * 说 明: * 调用方法:直接调用 ****************************************************************************/ void ADC_Key(void) { key=KEY_Scan(0); //得到键值 if(key) { switch(key) { case KEY1_PRES: ADC_flag=1; break; case KEY2_PRES: ADC_flag=2; break; } } else delay_nms(10); } /**************************************************************************** * 名 称:?char GlideaverageValueFilter(char Value) * 功 能: 递推平均滤波 * 入口参数: * 出口参数: * 说 明:带返回值的函数 * 调用方法:直接调用 ****************************************************************************/ u32 GlideaverageValueFilter(u32 Value) { static u32 i,value; static u32 Sum; Sum=0; Data[10]=Filter(Value); //采集数据放在最高位 mV for(i=0;i<10;i++) { Data=Data[i+1]; //所有数据左移,地位扔掉 Sum+=Data; } value=Sum/10; return(value); } /**************************************************************************** * 名 称:?uchar MaxValueFilter(u32 Value) * 功 能: 寻找最大值 * 入口参数: * 出口参数: * 说 明:带返回值的函数 * 调用方法:直接调用 ****************************************************************************/ u32 MaxValueFilter(u32 Value) { static u32 i,j,k,value,temp; static u32 ArrDataBuffer[N];//2400个数据 for(i=0;i<N;i++) { ArrDataBuffer = GlideaverageValueFilter(Value); } //采样由小到大排列,排序采样冒泡法 for(j=0;j<N-1;j++) //冒泡 { for(k=0;k<N-1-j;k++) { if(ArrDataBuffer[k]>ArrDataBuffer[k+1]) { temp=ArrDataBuffer[k]; ArrDataBuffer[k]=ArrDataBuffer[k+1]; ArrDataBuffer[k+1]=temp; } } } value=ArrDataBuffer[N-1]; return(value); }[/mw_shl_code]
---------------------------------
你回帖不看贴的。
你冒泡外循环改为for(j=0;j<3;j++) 就可以求出最大的3个值了。
另外,我5楼回帖中的N跟你程序里的N不是一个值,我5楼回帖中的N是一个若干值,比如上一行中的3。为了便于你理解,你可以将我5楼回帖中的N改成m。
---------------------------------
你的建议我再试试,现在出现的问题比较多,采集回来2400个点,还没有找到最大值,采集的都为中间的数值
---------------------------------
我采集的是一个锯齿波信号,我来直接采集电平信号都是对的,值也就误差才十几之间
一周热门 更多>