【STM32激光测距实战】基于CUBEMX与HAL库,解析STP-23模块串口中断数据采集与处理

news2026/3/16 19:24:41
1. 项目背景与模块选型为什么是STM32和STP-23大家好我是老李一个在嵌入式领域摸爬滚打了十多年的工程师。最近在做一个智能小车的项目需要用到激光测距来感知前方的障碍物距离。市面上测距模块不少超声波、红外、激光都有。超声波受环境影响大精度一般红外容易受光照干扰最后我选了激光方案精度高、响应快更适合需要快速反应的应用场景。在众多激光模块里我最终敲定了轮趣科技的STP-23。理由很简单第一它输出的是串口数据直接就能和单片机通信省去了复杂的模拟电路设计第二它只需要接收数据不需要单片机给它发指令协议相对简单第三价格合适性能也够用官方标称测量范围能达到几十米精度在厘米级对于我的小车项目来说完全足够了。拿到模块后我发现它默认的通信波特率是921600这个速率可不低对单片机的串口处理能力是个小考验。为了快速上手我决定用STM32F4系列的主控配合ST官方力推的HAL库和CUBEMX图形化配置工具来开发。这套组合拳对于从标准库转型过来的工程师或者刚入门的新手来说简直是福音能省下大量配置底层寄存器的时间让我们更专注于业务逻辑。2. 硬件连接与CUBEMX基础工程搭建工欲善其事必先利其器。在写代码之前我们得先把硬件连好把工程框架搭起来。STP-23模块通常有四根线VCC、GND、TX、RX。注意模块的TX要接我们STM32的RX接收引脚模块的RX接STM32的TX。但是STP-23比较特殊它是个“只读”模块只向外发送数据不接收指令。所以我们实际上只需要连接三根线VCC接3.3V或5V看模块规格、GND以及模块的TX接STM32的某个串口的RX引脚。模块的RX引脚悬空不接即可。我用的主控是STM32F401CCU6就把模块的TX接到了芯片的PA10脚也就是USART1的RX上。接下来就是软件部分的“利器”——STM32CubeMX。打开软件选择好你的芯片型号。第一步配置系统核心。在“Pinout Configuration”标签页里找到“System Core”下的“RCC”。高速外部时钟HSE选择“Crystal/Ceramic Resonator”这样我们才能使用外部晶振获得更精准的时钟。第二步配置时钟树。点击“Clock Configuration”标签这是关键一步。对于F401我想让主频跑到最高性能所以将HCLK设置为84MHz。系统会自动帮你计算和配置各级分频系数非常直观。第三步也是核心的一步配置串口。在左侧连接图里找到USART1将模式Mode设置为“Asynchronous”异步通信。然后在下方的参数设置Parameter Settings里将波特率Baud Rate手动修改为921600。数据位Word Length8位停止位Stop Bits1位无奇偶校验Parity None硬件流控制Hardware Flow Control选择Disable。别忘了在这个配置页的最下面找到“NVIC Settings”勾选上“USART1 global interrupt”使能全局中断。这就为后续的中断接收数据打下了基础。注意921600的波特率比较高务必确保你的时钟树配置正确否则实际波特率会产生偏差导致数据接收全是乱码。计算出的实际波特率Current Baud Rate应该非常接近921600。因为我们还需要把处理后的距离数据打印到电脑串口助手查看所以还得再配置一个串口用来发送。我使用了USART6对应PC6、PC7引脚模式同样为异步波特率设置为115200这是电脑串口助手常用的速率。这个串口不需要开启中断因为我们只用它发送数据。配置完成后点击“Project Manager”标签给工程起个名字选好保存路径IDE我习惯用Keil MDK。关键点来了在“Code Generator”里务必勾选“Generate peripheral initialization as a pair of ‘.c/.h’ files per peripheral”这样每个外设的代码会单独生成结构清晰。最后点击右上角的“GENERATE CODE”生成工程代码。用Keil打开工程一个最基础的、时钟和串口都配置好的工程框架就准备好了。3. 串口通信调试与printf重定向在开始处理激光模块的高速率数据之前我们必须确保基础的串口通信是畅通的。这就好比修一条高速公路之前得先确认乡间小路能走通。我们配置了两个串口USART1921600用来接收激光数据USART6115200用来向电脑打印信息。首先我们来打通USART6的打印功能。很多新手会直接用HAL_UART_Transmit函数来发送字符串但这样每次都要写一长串很麻烦。更优雅的做法是重定向C库的printf函数到我们的串口上这样就能直接用printf(“距离%d mm\n”, distance);这样的语句了和我们在电脑上编程的感觉一样。操作步骤如下首先在工程中找到usart.c文件。在文件最开头的用户代码区/* USER CODE BEGIN 0 */和/* USER CODE END 0 */之间包含标准输入输出头文件#include stdio.h。然后滚动到文件末尾在/* USER CODE BEGIN 1 */和/* USER CODE END 1 */之间添加下面两个函数// 重定向printf的发送函数 int fputc(int ch, FILE *f) { // 将字符ch通过USART6发送出去超时时间1000ms HAL_UART_Transmit(huart6, (uint8_t*)ch, 1, 1000); return ch; } // 重定向scanf的接收函数本例中未使用但通常一并实现 int fgetc(FILE *f) { uint8_t ch; HAL_UART_Receive(huart6, (uint8_t *)ch, sizeof(ch), 0xFFFF); return ch; }添加完代码后还需要在Keil的工程选项里开启“微库MicroLib”。右键点击Target选择“Options for Target”在“Target”标签页下勾选“Use MicroLIB”。微库是Keil为嵌入式设备优化的一个精简C库占用资源更少并且支持了我们刚才做的重定向。现在我们就可以在主函数里测试了。在main.c的/* USER CODE BEGIN Includes */区域也加入#include stdio.h。然后在main函数的初始化部分之后、主循环while(1)里添加测试代码printf(“串口打印测试Hello World!\r\n”); HAL_Delay(1000);编译下载程序用USB转TTL模块连接STM32的USART6TX到电脑打开串口助手如XCOM、SSCOM选择对应的COM口波特率115200。如果一切正常你应该能看到每秒输出一次“Hello World!”。这个步骤看似简单却至关重要它验证了我们的工程配置、编译下载流程和基础串口发送功能全部正常为后续复杂的调试铺平了道路。如果这里收不到数据就要回头检查接线、波特率、串口号以及重定向代码是否正确。4. 深入解析STP-23模块的数据帧协议基础通信调通了现在我们来啃最硬的骨头——理解STP-23发过来的数据到底是什么格式。很多朋友驱动传感器失败一半的原因是没有吃透它的通信协议。STP-23模块会以921600的波特率持续不断地向外发送数据包。每个数据包包含了一组12个测距点的信息。我们得像拆快递一样把这个数据包一层层拆开才能拿到我们想要的距离值。根据官方资料和我实际抓取的数据分析STP-23的一帧数据包长度是固定的47个字节。我们可以用一个C语言的结构体struct来完美地映射这个数据包格式这样处理起来会非常直观。这个结构体的定义我建议放在专门处理中断和数据的stm32f4xx_it.c文件对应的头文件stm32f4xx_it.h里方便全局使用。首先我们在头文件的用户代码区定义一些常量和类型/* USER CODE BEGIN EM */ #define PACK_HEADER 0x54 // 数据包帧头固定值 #define PACK_VER_LEN 0x2C // 版本与长度固定值低5位表示点数12 #define POINTS_PER_PACK 12 // 每包数据点数 // 单个测距点的数据结构注意内存对齐 typedef struct __attribute__((packed)) { uint16_t distance; // 距离值单位是毫米mm uint8_t intensity; // 信号强度/置信度 } LidarPointStructDef; // 整个数据包的结构体 typedef struct __attribute__((packed)) { uint8_t header; // 帧头 0x54 uint8_t ver_len; // 版本与长度 0x2C uint16_t temperature; // 模块内部温度原始ADC值 uint16_t start_angle; // 本包数据起始角度实际未使用可忽略 LidarPointStructDef point[POINTS_PER_PACK]; // 12个点的数据数组 uint16_t end_angle; // 本包数据结束角度实际未使用可忽略 uint16_t timestamp; // 时间戳 uint8_t crc8; // 从帧头到时间戳的CRC8校验和 } LiDARFrameTypeDef; /* USER CODE END EM */这里有个关键点__attribute__((packed))。这个GCC编译器特性在Keil AC6或IAR中也有类似方式是告诉编译器不要对这个结构体进行内存对齐优化。因为数据包是字节挨着字节发送的如果编译器为了效率在结构体成员之间插入空字节我们直接用结构体指针去解析接收到的字节数组就会错位导致数据全乱。用了packed属性结构体在内存中的布局就和网络数据包的布局完全一致了。一帧47个字节的构成是这样的第1字节是帧头0x54这是我们判断一帧数据开始的唯一标志。第2字节0x2C其低5位二进制是01100也就是十进制12表示后面有12个点。接着2个字节是温度再2个字节是起始角度。然后就是重头戏12个测距点数据每个点占3个字节2字节距离1字节强度所以一共36个字节。之后是2字节结束角度2字节时间戳最后1字节是CRC8校验码。整个数据流就像一列火车车头是0x54车尾是校验码中间装载着12个“货物”距离值。我们的任务就是在中断服务函数里把这列火车一节一节地、安全无误地“搬”进我们定义好的结构体仓库里。5. 高波特率下的串口中断服务程序实战波特率高达921600意味着每秒钟要接收近百万个字节。如果还用查询方式CPU啥也别干了光查串口状态就得忙死。所以中断是唯一的选择。我们的目标是在串口收到每一个字节的瞬间CPU都能立刻被中断然后我们把这个字节放到数据包的正确位置。听起来简单但写起来有很多细节和“坑”。首先在main.c文件中我们需要定义两个全局变量用于在中断服务程序和主程序之间传递信息。放在/* USER CODE BEGIN PV */区域/* USER CODE BEGIN PV */ volatile uint16_t packet_received_cnt 0; // 成功接收并校验正确的数据包计数 volatile uint16_t current_distance_mm 0; // 计算出的当前距离值 /* USER CODE END PV */这里用了volatile关键字告诉编译器这两个变量可能被中断程序随时修改不要对它做优化确保每次访问都从内存中读取最新值。接下来在main函数的初始化部分/* USER CODE BEGIN 2 */我们必须手动开启串口接收中断。CUBEMX生成的代码只初始化了串口但默认没有开启接收中断使能。/* USER CODE BEGIN 2 */ // 手动使能USART1的接收中断 __HAL_UART_ENABLE_IT(huart1, UART_IT_RXNE); // 也可以使用HAL库函数HAL_UART_Receive_IT(huart1, rx_byte, 1); 但这里我们用寄存器方式更直接 printf(“系统启动开始接收激光数据…\r\n”); /* USER CODE END 2 */重头戏来了我们要修改中断服务函数。找到工程中stm32f4xx_it.c文件里的USART1_IRQHandler函数。注意我们不是用HAL库的HAL_UART_RxCpltCallback回调函数因为那个函数在高速率、单字节接收的场景下会有额外的函数调用开销。我们选择直接“改造”中断服务函数在HAL_UART_IRQHandler(huart1);这行标准处理代码的前后插入我们自己的逻辑。这是一种更高效、更直接的做法但需要我们对中断标志位比较熟悉。整个中断程序的逻辑是一个“状态机”。我们用state变量记录当前处理到了数据包的哪个字节0-46。从接收到帧头0x54开始state0每成功接收一个预期字节state就加1同时计算CRC校验值。当state走到46即收到最后一个CRC字节后我们把自己计算的CRC和模块发来的CRC进行比对。如果一致说明这一包数据在传输过程中没有出错我们就可以调用data_process()函数来处理这12个距离值了。如果不一致就默默丢弃这一包状态机复位等待下一个帧头。这种状态机的方法是处理流式串口协议帧最经典、最可靠的方法之一。由于代码较长其核心思路是在中断标志判断接收到数据后读取数据寄存器DR中的值。然后根据当前的state值用switch-case或if-else将这一个字节的数据填充到我们之前定义的LiDARFrameTypeDef结构体变量的对应成员中。例如state为0时判断是否为帧头state为1时判断是否为VER_LENstate从2到5依次填充温度和起始角度的高低字节state从6到41这36个字节每3个字节一组填充一个点的距离低8位、高8位和强度值。在整个填充过程中每接收一个有效数据字节从帧头开始到时间戳都要同步更新CRC校验值。最后在state46时进行校验比对。校验成功则处理数据并将成功接收计数器packet_received_cnt加1。无论成功与否最后都要将state、crc、以及用于计点的cnt变量复位为0准备接收下一帧。6. CRC校验原理与数据可靠性保障在实际的工业或车载环境中电磁干扰无处不在可能导致串口线上传输的数据位发生翻转比如0变成1。如果恰好是距离数据的高位变了1米可能就被读成100米这后果是灾难性的。因此校验是通信协议中不可或缺的安全锁。STP-23模块使用的是CRC8校验它是一种非常高效且检错能力很强的校验算法。CRC叫循环冗余校验你可以把它理解为一个“数据指纹”生成器。发送方激光模块在发送完所有真实数据后会根据这些数据通过一个特定的公式计算出一个1字节8位的“指纹”附在数据包末尾一起发过来。接收方我们的STM32在收到数据后用同样的公式再算一遍“指纹”。如果两个指纹一致就认为数据在传输过程中极大概率是完整的如果不一致就可以肯定数据出错了这一包必须丢弃。在代码中我们预先定义好了一个长度为256的查找表CrcTable[256]。这个表是CRC8计算算法的核心它包含了所有可能输入字节对应的中间校验结果。使用查表法计算CRC比用公式一步步算要快几十上百倍这对于在921600波特率的中断里快速完成校验至关重要。计算过程很简单初始化一个crc变量为0。每收到一个有效数据字节temp_data就执行一次crc CrcTable[(crc ^ temp_data) 0xff];。这里的^是异或运算。等所有数据字节从帧头到时间戳都处理完得到的crc值就应该和数据包最后发来的crc8字节相等。在我的中断服务函数代码里你会在每一个case分支处理完数据赋值后都看到一行更新crc的语句。这就是在实时地计算“指纹”。最后在state46时进行比对。只有比对成功我才敢放心地去使用这一包里的12个距离值。如果失败了我选择不声张不打印错误避免占用CPU时间只是静静地重置状态机等待下一包数据。这种“沉默失败”的策略在高速数据流处理中很常见目的是保证中断服务函数的执行时间尽可能短避免丢失后续字节。7. 距离数据的滤波与稳定输出算法激光模块在实际测量时可能会因为物体表面特性如黑色吸光材料、强光干扰或者测量极限边缘返回一些无效值比如0。直接把这12个值拿来做平均如果混进去几个0平均距离就会被严重拉低。所以在计算之前必须进行滤波。我在data_process()函数里做的是两重滤波。第一重是“去零滤波”在累加12个点的距离值之前先判断这个点的distance是否等于0。如果为0就跳过这个点不把它计入总和和点数。这样就避免了无效数据对结果的污染。第二重是“滑动平均滤波”我不是每收到一包数据就计算并输出一个距离而是累计100包有效数据注意是校验成功的100包将这100包里所有有效的、非零的点距离值求一个总平均。这样做的好处是能极大地平滑数据。比如小车前方是一个栅栏激光点可能一会儿打在栏杆上距离近一会儿打在栏杆后的墙上距离远单包数据跳动会很大。但通过100包数据的平均最终输出的距离值就会非常稳定接近于一个“统计意义上”的真实距离。这个函数会在每次中断服务程序成功接收并校验一包数据后调用。函数内部维护了几个静态变量sum用于累加有效距离count用于统计有效点的个数cnt用于统计处理了多少包数据。当cnt累加到100时才计算一次平均距离current_distance_mm sum / count;然后将sum、count、cnt清零开始下一个100包的统计周期。这个current_distance_mm就是我们要的最终结果。把它赋值给我们在main.c里定义的全局变量current_distance_mm主循环里就能读取并打印它了。8. 主循环逻辑与项目实战经验分享所有的脏活累活都在后台中断和数据处理函数干完了主循环while(1)里的工作就变得异常清爽。它的任务就是定期去查看“结果”并把结果告诉我们。通常我会这样写主循环while (1) { // 打印成功接收的数据包总数这个值在中断里被修改 printf(“[INFO] 成功接收数据包: %d 个\r\n”, packet_received_cnt); // 打印经过滤波计算出的当前距离 if(current_distance_mm 0) { printf(“[DATA] 当前距离: %d mm\r\n”, current_distance_mm); } else { printf(“[DATA] 当前距离: 无效或超出量程\r\n”); } // 可以根据距离做一些简单的控制逻辑比如 // if(current_distance_mm 500) { // 距离小于50厘米 // HAL_GPIO_WritePin(LED_GPIO_Port, LED_Pin, GPIO_PIN_SET); // 点亮报警灯 // } else { // HAL_GPIO_WritePin(LED_GPIO_Port, LED_Pin, GPIO_PIN_RESET); // } HAL_Delay(200); // 每200ms打印一次避免串口输出过于频繁 }在实际项目中我踩过几个坑这里分享给大家希望能帮你节省时间。第一个坑是中断优先级。如果你的系统里还有其他中断比如定时器中断、外部按键中断一定要在CUBEMX的NVIC配置里规划好优先级。串口接收中断的优先级不能设得太低否则当它正在接收一包数据47个字节连续到达时如果被一个更高级的中断长时间打断就很可能丢失字节导致帧同步失败一直等不到正确的帧头。我通常会把串口接收中断的抢占优先级设为较高。第二个坑是电源噪声。激光模块对电源比较敏感如果直接用开发板的3.3V当电机或其他大电流设备启动时电源纹波可能导致模块工作不稳定甚至数据错乱。最好给激光模块的电源脚加一个磁珠和一大一小两个电容比如100uF和0.1uF进行滤波或者使用独立的LDO给它供电。第三个是物理安装。STP-23这类单点激光模块的测量光斑非常小安装时要确保它和被测物体表面尽量垂直。如果倾斜角度过大激光点可能会打滑或反射不回来导致测量失败。在小车应用里我通常会把模块用海绵双面胶稍微垫一下做个简单的减震防止车体震动影响测量。最后调试利器是逻辑分析仪。当你怀疑数据不对时别光看代码用逻辑分析仪或者示波器的串口解码功能直接抓取STM32的RX引脚上的波形看看发过来的原始字节到底是什么。很多时候问题不是出在代码而是硬件连接、波特率偏差或者模块本身。亲眼看到原始数据流能让你快速定位问题是通信层、协议层还是应用层。这个项目从硬件连接到稳定输出距离值我花了差不多两天时间大部分时间都在调试中断状态机和CRC校验。当你看到串口助手第一次稳定地输出“当前距离1250 mm”这样有规律的数字时那种成就感就是咱们嵌入式工程师最大的乐趣。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2416927.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;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…