RK3568平台OpenCV交叉编译实战:从源码到部署的完整指南

news2026/5/20 14:08:58
1. 项目概述为什么要在RK3568上折腾OpenCV最近在做一个基于瑞芯微RK3568芯片的边缘计算盒子项目其中一个核心需求就是要在设备上跑实时的图像识别算法。算法框架选型时我们团队内部有过一些讨论最终还是决定用OpenCV这个“老伙计”。原因很简单一是生态成熟无论是基础的图像处理、特征提取还是跟深度学习框架比如我们用的PyTorch做结合OpenCV都有现成的、经过大量验证的接口二是社区活跃遇到什么稀奇古怪的问题大概率能找到解决方案。但问题来了RK3568是一颗Arm架构的处理器而我们平时在x86的Ubuntu或者Windows上开发都是直接apt-get install或者下载预编译好的库简单省事。可到了嵌入式平台尤其是像RK3568这样资源相对受限、系统环境可能定制的场景直接安装的版本往往水土不服。要么是编译时用的指令集优化没开启性能上不去要么是依赖的某些系统库版本对不上运行时直接给你来个“Segmentation fault”。所以从源码开始针对RK3568的硬件特性比如它那个Mali-G52 GPU和NPU进行交叉编译就成了一个绕不开的“硬骨头”。这个过程说好听点叫“深度定制化”说直白点就是一堆坑等着你踩。网上能找到的教程要么太旧对应的OpenCV版本和RK3568的SDK已经对不上了要么就是步骤跳跃太大对于没怎么玩过交叉编译的朋友来说容易卡在某个环节动弹不得。我这篇文章就是把我从准备环境、配置编译选项、处理各种依赖和报错到最后成功移植并测试的全过程以及其中积累的经验和教训做一个详细的复盘。目标很明确让你拿到这份“攻略”能在一台x86的开发机上为你的RK3568设备编译出一套性能达标、稳定可靠的OpenCV库直接用于你的项目。2. 编译环境搭建与核心工具链解析为RK3568编译OpenCV本质上是一个交叉编译的过程。我们的“主战场”是一台x86_64架构的Ubuntu 20.04 LTS开发主机而“目标战场”是Arm架构的RK3568开发板。连接这两者的桥梁就是RK3568官方提供的交叉编译工具链。2.1 工具链的选择与获取瑞芯微为RK3568提供了完整的SDK开发包其中就包含了预编译好的交叉编译工具链。这是最推荐、兼容性最好的选择。通常你可以在瑞芯微的官方Wiki或你购买开发板的供应商那里获取到SDK。SDK包一般比较大里面包含了Linux内核源码、U-Boot、根文件系统以及工具链。工具链的路径通常在SDK的prebuilts/gcc/linux-x86/aarch64/目录下。你需要关注的是gcc-arm-10.3-2021.07-x86_64-aarch64-none-linux-gnu这样的一个目录。这个工具链是基于GCC 10.3版本构建的针对aarch64即64位Arm架构运行在Linux-gnu系统上。把它解压到你的开发主机上一个合适的路径例如/opt/toolchains/。接下来最关键的一步是将工具链的路径加入到系统的环境变量中这样后续的cmake命令才能找到正确的编译器。通常需要设置以下几个变量export RK_TOOLCHAIN/opt/toolchains/gcc-arm-10.3-2021.07-x86_64-aarch64-none-linux-gnu export PATH$RK_TOOLCHAIN/bin:$PATH export CCaarch64-none-linux-gnu-gcc export CXXaarch64-none-linux-gnu-g export LDaarch64-none-linux-gnu-ld你可以将这些命令写入~/.bashrc文件然后执行source ~/.bashrc使其永久生效。验证是否配置成功可以执行aarch64-none-linux-gnu-gcc --version如果正确输出了GCC版本信息并且前缀是aarch64-none-linux-gnu-那就说明工具链准备就绪了。注意不同版本的SDK其工具链的命名和GCC版本可能略有差异。务必使用与你目标板系统内核版本匹配的工具链否则编译出的库可能在运行时出现不兼容问题。2.2 主机开发环境依赖安装交叉编译OpenCV不仅需要目标板的工具链主机上也需要安装一些必要的本地编译工具和库。这些主要用于编译过程中生成的一些主机端工具如代码生成器。sudo apt-get update sudo apt-get install -y \ build-essential \ cmake \ git \ pkg-config \ libgtk2.0-dev \ libavcodec-dev libavformat-dev libswscale-dev \ libtbb2 libtbb-dev \ libjpeg-dev libpng-dev libtiff-dev \ libdc1394-22-dev \ libv4l-dev \ python3-dev python3-numpy这里安装的包像cmake是构建系统的核心build-essential提供了基础的编译工具pkg-config用于帮助查找依赖库的头文件和库路径libgtk2.0-dev等是OpenCV部分GUI功能和高层IO模块的可选依赖。即使目标板没有GUI编译某些模块时也可能需要主机端的这些库来通过配置检查。2.3 OpenCV源码与Contrib模块准备我们选择OpenCV 4.5.5版本进行编译这是一个长期支持版本相对稳定。同时我们还需要OpenCV contrib模块它包含了许多主仓库中没有的额外功能比如人脸识别、文本检测、深度神经网络DNN模块的更多后端支持等这些在边缘计算项目中非常有用。# 创建工作目录 mkdir -p ~/workspace/rk3568_opencv cd ~/workspace/rk3568_opencv # 下载OpenCV主仓库源码 wget -O opencv-4.5.5.tar.gz https://github.com/opencv/opencv/archive/4.5.5.tar.gz tar -xzf opencv-4.5.5.tar.gz # 下载OpenCV contrib仓库源码 wget -O opencv_contrib-4.5.5.tar.gz https://github.com/opencv/opencv_contrib/archive/4.5.5.tar.gz tar -xzf opencv_contrib-4.5.5.tar.gz解压后你会得到opencv-4.5.5和opencv_contrib-4.5.5两个目录。请确保它们的版本号完全一致否则编译时可能会遇到模块找不到的错误。3. CMake配置详解为RK3568量身定做这是整个编译过程中最核心、最考验功力的环节。CMake的配置直接决定了最终生成的OpenCV库包含哪些功能、依赖哪些外部库、以及针对目标硬件做了哪些优化。3.1 基础交叉编译配置我们在源码目录下创建一个用于构建的目录并进入该目录开始配置。cd opencv-4.5.5 mkdir build cd build然后执行cmake命令。下面是一个经过精简和优化的配置示例你需要重点关注其中与交叉编译相关的参数cmake -D CMAKE_SYSTEM_NAMELinux \ -D CMAKE_SYSTEM_PROCESSORaarch64 \ -D CMAKE_C_COMPILERaarch64-none-linux-gnu-gcc \ -D CMAKE_CXX_COMPILERaarch64-none-linux-gnu-g \ -D CMAKE_INSTALL_PREFIX../install \ -D OPENCV_EXTRA_MODULES_PATH../../opencv_contrib-4.5.5/modules \ -D WITH_GTKOFF \ -D WITH_GTK_2_XOFF \ -D WITH_V4LON \ -D WITH_LIBV4LON \ -D WITH_FFMPEGON \ -D WITH_GSTREAMEROFF \ -D BUILD_opencv_python2OFF \ -D BUILD_opencv_python3ON \ -D PYTHON3_INCLUDE_PATH$(python3 -c import sysconfig; print(sysconfig.get_path(include))) \ -D PYTHON3_LIBRARY$(python3 -c import sysconfig; print(sysconfig.get_config_var(LIBDIR)))/libpython3.8.so \ -D PYTHON3_NUMPY_INCLUDE_DIRS$(python3 -c import numpy; print(numpy.get_include())) \ -D BUILD_EXAMPLESOFF \ -D BUILD_TESTSOFF \ -D BUILD_PERF_TESTSOFF \ -D BUILD_DOCSOFF \ -D CMAKE_BUILD_TYPERelease ..关键参数解析CMAKE_SYSTEM_NAME和CMAKE_SYSTEM_PROCESSOR明确告诉CMake我们是在为Linux系统下的aarch64处理器进行交叉编译。CMAKE_C_COMPILER和CMAKE_CXX_COMPILER指定交叉编译器的绝对路径或已在PATH环境变量中的命令名。这是交叉编译的“开关”。CMAKE_INSTALL_PREFIX指定编译安装的路径。这里设置为../install所有编译好的库、头文件都会安装到这个目录下方便我们后续打包拷贝到RK3568。OPENCV_EXTRA_MODULES_PATH指向contrib模块的路径这样CMake就会一并编译这些额外模块。WITH_GTKOFFRK3568作为无头设备没有显示器通常不需要GUI支持关闭GTK可以避免不必要的依赖和编译错误。WITH_V4L和WITH_LIBV4L如果项目需要用到摄像头Video4Linux这两个选项必须打开。WITH_FFMPEGON用于视频文件的编解码。虽然RK3568有硬解码能力但OpenCV的VideoCapture和VideoWriter通常需要FFmpeg的软解支持建议开启。但需要注意这需要你事先为RK3568交叉编译好FFmpeg库并在CMake中指定其路径否则会编译失败或回退到内部实现。BUILD_opencv_python3ON如果你需要在RK3568上使用Python调用OpenCV这个必须开启。后面对应的PYTHON3_*参数需要指向主机系统的Python3开发环境用于生成Python绑定文件。最终在RK3568上运行的Python库其解释器版本需要与主机生成绑定时的一致。BUILD_EXAMPLES/TESTS/PERF_TESTS/DOCSOFF关闭这些可以显著加快编译速度减少生成文件的大小。3.2 性能优化关键配置RK3568的CPU是Cortex-A55支持NEON SIMD指令集。GPU是Mali-G52理论上OpenCV的某些模块可以通过OpenCL加速。此外RK3568还有一个独立的NPU。针对这些硬件特性我们可以进行针对性优化。# 在上面的cmake命令后继续添加以下参数实际应合并为一条长命令 cmake ... \ -D ENABLE_NEONON \ -D ENABLE_VFPV3ON \ -D WITH_OPENCLON \ -D WITH_OPENCLAMDFFTOFF \ -D WITH_OPENCLAMDBLASOFF \ -D WITH_OPENCL_SVMOFF \ -D WITH_TBBOFF \ -D WITH_OPENMPON \ ..ENABLE_NEONON为Arm NEON指令集生成优化代码对图像处理中的矩阵运算有巨大提升。这是必选项。ENABLE_VFPV3ON启用浮点运算单元优化。WITH_OPENCLON开启OpenCL支持允许部分算法如矩阵操作、图像变换在Mali-G52 GPU上运行。但是这需要RK3568的系统内核中已启用并提供了正确的OpenCL驱动和ICDInstallable Client Driver文件。如果目标板系统没有开启此选项可能导致编译失败或运行时找不到设备。这是一个需要权衡的选项。WITH_TBBOFFTBB是Intel的线程构建库在Arm平台上通常性能不如OpenMP且会增加依赖复杂性建议关闭。WITH_OPENMPON使用OpenMP进行多线程并行化能充分利用RK3568的四核CPU。实操心得关于OpenCL我建议第一次编译时可以先关闭 (WITH_OPENCLOFF)确保基础库能顺利编译通过并在板子上运行。后续再尝试交叉编译OpenCL的支持库如Mali的OpenCL SDK并开启此选项进行二次编译。NPU的调用通常不通过OpenCV直接进行而是通过RKNN-Toolkit等专用SDK将模型转换成RKNN格式后在NPU上推理OpenCV负责前后处理。3.3 依赖库的指定与问题规避交叉编译最大的挑战之一是处理第三方依赖。像libjpeg,libpng,libtiff,ffmpeg等都需要使用针对RK3568编译的版本。你有两个选择使用工具链的sysroot如果SDK提供了完整的根文件系统sysroot可以在CMake中通过-D CMAKE_FIND_ROOT_PATH/path/to/sysroot指定CMake会自动在该路径下查找依赖。手动指定路径如果依赖库是自己单独交叉编译的可以通过-D XXX_INCLUDE_DIR/path/to/include -D XXX_LIBRARY/path/to/libxxx.so的形式逐个指定。一个常见的技巧是对于某些在目标板上可能不存在、或者很难交叉编译的依赖如libwebp,libjasper如果项目用不到直接强制关闭它们避免CMake去查找导致失败cmake ... \ -D WITH_WEBPOFF \ -D WITH_JASPEROFF \ -D BUILD_ZLIBON \ -D BUILD_JPEGON \ -D BUILD_PNGON \ -D BUILD_TIFFON \ ..将BUILD_XXX设置为ON可以让OpenCV使用内置的第三方源码进行编译这能极大简化依赖管理是嵌入式交叉编译的常用手段。虽然版本可能不是最新的但保证了可用性和兼容性。执行完CMake命令后仔细查看终端输出。你会看到一大片配置信息重点关注Compiler:一行确认是aarch64-none-linux-gnu-g。Install path:确认是你设置的路径。To be built:列表确认需要的模块都被包含进来了。Found和NOT found的库检查是否有关键依赖缺失。对于标记为NO的非必需依赖如果不需要可以忽略对于标记为YES但路径不对的必需依赖则需要解决。4. 编译、安装与部署实战配置成功后就可以开始编译了。这个过程耗时较长取决于你的主机性能。4.1 并行编译与安装# 使用make进行并行编译-j参数后面的数字建议设为你的CPU核心数以加快速度 make -j$(nproc) # 编译成功后将库和头文件安装到CMAKE_INSTALL_PREFIX指定的目录 make install编译过程可能会遇到各种错误常见的有找不到某个头文件通常是交叉编译的依赖库路径没设置对或者该依赖需要手动关闭。链接阶段失败提示未定义的引用可能是某个库的链接顺序不对或者依赖库本身就没编译成功。需要根据错误信息回溯检查CMake的配置。内存不足在虚拟机或内存较小的主机上编译OpenCV这种大项目可能遇到编译器因内存不足被杀死的情况。可以尝试减少-j后的并行任务数比如make -j2。编译安装完成后进入../install目录你会看到熟悉的OpenCV目录结构include/,lib/,bin/等。lib目录下就是生成的所有动态库.so和静态库.a文件。4.2 库文件精简与部署直接生成的lib目录可能包含很多你不需要的模块。你可以根据你的项目需求只拷贝必要的库文件到RK3568。最少情况下你可能只需要libopencv_core.so,libopencv_imgproc.so,libopencv_dnn.so等核心模块。将整个install目录打包通过scp或U盘拷贝到RK3568开发板上例如放到/usr/local/opencv-4.5.5目录下。接下来需要在RK3568上配置环境让系统能找到这些库添加库路径编辑板子上的/etc/ld.so.conf文件添加一行/usr/local/opencv-4.5.5/lib然后运行sudo ldconfig更新动态链接库缓存。设置Python路径如果编译了Python绑定将install/lib/python3.8/site-packages/具体路径根据你的Python版本下的cv2目录拷贝到RK3568上Python3的site-packages目录下。或者通过设置PYTHONPATH环境变量来添加。4.3 基础功能验证在RK3568上编写一个简单的测试程序验证OpenCV是否正常工作。C测试 (test_opencv.cpp):#include opencv2/opencv.hpp #include iostream int main() { std::cout OpenCV version: CV_VERSION std::endl; // 创建一个简单的图像并显示其尺寸 cv::Mat img(100, 200, CV_8UC3, cv::Scalar(0, 255, 0)); std::cout Image size: img.cols x img.rows std::endl; // 尝试一个简单的图像操作 cv::Mat gray; cv::cvtColor(img, gray, cv::COLOR_BGR2GRAY); std::cout Convert to gray done. std::endl; return 0; }使用交叉编译器在主机上编译这个测试程序aarch64-none-linux-gnu-g test_opencv.cpp -o test_opencv \ -I/path/to/install/include/opencv4 \ -L/path/to/install/lib \ -lopencv_core -lopencv_imgproc -lopencv_highgui -lopencv_imgcodecs \ --sysroot/path/to/sysroot # 如果使用了sysroot将编译出的test_opencv可执行文件拷贝到RK3568并确保动态库路径已配置正确然后运行./test_opencv如果成功输出OpenCV版本和相关信息则说明基础库移植成功。Python测试在RK3568的终端中运行Python并导入cv2python3 import cv2 print(cv2.__version__) print(cv2.getBuildInformation())如果能成功打印出版本信息和构建信息注意看里面的CPU features: NEON是否启用则说明Python绑定也成功了。5. 疑难杂症与性能调优实录在实际操作中你几乎一定会遇到一些预料之外的问题。这里记录几个我踩过的坑和解决方案。5.1 常见编译错误与解决问题1CMake配置时FFmpeg相关功能被禁用提示 “NO”FFMPEG: NO排查与解决这通常是因为没有为RK3568提供交叉编译好的FFmpeg库。如果你确实需要视频文件读写功能有两条路路径A自行交叉编译FFmpeg。这是一个相对独立且复杂的过程需要为RK3568配置合适的编解码器。成功后在OpenCV的CMake配置中通过-D WITH_FFMPEGON -D FFMPEG_INCLUDE_DIR/path/to/ffmpeg/include -D FFMPEG_LIBRARY_DIR/path/to/ffmpeg/lib等参数指定路径。路径B使用OpenCV内置的视频IO。将WITH_FFMPEG设为OFFOpenCV会回退到其内置的videoio模块可能支持部分格式如MP4的读取需要依赖其他如libx264可能更麻烦。对于边缘设备有时直接处理RTSP流或RAW数据反而更简单。问题2编译过程中链接阶段报错 “undefined reference topng_xxx’[ 98%] Linking CXX shared library …/…/lib/libopencv_imgcodecs.so …/…/3rdparty/lib/liblibpng.a(png.o): In function png_init_filter_functions_neon‘: undefined reference to png_do_filter_intrapixel‘排查与解决这是典型的第三方静态库编译选项冲突。OpenCV内置的libpng在编译时可能启用了某些ARM特有的汇编优化但与工具链的配置不兼容。最稳妥的解决方案是避免使用OpenCV内置的第三方库转而使用工具链sysroot中提供的系统库。在CMake中将对应的BUILD_PNGOFF并确保CMAKE_FIND_ROOT_PATH正确指向了sysroot让CMake自动找到系统里的libpng。5.2 运行时问题与依赖检查问题3在RK3568上运行程序提示 “error while loading shared libraries: libopencv_core.so.4.5: cannot open shared object file”解决这是动态链接器找不到库文件。确保你已经正确执行了ldconfig或者可以在运行程序前临时指定库路径LD_LIBRARY_PATH/usr/local/opencv-4.5.5/lib ./your_program。**问题4Python导入cv2时报错 “ImportError: /lib/aarch64-linux-gnu/libc.so.6: versionGLIBC_2.33‘ not found”** **解决**这表示你的主机交叉编译环境使用的Glibc版本2.33高于RK3568目标系统上的版本比如2.31。Glibc是系统核心库向下兼容性差。**必须使用与目标板系统版本匹配的工具链进行编译**。检查你的RK3568文件系统版本 (ldd --version)并获取对应Glibc版本的工具链重新编译OpenCV。5.3 性能验证与优化建议编译移植成功后性能如何验证这里有几个简单的方向NEON优化验证在测试程序中使用OpenCV的cv::checkHardwareSupport(CV_CPU_NEON)函数检查NEON是否启用。或者在板子上运行一个简单的图像处理循环比如高斯模糊与未开启NEON的编译版本理论上只能通过QEMU模拟测试对比进行耗时比较性能提升应该是非常明显的。OpenCL加速验证如果开启了WITH_OPENCL在程序中可以通过cv::ocl::haveOpenCL()和cv::ocl::useOpenCL()来检查并启用OpenCL。使用cv::UMat代替cv::Mat可以让一些操作自动在GPU上执行。你可以对比同一个算法如resize在CPU和UMatGPU上的耗时。注意数据在CPU和GPU之间传输是有开销的对于小尺寸图像或简单操作可能得不偿失。内存与存储优化RK3568的RAM和eMMC/Flash资源有限。链接方式考虑使用静态链接.a库将OpenCV核心代码编译进你的应用程序虽然可执行文件会变大但可以避免动态链接的加载开销和依赖问题。使用CMake的-DBUILD_SHARED_LIBSOFF可以编译静态库。裁剪模块在CMake阶段使用-DBUILD_LISTcore,imgproc,dnn,...来精确指定只编译你需要的模块可以大幅减少库文件体积和编译时间。Strip符号表部署到板子前使用aarch64-none-linux-gnu-strip工具去掉库文件和可执行文件中的调试符号能有效减小文件大小。整个RK3568上OpenCV的编译移植是一个典型的嵌入式交叉编译项目。其核心逻辑在于环境隔离主机 vs 目标和依赖管理交叉编译的第三方库。耐心和细心是关键遇到报错不要慌仔细阅读错误信息从编译器、链接器、依赖库这几个方向逐一排查。一旦走通这个流程你对嵌入式开发的工具链和构建系统的理解会上一个大台阶。这份经验不仅适用于OpenCV也适用于其他任何需要在特定Arm平台上从源码构建的复杂C项目。

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