AI嵌入式3——君正T40之MIPS32架构交叉编译opencv4篇

2024-01-11 05:20

本文主要是介绍AI嵌入式3——君正T40之MIPS32架构交叉编译opencv4篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

系列文章目录

opencv基本安装
深度学习环境搭建
君正T40基础使用
参考文献
参考文献
参考文献

文章目录

  • 系列文章目录
  • 当前环境
  • 一、编译工具链准备
  • 二、编译环境准备
    • 1、下载cmake-gui
    • 2、下载opencv4.4.0
  • 三、交叉编译工作
    • 1、构建目录
    • 2、指定CMAKE_TOOLCHAIN_FILE
    • 3、opencv编译环境配置
    • 4、终端编译安装


当前环境

主机环境:Ubuntu 18.04.6 LTS,x86_64

目标平台:君正T40,mips32r2架构

CMake GUI版本:3.14.7

OpenCV版本:4.4.0

交叉编译链:mips-gcc720-glibc226

一、编译工具链准备

在君正提供的SDK包中有一个类似的编译链压缩包mips-gcc720-glibc226.tar.gz,可能版本会不一样,命名格式差不多的。
在这里插入图片描述

解压指定位置,然后配置工具链路径,主机终端命令行打开

sudo gedit  ~/.bashrc

在末尾添加工具链路径:

export PATH=/xxx/mips-gcc720-glibc226/bin:$PATH

使配置文件生效

source ~/.bashrc

终端输入以下命令检查是否安装成功:

mips-linux-gnu-gcc -v

在这里插入图片描述

二、编译环境准备

1、下载cmake-gui

官网下载cmake

具体的参考博客

2、下载opencv4.4.0

opencv下载地址和opencv_contrib下载地址

具体的参考博客

在这里插入图片描述

三、交叉编译工作

1、构建目录

在解压的opencv文件夹中建立两文件夹,名字任意。

如:build , install

打开cmake-gui可视化工具

Where is the source code :选择解压好的opencv根目录
Where to build the binaries:选择新建的build目录

在这里插入图片描述

2、指定CMAKE_TOOLCHAIN_FILE

该步骤很重要,而且必须在点击Configure之前配置(详见以下官方介绍)。一般编译过程出现某些模块不通过就是因为缺少该环节,以及提示警告“CMAKE_SYSTEM_PROCESSOR is not defined”也是缺少该环节。

CMAKE_TOOLCHAIN_FILE: This variable is specified on the command line when cross-compiling with CMake. It is the path to a file which is read early in the CMake run and which specifies locations for compilers and toolchain utilities, and other target platform and compiler related information.

参考文献

在opencv根目录platforms子目录下存放有android、apple、ios、Linux等平台的cmake文件。

在这里插入图片描述

君正T40的是MIPS32架构,点击+Add Entry选项进行选择。

在这里插入图片描述

点击configure按钮进入配置向导

3、opencv编译环境配置

想要编译安装的顺利,需要好好捋一捋配置。

需要编译的是mips平台opencv库,所以选择Unix Makefiles,接着选择Specify options for cross-compiling。

在这里插入图片描述

点击Next进入交叉编译环境配置页面
“Operating System”填写Linux
“Processor”填写mips
“C Compilers”填写交叉编译器( mips-linux-gnu-gcc )的路径
“C++ Compilers”填写( mips-linux-gnu-g++ )路径
“Target Root”填写交叉编译链的所在目录

然后选择Finish,信息基本就配置好了。
在这里插入图片描述

参考文献

点击configure,接下来需要多次补充修改部分配置项,可能需要多次点击configure。

为了方便查找,勾工具的Advanced和Grouped选项。

查找以下这4个选项, 分别增加-fPIC。

CMAKE_CXX_FLAGS                                 -fPICCMAKE_CXX_FLAGS_DEBUG               -g -fPICCMAKE_C_FLAGS                                      -fPICCMAKE_C_FLAGS_DEBUG                     -g -fPIC

查找以下两项 ,分别加上 -lpthread -lrt -ldl

CMAKE_EXE_LINKER_FLAGS                          -lpthread -lrt -ldlCMAKE_EXE_LINKER_FLAGS_DEBUG        -lpthread -lrt –ldl

修改配置CMAKE_INSTALL_PREFIX默认安装目录/usr/local,改为新建的目录install。

在这里插入图片描述

修改OPENCV_EXTRA_MODULES_PATH,也就是contrib路径。

在这里插入图片描述

勾选BUILD_ZLIB
修改ZLIB_INCLUDE_DIR

在这里插入图片描述

是否选择勾选opencv_world选项。

OpenCV中有很多模块,模块间保持最小的依赖关系,用户可以根据自己的实际需要链接相关的库,而不需链接所有的库,这样在最终交付应用程序时可以减少总库的大小。但如果需要依赖OpenCV的库太多,有时会带来不方便,此时可以使用OpenCV的world模块。

OpenCV中的world模块,也称为超级模块(super-module),它结合了用户选择的所有其它模块。它是一个一体化(all-in-one)模块,具有所有库的功能。使用world模块可能会使应用程序的编译时间略有增加。

所以勾选opencv_world选项就会得到库的集合体,不选每个库就会相对独立。

在这里插入图片描述

如果想编译静态库,则不要选择BUILD_SHARED_LIBS,这样make install后生成的就是静态库,不过用动态库多一点,可以选择保留。

在这里插入图片描述
参考文献

感觉差不多了,可以尝试点点configure,看看还有没有红字报错出现。

可能还会出现一些报错,环境不一样出现的报错可能也不一样,如果出现一些JPEG,PNG,TIFF,WEBP等找不到报错,可以尝试在WITH中取消对应的WITH_xxx选项。

以下图片中的选项勾选仅供参考,每个人的配置不一,请勿照搬。

在这里插入图片描述
在这里插入图片描述

还有一些常见错误:

boostdesc_bgm.i文件出错IPPICV: Download: ippicv_2017u3_lnx_intel64_general_20180518.tgz CMake出错Face: Can’t get model file for face alignment出错

参考该博客,有详细解决

点击Generate等待出现Generating done。

在这里插入图片描述

4、终端编译安装

在opencv/build目录下打开终端,输入:

make -j4

在这里插入图片描述

编译成功之后,再输入

sudo make install

在这里插入图片描述

最终install文件夹下生成bin include lib share四个文件夹,是交叉编译后的程序和相关资源。

在交叉编译过程中,生成的可执行文件通常包含四个主要部分:bin、include、lib和share。

bin(二进制文件):这个目录包含了交叉编译后生成的可执行文件。这些文件是在目标体系结构上运行的程序,可以直接在目标计算机上执行。

include(头文件):这个目录包含了用于编译目标体系结构上的程序所需的头文件。头文件包含了函数和变量的声明,用于在编译时进行类型检查和函数调用。

lib(库文件):这个目录包含了目标体系结构上的库文件。库文件是预编译的代码,包含了一组函数和数据,可以在程序中被调用和使用。在交叉编译中,生成的库文件是为目标体系结构而编译的,以便在目标计算机上使用。

share(共享文件):这个目录包含了一些共享的数据文件,如配置文件、资源文件等。这些文件在不同的程序之间可以共享和重用。

交叉编译后生成的bin目录包含可执行文件,include目录包含头文件,lib目录包含库文件,share目录包含共享文件。

在这里插入图片描述

这篇关于AI嵌入式3——君正T40之MIPS32架构交叉编译opencv4篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/593301

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

Spring AI Alibaba接入大模型时的依赖问题小结

《SpringAIAlibaba接入大模型时的依赖问题小结》文章介绍了如何在pom.xml文件中配置SpringAIAlibaba依赖,并提供了一个示例pom.xml文件,同时,建议将Maven仓... 目录(一)pom.XML文件:(二)application.yml配置文件(一)pom.xml文件:首

SpringBoot整合DeepSeek实现AI对话功能

《SpringBoot整合DeepSeek实现AI对话功能》本文介绍了如何在SpringBoot项目中整合DeepSeekAPI和本地私有化部署DeepSeekR1模型,通过SpringAI框架简化了... 目录Spring AI版本依赖整合DeepSeek API key整合本地化部署的DeepSeek

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

微服务架构之使用RabbitMQ进行异步处理方式

《微服务架构之使用RabbitMQ进行异步处理方式》本文介绍了RabbitMQ的基本概念、异步调用处理逻辑、RabbitMQ的基本使用方法以及在SpringBoot项目中使用RabbitMQ解决高并发... 目录一.什么是RabbitMQ?二.异步调用处理逻辑:三.RabbitMQ的基本使用1.安装2.架构

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20