STM32F429 ADC 结果超过4096

2019-07-14 13:26发布

诸君:
       使用STM32F429,选择ADC1 PA0作为输入。
       所得结果都是大于4096,求解!
       另外,试了下将结果与0x0fff,屏蔽最高4位,得出了正确结果,这个是什么道理?
       程序都是按照 原子F407 的程序对照修改的。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
7条回答
saber_miku
2019-07-15 01:23
/**
  * @brief  ADC1 Init
  * @param  None
  * @retval None
  */
void stm32f4xx_ADC1_Init(void)
{
       
/*【Step 1:定义结构体】↓----------------------------------------------------*/        
        GPIO_InitTypeDef  GPIO_InitStructure;
        ADC_CommonInitTypeDef ADC_CommonInitStructure;
        ADC_InitTypeDef       ADC_InitStructure;
/*【Step 1:结束】↑---------------------------------------------------------*/
       
/*【Step 2:开启PA口时钟和ADC1时钟,设置PA0为模拟输入】↓----------------------*/
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL ;//不带上下拉
  GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化  
/*【Step 2:结束】↑---------------------------------------------------------*/
       
/*【Step 3:ADC1复位】↓-----------------------------------------------------*/
        RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,ENABLE);          
        RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,DISABLE);       
/*【Step 3:结束】↑---------------------------------------------------------*/

/*【Step 4:设置ADC的CCR,配置ADC输入时钟分频,模式为独立模式等】↓------------*/
        ADC_CommonInitStructure.ADC_Mode = ADC_Mode_Independent;
        ADC_CommonInitStructure.ADC_Prescaler = ADC_Prescaler_Div4;
        ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAAccessMode_Disabled;
        ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TwoSamplingDelay_5Cycles;
        ADC_CommonInit(&ADC_CommonInitStructure);
/*【Step 4:结束】↑---------------------------------------------------------*/

/*【Step 5:初始化ADC1参数,设置分辨率,转换方式,对齐方式,规则序列】↓-------*/
  ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b;//12位模式
  ADC_InitStructure.ADC_ScanConvMode = DISABLE;
  ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
  ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None;
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//右对齐       
  ADC_InitStructure.ADC_NbrOfConversion = 1;//1个转换在规则序列中 也就是只转换规则序列1
  ADC_Init(ADC1, &ADC_InitStructure);//ADC初始化
/*【Step 5:结束】↑---------------------------------------------------------*/

/*【Step 6:开启AD转换器】↓-------------------------------------------------*/        
        ADC_Cmd(ADC1, ENABLE);
/*【Step 6:结束】↑---------------------------------------------------------*/

}

/**
  * @brief  获得ADC值
  * @param  ADC_Channel
  * @retval ADC一次转换结果数据
  */
uint16_t Get_ADC(uint8_t ADC_Channel)   
{

        ADC_RegularChannelConfig(ADC1,ADC_Channel,1,ADC_SampleTime_480Cycles);                             
        ADC_SoftwareStartConv(ADC1);                //使能指定的ADC1的软件转换启动功能                 
        while(!ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC))//等待转换结束
        {
        }
                return ADC_GetConversionValue(ADC1);//返回最近一次ADC1规则组的转换结果
       
}

/**
  * @brief  获取通道ADC_Channel的转换值,取times次,然后平均
  * @param  ADC_Channel,times
  * @retval 平均值
  */
uint16_t Get_ADC_Average(uint8_t ADC_Channel,uint8_t times)
{
        uint32_t sum=0;
        uint8_t n;
        for(n=0;n<times;n++)
        {
                sum+=Get_ADC(ADC_Channel);
                Delay_ms(5);
        }
        return sum/times;
}

一周热门 更多>