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

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Spring AI ectorStore的使用流程

《SpringAIectorStore的使用流程》SpringAI中的VectorStore是一种用于存储和检索高维向量数据的数据库或存储解决方案,它在AI应用中发挥着至关重要的作用,本文给大家介... 目录一、VectorStore的基本概念二、VectorStore的核心接口三、VectorStore的

Spring AI集成DeepSeek三步搞定Java智能应用的详细过程

《SpringAI集成DeepSeek三步搞定Java智能应用的详细过程》本文介绍了如何使用SpringAI集成DeepSeek,一个国内顶尖的多模态大模型,SpringAI提供了一套统一的接口,简... 目录DeepSeek 介绍Spring AI 是什么?Spring AI 的主要功能包括1、环境准备2

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

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