大学生
最后登录1970-1-1
在线时间 小时
注册时间2014-1-9
|
本帖最后由 kevin_D 于 2016-1-5 14:40 编辑
程序主要分 1:测试FFT处理数据显示部份 2:ADC+DMA数据处理部份 3:幅度计算部份 4:频率计算部份 5:频谱显示系统
1:测试FFT处理数据显示部份- float testInput[BufferSize*2]; //BufferSize为采样点数,数据来自 ADC.H
- float testOutput[BufferSize];
复制代码
2:ADC+DMA数据处理部份
- #include "./adc/bsp_adc.h"
- uint16_t uhADC3Converted_buffer1[BufferSize]={0};
- uint16_t uhADC3Converted_buffer2[BufferSize]={0};
- DMA_InitTypeDef DMA_InitStructure;
- void ADC3_DMA_RX_Config(uint16_t *Bufferdst)
- {
- ADC_Cmd(RHEOSTAT_ADC, DISABLE);//ADC_Cmd(ADC3, DISABLE);//必顺先把ADC关掉然后再把DMA传输关掉
- DMA_Cmd(RHEOSTAT_ADC_DMA_STREAM, DISABLE);//DMA_Cmd(DMA2_Stream0, DISABLE);//
- DMA_ClearFlag(RHEOSTAT_ADC_DMA_STREAM,DMA_FLAG_TCIF0|DMA_FLAG_HTIF0|DMA_FLAG_TEIF0|DMA_FLAG_DMEIF0|DMA_FLAG_FEIF0);
- DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)Bufferdst;
- DMA_Init(RHEOSTAT_ADC_DMA_STREAM, &DMA_InitStructure);
复制代码 ADC函数部份
- #ifndef __ADC_H
- #define __ADC_H
- #include "stm32f4xx.h"
- #define BufferSize 1024 //2048//4096 //下面就直接引用 野火 STM32F429 例程文件中的“ADC—单通道(DMA)”
复制代码 TIM2采样频率 40K或44.1K配置
- void TIM_GPIO_Config_2(void)
- {
- GPIO_InitTypeDef GPIO_InitStructure;
- RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
- GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
- GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
- GPIO_Init(GPIOA,&GPIO_InitStructure);
- GPIO_PinAFConfig(GPIOA,GPIO_PinSource3,GPIO_AF_TIM2);
- }
-
- static void TIM2_NVIC_Configuration(void)
- {
- NVIC_InitTypeDef NVIC_InitStructure;
- NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);
- NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;
- NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
- NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
- NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
- NVIC_Init(&NVIC_InitStructure);
- }
- static void TIM2_Mode_Config(void)
- {
- TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;
- u16 TimerPeriod = (SystemCoreClock / TimerPeriodDIV ) - 1;
- RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);
- //RCC_TIMCLKPresConfig(RCC_TIMPrescActivated);
- TIM_Cmd(TIM3, DISABLE);
- TIM_TimeBaseInitStructure.TIM_Period = TimerPeriod-1;
- TIM_TimeBaseInitStructure.TIM_Prescaler = 0;
- TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;
- TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1;
- TIM_TimeBaseInitStructure.TIM_RepetitionCounter = 0;
- TIM_TimeBaseInit(TIM2,&TIM_TimeBaseInitStructure);
- if(GPIO_PWM_OUT) //如果 GPIO_PWM_OUT 为直,说明大家有示波器,就让TIM2_CH1/CH2/CH3/CH4输出波形,测试一下方波周期是否是正确,
- <blockquote><span class="Apple-tab-span" style="line-height: 1.5; white-space: pre;"> </span><span style="line-height: 1.5;">{</span>
复制代码 最后就是主程序部份- while(1)
- {
- if(it_flag==1)
- {
- if(buffer_flag==0)
- {
- buffer_flag=1;
-
- FFTDisp_MainLoop(uhADC3Converted_buffer1);
-
- if(TEST_FFT_V)TEST_FFT_VIEW(); //这里是显示 频谱部份就没有写,因为有些人使用的是LED灯显示,有些使用的是 液晶屏
-
- else TEST_FFT_MAXT(); //这是求最大频率
-
- ADC3_DMA_RX_Config(uhADC3Converted_buffer2);
- }
- else
- {
- buffer_flag=0;
-
- FFTDisp_MainLoop(uhADC3Converted_buffer2);
-
- if(TEST_FFT_V)TEST_FFT_VIEW();
-
- else TEST_FFT_MAXT();
-
- ADC3_DMA_RX_Config(uhADC3Converted_buffer1);
- }
- it_flag=0;
- }
- }
- }
复制代码
|
-
主程序框图
|