Adafruit Metro M4 AirLift开发板:硬件解析与物联网开发实战

news2026/5/17 8:16:41
1. 项目概述与硬件解析如果你正在寻找一款既能提供强大本地计算能力又能轻松接入无线网络的微控制器开发板那么Adafruit Metro M4 Express AirLift绝对是一个值得深入研究的选项。它不是简单的单片机加WiFi模块的堆砌而是一个经过精心整合的系统级解决方案。核心在于那块120MHz主频的Microchip ATSAMD51 Cortex-M4微控制器以及板上集成的Espressif ESP32无线协处理器。这种“主控协处理器”的架构在嵌入式开发中越来越常见它的精妙之处在于职责分离主控ATSAMD51专注于执行你的核心业务逻辑比如复杂的传感器数据处理、算法运行或设备控制而ESP32则专职处理所有与网络相关的繁重任务包括TCP/IP协议栈、TLS/SSL加密、WiFi连接维护等。这样一来你的主程序不会被网络请求阻塞系统响应更迅速开发时也无需在单一线程里混杂网络代码结构清晰得多。这块板子给我的第一印象是“均衡且实用”。它保留了经典Arduino Metro的引脚布局和外形尺寸这意味着你积累的大量Metro兼容扩展板Shield可以直接复用保护了原有的硬件投资。板载的2MB QSPI Flash在CircuitPython环境下会直接挂载为一个可读写的磁盘CIRCUITPY你保存的代码、库文件甚至数据文件都存放在这里像操作U盘一样方便这彻底改变了嵌入式开发的文件管理体验。那个小小的RGB NeoPixel LED和四个状态指示灯电源、USB收发在调试时能提供非常直观的视觉反馈。我实际用下来最欣赏的是它的双供电设计和极简的UF2拖放式编程用Micro USB线连上电脑双击复位键一个名为METROM4BOOT的驱动器就会出现直接把.uf2格式的固件拖进去程序就烧录好了完全不需要安装任何额外的烧录软件或驱动程序对新手和快速迭代的场景极其友好。2. 核心硬件与引脚功能深度剖析拿到一块新板子我习惯先彻底搞清楚它的“资源地图”也就是引脚定义和外设分配这是后续一切开发的基础。Metro M4 Express AirLift的引脚功能相当丰富但逻辑清晰我们可以分区域来理解。2.1 电源系统设计电源是稳定运行的基石。这块板子提供了三种供电方式和两种输出电压设计得很周到Micro USB供电最常用的方式提供5V电压。板载了一个可恢复的保险丝限流大约在500mA。这意味着如果你从USB口取电所有引脚Vin, 5V, 3.3V的总电流最好不要超过500mA否则保险丝可能会动作以保护电脑的USB端口。DC圆孔插座供电标准的5.5mm/2.1mm中心正极接口输入范围是6V-12V。这里没有保险丝所以供电能力更强5V和3.3V输出合计可达约800mA而Vin引脚可以直接输出输入的DC电压最高2A。旁边的物理开关只控制DC输入的通断不影响USB供电。输出引脚3V来自板载3.3V线性稳压器的输出最大负载能力约500mA。这是给大部分数字逻辑芯片和传感器供电的引脚。5V当使用DC供电时它来自5V稳压器当使用USB供电时它直接来自USB的5V。负载能力如前所述。Vin输入电压的“直通”引脚。接DC时是DC电压接USB时是5V。适合给需要较高电压的模块供电但要注意电压不能超过12V。GND公共地线所有回路都要汇聚于此。实操心得当同时连接USB和DC电源时板子会自动选择电压更高的DC输入作为主电源这是一个很实用的设计。但在进行高功耗外设如多个舵机、大功率LED灯带实验时强烈建议使用DC供电而非USB以避免电脑USB端口过载或触发保护。2.2 AirLift ESP32协处理器连接详解这是本板的灵魂所在。ESP32并非通过简单的UART与主控通信而是使用了SPI总线这带来了远超串口的速度和效率足以支撑高带宽和低延迟的网络应用。主控与ESP32之间通过一组专用引脚连接SPI总线引脚SCK,MOSI,MISO。这些引脚在板子上标出但非常重要的一点是在CircuitPython或Arduino的AirLift库中你通常不需要直接操作这些引脚。库函数已经内部处理了SPI通信。你应避免将这些引脚用于其他普通GPIO或连接其他SPI设备否则会与WiFi功能冲突。控制引脚ESP_CS(Chip Select)片选信号主控通过它通知ESP32开始通信。ESP_BUSY(Ready/Busy)ESP32的状态信号高电平表示忙低电平表示就绪。用于实现硬件流控防止数据丢失。ESP_RESET复位引脚用于硬件重启ESP32协处理器。ESP_GPIO0ESP32的引导模式引脚通常用于固件更新。调试UARTESP_RX和ESP_TX。这是一组独立的硬件串口专门用于ESP32的深度调试或高级用途例如直接向ESP32发送AT指令。在大多数应用场景下你不需要接触它们。在CircuitPython中你可以通过board模块方便地访问这些引脚例如board.ESP_CS。这种硬件设计使得网络栈几乎完全由ESP32托管你的主程序代码只需调用简单的网络请求函数底层复杂的握手、加密、重传都由协处理器搞定。2.3 主控GPIO与模拟功能引脚主控ATSAMD51的GPIO引脚分为顶排、底排和右侧功能规划明确顶排数字引脚为主D0/RX与D1/TX这是硬件串口Serial1的收发引脚。如果你需要连接GPS、蓝牙模块等串口设备优先使用这组引脚性能最稳定。D2至D12通用数字输入输出引脚。除了SCL所有引脚都支持PWM输出。D13连接至板载的红色用户LED。这是一个快速的调试工具。SDA与SCL硬件I2C总线引脚已内置10K上拉电阻。这是连接绝大多数传感器温湿度、气压、光强等的主要通道。底排模拟功能突出A0与A1这不仅是模拟输入更是**真正的模拟输出DAC**引脚。与PWM的方波不同DAC可以输出0-3.3V之间任意精确的直流电压。这对于生成音频信号、控制某些需要精确电压的模块至关重要。A2至A5模拟输入引脚也可作为数字IO使用。特别注意A3引脚在硬件上映射的微控制器内部引脚与无WiFi版本的Metro M4不同。对于99%的应用这没影响但如果你在进行极其底层的操作比如直接配置定时器或SERCOM外设务必查阅原理图确认。右侧专用外设接口SCK,MOSI,MISO如前所述这是主SPI端口默认被AirLift协处理器占用。除非你确定要禁用WiFi功能否则不要在此连接其他SPI设备。其他重要引脚ARef模拟参考电压引脚。默认连接至3.3V。这里有一个关键陷阱由于ATSAMD51芯片早期版本的硅片缺陷要使A0和A1的DAC正常工作ARef必须连接到3.3V。板子出厂时通过一个0欧姆电阻跳线将其短接。如果你需要改变参考电压例如使用更精确的外部基准源必须割断这个跳线但要做好心理准备DAC的输出范围可能会受到影响。RST复位引脚拉低可强制重启主控。NEOPIXEL板载单颗RGB NeoPixel LED的驱动引脚在CircuitPython中通过board.NEOPIXEL访问。2.4 高级外设I2S与PCCATSAMD51还隐藏了两个对于多媒体应用很有吸引力的外设I2S数字音频接口引脚是固定的D8: 数据出D1: 数据入D3: 位时钟D9: 字选择D2: 主时钟。你可以用它连接高质量的I2S数字麦克风或DAC音频模块实现音频录制或播放音质远胜于普通的PWM模拟。PCC并行捕捉控制器这实际上是一个简单的摄像头接口可以连接某些并行输出的摄像头传感器如OV7670。它将数据引脚映射到了D13,D12,D10,D11,D9,D8,D1,D0,D5,D6。虽然应用相对小众但为图像识别、监控等应用提供了硬件基础。3. 软件生态与开发环境搭建硬件是躯体软件是灵魂。Metro M4 Express AirLift最大的优势之一在于其强大的软件生态支持尤其是对CircuitPython的原生优化。3.1 UF2引导加载器极简的编程体验UF2是微软为MakeCode项目设计的一种文件格式现在已成为Adafruit Express系列板子的标准。它的工作原理是将二进制程序代码包装成一种文件系统友好的格式。当你双击复位键进入引导模式时芯片并不运行你的主程序而是运行一段存储在受保护区域的小程序即引导加载器。这段程序将芯片的Flash存储器模拟成一个USB大容量存储设备U盘。你看到的METROM4BOOT驱动器就是这个虚拟磁盘。当你把一个.uf2文件拖入这个驱动器时操作系统只是执行了一个普通的文件复制操作。引导加载器会监测磁盘的写入识别.uf2文件的特殊结构然后自动将其解包并把真正的程序代码写入到Flash的应用程序区域。完成后它会自动复位芯片开始运行新程序。这个过程完全不需要任何烧录软件、驱动程序或命令行操作极大地降低了入门门槛。如何进入引导加载器模式如果当前正在运行Arduino程序或MakeCode快速双击板子上的复位按钮RST。如果正在运行CircuitPython同样快速双击复位按钮。此时板载的NeoPixel LED会变为绿色如果已连接电脑并且电脑上会出现一个名为METROM4BOOT的可移动磁盘。检查与更新引导加载器 一个健壮的引导加载器很重要。早期版本的引导加载器可能存在罕见bug。建议检查并更新到v3.9.0或更高版本。进入引导模式打开METROM4BOOT驱动器。用文本编辑器打开INFO_UF2.TXT文件。查看其中的版本号例如UF2 Bootloader v3.6.0。如果版本低于v3.9.0需要更新。前往CircuitPython官网的下载页面找到你的板子型号下载名为update-bootloader-metro_m4_airlift-v3.9.0.uf2或更高版本的文件。将这个.uf2文件拖入METROM4BOOT驱动器。你会看到红色LED闪烁然后慢闪几次。驱动器会自动重新挂载。再次检查INFO_UF2.TXT确认版本已更新。3.2 CircuitPython安装与初次体验CircuitPython是Adafruit基于MicroPython为自家硬件深度优化的Python 3方言。它的哲学是“简单易用即时反馈”。对于物联网原型开发它比C/CArduino更高效。安装步骤确保你的引导加载器是最新的按上述步骤。进入引导模式双击RST出现METROM4BOOT驱动器。访问CircuitPython官网下载页面找到“Metro M4 Express AirLift”的最新稳定版.uf2文件例如adafruit-circuitpython-metro_m4_airlift-en_US-8.2.6.uf2。将下载的.uf2文件拖入METROM4BOOT驱动器。驱动器会消失几秒后一个新驱动器CIRCUITPY会出现。这就是你的CircuitPython运行时环境了首次连接与验证使用一个支持串行终端的编辑器。我强烈推荐Mu Editor它专为CircuitPython设计内置了串行监视器和代码检查器。打开Mu Editor它会自动检测到板子。在底部的“串行”面板你应该能看到类似下面的提示符这表示你已经进入了CircuitPython的交互式环境REPLAdafruit CircuitPython 8.2.6 on 2024-01-01; Adafruit Metro M4 Express AirLift with samd51j19 在REPL中你可以直接输入Python代码并立即执行。试试print(“Hello, Metro!”)或者import board; import digitalio; led digitalio.DigitalInOut(board.D13); led.direction digitalio.Direction.OUTPUT; led.value True来点亮板载的红色LED。3.3 项目文件管理与库安装CIRCUITPY驱动器是你的工作区。里面有几个关键文件code.py这是主程序入口。CircuitPython启动后会自动执行这个文件。lib/文件夹存放所有第三方库文件。你需要把下载的库文件.mpy或.py放在这里。settings.toml配置文件用于存储WiFi密码、API密钥等敏感信息避免硬编码在代码中。安装库的两种方法手动安装推荐初学者访问CircuitPython库包页面下载最新的“适配包”。解压后找到你需要的库文件例如adafruit_requests.mpy用于网络请求adafruit_esp32spi用于WiFi驱动。将这些.mpy文件复制到CIRCUITPY驱动器下的lib文件夹内。如果lib文件夹不存在就创建一个。使用CircUp工具命令行适合进阶在电脑上通过pip安装pip install circup连接板子后在命令行运行circup list查看已安装的库。运行circup install adafruit_esp32spi来安装指定库circup update来更新所有库。避坑指南库文件有版本兼容性问题。务必确保你安装的库版本与你的CircuitPython核心版本匹配。通常下载页面提供的库包是与该版CircuitPython兼容的。使用CircUp可以自动处理兼容性是最安全的方式。4. 物联网核心WiFi连接与网络通信实战一切准备就绪现在让我们点亮这块板子的核心技能——无线连接。我们将通过一个完整的例子实现连接WiFi、获取网络时间、并向一个Web API发送传感器数据模拟的全过程。4.1 配置网络凭证安全第一永远不要在代码中明文写入WiFi密码。我们使用settings.toml文件。在CIRCUITPY驱动器根目录下用文本编辑器创建一个新文件命名为settings.toml。写入以下内容替换为你自己的网络信息CIRCUITPY_WIFI_SSID 你的WiFi名称 CIRCUITPY_WIFI_PASSWORD 你的WiFi密码保存文件。这样你的密码就不会随着代码一起被分享出去了。4.2 编写第一个联网程序在CIRCUITPY驱动器根目录下打开或创建code.py写入以下代码import time import os import board import busio from digitalio import DigitalInOut import adafruit_esp32spi.adafruit_esp32spi_socket as socket from adafruit_esp32spi import adafruit_esp32spi import adafruit_requests as requests # 获取WiFi配置 try: from settings import secrets except ImportError: print(WiFi配置未在settings.toml中找到) raise # 配置ESP32 SPI引脚 esp32_cs DigitalInOut(board.ESP_CS) esp32_ready DigitalInOut(board.ESP_BUSY) esp32_reset DigitalInOut(board.ESP_RESET) # 创建SPI总线对象使用硬件SPI默认引脚已被AirLift占用 spi busio.SPI(board.SCK, board.MOSI, board.MISO) # 初始化ESP32对象 esp adafruit_esp32spi.ESP_SPIcontrol(spi, esp32_cs, esp32_ready, esp32_reset) # 初始化网络请求对象 requests.set_socket(socket, esp) def connect_to_wifi(): 连接到WiFi网络 print(ESP32固件版本:, esp.firmware_version.decode(utf-8)) # 检查ESP32芯片ID if esp.status adafruit_esp32spi.WL_IDLE_STATUS: print(ESP32找到并处于就绪状态) # 扫描可用网络可选 print(扫描网络中...) for ap in esp.scan_networks(): print(\t%s\t信号强度: %d dBm % (str(ap[ssid], utf-8), ap[rssi])) # 连接网络 print(连接到AP..., end) while not esp.is_connected: try: esp.connect_AP(secrets[ssid], secrets[password]) except RuntimeError as e: print(连接失败重试中..., e) continue time.sleep(1) print(成功!) print(IP地址:, esp.pretty_ip(esp.ip_address)) print(信号强度 (RSSI):, esp.rssi, dBm) def get_network_time(): 从NTP服务器获取网络时间 print(获取网络时间...) try: # 使用Adafruit的IO服务作为时间源示例实际可使用任何NTP服务器 TIME_URL http://worldtimeapi.org/api/ip response requests.get(TIME_URL) if response.status_code 200: json_data response.json() current_time json_data[datetime] print(当前网络时间 (UTC):, current_time) else: print(获取时间失败状态码:, response.status_code) response.close() except Exception as e: print(获取时间出错:, e) def post_sensor_data(): 模拟向物联网平台发送传感器数据 print(准备发送传感器数据...) # 模拟读取传感器数据例如温度、湿度 # 在实际应用中这里应替换为真实的传感器读取代码 simulated_temp 24.5 simulated_humidity 65.2 # 假设的API端点此处为示例需要替换为真实可用的API API_ENDPOINT https://httpbin.org/post # 一个用于测试的公共API payload { device_id: metro_m4_airlift_001, temperature: simulated_temp, humidity: simulated_humidity, timestamp: time.time() } try: print(发送数据到:, API_ENDPOINT) response requests.post(API_ENDPOINT, jsonpayload) print(HTTP状态码:, response.status_code) if response.status_code 200: print(服务器响应:, response.text[:200]) # 打印前200字符 else: print(请求失败响应:, response.text) response.close() except Exception as e: print(发送数据时出错:, e) # 主循环 print( Metro M4 AirLift 物联网演示 ) connect_to_wifi() while True: if esp.is_connected: get_network_time() post_sensor_data() # 每60秒执行一次 for _ in range(60): time.sleep(1) # 可以在这里添加其他周期性任务比如读取真实传感器 else: print(WiFi连接断开尝试重连...) connect_to_wifi() time.sleep(1)代码逐段解析导入与配置首先导入必要的库。adafruit_esp32spi是驱动ESP32协处理器的核心库adafruit_requests则提供了类似Pythonrequests库的HTTP客户端功能极大简化了网络请求。初始化ESP32通过busio.SPI指定硬件SPI总线引脚已由板子固定并传入三个控制引脚对象创建ESP_SPIcontrol对象。这个对象封装了所有与ESP32通信的底层细节。连接WiFiconnect_to_wifi函数展示了标准流程检查状态、扫描网络调试用、然后循环尝试连接直到成功。esp.is_connected属性非常有用可以随时检查连接状态。HTTP请求使用requests.get()和requests.post()发起HTTP请求语法与桌面Python几乎一致。注意在发送完请求后务必调用response.close()来释放socket资源这对于内存有限的嵌入式系统非常重要。错误处理网络操作极易失败。代码中使用了try...except块来捕获可能出现的超时、断线、服务器无响应等异常并给出提示或进行重试这是生产级代码的必备要素。主循环连接成功后进入一个无限循环定期执行获取时间和发送数据的任务。同时循环内每秒检查一次连接状态如果断线则触发重连。将这段代码保存为code.py后CircuitPython会自动重启并运行。打开Mu Editor的串行控制台你将看到详细的连接和通信日志。4.3 高级话题WiFi管理器与低功耗考虑对于更复杂的应用你可能需要WiFi管理器上述代码实现了基本的重连但对于多网络选择、智能配置如通过Web Portal配网场景可以考虑使用更高级的WiFi管理库或自行实现状态机。低功耗模式ATSAMD51支持多种睡眠模式。在电池供电的物联网传感器节点中你可以在数据发送间隙让主控进入深度睡眠alarm.sleep_memory同时也可以控制ESP32进入节能模式。这需要仔细设计唤醒源如定时器、外部中断和程序流程。SSL/TLS安全连接ESP32协处理器的优势在于其内置的硬件加密引擎可以高效处理HTTPS连接。adafruit_requests库默认支持HTTPS。只需将URL中的http://改为https://即可。ESP32会处理证书验证和加密解密对主控CPU几乎没有负担。5. 常见问题排查与实战技巧即使按照指南操作在实际项目中你仍可能遇到各种问题。以下是我在多次项目中总结的常见问题与解决方案。5.1 驱动与连接问题排查表问题现象可能原因排查步骤与解决方案电脑无法识别METROM4BOOT或CIRCUITPY驱动器1. USB线仅供电无数据。2. USB端口故障或驱动问题。3. 板子进入异常状态。1.更换一条已知良好的USB数据线这是最常见的原因。2. 尝试电脑上不同的USB端口。3. 长按复位键超过10秒然后重新插拔USB尝试强制进入引导模式。串行控制台无输出或乱码1. 串口波特率设置错误。2. 程序崩溃导致REPL无法启动。3. 代码code.py有语法错误循环重启。1. 在Mu Editor或串口终端中确认波特率设置为115200。2. 进入引导模式检查CIRCUITPY驱动器是否存在。如果存在尝试重命名code.py为code.txt然后重启看REPL是否恢复。3. 查看串口是否有快速的错误信息刷屏这通常是code.py导入不存在的库或语法错误。ImportError: no module named ‘adafruit_esp32spi’库文件未正确安装或路径不对。1. 确认lib文件夹存在于CIRCUITPY根目录。2. 确认adafruit_esp32spi和adafruit_requests的.mpy文件在lib文件夹内。3. 使用circup list检查库是否被正确识别。WiFi连接始终失败1.settings.toml配置错误或未加载。2. 网络信号太弱。3. ESP32固件过旧。1. 检查settings.toml文件名和格式是否正确TOML格式。可以在REPL中直接import settings测试。2. 在代码中添加网络扫描打印信号强度(RSSI)。低于-70dBm可能不稳定。3. 考虑更新ESP32协处理器固件详见官方指南通常板载固件已是最新。程序运行一段时间后死机或重启1. 内存泄漏如未关闭网络连接。2. 看门狗定时器未喂食。3. 电源不稳定。1.确保每个requests响应对象在使用后都调用.close()。2. 在长时间循环中可以加入microcontroller.reset()逻辑或使用watchdog库。3. 使用示波器检查3.3V电源纹波尤其在电机或大功率LED启动时。向CIRCUITPY复制文件失败Mac用户常见macOS系统自动生成.DS_Store等隐藏文件占满Flash空间。1. 定期清理在终端执行rm -rf /Volumes/CIRCUITPY/.Trashes /Volumes/CIRCUITPY/.fseventsd /Volumes/CIRCUITPY/.Spotlight* /Volumes/CIRCUITPY/.DS_Store。2. 使用命令行cp或rsync复制文件避免Finder。3. 在settings.toml中添加CIRCUITPY_AUTORELOAD_DELAY200可能有助于缓解。5.2 性能优化与内存管理Metro M4虽然有192KB RAM但在复杂的物联网应用中仍需精打细算。使用.mpy库文件与纯文本的.py文件相比预编译的.mpy文件加载更快占用内存更少。始终从官方库包中获取.mpy文件。谨慎使用字符串操作在Python中字符串拼接尤其是循环内会产生大量临时对象。对于固定的日志或网络数据考虑使用bytes或bytearray或者使用format()或f-string进行一次性格式化。及时释放资源网络连接socket、文件句柄都是资源。使用with语句如果库支持或确保在finally块中关闭它们。缓冲区复用对于频繁读写的操作可以预分配一个bytearray缓冲区而不是每次创建新的对象。5.3 混合开发与Arduino IDE共存有时你可能需要Arduino生态的某个特定库或者需要追求极致的性能。Metro M4 Express AirLift同样完美支持Arduino。安装板卡支持在Arduino IDE的“开发板管理器”中搜索并安装“Adafruit SAMD Boards”。选择板卡在“工具”-“开发板”中选择“Adafruit Metro M4 Express AirLift (SAMD51)”。安装库通过“库管理器”搜索安装“Adafruit AirLift Library”和“Adafruit ESP32 SPI”等相关库。编程与上传编写Arduino代码点击上传。IDE会通过BOSSA协议将代码烧录到板子。切换回CircuitPython只需再次进入引导模式双击RST将CircuitPython的.uf2文件拖入METROM4BOOT驱动器即可。这种无缝切换的能力使得这块板子成为一个真正的“全能”实验平台你可以在快速原型CircuitPython和性能优化Arduino之间自由选择。

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