低成本搭建BLE嗅探器:基于nRF52840与Wireshark的物联网协议分析实战

news2026/5/16 2:46:35
1. 项目概述与核心价值如果你正在开发或调试基于蓝牙低功耗BLE的物联网设备比如智能手环、传感器节点或者任何通过蓝牙通信的小玩意儿那么你肯定遇到过这样的困境设备明明发了数据手机App却没收到或者连接时断时续日志里却一片祥和根本不知道问题出在协议栈的哪一层。这时候一个能“窃听”空中无线信号的BLE嗅探器就成了定位问题的“终极武器”。市面上的专业嗅探工具动辄数千甚至上万美元让个人开发者和小团队望而却步。好在借助Nordic Semiconductor官方提供的嗅探器固件和开源的Wireshark网络分析工具我们可以用一块成本仅百元左右的nRF52840开发板例如Adafruit的Feather nRF52840 Express或nRF52840 USB Key搭建一个功能强大的低成本BLE嗅探器。这个方案的核心思路是将nRF52840这块高性能蓝牙芯片“变身”为一个被动的射频接收机专门捕获空中的BLE广播和数据包然后通过USB虚拟串口将原始数据实时发送给电脑上的Wireshark。Wireshark凭借其强大的协议解析能力将这些二进制数据流翻译成人类可读的协议字段让我们能像查看网页访问记录一样清晰地看到BLE设备间每一次“握手”和“对话”的细节。这个项目的价值远不止于“看个热闹”。它能帮你深度调试亲眼验证你的设备广播数据是否正确、连接参数是否合理、数据收发是否完整精准定位是硬件问题、固件bug还是协议逻辑错误。协议学习直观地学习BLE协议栈从链路层LL到属性协议ATT理解广播、扫描、连接、数据交换的完整生命周期。逆向分析分析市面上已有的BLE设备如智能家居产品的通信协议为兼容性开发或安全研究提供第一手资料。成本可控总成本主要就是一块nRF52840开发板软件全部免费开源堪称性价比最高的BLE协议分析入门方案。接下来我将以一个物联网开发者的视角带你从硬件准备、环境搭建、实战抓包到深度分析完整走通搭建和使用这个低成本嗅探器的全过程并分享我在这过程中踩过的坑和总结出的实用技巧。2. 硬件选型与固件刷写要点工欲善其事必先利其器。搭建嗅探器的第一步是选择合适的硬件并为其刷入“灵魂”——嗅探器固件。2.1 核心硬件选择为什么是nRF52840不是所有的蓝牙开发板都能胜任嗅探工作。这个方案依赖于Nordic官方为nRF52系列芯片提供的专用嗅探器固件。nRF52840是其中的旗舰型号也是目前最合适的选择原因有三性能充足它拥有强大的Cortex-M4内核和充足的RAM/Flash能够实时处理射频数据并转发不易丢包。官方支持Nordic为其提供了持续维护和更新的嗅探器固件兼容性和稳定性有保障。生态丰富基于nRF52840的开发板选择很多且大多带有USB接口便于即插即用。市面上常见的可选板卡有Adafruit Feather nRF52840 Express集成度高自带锂电池管理引脚兼容Feather生态适合移动使用。Adafruit nRF52840 USB Key (带TinyUF2)外形像U盘极度便携即插即用体验好。Nordic官方开发板 (如nRF52840 DK)功能最全调试接口丰富但价格和体积也更大。个人心得对于纯嗅探用途我强烈推荐Adafruit nRF52840 USB Key。它体积小巧无需额外接线刷机和使用都像U盘一样简单真正实现了“低成本、便携式”嗅探。Feather板则更适合你同时需要用它进行其他开发或测试的场景。2.2 关键一步刷写嗅探器固件拿到板子后第一步是把它从普通的开发板变成专用的嗅探器。这个过程本质上是刷写一个特殊的.uf2固件文件。操作步骤获取固件从Nordic或Adafruit的指定链接下载最新的嗅探器UF2文件。例如对于nRF52840 USB Key文件通常名为sniffer_nrf52840dongle_nrf52840_4.1.0.uf2版本号可能更新。请务必确认固件与你的硬件型号匹配。进入Bootloader模式对于大多数带复位按钮的nRF52840板如Feather双击板载的RESET按钮。此时板载的RGB LED通常会变成绿色有些是蓝色并且电脑上会出现一个名为FTHR840BOOT或类似的可移动磁盘。对于nRF52840 USB Key操作略有不同需要按住板载的按钮不放同时将USB插入电脑直到出现BOOT磁盘。刷写固件将下载好的.uf2文件直接拖拽或复制到刚刚出现的BOOT磁盘中。磁盘会自动弹出板子将重启。验证成功重启后电脑会识别到一个新的USB设备并在设备管理器中创建一个新的虚拟串口COM口在Linux/macOS下是/dev/ttyACMx或/dev/ttyUSBx。这就意味着你的nRF52840已经成功变身为一个BLE嗅探器硬件。注意事项与避坑指南Bootloader版本确保你的板子Bootloader版本在0.6.0及以上。旧版本可能无法正确刷写或运行UF2文件。如果遇到问题先去Adafruit的教程页面更新Bootloader。固件与硬件匹配务必下载对应你硬件型号的固件。给USB Key刷了Feather的固件可能会导致功能异常。指示灯含义刷写时LED变绿通常表示进入Bootloader模式成功变红则可能表示USB供电或连接有问题请尝试更换数据线或USB端口。恢复原厂固件如果你想将板子恢复为普通开发板用于Arduino或CircuitPython开发需要刷回“SoftDevice”蓝牙协议栈和应用程序固件。通常需要下载一个名为s140_nrf52_6.1.1_softdevice.uf2的文件用同样的拖拽方式刷入。重要提示嗅探器固件会擦除原有的蓝牙协议栈所以“恢复”是必要步骤。3. 软件环境搭建全流程解析硬件就绪后我们需要在电脑上搭建一个能够与嗅探器硬件对话并解析数据的软件环境。这套环境主要由Python、Wireshark和一个桥梁插件构成。3.1 Python与串口库安装搭建数据桥梁嗅探器硬件通过虚拟串口与电脑通信而Wireshark插件是用Python写的它负责从这个串口读取原始数据并转发给Wireshark。因此Python环境是必需的底层支撑。安装步骤安装Python 3前往Python官网下载并安装最新稳定版的Python 3。安装时务必勾选 “Add Python to PATH” 选项这样可以在命令行中直接使用python命令。验证安装打开命令行Windows CMD/PowerShell macOS/Linux Terminal输入python --version或python3 --version应能正确显示版本号。安装pyserial库这是Python与串口通信的关键库。在命令行中执行pip install pyserial。如果系统中有多个Python版本请使用pip3以确保安装到Python 3环境下。为什么是Python和pyserialWireshark的“extcap”插件机制支持用外部程序这里就是Python脚本来捕获数据。Nordic提供的插件正是一个Python脚本它利用pyserial库以特定波特率通常是1000000从nRF52840的虚拟串口读取数据并将其转换成Wireshark能识别的标准pcap格式进行实时推送。这种设计非常灵活使得硬件数据捕获和软件协议分析得以解耦。3.2 Wireshark与嗅探器插件安装核心分析平台Wireshark是网络分析领域的“瑞士军刀”其对协议的解码能力无出其右。我们需要安装Wireshark本体和Nordic提供的BLE嗅探插件。安装步骤安装Wireshark从Wireshark官网下载安装包。安装过程中注意勾选“Install USBPcap”Windows以支持USB抓包虽然BLE嗅探不走这个但有益无害。在Linux系统下安装后可能需要将当前用户加入wireshark组以避免每次使用sudosudo usermod -aG wireshark $USER然后注销并重新登录生效。下载Nordic BLE嗅探插件从Nordic Semiconductor官网或其GitHub仓库下载“nRF Sniffer for Bluetooth LE”的压缩包例如nrf_sniffer_for_bluetooth_le_4.x.x.zip。定位Wireshark插件目录这是关键一步。打开Wireshark点击菜单栏的帮助 - 关于Wireshark在弹出的窗口中选择文件夹标签页。在这里找到“Extcap路径”或“个人Extcap路径”。记下这个文件夹的完整路径。安装插件解压下载的ZIP文件进入其中的extcap文件夹。将其内的所有文件通常包括nrf_sniffer_ble.py这个主脚本和一些辅助文件全部复制到上一步找到的Wireshark插件目录中。安装验证与首次抓包测试完成以上步骤后关闭所有Wireshark窗口重新打开。将已刷好嗅探器固件的nRF52840插入电脑USB口。打开Wireshark在首页的“捕获”区域你应该能看到一个新增的接口名称通常包含nRF Sniffer for Bluetooth LE以及你的串口号如COM4或/dev/ttyACM0。双击这个接口开始捕获。如果周围有BLE设备在广播比如你的手机蓝牙开着或者有BLE传感器你几乎会立刻看到屏幕上滚动出现大量的BTLE数据包。如果一片空白可能是附近确实没有BLE活动可以尝试用手机打开一个蓝牙扫描App来产生广播流量。避坑提示如果Wireshark里看不到嗅探器接口请按以下步骤排查检查插件路径确认文件是否复制到了正确的extcap目录。可以尝试将插件文件也复制到“个人Extcap路径”下。检查Python脚本权限Linux/macOS确保nrf_sniffer_ble.py文件有可执行权限 (chmod x /path/to/nrf_sniffer_ble.py)。检查串口占用确保没有其他程序如串口调试助手、Arduino IDE占用了nRF52840对应的串口。查看Wireshark启动日志Wireshark的“帮助”菜单下可能有“启动日志”里面会显示加载extcap插件时的错误信息是重要的调试依据。4. Wireshark实战从广播包到数据交换深度解析环境搭建成功看到数据包滚动只是第一步。如何从海量的数据包中提取有价值的信息才是嗅探器使用的精髓。下面我们以一个典型的BLE设备连接和数据传输过程为例进行深度解析。4.1 理解基础广播信道与数据包结构BLE设备在未连接时会在3个固定的广播信道37 38 39上周期性地发送广播包。嗅探器会监听这些信道。 在Wireshark中一个典型的广播包解析视图如下No. Time Source Destination Protocol Info 1234 1.234567 aa:bb:cc:dd:ee:ff (random) BTLE ADV_IND, Flags: 0x06, AdvA: aa:bb:cc:dd:ee:ff点击该数据包在下方面板中展开Bluetooth Low Energy Link LayerPDU TypeADV_IND表示可连接的非定向广播这是最常见的类型。AdvA广播者的设备地址。注意BLE地址有Public和Random两种Random地址常用于保护隐私。AdvData/ScanRspData这是最重要的部分展开后可以看到广播数据。其中可能包含Flags指明设备能力如“LE Limited Discoverable Mode”、“BR/EDR Not Supported”仅BLE。Complete Local Name设备的广播名称。Service UUIDs设备支持的GATT服务列表如电池服务0x180F、设备信息服务0x180A或自定义的128位UUID服务。Tx Power Level发射功率用于粗略的距离估算。Manufacturer Specific Data制造商自定义数据是设备识别和传递初始信息的关键字段。实操技巧过滤与聚焦在Wireshark顶部的过滤栏输入表达式可以快速筛选btle只看BLE链路层数据包。btle.advertising_header.pdu_type 0x00只看ADV_IND类型的广播包。btle.advertising_header.address aa:bb:cc:dd:ee:ff只看特定MAC地址的设备。btcommon.eir_ad.entry.device_name contains Sensor查找广播名包含“Sensor”的设备。4.2 捕获连接建立全过程当你的手机作为中央设备Central试图连接一个BLE外设如一个心率带时嗅探器可以捕获到完整的握手过程。扫描请求与响应手机在扫描时可能会主动向感兴趣的广播设备发送SCAN_REQ包请求更多的信息。被扫描的设备则会回复一个SCAN_RSP包其中通常包含完整的设备名因为广播包空间有限可能放不下长名字。连接请求当你在手机App上点击“连接”时手机会发出CONNECT_REQ数据包。这个包极其重要它包含了连接参数协商的所有核心信息Access Address连接建立后后续通信将使用这个新的私有地址而非广播地址。CRCInit用于校验的初始化值。WinSize/WinOffset/Interval/Latency/Timeout这些是连接参数的核心。Interval连接间隔两个数据包之间允许的最小时间间隔范围7.5ms到4s。更短的间隔意味着更高的数据吞吐量和更快的响应但功耗也更高。这是功耗优化的关键参数。Latency从机延迟允许外设Slave跳过多少个连接事件而不必回复。用于降低从设备的功耗。Timeout监督超时连接丢失的判断时间。调试经验很多连接不稳定、断续或高功耗的问题根源都在连接参数设置不合理。通过嗅探器抓取CONNECT_REQ你可以精确看到手机通常是Central提出的参数建议与你设备端期望的参数进行对比是调试连接问题的黄金依据。4.3 解析数据交换ATT协议与“句柄”连接建立后通信就从广播信道跳转到37个数据信道并采用跳频机制。此时的数据交换遵循ATT属性协议和GATT通用属性配置文件规范。在Wireshark中你会看到大量的ATT协议数据包。GATT操作的核心是“句柄”它是一个16位的地址唯一标识了设备上的某个特征值Characteristic Value或描述符Descriptor。典型的数据流分析特征值发现连接后Central手机会发送ATT Read By Type Request等包来读取外设的GATT数据库获取所有服务和特征的句柄。启用通知为了接收外设主动发送的数据如心率值Central需要在外设对应特征的CCCD客户端特征配置描述符句柄上写入0x0001启用通知或0x0002启用指示。在Wireshark中你会看到一个ATT Write Request包其Handle指向CCCD通常是特征值句柄1Value为01:00小端序表示0x0001。数据收发Central 写数据给外设表现为ATT Write Request需应答或ATT Write Command无需应答指定目标句柄和写入的值。外设 发送数据给 Central启用通知后当外设的特征值变化它会发送ATT Handle Value Notification包。在Wireshark中你可以看到Handle字段指明是哪个特征Value字段就是实际的数据载荷。实战案例解码一个温度传感器假设你抓到一个ATT Handle Value Notification句柄是0x001B值是0x0F 0x27。结合之前抓到的GATT数据库信息你知道句柄0x001B对应“温度测量特征”。根据该特征的定义通常在其GATT声明中会指定格式你知道它是16位有符号整数单位0.01摄氏度。值0x0F 0x27是小端序转换为0x270F即十进制9999。因此当前温度是 99.99°C。这显然不合理可能意味着传感器需要校准或者你的解码格式有误。这就是嗅探器在调试数据解析错误时的直接价值。5. 高级技巧与常见问题排查实录掌握了基础操作后一些高级技巧和问题排查经验能让你事半功倍。5.1 过滤与显示技巧精要Wireshark的过滤语法功能强大合理使用能快速定位问题。追踪单一连接先找到一个连接请求包 (btle.ll.connection_access_address字段出现)右键该包 -应用为过滤器-选中。这样就会只显示属于这个特定连接的所有后续数据包排除其他设备的干扰。只看有效载荷过滤att.opcode 0x1b可以只看“通知”包 (Handle Value Notification)。查找错误过滤att.errorcode可以快速找到所有ATT层出错的包如“句柄无效”、“属性不允许”等。自定义列Wireshark默认的列可能不包含你需要的信息。你可以右键数据包列表的表头 -列首选项-添加将btle.access_address连接地址、att.handle属性句柄、att.value属性值等字段添加为常驻显示列分析效率大增。5.2 常见问题与解决方案速查表问题现象可能原因排查步骤与解决方案Wireshark中看不到嗅探器接口1. 插件未正确安装2. Python环境或pyserial问题3. 串口被占用1. 检查插件文件是否在正确的extcap路径并具有可执行权限。2. 在命令行手动运行插件脚本python /path/to/nrf_sniffer_ble.py --extcap-interfaces看是否有错误输出。3. 关闭所有可能占用串口的软件如串口监视器、IDE。能看到接口但点击后无数据包1. 附近无BLE活动2. 嗅探器固件/硬件问题3. 信道问题1. 用手机打开蓝牙设置或BLE扫描App产生广播流量。2. 尝试重新刷写嗅探器固件或换一个USB端口。3. BLE嗅探器默认监听所有信道但某些设备可能使用非常规的广播参数。可尝试在Wireshark的接口配置中调整扫描窗口等参数但通常默认即可。抓包时丢包严重数据不连续1. 电脑性能不足或USB带宽瓶颈2. 环境干扰大3. 连接间隔太短1. 关闭不必要的程序尝试将Wireshark捕获过滤器设置为btle减少不必要的数据处理。2. 将嗅探器尽量靠近被监测的设备远离Wi-Fi路由器等2.4GHz干扰源。3. 对于高速数据流被动嗅探本身就可能丢包这是其原理限制。可尝试优化连接参数增大连接间隔或考虑使用支持主动注入的专业工具。无法解析ATT层数据只看到LL层空包1. 未成功捕获连接请求2. 跳频跟踪失败1. 确保从设备开始广播到连接建立的完整过程都被捕获。有时需要提前开始抓包。2. nRF嗅探器固件会尝试跟踪跳频但在复杂射频环境下可能失锁。尝试让嗅探器与通信双方在物理上更靠近。看到大量ATT Exchange MTU Request/Response这是正常过程。MTU最大传输单元协商是连接后的第一步用于确定后续ATT包的最大长度。更大的MTU能提高数据传输效率。无需处理。你可以通过这个包看到协商后的MTU大小对于需要传输大量数据的应用有参考价值。5.3 个人实操心得与进阶建议保持固件更新定期去Nordic或Adafruit的页面查看是否有新的嗅探器固件或Wireshark插件更新。新版本可能会修复bug、增加对新BLE版本特性的支持或提升性能。结合逻辑分析仪对于时序要求极其苛刻的调试例如分析广播事件与GPIO触发之间的精确延时可以尝试将nRF52840的某个GPIO如P1.09根据文档可接LED作为活动指示灯连接到逻辑分析仪。在固件中修改代码如果你有源码让该GPIO在收到特定类型数据包时产生一个脉冲从而实现硬件级的精确时间戳同步。理解被动嗅探的局限我们这个方案是被动嗅探意味着它只能“听”不能“说”。因此它无法解密已加密的连接因为不知道LTK也无法干扰或注入数据包。对于安全测试需要更专业的工具。但对于协议学习、功能调试和大多数逆向工程它已经完全足够。保存与分析会话遇到复杂问题时不要只盯着实时滚动屏幕。使用Wireshark的文件 - 保存功能将抓包会话保存为.pcapng文件。你可以事后反复分析添加注释甚至分享给同事共同研究。

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