从零开始学习安时积分法(STM32实现程序)

news/2025/2/1 21:57:17 标签: 算法

在STM32微控制器上实现安时积分法(Coulomb Counting)来估算电池的SOC(State of Charge),需要完成以下几个步骤:

  1. 硬件配置:

    • 使用STM32的ADC模块测量电池的电流。
    • 使用定时器模块进行时间积分。
    • 配置GPIO和串口用于调试和输出结果。
  2. 软件实现:

    • 初始化ADC和定时器。
    • 实时读取电流值并进行积分计算。
    • 根据积分结果更新SOC值。

以下是基于STM32的安时积分法实现代码示例(以STM32F4系列为例,使用HAL库):


代码实现

#include "stm32f4xx_hal.h"
 
// 定义变量 
#define BATTERY_CAPACITY 5000  // 电池标称容量,单位:mAh 
#define ADC_RESOLUTION   4095  // ADC分辨率(12位)
#define ADC_REF_VOLTAGE  3.3   // ADC参考电压,单位:V 
#define SHUNT_RESISTOR   0.1   // 电流采样电阻,单位:Ω 
 
float soc = 100.0;  // 初始SOC值,单位:%
float current = 0.0;  // 当前电流值,单位:mA 
uint32_t adc_value = 0;  // ADC读取的原始值 
 
// ADC初始化 
void ADC_Init(void) {
    ADC_HandleTypeDef hadc;
    hadc.Instance = ADC1;
    hadc.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV2;
    hadc.Init.Resolution = ADC_RESOLUTION_12B;
    hadc.Init.ScanConvMode = DISABLE;
    hadc.Init.ContinuousConvMode = ENABLE;
    hadc.Init.DiscontinuousConvMode = DISABLE;
    hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
    hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START;
    hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT;
    hadc.Init.NbrOfConversion = 1;
    hadc.Init.DMAContinuousRequests = DISABLE;
    hadc.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
    HAL_ADC_Init(&hadc);
}
 
// 读取ADC值 
uint32_t ADC_Read(void) {
    HAL_ADC_Start(&hadc);
    HAL_ADC_PollForConversion(&hadc, HAL_MAX_DELAY);
    return HAL_ADC_GetValue(&hadc);
}
 
// 计算电流值 
float Calculate_Current(uint32_t adc_value) {
    float voltage = (adc_value * ADC_REF_VOLTAGE) / ADC_RESOLUTION;  // 计算电压 
    return (voltage / SHUNT_RESISTOR) * 1000;  // 计算电流,单位:mA 
}
 
// SOC估算函数 
void Update_SOC(float current, uint32_t time_interval_ms) {
    float delta_soc = (current * time_interval_ms) / (BATTERY_CAPACITY * 3600);  // SOC变化量 
    soc -= delta_soc;  // 更新SOC 
    if (soc < 0) soc = 0;  // SOC下限保护 
    if (soc > 100) soc = 100;  // SOC上限保护 
}
 
int main(void) {
    HAL_Init();  // 初始化HAL库 
    SystemClock_Config();  // 配置系统时钟 
    ADC_Init();  // 初始化ADC 
 
    uint32_t last_time = HAL_GetTick();  // 获取初始时间 
 
    while (1) {
        uint32_t current_time = HAL_GetTick();  // 获取当前时间 
        uint32_t time_interval_ms = current_time - last_time;  // 计算时间间隔 
 
        adc_value = ADC_Read();  // 读取ADC值 
        current = Calculate_Current(adc_value);  // 计算电流值 
        Update_SOC(current, time_interval_ms);  // 更新SOC 
 
        last_time = current_time;  // 更新时间戳 
 
        // 输出SOC值(通过串口或调试接口)
        printf("Current SOC: %.2f%%\n", soc);
 
        HAL_Delay(100);  // 延时100ms 
    }
}

代码说明

  1. ADC初始化:
    • 配置ADC模块以读取电流采样电阻上的电压。
    • STM32的ADC分辨率为12位,

http://www.niftyadmin.cn/n/5839600.html

相关文章

深度学习之“缺失数据处理”

缺失值检测 缺失数据就是我们没有的数据。如果数据集是由向量表示的特征组成&#xff0c;那么缺失值可能表现为某些样本的一个或多个特征因为某些原因而没有测量的值。通常情况下&#xff0c;缺失值由特殊的编码方式。如果正常值都是正数&#xff0c;那么缺失值可能被标记为-1…

团体程序设计天梯赛-练习集——L1-029 是不是太胖了

前言 5分级别里面目前做到的最难的一道题&#xff0c;但是非常简单&#xff0c;5分的题看看写点代码就行了。 L1-029 是不是太胖了 据说一个人的标准体重应该是其身高&#xff08;单位&#xff1a;厘米&#xff09;减去100、再乘以0.9所得到的公斤数。已知市斤的数值是公斤数…

LVGL+FreeRTOS实战项目:智能健康助手(lcd篇)

1.8寸彩色TFT显示屏简介 接线图 我们选用的是分辨率为128*160的彩色显示屏&#xff0c;采用的SPI接口&#xff0c;通过我们STM32的SPI外设&#xff0c;来和我们的屏幕进行通信&#xff0c;以显示我们需要显示的图片。 软件部分 #include "lcd_driver.h"//液晶IO初始…

五. Redis 配置内容(详细配置说明)

五. Redis 配置内容(详细配置说明) 文章目录 五. Redis 配置内容(详细配置说明)1. Units 单位配置2. INCLUDES (包含)配置3. NETWORK (网络)配置3.1 bind(配置访问内容)3.2 protected-mode (保护模式)3.3 port(端口)配置3.4 timeout(客户端超时时间)配置3.5 tcp-keepalive()配置…

智能小区物业管理系统推动数字化转型与提升用户居住体验

内容概要 在当今快速发展的社会中&#xff0c;智能小区物业管理系统的出现正在改变传统的物业管理方式。这种系统不仅仅是一种工具&#xff0c;更是一种推动数字化转型的重要力量。它通过高效的技术手段&#xff0c;将物业管理与用户居住体验紧密结合&#xff0c;无疑为社区带…

Android Services开机自启动程序

参考&#xff1a;https://android.stackexchange.com/questions/214839/how-to-run-an-android-init-service-with-superuser-selinux-context 手机为小米4C&#xff0c;已rooted。 以dropbear为例 #如不修改权限会出现permission错误~# chown 0.0 /etc/init/custom.rc ~# ch…

从未标记图像中生成有标记图像特征的半监督分割方法

今天看到一篇文章很有意思&#xff0c;给大家分享一下。现在传统半监督分割网络训练时往往有标注数据与未标注数据分开训练&#xff0c;导致模型不好。这篇文章作者提出了一个很有意思的想法。它通过通道注意力从未标记的特征中重新加载标记的特征。这篇文章是AllSpark。 大家感…

【PLL】杂散生成和调制

时钟生成 --》 数字系统 --》峰值抖动频率生成 --》无线系统 --》 频谱纯度、 周期信号的相位不确定性 随机抖动&#xff08;random jitter, RJ&#xff09;确定性抖动&#xff08;deterministic jitter,DJ&#xff09; 时域频域随机抖动积分相位噪声确定性抖动边带 杂散生成和…