STM32 HAL库F103系列之ADC实验(三)

2024-04-22 20:04
文章标签 系列 实验 stm32 adc hal f103

本文主要是介绍STM32 HAL库F103系列之ADC实验(三),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内部温度传感器实验

本实验代码是基于单通道ADC采集实验进行编写

STM32内部温度传感器介绍

 温度计算方法

 实验简要

1,功能描述

        通过ADC1通道16采集芯片内部温度传感器的电压,将电压值换算成温度后,显示在液晶屏(可看作四步:1、上电 2、采集 3、计算 4、显示)

2,确定最小刻度

        VREF+ = 3.3V  0VVIN3.3V  最小刻度 = 3.3 / 4096  (分辨率:12位)

3,确定转换时间

        采样时间239.5ADC时钟周期为例,可以得到转换时间为21us

转换时间计算方法:

4,模式组合

        单次转换模式、不使用扫描模式

源码

adc.c

#include "./BSP/ADC/adc.h"ADC_HandleTypeDef g_adc_handle;/* ADC 内部温度传感器 初始化函数 */
void adc_temperature_init(void)
{ADC_ChannelConfTypeDef adc_ch_conf;g_adc_handle.Instance = ADC1;g_adc_handle.Init.DataAlign = ADC_DATAALIGN_RIGHT;g_adc_handle.Init.ScanConvMode = ADC_SCAN_DISABLE;g_adc_handle.Init.ContinuousConvMode = DISABLE;g_adc_handle.Init.NbrOfConversion = 1;g_adc_handle.Init.DiscontinuousConvMode = DISABLE;g_adc_handle.Init.NbrOfDiscConversion = 0;g_adc_handle.Init.ExternalTrigConv = ADC_SOFTWARE_START;HAL_ADC_Init(&g_adc_handle);HAL_ADCEx_Calibration_Start(&g_adc_handle);adc_ch_conf.Channel = ADC_CHANNEL_16;adc_ch_conf.Rank = ADC_REGULAR_RANK_1;adc_ch_conf.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;HAL_ADC_ConfigChannel(&g_adc_handle, &adc_ch_conf);
}/* ADC MSP初始化函数 */
void HAL_ADC_MspInit(ADC_HandleTypeDef *hadc)
{if(hadc->Instance == ADC1){RCC_PeriphCLKInitTypeDef adc_clk_init = {0};__HAL_RCC_ADC1_CLK_ENABLE();adc_clk_init.PeriphClockSelection = RCC_PERIPHCLK_ADC;adc_clk_init.AdcClockSelection = RCC_ADCPCLK2_DIV6;HAL_RCCEx_PeriphCLKConfig(&adc_clk_init);}
}/* 获得ADC转换后的结果函数 */
uint32_t adc_get_result(void)
{HAL_ADC_Start(&g_adc_handle);HAL_ADC_PollForConversion(&g_adc_handle, 10);return (uint16_t)HAL_ADC_GetValue(&g_adc_handle);
}/* 获取内部温度传感器温度值 */
short adc_get_temperature(void)
{uint32_t adcx;short result;double temperature;adcx = adc_get_result();/*得到数字量*/temperature = adcx * (3.3 / 4096);/*数字量转换成电压值*/temperature = (1.43 - temperature) / 0.0043 + 25;/*温度计算*/result = temperature *= 100;return result;
}

adc.h

#ifndef __ADC_H
#define __ADC_H#include "./SYSTEM/sys/sys.h"void adc_temperature_init(void);
uint32_t adc_get_result(void);
short adc_get_temperature(void);#endif 

main.c

#include "./SYSTEM/sys/sys.h"
#include "./SYSTEM/usart/usart.h"
#include "./SYSTEM/delay/delay.h"
#include "./USMART/usmart.h"
#include "./BSP/LED/led.h"
#include "./BSP/LCD/lcd.h"
#include "./BSP/ADC/adc.h"int main(void)
{short temp;HAL_Init();                                 /* 初始化HAL库 */sys_stm32_clock_init(RCC_PLL_MUL9);         /* 设置时钟, 72Mhz */delay_init(72);                             /* 延时初始化 */usart_init(115200);                         /* 串口初始化为115200 */led_init();                                 /* 初始化LED */lcd_init();                                 /* 初始化LCD */adc_temperature_init();                     /* 初始化ADC内部温度传感器采集 */lcd_show_string(30,  50, 200, 16, 16, "STM32", RED);lcd_show_string(30,  70, 200, 16, 16, "Temperature TEST", RED);lcd_show_string(30,  90, 200, 16, 16, "ATOM@ALIENTEK", RED);lcd_show_string(30, 120, 200, 16, 16, "TEMPERATE: 00.00C", BLUE);while (1){temp = adc_get_temperature();   /* 得到温度值 */if (temp < 0){temp = -temp;lcd_show_string(30 + 10 * 8, 120, 16, 16, 16, "-", BLUE);   /* 显示负号 */}else{lcd_show_string(30 + 10 * 8, 120, 16, 16, 16, " ", BLUE);   /* 无符号 */}lcd_show_xnum(30 + 11 * 8, 120, temp / 100, 2, 16, 0, BLUE);    /* 显示整数部分 */lcd_show_xnum(30 + 14 * 8, 120, temp % 100, 2, 16, 0X80, BLUE); /* 显示小数部分 */LED0_TOGGLE();  /* LED0闪烁,提示程序运行 */delay_ms(250);}
}

光敏传感器实验

本实验代码是基于单通道ADC采集实验进行编写

光敏二极管原理图

 实验简要

1,功能描述

        通过ADC3通道6PF8)采集光敏二极管的电压,然后转换为0~100的光线强度值,并显示

2,确定最小刻度

        VREF+ = 3.3V  0VVIN3.3V  最小刻度 = 3.3 / 4096

3,确定转换时间

        采样时间239.5ADC时钟周期为例,可以得到转换时间为21us

4,模式组合

        单次转换模式、不使用扫描模式

源码

adc.c

#include "./BSP/ADC/adc3.h"ADC_HandleTypeDef g_adc_handle;/* ADC单通道 */
void adc3_init(void)
{ADC_ChannelConfTypeDef adc_ch_conf;g_adc_handle.Instance = ADC3;g_adc_handle.Init.DataAlign = ADC_DATAALIGN_RIGHT;g_adc_handle.Init.ScanConvMode = ADC_SCAN_DISABLE;g_adc_handle.Init.ContinuousConvMode = DISABLE;g_adc_handle.Init.NbrOfConversion = 1;g_adc_handle.Init.DiscontinuousConvMode = DISABLE;g_adc_handle.Init.NbrOfDiscConversion = 0;g_adc_handle.Init.ExternalTrigConv = ADC_SOFTWARE_START;HAL_ADC_Init(&g_adc_handle);HAL_ADCEx_Calibration_Start(&g_adc_handle);adc_ch_conf.Channel = ADC_CHANNEL_6;adc_ch_conf.Rank = ADC_REGULAR_RANK_1;adc_ch_conf.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;HAL_ADC_ConfigChannel(&g_adc_handle, &adc_ch_conf);
}/* ADC MSP初始化函数 */
void HAL_ADC_MspInit(ADC_HandleTypeDef *hadc)
{if(hadc->Instance == ADC3){GPIO_InitTypeDef gpio_init_struct;RCC_PeriphCLKInitTypeDef adc_clk_init = {0};__HAL_RCC_GPIOF_CLK_ENABLE();__HAL_RCC_ADC3_CLK_ENABLE();gpio_init_struct.Pin = GPIO_PIN_8;gpio_init_struct.Mode = GPIO_MODE_ANALOG;HAL_GPIO_Init(GPIOF, &gpio_init_struct); adc_clk_init.PeriphClockSelection = RCC_PERIPHCLK_ADC;adc_clk_init.AdcClockSelection = RCC_ADCPCLK2_DIV6;HAL_RCCEx_PeriphCLKConfig(&adc_clk_init);}
}/* 获得ADC转换后的结果函数 */
uint32_t adc_get_result(void)
{HAL_ADC_Start(&g_adc_handle);HAL_ADC_PollForConversion(&g_adc_handle, 10);return (uint16_t)HAL_ADC_GetValue(&g_adc_handle);
}/* 读取光敏传感器值 */
uint8_t lsens_get_val(void)
{uint32_t temp_val;temp_val = adc_get_result();temp_val /= 40;                     /*把转换到的数字量转换为0 ~ 100 之间的数*/if (temp_val > 100) temp_val = 100;return (uint8_t)(100 - temp_val);   /*光强与转化值为负相关 光强越大电压越小*/
}

adc.h

#ifndef __ADC_H
#define __ADC_H#include "./SYSTEM/sys/sys.h"void adc3_init(void);
uint32_t adc_get_result(void);
uint8_t lsens_get_val(void);#endif 

main.c

#include "./SYSTEM/sys/sys.h"
#include "./SYSTEM/usart/usart.h"
#include "./SYSTEM/delay/delay.h"
#include "./USMART/usmart.h"
#include "./BSP/LED/led.h"
#include "./BSP/LCD/lcd.h"
#include "./BSP/ADC/adc3.h"int main(void)
{short adcx;HAL_Init();                                 /* 初始化HAL库 */sys_stm32_clock_init(RCC_PLL_MUL9);         /* 设置时钟, 72Mhz */delay_init(72);                             /* 延时初始化 */usart_init(115200);                         /* 串口初始化为115200 */led_init();                                 /* 初始化LED */lcd_init();                                 /* 初始化LCD */adc3_init();                                /* 初始化ADC3 */lcd_show_string(30,  50, 200, 16, 16, "STM32", RED);lcd_show_string(30,  70, 200, 16, 16, "LSENS TEST", RED);lcd_show_string(30,  90, 200, 16, 16, "ATOM@ALIENTEK", RED);lcd_show_string(30, 110, 200, 16, 16, "LSENS_VAL:", BLUE);while (1){ adcx = lsens_get_val();lcd_show_xnum(30 + 10 * 8, 110, adcx, 3, 16, 0, BLUE); /* 显示ADC的值 */LED0_TOGGLE();                                         /* LED0闪烁,提示程序运行 */delay_ms(250);}
}

这篇关于STM32 HAL库F103系列之ADC实验(三)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/926728

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

STM32(十一):ADC数模转换器实验

AD单通道: 1.RCC开启GPIO和ADC时钟。配置ADCCLK分频器。 2.配置GPIO,把GPIO配置成模拟输入的模式。 3.配置多路开关,把左面通道接入到右面规则组列表里。 4.配置ADC转换器, 包括AD转换器和AD数据寄存器。单次转换,连续转换;扫描、非扫描;有几个通道,触发源是什么,数据对齐是左对齐还是右对齐。 5.ADC_CMD 开启ADC。 void RCC_AD

STM32内部闪存FLASH(内部ROM)、IAP

1 FLASH简介  1 利用程序存储器的剩余空间来保存掉电不丢失的用户数据 2 通过在程序中编程(IAP)实现程序的自我更新 (OTA) 3在线编程(ICP把整个程序都更新掉) 1 系统的Bootloader写死了,只能用串口下载到指定的位置,启动方式也不方便需要配置BOOT引脚触发启动  4 IAP(自己写的Bootloader,实现程序升级) 1 比如蓝牙转串口,

GPT系列之:GPT-1,GPT-2,GPT-3详细解读

一、GPT1 论文:Improving Language Understanding by Generative Pre-Training 链接:https://cdn.openai.com/research-covers/languageunsupervised/language_understanding_paper.pdf 启发点:生成loss和微调loss同时作用,让下游任务来适应预训

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类