ADC采集数据,冒泡排序寻找最大值

2019-07-21 02:39发布


思路: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]
 
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
11条回答
ahsssxd
1楼-- · 2019-07-21 21:51

[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]

mack13013
2楼-- · 2019-07-21 22:17
回复【7楼】ahsssxd:
---------------------------------
你回帖不看贴的。

你冒泡外循环改为for(j=0;j<3;j++) 就可以求出最大的3个值了。

另外,我5楼回帖中的N跟你程序里的N不是一个值,我5楼回帖中的N是一个若干值,比如上一行中的3。为了便于你理解,你可以将我5楼回帖中的N改成m。
ahsssxd
3楼-- · 2019-07-21 22:43
回复【9楼】mack13013:
---------------------------------
你的建议我再试试,现在出现的问题比较多,采集回来2400个点,还没有找到最大值,采集的都为中间的数值
mack13013
4楼-- · 2019-07-21 23:03
 精彩回答 2  元偷偷看……
ahsssxd
5楼-- · 2019-07-22 04:49
回复【11楼】mack13013:
---------------------------------
我采集的是一个锯齿波信号,我来直接采集电平信号都是对的,值也就误差才十几之间

一周热门 更多>