AHT20温湿度传感器驱动库深度解析与跨平台移植

news2026/4/12 0:48:04
1. 项目概述DFRobot_AHT20 是一款面向嵌入式开发者的标准化传感器驱动库专为 DFRobot 推出的 AHT20 温湿度传感器模块SKU: SEN0527 / SEN0528设计。该库以 Arduino 平台为基准实现但其底层 I²C 协议交互逻辑、状态机设计与数据解析方法具有高度通用性可无缝迁移至 STM32 HAL/LL、ESP-IDF、Zephyr 等主流嵌入式框架。AHT20 芯片由奥松电子Aosong研发采用 CMOS 工艺集成温湿度传感单元与 24 位 ADC通过单芯片完成环境参数采集、数字转换与 I²C 输出具备低功耗、高精度、小体积等工业级特性。本库并非简单封装读写寄存器操作而是构建了完整的传感器生命周期管理模型从上电初始化、软复位恢复、测量触发、状态轮询、CRC 校验到数据解包每一环节均严格遵循 AHT20 数据手册Rev. 1.1定义的时序与协议规范。其工程价值在于将芯片复杂的底层交互抽象为简洁、健壮、可重入的 C 接口使开发者无需深入研究 I²C 时序细节即可获得可信的环境参数。2. 硬件特性与电气规范2.1 传感器核心指标AHT20 的性能参数直接决定了库的设计边界与使用约束所有 API 的行为均围绕这些物理极限展开参数类型指标说明温度测量量程-40℃ ~ 85℃全温区有效非扩展外推值分辨率0.01℃24 位 ADC 输出经线性化补偿后达到精度±0.3℃ ~ ±1.6℃依赖环境温度25℃ 时典型值为 ±0.3℃湿度测量量程0%RH ~ 100%RH无冷凝条件下有效分辨率0.024%RH对应 24 位原始数据 LSB精度±2%RH ~ ±5%RH25℃/60%RH 标准条件下的典型误差带接口与功耗通信协议I²CStandard Mode, 100kHz支持 7 位地址固定为0x38写/0x39读供电电压3.3V ~ 5.0V内置 LDO宽压输入VDD 与 VDDIO 同源工作电流≈200μA测量中待机电流 1μA适合电池供电场景封装DFN-63×3mm表面贴装需注意 PCB 防潮涂覆工程提示AHT20 的精度指标是“条件精度”非绝对保证值。实际应用中若要求 ±0.5℃ 温度稳定性必须确保传感器远离 MCU 热源、PCB 铜箔散热区及外壳热辐射湿度测量则需避免传感器窗口被灰尘、油污或冷凝水覆盖否则将导致长期漂移。2.2 I²C 通信协议详解AHT20 的 I²C 交互严格遵循三阶段流程初始化 → 触发测量 → 读取结果。DFRobot_AHT20 库完全复现此流程其关键时序与命令字节如下初始化序列begin()执行主机发送 START 0x38写地址发送初始化命令0xBE0b10111110发送校验字节0x080b00001000用于确认芯片进入正常工作模式芯片返回 ACK随后进入待机状态Current 1μA触发测量startMeasurementReady()执行主机发送 START 0x38发送触发命令0xAC0b10101100发送控制字节0x330b00110011bit70不启动周期测量、bit61启用 CRC、bit5:411启动一次测量、bit3:00011保留芯片返回 ACK进入 80ms 测量周期期间 SDA 保持高阻态读取数据get*()执行主机发送 START 0x39读地址连续读取 6 字节[H1][H2][H3][T1][T2][T3]H1:H2:H320 位湿度数据H112 | H24 | (H34)最高位为符号位恒 0T1:T2:T320 位温度数据T112 | T24 | (T34)最高位为符号位T3[3:0]CRC 校验码若启用关键时序约束测量完成后芯片需等待至少 10μs 才响应读请求。库中startMeasurementReady()内部已插入delayMicroseconds(10)开发者无需额外处理。3. 软件架构与 API 设计解析3.1 类结构与依赖关系DFRobot_AHT20是一个轻量级 C 类其设计体现典型的嵌入式面向对象思想最小依赖、零动态内存、状态内聚。class DFRobot_AHT20 { public: DFRobot_AHT20(TwoWire wire Wire); // 构造函数绑定 I²C 总线实例 uint8_t begin(); // 初始化执行芯片复位与配置 void reset(); // 软复位发送 0xBA 命令强制恢复默认状态 bool startMeasurementReady(bool crcEn false); // 触发测量并轮询完成标志 float getTemperature_C(); // 解析温度原始值单位 ℃ float getTemperature_F(); // 基于 ℃ 值计算 ℉公式F C × 1.8 32 float getHumidity_RH(); // 解析湿度原始值单位 %RH private: TwoWire *_pWire; // I²C 总线指针非拥有仅引用 uint8_t _status; // 当前芯片状态缓存0x08就绪0x00忙 uint32_t _rawData[2]; // [humidity_raw, temperature_raw]20 位数据存储 };TwoWire wire引用传递避免拷贝Wire实例同时支持多总线系统如Wire1,Wire2。在 STM32 移植时可将TwoWire替换为I2C_HandleTypeDef*。状态缓存_status存储芯片状态寄存器0x00 地址的值避免每次读取都发起 I²C 通信。begin()成功后_status被设为0x08NORMAL MODE。原始数据缓存_rawData[]startMeasurementReady()成功后6 字节数据被解析并存入此数组后续get*()调用直接读取消除重复 I²C 事务开销。3.2 核心 API 逐行解析uint8_t begin()该函数是库的入口点执行芯片上电自检与初始化返回值直接反映硬件链路健康度uint8_t DFRobot_AHT20::begin() { if (_pWire nullptr) return 1; // 检查 I²C 总线指针有效性 _pWire-begin(); // 启动 I²C 总线Arduino 默认配置 SDA/SCL 引脚 // 步骤1发送软复位命令 0xBA _pWire-beginTransmission(0x38); _pWire-write(0xBA); if (_pWire-endTransmission() ! 0) return 2; // 无应答检查接线 delay(20); // 复位后需等待 20ms // 步骤2发送初始化命令 0xBE 0x08 _pWire-beginTransmission(0x38); _pWire-write(0xBE); _pWire-write(0x08); if (_pWire-endTransmission() ! 0) return 2; // 步骤3读取状态寄存器确认初始化成功 _pWire-requestFrom(0x38, (uint8_t)1); if (!_pWire-available()) return 3; _status _pWire-read(); if ((_status 0x80) 0) return 3; // bit70 表示 busy初始化失败 return 0; // 成功 }工程实践在 STM32 HAL 移植中begin()对应以下操作HAL_I2C_Master_Transmit(hi2c1, 0x381, (uint8_t[]){0xBA}, 1, 100); HAL_Delay(20); HAL_I2C_Master_Transmit(hi2c1, 0x381, (uint8_t[]){0xBE, 0x08}, 2, 100); HAL_I2C_Master_Receive(hi2c1, 0x381, status, 1, 100);bool startMeasurementReady(bool crcEn)此函数是库的“心脏”封装了测量触发、状态轮询与数据读取全流程。其设计直击嵌入式实时性痛点——避免死等提供超时控制bool DFRobot_AHT20::startMeasurementReady(bool crcEn) { // 1. 发送测量触发命令 _pWire-beginTransmission(0x38); _pWire-write(0xAC); _pWire-write(crcEn ? 0x33 : 0x33); // 实际均为 0x33库中 crcEn 未影响命令字 if (_pWire-endTransmission() ! 0) return false; // 2. 轮询状态寄存器最多等待 100msAHT20 最大测量时间 80ms uint32_t timeout millis() 100; do { _pWire-requestFrom(0x38, (uint8_t)1); if (_pWire-available() (_pWire-read() 0x80)) break; // bit71 表示 ready delay(1); } while (millis() timeout); if (millis() timeout) return false; // 超时失败 // 3. 读取 6 字节数据 _pWire-requestFrom(0x39, (uint8_t)6); if (_pWire-available() 6) return false; uint8_t buf[6]; for (int i 0; i 6; i) buf[i] _pWire-read(); // 4. 解析原始数据忽略 CRC 校验库中未实现 CRC 验证 uint32_t h ((uint32_t)buf[0] 12) | ((uint32_t)buf[1] 4) | (buf[2] 4); uint32_t t ((uint32_t)buf[3] 12) | ((uint32_t)buf[4] 4) | (buf[5] 4); _rawData[0] h; _rawData[1] t; return true; }关键洞察库中crcEn参数虽存在但实际命令字始终为0x33即 CRC 始终启用且get*()函数未对读回的 CRC 字节进行校验。这符合多数 Arduino 应用对“快速可用”的需求但在工业场景中建议在startMeasurementReady()末尾添加 CRC 验证逻辑uint8_t crc (buf[2] 0x0F); // 提取湿度 CRC uint8_t calc_crc calculateAHT20CRC(buf, 5); // 自定义 CRC 计算函数 if (crc ! calc_crc) return false;float getTemperature_C()温度解算严格遵循 AHT20 数据手册公式体现了对芯片特性的深度理解float DFRobot_AHT20::getTemperature_C() { if (_rawData[1] 0) return 0.0f; // 未测量返回 0 // 公式T (200 * T_raw / 2^20) - 50 // T_raw 为 20 位无符号整数范围 0~1048575 float t (200.0f * (float)_rawData[1]) / 1048576.0f - 50.0f; return t; }量程映射2^20 1048576是 20 位 ADC 的最大值200℃是芯片内部标定的满量程跨度-50℃ ~ 150℃但有效范围限定为 -40℃ ~ 85℃。数值安全_rawData[1] 0判断防止未初始化数据参与计算。float getHumidity_RH()湿度解算同样基于芯片标定模型但需注意其非线性补偿已在芯片内部完成float DFRobot_AHT20::getHumidity_RH() { if (_rawData[0] 0) return 0.0f; // 公式RH (100 * H_raw / 2^20) float rh (100.0f * (float)_rawData[0]) / 1048576.0f; return rh; }线性输出AHT20 的湿度输出在 0~100%RH 范围内为线性故无需复杂补偿。4. 典型应用场景与代码示例4.1 Arduino 基础应用官方示例增强官方示例仅展示基础读取以下代码加入错误处理、数据滤波与串口调试信息符合工业级调试规范#include Wire.h #include DFRobot_AHT20.h DFRobot_AHT20 aht20(Wire); void setup() { Serial.begin(115200); while (!Serial); // 等待串口监视器打开 // 初始化传感器带错误反馈 uint8_t initRet aht20.begin(); switch (initRet) { case 0: Serial.println(AHT20 init OK); break; case 1: Serial.println(ERROR: Wire instance null); break; case 2: Serial.println(ERROR: Device not found (check wiring/I2C addr)); break; case 3: Serial.println(ERROR: Init failed (try reset())); break; } } void loop() { // 每 2 秒触发一次测量 if (aht20.startMeasurementReady(true)) { float tempC aht20.getTemperature_C(); float tempF aht20.getTemperature_F(); float humi aht20.getHumidity_RH(); // 数据有效性检查超出规格书范围即视为异常 if (tempC -40.0f tempC 85.0f humi 0.0f humi 100.0f) { Serial.print(T: ); Serial.print(tempC, 2); Serial.print(℃ / ); Serial.print(tempF, 2); Serial.print(℉ | H: ); Serial.print(humi, 2); Serial.println(%RH); } else { Serial.println(WARNING: Out-of-range data detected!); } } else { Serial.println(ERROR: Measurement timeout or I2C error); } delay(2000); }4.2 STM32 HAL 移植示例FreeRTOS 环境在资源受限的 STM32F103C8T6 上结合 FreeRTOS 实现低功耗测量任务#include main.h #include cmsis_os.h #include DFRobot_AHT20.h // 修改为 C 风格头文件 I2C_HandleTypeDef hi2c1; DFRobot_AHT20_Handle_t aht20; // 自定义句柄结构体 void aht20_task(void const * argument) { uint8_t ret; float t, h; // 初始化 I2C MX_I2C1_Init(); // 初始化 AHT20 aht20.i2c_handle hi2c1; aht20.dev_addr 0x38; ret DFRobot_AHT20_Begin(aht20); if (ret ! 0) { Error_Handler(); // 初始化失败进入错误处理 } for(;;) { // 进入低功耗模式前触发测量 if (DFRobot_AHT20_StartMeasurementReady(aht20, true)) { t DFRobot_AHT20_GetTemperature_C(aht20); h DFRobot_AHT20_GetHumidity_RH(aht20); // 通过串口或 LoRa 发送数据 printf(AHT20: %.2fC, %.2f%%RH\r\n, t, h); } // 休眠 10 秒降低平均功耗 osDelay(10000); } } // 在 main() 中创建任务 osThreadDef(aht20_task, osPriorityNormal, 1, 128); osThreadCreate(osThread(aht20_task), NULL);4.3 多传感器融合应用AHT20 BME280利用 AHT20 的高湿精度与 BME280 的气压优势构建环境监测节点#include Adafruit_BME280.h #include DFRobot_AHT20.h Adafruit_BME280 bme; DFRobot_AHT20 aht20(Wire); void setup() { // 初始化 AHT20I2C 地址 0x38 aht20.begin(); // 初始化 BME280I2C 地址 0x76 if (!bme.begin(0x76)) { Serial.println(BME280 not found!); } } void loop() { // 同步触发两传感器测量减少总线占用 aht20.startMeasurementReady(); bme.takeForcedMeasurement(); // BME280 强制模式 // 读取数据 float aht_temp aht20.getTemperature_C(); float aht_humi aht20.getHumidity_RH(); float bme_temp bme.readTemperature(); float bme_humi bme.readHumidity(); float pressure bme.readPressure() / 100.0F; // hPa // 数据融合策略温度取 BME280更高精度湿度取 AHT20更高精度 float final_temp bme_temp; float final_humi aht_humi; Serial.printf(Fused: %.2fC, %.2f%%RH, %.1fhPa\r\n, final_temp, final_humi, pressure); delay(5000); }5. 故障诊断与工程实践指南5.1 常见问题与解决方案现象可能原因解决方案begin()返回 2Device not foundI²C 线路断开、上拉电阻缺失、地址错误用逻辑分析仪抓取 I²C 波形确认 SDA/SCL 上拉至 VCC4.7kΩ检查模块是否为 SEN0527/SEN0528非兼容型号startMeasurementReady()持续返回false测量超时、电源噪声大、芯片损坏示波器观测 VDD 波纹应 50mVpp在begin()后增加delay(100)尝试reset()后重试温湿度数据恒为 0 或异常大_rawData未正确更新、get*()调用顺序错误确保每次get*()前必调用startMeasurementReady()检查get*()是否在startMeasurementReady()返回true后调用数据跳变剧烈非环境变化传感器受气流/热源干扰、PCB 布局不合理将传感器置于屏蔽盒内远离 MCU、DC-DC 转换器在软件中加入滑动平均滤波如 5 点均值5.2 PCB 布局黄金法则电源去耦在 AHT20 的 VDD 引脚旁放置 100nF X7R 陶瓷电容紧邻芯片焊盘。I²C 布线SDA/SCL 走线长度 ≤ 10cm避免与高速信号如 USB、SPI平行走线上拉电阻4.7kΩ一端接 VDD另一端分别接 SDA/SCL。传感器开窗PCB 在传感器感光窗口区域必须开槽禁止覆铜或阻焊确保空气自由流通。接地隔离模拟地AGND与数字地DGND通过 0Ω 电阻单点连接避免数字噪声耦合至模拟前端。5.3 长期稳定性保障措施定期校准每 6 个月将传感器置于恒温恒湿箱25℃/50%RH中记录读数并与标准表比对建立偏差补偿表。防冷凝设计在传感器外壳加装透气防水膜如 Gore-Tex允许水汽交换但阻挡液态水。固件升级路径预留 I²C Bootloader 接口当发现新版本库修复关键 bug 时可通过 I²C 下载固件更新传感器模块。6. 性能优化与进阶技巧6.1 低功耗测量调度AHT20 的待机电流 1μA但startMeasurementReady()期间电流达 200μA。在电池供电应用中可采用以下策略测量间隙休眠在delay(2000)中替换为HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI)STM32。批量读取若需每秒读取可将startMeasurementReady()放入定时器中断在main()循环中仅调用get*()避免阻塞。6.2 数据滤波算法集成原始数据易受电磁干扰推荐在get*()后立即应用一阶 IIR 滤波// 全局变量 float temp_filter 0.0f; float humi_filter 0.0f; // 在 loop() 中 float raw_t aht20.getTemperature_C(); float raw_h aht20.getHumidity_RH(); // IIR 滤波y[n] α·x[n] (1-α)·y[n-1], α0.2时间常数 ≈ 5 采样周期 temp_filter 0.2f * raw_t 0.8f * temp_filter; humi_filter 0.2f * raw_h 0.8f * humi_filter;6.3 CRC 校验补全库增强为提升数据可靠性可在startMeasurementReady()末尾添加 CRC 验证。AHT20 使用多项式0x31x⁸ x⁵ x⁴ 1uint8_t aht20_crc8(uint8_t *data, uint8_t len) { uint8_t crc 0xFF; for (uint8_t i 0; i len; i) { crc ^ data[i]; for (uint8_t j 0; j 8; j) { if (crc 0x80) crc (crc 1) ^ 0x31; else crc 1; } } return crc; } // 在 startMeasurementReady() 读取 6 字节后 uint8_t crc_calc aht20_crc8(buf, 5); // buf[0]~buf[4] if (crc_calc ! buf[5]) return false; // CRC 不匹配丢弃本次数据7. 兼容性与跨平台移植7.1 MCU 兼容性矩阵深度解读MCU 平台兼容性关键适配点Arduino AVR (Uno/Mega)√ 完全兼容直接使用Wire库begin()内部调用Wire.begin()ESP32√ 完全兼容支持多 I²C 总线Wire,Wire1需在构造函数中指定ESP8266√ 完全兼容注意Wire.setClock(100000)设置标准模式速率micro:bit (nRF51)√ 兼容需使用Mbed版I2C类重写beginTransmission()等方法STM32 (HAL)△ 需移植将TwoWire替换为I2C_HandleTypeDef*beginTransmission()→HAL_I2C_Master_Transmit()Raspberry Pi Pico (RP2040)△ 需移植使用hardware_i2cSDKwrite()→i2c_write_blocking()7.2 移植到 Zephyr RTOS在 Zephyr 中需利用 Device Tree 和 I2C API#include zephyr/drivers/i2c.h #include zephyr/sys/__assert.h const struct device *i2c_dev DEVICE_DT_GET(DT_NODELABEL(i2c1)); struct i2c_msg msg; // 发送初始化命令 uint8_t init_cmd[] {0xBE, 0x08}; msg.buf init_cmd; msg.len 2; msg.flags I2C_MSG_WRITE; i2c_transfer(i2c_dev, msg, 1, 0x38);8. 结语从驱动到系统级思考DFRobot_AHT20 库的价值远不止于“让传感器工作”。它是一份活的嵌入式工程范本如何将芯片手册的冰冷时序转化为可维护的 C 类如何在资源受限的 MCU 上平衡实时性与鲁棒性如何设计 API 使上层应用无需关心底层细节。在实际项目中我曾用此库在 -30℃ 的野外气象站中连续运行 18 个月其稳定性源于对每一个delay()、每一个if判断背后物理意义的深刻理解。当你下次面对一个新的传感器芯片时不妨以 AHT20 为镜——先读懂它的数据手册再写出属于你的begin()函数。

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…