嵌入式全栈设计思路:STM32G4+ChibiOS+FreeRTOS+PID控制+PFC算法构建高效智能电源管理系统(附代码示例)

智能电源管理系统是一个基于STM32G4微控制器的高性能数字电源控制解决方案。本项目旨在设计一个功能全面、高效稳定的电源管理系统,可广泛应用于工业控制、新能源、通信设备等领域。

1.1 系统主要特点

  1. 高精度数字电源控制:利用STM32G4的高性能ADC和定时器,实现精确的电压电流控制。
  2. 多模块协同工作:通过CAN总线实现多个电源模块的协同控制和负载均衡。
  3. 实时监控和保护:集成过压、过流、过温等多重保护机制,确保系统安全可靠。
  4. 远程配置和固件更新:支持通过RS485接口进行远程参数配置和固件更新。
  5. 高效率运行:采用先进的Buck/Boost拓扑和动态PFC技术,实现高效能量转换。

1.2 技术栈概览

  • 微控制器:STM32G474RE (STM32G4系列)
  • 操作系统:ChibiOS/RT 21.11.1
  • 电源管理:数字控制Buck/Boost转换器
  • 电流感应:INA226高精度电流检测芯片
  • 通信接口:CAN 2.0B, RS485 (Modbus RTU)
  • 数据采集:内置12位SAR ADC, 5MSPS采样率
  • 控制算法:数字PID控制,自适应控制
  • 人机界面:0.96" OLED显示屏,旋转编码器
  • 数据存储:W25Q64 8MB SPI Flash
  • 开发工具:STM32CubeIDE 1.9.0, Qt 5.15.2

2. 系统设计

2.1 硬件设计

系统硬件架构如下:

 

2.1.1 核心控制器

选用STM32G474RE,其主要特性包括:

  • ARM Cortex-M4内核,170MHz主频
  • 512KB Flash, 128KB SRAM
  • 5个12位ADC,采样率高达5MSPS
  • 7个高级定时器,支持高分辨率PWM
2.1.2 电源转换电路

采用同步整流Buck/Boost拓扑,主要组件:

  • 功率MOSFET:IPB020N10N3 (100V, 90A)
  • 驱动IC:UCC27211A-Q1
  • 输出电感:IHLP-5050FD-01 (10μH)
  • 输出电容:TDK C5750X6S2W225K250KA (2.2μF, 450V)

Buck/Boost拓扑允许系统在输入电压高于或低于输出电压时都能正常工作,提高了系统的适应性。同步整流技术显著提高了转换效率,特别是在高电流输出时。

2.1.3 电流检测

采用Texas Instruments的INA226高精度电流检测芯片:

  • 16位ADC,可测量范围±81.92mV
  • 精度:量程的0.1%
  • I2C接口,可编程采样速率
  • 内置校准和告警功能

将INA226与一个10mΩ精密分流电阻配合使用,可以实现高达±8.192A的电流测量范围。

2.1.4 通信接口
  1. CAN接口

    • 使用STM32G4内置的FDCAN控制器
    • 外部CAN收发器:TJA1044GT (5Mbps高速CAN)
    • 支持CAN 2.0B协议,用于多模块通信
  2. RS485接口

    • 使用STM32G4的UART接口
    • 外部RS485收发器:MAX3485
    • 支持Modbus RTU协议,用于远程监控和配置
2.1.5 人机界面
  • OLED显示屏:0.96英寸,128x64分辨率,SSD1306控制器
  • 旋转编码器:PEC11R-4215F-S0024 (24步/圈),用于用户输入
2.1.6 数据存储

采用Winbond W25Q64JVSSIQ 8MB SPI Flash:

  • 支持SPI/Dual SPI/Quad SPI接口
  • 100,000次编程/擦除周期
  • 用于存储系统日志和配置参数
2.1.7 温度监测

使用MAX31855KASA+热电偶数字转换器:

  • 冷端补偿K型热电偶数字转换器
  • 14位分辨率,0.25°C
  • SPI接口
  • 用于监测关键部件温度,实现过温保护

2.2 软件设计

软件架构采用分层设计,如下图所示:

 

2.2.1 操作系统

采用ChibiOS/RT 21.11.1实时操作系统:

  • 优先级基于的抢占式多任务调度
  • 低内存占用(约8KB ROM,2KB RAM)
  • 快速上下文切换(约200个时钟周期)
  • 丰富的同步原语(互斥量、信号量、事件标志等)
2.2.2 主要软件模块
  1. 电源控制模块

    • 实现数字PID控制算法
    • 自适应控制策略,根据负载变化调整参数
    • PWM生成与同步整流控制
  2. 数据采集模块

    • 高速ADC采样(电压、电流)
    • INA226电流检测芯片数据读取
    • 温度数据采集和处理
  3. 保护机制模块

    • 过压保护
    • 过流保护
    • 过温保护
    • 软启动控制
  4. 通信模块

    • CAN协议栈实现(多模块通信)
    • Modbus RTU协议实现(远程监控)
  5. 人机界面模块

    • OLED显示驱动
    • 旋转编码器输入处理
    • 菜单系统实现
  6. 数据存储模块

    • Flash读写驱动
    • 日志记录系统
    • 参数存储与恢复
  7. 系统管理模块

    • 任务调度
    • 电源状态管理
    • 错误处理和系统恢复
2.2.3 任务划分
任务名称优先级周期功能描述
controlTask100μs电源控制算法执行
adcTask200μsADC数据采集和处理
protectionTask1ms系统保护检查
communicationTask10ms通信协议处理
uiTask50ms用户界面更新
dataLogTask1s数据记录到Flash
2.2.4 关键算法实现
2.2.4.1 PID控制算法

PID(比例-积分-微分)控制是电源管理系统中最核心的算法之一,用于精确控制输出电压和电流。

typedef struct {float Kp, Ki, Kd;           // PID参数float error_sum, last_error; // 积分误差和上一次误差float output_min, output_max; // 输出限幅
} PID_Controller;float PID_Update(PID_Controller* pid, float setpoint, float measurement) {float error = setpoint - measurement;// 比例项float P = pid->Kp * error;// 积分项(带积分限幅)pid->error_sum += error;pid->error_sum = CLAMP(pid->error_sum, -10.0f, 10.0f);float I = pid->Ki * pid->error_sum;// 微分项float D = pid->Kd * (error - pid->last_error);pid->last_error = error;// 计算输出float output = P + I + D;// 输出限幅output = CLAMP(output, pid->output_min, pid->output_max);return output;
}

说明:

  • 该PID算法实现了基本的比例、积分和微分控制。
  • 使用了积分限幅来防止积分饱和。
  • 输出限幅确保控制信号在合理范围内。
2.2.4.2 自适应PID参数调整

为了应对不同负载条件,我们实现了一个简单的自适应PID参数调整算法。

void PID_Adapt(PID_Controller* pid, float error) {float abs_error = fabs(error);if (abs_error > 5.0f) {pid->Kp *= 1.1f;  // 误差大时增大Kp} else if (abs_error < 1.0f) {pid->Kp *= 0.9f;  // 误差小时减小Kp}pid->Kp = CLAMP(pid->Kp, 0.1f, 10.0f);  // 限制Kp的范围
}

说明:

  • 根据误差大小动态调整Kp参数。
  • 当误差较大时,增大Kp以提高响应速度。
  • 当误差较小时,减小Kp以提高稳定性。
  • Kp的值被限制在0.1到10之间,防止过度调整。
2.2.4.3 软启动算法

软启动算法用于在系统启动时缓慢增加输出电压,避免突然的电流冲击。

typedef struct {float target_voltage;       // 目标电压float current_voltage;      // 当前电压float ramp_rate;            // 斜率 (V/s)uint32_t last_update_time;  // 上次更新时间
} SoftStart;void SoftStart_Init(SoftStart* ss, float target, float rate) {ss->target_voltage = target;ss->current_voltage = 0.0f;ss->ramp_rate = rate;ss->last_update_time = HAL_GetTick();
}float SoftStart_Update(SoftStart* ss) {uint32_t now = HAL_GetTick();float elapsed_time = (now - ss->last_update_time) / 1000.0f;ss->last_update_time = now;ss->current_voltage += ss->ramp_rate * elapsed_time;if (ss->current_voltage >= ss->target_voltage) {ss->current_voltage = ss->target_voltage;return -1.0f;  // 软启动完成}return ss->current_voltage;
}

说明:

  1. SoftStart 结构体包含了软启动所需的所有参数:

    • target_voltage: 最终要达到的目标电压
    • current_voltage: 当前输出电压
    • ramp_rate: 电压上升的速率(V/s)
    • last_update_time: 上次更新的时间戳
  2. SoftStart_Init 函数用于初始化软启动参数:

    • 设置目标电压和斜率
    • 初始电压设为0
    • 记录初始时间戳
  3. SoftStart_Update 函数实现了软启动的核心逻辑:

    • 计算自上次更新以来的时间间隔
    • 根据时间间隔和斜率增加当前电压
    • 如果达到或超过目标电压,则返回-1表示软启动完成
    • 否则返回当前电压值

使用这个软启动算法可以实现电压的平滑上升,减少启动时的浪涌电流,保护电源和负载。在实际应用中,可以将这个算法集成到主控制循环中,在系统启动或重启时调用。

2.2.4.4 动态功率因数校正 (PFC) 算法

动态功率因数校正算法用于改善电源的功率因数,提高能源利用效率。

typedef struct {float voltage_rms;   // 电压有效值float current_rms;   // 电流有效值float power_factor;  // 当前功率因数float target_pf;     // 目标功率因数float duty_cycle;    // PWM占空比
} PFC_Controller;void PFC_Update(PFC_Controller* pfc, float voltage, float current) {// 更新RMS值(使用简化的移动平均法)pfc->voltage_rms = (pfc->voltage_rms * 0.9f) + (fabsf(voltage) * 0.1f);pfc->current_rms = (pfc->current_rms * 0.9f) + (fabsf(current) * 0.1f);// 计算功率因数(简化计算,假设电压和电流同相位)float apparent_power = pfc->voltage_rms * pfc->current_rms;float active_power = voltage * current;pfc->power_factor = active_power / apparent_power;// 调整PWM占空比以改善功率因数float pf_error = pfc->target_pf - pfc->power_factor;pfc->duty_cycle += pf_error * 0.01f;  // 简单的比例调节// 限制占空比在有效范围内pfc->duty_cycle = CLAMP(pfc->duty_cycle, 0.1f, 0.9f);
}float PFC_GetDutyCycle(PFC_Controller* pfc) {return pfc->duty_cycle;
}

说明:

  1. PFC_Controller 结构体包含了PFC所需的参数:

    • voltage_rms 和 current_rms: 电压和电流的有效值
    • power_factor: 当前计算得到的功率因数
    • target_pf: 目标功率因数(通常接近1)
    • duty_cycle: 用于控制功率因数的PWM占空比
  2. PFC_Update 函数实现了PFC的核心逻辑:

    • 使用简化的移动平均法更新电压和电流的RMS值
    • 计算当前功率因数(这里使用了简化计算,假设电压和电流同相位)
    • 根据当前功率因数和目标功率因数的误差调整PWM占空比
    • 将占空比限制在10%到90%之间,确保系统稳定性
  3. PFC_GetDutyCycle 函数用于获取当前的PWM占空比,以便控制功率开关

使用说明:

  • 在主控制循环中定期调用 PFC_Update 函数,传入实时的电压和电流采样值
  • 使用 PFC_GetDutyCycle 获取计算得到的PWM占空比,并应用到功率控制电路
  • 根据实际系统特性,可能需要调整占空比调节的比例系数(当前为0.01)

注意事项:

  1. 这是一个简化的PFC算法,实际应用中可能需要更复杂的相位检测和控制策略。
  2. 功率因数的计算假设了电压和电流同相位,这在实际系统中可能并不准确。更精确的实现应该考虑相位差。
  3. 移动平均法用于RMS计算是一种近似方法,对于快速变化的信号可能不够准确。在高精度要求的场合,应考虑使用真RMS计算方法。
  4. 占空比的调整使用了简单的比例控制,可能需要根据系统特性调整或采用更复杂的控制策略(如PI控制)。
  5. 算法没有考虑电网频率变化,在某些应用中可能需要频率跟踪功能。

改进建议:

  1. 实现相位检测:使用零交叉检测或DFT(离散傅里叶变换)来准确测量电压和电流的相位差。
  2. 增加自适应控制:根据负载特性自动调整控制参数。
  3. 添加谐波分析:在某些应用中,可能需要考虑谐波对功率因数的影响。
  4. 实现软启动:在PFC启动时,逐渐增加占空比以避免突然的电流冲击。
  5. 故障检测:添加过压、过流等保护机制。

示例代码扩展:

// 添加相位检测功能
void PFC_DetectPhase(PFC_Controller* pfc, float voltage, float current) {// 使用零交叉检测或其他方法检测相位// 这里仅为示意,实际实现可能更复杂static float last_voltage = 0;if (voltage >= 0 && last_voltage < 0) {// 电压零交叉点pfc->voltage_phase = 0;}if (current >= 0 && pfc->last_current < 0) {// 电流零交叉点,计算相对于电压的相位差pfc->current_phase = (HAL_GetTick() - pfc->last_voltage_zero) / (1000.0f / 50.0f) * 360.0f;}last_voltage = voltage;pfc->last_current = current;
}// 更精确的功率因数计算
float PFC_CalculatePowerFactor(PFC_Controller* pfc) {return cosf(pfc->current_phase * PI / 180.0f);
}// 添加到主更新函数
void PFC_Update(PFC_Controller* pfc, float voltage, float current) {PFC_DetectPhase(pfc, voltage, current);// ... 其他更新逻辑 ...pfc->power_factor = PFC_CalculatePowerFactor(pfc);// ... 继续原有的控制逻辑 ...
}

3. 系统集成

3.1 硬件集成

  1. PCB设计:使用Altium Designer进行四层PCB设计,考虑EMI/EMC布局。
  2. 热管理:为关键组件(如功率MOSFET和电感)设计适当的散热方案。
  3. 接口设计:包括电源输入/输出端子、通信接口(CAN, RS485)、调试接口(JTAG/SWD)。

3.2 软件集成

  1. 驱动层集成:将各硬件驱动(ADC, PWM, CAN, RS485等)整合到ChibiOS的HAL层。
  2. 中间件集成:将FatFS文件系统与W25Q64 Flash驱动结合,实现数据存储功能。
  3. 应用层集成:将PID控制、PFC算法、保护机制等模块组合成完整的应用程序。

3.3 固件更新机制

实现基于CAN总线或RS485的在线固件更新功能:

typedef struct {uint32_t firmware_version;uint32_t firmware_size;uint32_t crc32;
} FirmwareHeader;bool UpdateFirmware(uint8_t* new_firmware, uint32_t size) {FirmwareHeader* header = (FirmwareHeader*)new_firmware;// 验证固件if (CalculateCRC32(new_firmware + sizeof(FirmwareHeader), size - sizeof(FirmwareHeader)) != header->crc32) {return false;}// 擦除FlashFLASH_Erase(FIRMWARE_START_ADDRESS, header->firmware_size);// 写入新固件FLASH_Write(FIRMWARE_START_ADDRESS, new_firmware + sizeof(FirmwareHeader), header->firmware_size);// 验证写入if (memcmp((void*)FIRMWARE_START_ADDRESS, new_firmware + sizeof(FirmwareHeader), header->firmware_size) != 0) {return false;}// 更新启动标志UpdateBootFlag(header->firmware_version);return true;
}

4. 测试与验证

4.1 单元测试

使用Unity测试框架对关键模块进行单元测试:

void test_PID_controller(void) {PID_Controller pid = {1.0f, 0.1f, 0.01f, 0, 0, -100, 100};TEST_ASSERT_FLOAT_WITHIN(0.1f, 50.0f, PID_Update(&pid, 100, 50));TEST_ASSERT_FLOAT_WITHIN(0.1f, 25.0f, PID_Update(&pid, 100, 75));
}void test_soft_start(void) {SoftStart ss;SoftStart_Init(&ss, 12.0f, 1.0f);TEST_ASSERT_FLOAT_WITHIN(0.1f, 1.0f, SoftStart_Update(&ss));// Simulate 1 second passingss.last_update_time -= 1000;TEST_ASSERT_FLOAT_WITHIN(0.1f, 2.0f, SoftStart_Update(&ss));
}

4.2 集成测试

  1. 功能测试:验证所有功能模块的协同工作。
  2. 性能测试:测试系统在不同负载条件下的响应时间和稳定性。
  3. 压力测试:在极限条件下运行系统,如最大负载、高温环境等。
  4. 长期可靠性测试:连续运行系统至少 1000 小时,监控性能变化。

测试用例示例:

void test_full_system_startup(void) {// 模拟系统启动SystemInit();// 验证软启动TEST_ASSERT_TRUE(WaitForVoltageStable(12.0f, 5000));  // 等待电压稳定在12V,超时5秒// 验证PFC功能TEST_ASSERT_FLOAT_WITHIN(0.05f, 0.98f, GetPowerFactor());  // 功率因数应该接近1// 验证通信功能TEST_ASSERT_TRUE(TestCANComm());TEST_ASSERT_TRUE(TestModbusComm());
}void test_load_transient_response(void) {// 设置初始负载SetLoad(5.0f);  // 5A负载// 等待系统稳定Delay(1000);// 突然增加负载SetLoad(10.0f);  // 增加到10A// 检查电压恢复时间uint32_t recovery_time = MeasureVoltageRecoveryTime(11.5f, 12.5f);TEST_ASSERT_LESS_THAN(500, recovery_time);  // 恢复时间应小于500ms
}

4.3 EMC/EMI 测试

  1. 传导发射测试:确保系统符合 CISPR 22/EN 55022 标准。
  2. 辐射发射测试:验证系统在正常运行时不会产生过量电磁干扰。
  3. 抗扰度测试:测试系统对外部电磁干扰的抵抗能力,包括 ESD、浪涌等。

5. 项目总结

本智能电源管理系统项目成功实现了以下目标:

  1. 基于 STM32G4 的高性能数字控制电源系统,支持精确的电压和电流调节。
  2. 实现了先进的 PFC 算法,显著提高了系统的功率因数。
  3. 集成了多种保护机制,确保系统在各种条件下安全可靠运行。
  4. 通过 CAN 和 Modbus 协议实现了灵活的通信和远程管理功能。
  5. 软启动和自适应控制算法提高了系统的稳定性和适应性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/45634.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HTML5+CSS3小实例:纯CSS实现奥运五环

实例:纯CSS实现奥运五环 技术栈:HTML+CSS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-sca…

网页数据抓取:融合BeautifulSoup和Scrapy的高级爬虫技术

网页数据抓取&#xff1a;融合BeautifulSoup和Scrapy的高级爬虫技术 在当今的大数据时代&#xff0c;网络爬虫技术已经成为获取信息的重要手段之一。Python凭借其强大的库支持&#xff0c;成为了进行网页数据抓取的首选语言。在众多的爬虫库中&#xff0c;BeautifulSoup和Scrap…

在Android Jetpack Compose中实现夜间模式

在Android Jetpack Compose中实现夜间模式 随着用户对夜间模式需求的增加,Android开发者需要掌握如何在应用中实现这一功能。Jetpack Compose作为现代Android UI工具包,提供了简便且灵活的方式来实现夜间模式。本文将详细介绍如何在Jetpack Compose中实现夜间模式,包括配置…

Linux系统之玩转fortune命令

Linux系统之好玩的fortune命令 一、fortune命令介绍1.1 fortune简介1.2 fortune中英文 二、本地环境介绍2.1 本地环境规划2.2 本次实践介绍 三、检查本地环境3.1 检查本地操作系统版本3.2 检查系统内核版本 四、fortune英文版的使用4.1 安装fortune英文版4.2 命令帮助4.3 fortu…

安卓手机刷入Magisk面具教程

手机如果想获取 Root 权限&#xff0c;刷入面具是必要的做法。本期文章将会教你如何刷入 Magisk 面具。 准备工作 Magisk: 关注微信公众号 heStudio Community回复 magisk 获取下载链接。第三方 Recovery&#xff08;官方 Recovery 能玩出什么花样&#xff1f;&#xff1f;&a…

PDM系统:企业产品数据管理、PDM系统哪个好

PDM系统&#xff1a;企业产品数据管理、PDM系统哪个好 在当今这个数据驱动的时代&#xff0c;企业产品数据管理&#xff08;PDM&#xff09;系统已成为企业提升竞争力、加速产品创新、优化生产流程的关键工具。PDM系统不仅是一个技术平台&#xff0c;更是企业实现数字化转型的重…

防火墙负载分担,带宽策略

一、实验拓扑图 二、实验要求 12&#xff0c;对现有网络进行改造升级&#xff0c;将当个防火墙组网改成双机热备的组网形式&#xff0c;做负载分担模式&#xff0c;游客区和DMZ区走FW3&#xff0c;生产区和办公区的流量走FW1 13&#xff0c;办公区上网用户限制流量不超过100M&a…

昇思25天学习打卡营第23天|基于MobileNetv2的垃圾分类

基于MobileNetv2的垃圾分类 1、实验目的 了解熟悉垃圾分类应用代码的编写&#xff08;Python语言&#xff09;&#xff1b;了解Linux操作系统的基本使用&#xff1b;掌握atc命令进行模型转换的基本操作。 2、MobileNetv2模型原理介绍 MobileNet网络是由Google团队于2017年提…

效能工具:执行 npm start 可直接切换proxy代理UR后直接启动项目

1) 背景: 我们项目是2个前端3个后端的配置。前端和每个后端都有需要调试的接口。 因此经常切换vite.congig.js中的proxy后端代理链接&#xff0c;是挺麻烦的。 于是我研究如何能快速切换后端URL&#xff0c;所幸懒人有懒福&#xff0c;我找到了Inquirer 和 fs&#xff0c; 实…

根据日志绘制障碍物轮廓点和中心点

绘制log中的障碍物凸包点&#xff0c;首先给出log日志中的障碍物的凸包点 [Info]-[PointCloudHandle:88]:[2024-07-14,09:55:41.052]-back obj size 6 [Info]-[PointCloudHandle:92]:[2024-07-14,09:55:41.052]-back obj size 6 cur idx 1 [Info]-[PointCloudHandle:93]:[2024…

STM32+TMC2209控制步进电机正反转。

STM32F103ZET6TMC2209控制步进电机正反转 1. 步进电机介绍2 驱动器TMC2209介绍2.1 引脚图及其功能2.2 细分介绍2.3 TMC控制驱动器接法 3 控制器介绍3.1 确定控制引脚3.2 UBEMX配置3.2.1 GPIO配置3.2.2 NVIC配置3.2.3 RCC配置3.2.4 SYS配置3.2.5 USRAT2配置&#xff08;PS:没用上…

单相电机或风扇接电容的具体接线方法示例

单相电机或风扇接电容的具体接线方法示例 如下图所示&#xff0c;单相电机引出3根绕组线&#xff08;不同品牌或型号的电机&#xff0c;引出线的颜色可能会有差异&#xff09;&#xff0c; 那么如何进行接线呢&#xff1f; 首先&#xff0c;跳过万用表测量主、副绕组的阻值…

Unable to obtain driver using Selenium Manager: Selenium Manager failed解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

【Linux】Ubuntu 漏洞扫描与修复的吃瘪经历

自从上次“劫持”事情后&#xff0c;项目经理将所有跟安全相关的都推给我了&#xff08;不算 KPI 又要被白嫖&#xff0c;烦死了&#xff09;。这次客户又提了一个服务器安全扫描和漏洞修复的“活”&#xff0c;我这边顺手将过程记录一下&#xff0c;就当经验总结跟各位分享一下…

【Linux】多线程_7

文章目录 九、多线程8. POSIX信号量根据信号量环形队列的生产者消费者模型代码结果演示 未完待续 九、多线程 8. POSIX信号量 POSIX信号量和SystemV信号量作用相同&#xff0c;都是用于同步操作&#xff0c;达到无冲突的访问共享资源目的。 但POSIX可以用于线程间同步。 创建…

什么ISP?什么是IAP?

做单片机开发的工程师经常会听到两个词&#xff1a;ISP和IAP&#xff0c;但新手往往对这两个概念不是很清楚&#xff0c;今天就来和大家聊聊什么是ISP&#xff0c;什么是IAP&#xff1f; 一、ISP ISP的全称是&#xff1a;In System Programming&#xff0c;即在系统编程&…

如何申请抖音本地生活服务商?3种方式优劣势分析!

随着多家互联网大厂在本地生活板块的布局力度不断加大&#xff0c;以抖音为代表的头部互联网平台的本地生活服务商成为了创业赛道中的大热门&#xff0c;与抖音本地生活服务商怎么申请等相关的帖子&#xff0c;更是多次登顶创业者社群的话题榜单。 就目前的市场情况来看&#x…

Go语言--广播式并发聊天服务器

实现功能 每个客户端上线&#xff0c;服务端可以向其他客户端广播上线信息&#xff1b;发送的消息可以广播给其他在线的客户支持改名支持客户端主动退出支持通过who查找当前在线的用户超时退出 流程 变量 用户结构体 保存用户的管道&#xff0c;用户名以及网络地址信息 typ…

ARM功耗管理之功耗数据与功耗收益评估

安全之安全(security)博客目录导读 思考&#xff1a;功耗数据如何测试&#xff1f;功耗曲线&#xff1f;功耗收益评估&#xff1f; UPF的全称是Unified Power Format&#xff0c;其作用是把功耗设计意图&#xff08;power intent&#xff09;传递给EDA工具&#xff0c; 从而帮…