【STM32+HAL】ADC采集波形实现

一、准备工作:


有关CUBEMX的初始化配置,参见我的另一篇blog:【STM32+HAL】CUBEMX初始化配置

二、所用工具:


1、芯片: STM32F407ZGT6

2、STM32CubeMx软件

3、IDE: MDK-Keil软件

4、STM32F4xxHAL库

三、实现功能:

ADC采集波形并通过上位机显示

四、HAL库配置 (初始配置完成):

1、开启ADC

(可以先试试软件触发模式)

2、开启DAC以输出波形

有关DAC的详细配置,请参见【STM32+HAL】DAC+DMA输出波形实现

3、ADC定时器开启

PSC,ARR将决定采样频率,采样频率越高可采集的波形频率越高

4、DAC定时器开启

5、全局定时器开启

以周期1s闪烁LED灯

6、中断配置(不唯一)

 至此,CUBEMX配置完成

五、KEIL填写代码:

1、初始化DAC,ADC
	#define MAX_SAMP 1024

    uint16_t adc1[MAX_SAMP]={0};
    int flag=1,flag1=1;

    HAL_TIM_Base_Start(&htim2);
	HAL_DAC_Start(&hdac, DAC_CHANNEL_1);
	
	HAL_TIM_Base_Start(&htim8);
	HAL_TIM_Base_Start_IT((TIM_HandleTypeDef *)&htim1);
	HAL_ADC_Start_DMA(&hadc1,(uint32_t *)adc1,MAX_SAMP);
	
	printf("Hello World!\r\n");
	HAL_Delay(500);

2、ADC回调函数
void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)   //ADC中断
{
	if(hadc->Instance==hadc1.Instance){
		HAL_TIM_Base_Stop(&htim8);
		flag1=1;
	}
}
3、定时器TIM1中断
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
	if ( htim -> Instance == TIM1 ){
			HAL_GPIO_TogglePin(GPIOF,LED_Pin);
	}
}

4、main.c
  while (1)
  {
	  if(flag&&flag1){
		flag1=0;
		for(int i=0;i<MAX_SAMP;i++) printf("%d\n",adc1[i]);
		HAL_TIM_Base_Start(&htim8);
	  }
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }

六、VOFA+上位机配置

至此,只要在主函数中写printf("%d,%d\n",xx1,xx2);即可输出数据

七、巨人之肩

【STM32】HAL库 STM32CubeMX教程九---ADC

ADC采样时间、采样周期、采样频率计算方法

STM32CubeMX学习笔记(8)——ADC接口使用

STM32 DSP库的使用方法

八、源码提供

【STM32+HAL】ADC采集波形实现

  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用STM32的DAC模块来输出一个波形,然后使用ADC模块来采集这个波形。下面是一个简单的例子,展示了如何使用STM32Cube HAL库来实现这个功能。 首先,你需要配置DAC和ADC的引脚和模式。例如,你可以选择一个DAC通道输出一个三角波形,然后将该通道连接到ADC输入引脚。 接下来,你需要初始化DAC和ADC模块。在初始化DAC时,你可以设置输出波形的幅值和频率。在初始化ADC时,你需要配置输入通道和采样率等参数。 然后,在主循环中,你可以使用DAC模块来生成波形,并同时使用ADC模块来采集波形。 以下是一个简单的示例代码,展示了如何实现这个功能: ```c #include "stm32f4xx_hal.h" DAC_HandleTypeDef hdac; ADC_HandleTypeDef hadc; void SystemClock_Config(void); static void MX_GPIO_Init(void); static void MX_DAC_Init(void); static void MX_ADC1_Init(void); int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); MX_DAC_Init(); MX_ADC1_Init(); HAL_DAC_Start(&hdac, DAC_CHANNEL_1); HAL_ADC_Start(&hadc); while (1) { for (uint16_t i = 0; i < 4096; i++) { HAL_DAC_SetValue(&hdac, DAC_CHANNEL_1, DAC_ALIGN_12B_R, i); HAL_ADC_PollForConversion(&hadc, HAL_MAX_DELAY); uint16_t adcValue = HAL_ADC_GetValue(&hadc); // 在这里可以处理采集到的ADC值 } } } void SystemClock_Config(void) { // 系统时钟配置 } static void MX_GPIO_Init(void) { // GPIO初始化配置 } static void MX_DAC_Init(void) { hdac.Instance = DAC; HAL_DAC_Init(&hdac); DAC_ChannelConfTypeDef sConfig = {0}; sConfig.DAC_Trigger = DAC_TRIGGER_NONE; sConfig.DAC_OutputBuffer = DAC_OUTPUTBUFFER_ENABLE; HAL_DAC_ConfigChannel(&hdac, &sConfig, DAC_CHANNEL_1); } static void MX_ADC1_Init(void) { hadc.Instance = ADC1; hadc.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4; hadc.Init.Resolution = ADC_RESOLUTION_12B; hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT; hadc.Init.ScanConvMode = DISABLE; hadc.Init.EOCSelection = ADC_EOC_SINGLE_CONV; hadc.Init.ContinuousConvMode = ENABLE; hadc.Init.NbrOfConversion = 1; hadc.Init.DiscontinuousConvMode = DISABLE; hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE; hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START; HAL_ADC_Init(&hadc); ADC_ChannelConfTypeDef sConfig = {0}; sConfig.Channel = ADC_CHANNEL_0; // 根据实际情况选择ADC通道 sConfig.Rank = ADC_REGULAR_RANK_1; sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES; HAL_ADC_ConfigChannel(&hadc, &sConfig); } ``` 请记得根据你的具体硬件配置和需求进行适当的修改。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值