首页 > 技术 > 内容

Zybo Z7上OpenCV和SDSoC的结合

时间:2026-01-21  作者:Diven  阅读:0

软硬件清单

SDSoC

Zybo Z7

包含Linux内核+根文件系统的平台

装有Linux系统的计算机

获取OpenCV

这一步你至少可以有两个选择,是下载并交叉编译库(docs.opencv.org/2.4/doc/tutorials/introduction/crosscompilation/arm_crosscompile_with_cmake);第二种是获取一个已经交叉编译好的库。在这一教程中,我们事先已经在SDSoC安装文件夹中建立好了OpenCV 2.4.5版本。

修改平台

这里我们需要将编译好的库添加到你想要用于项目的SDSoC平台的根文件系统中。在这步操作之后,可执行文件(你的应用程序)将能够加载库。 在Zybo Z7平台中使用的文件系统镜像类型是initRAMfs。如果你手头的是另镜像类型,你可以在Xilinx wiki上得到更多的所需信息:+and+Modify+a+Rootfs

3.1 将根文件系统复制到临时文件夹中

将位于平台的启动文件夹中名为“uRAMdisk.image.gz”的存档复制黏贴到一个临时文件夹中。打开终端,并进入该文件夹。

3.2 去掉U-BOOT头文件以获得CPIO存档

dd if=uramdisk.image.gz bs=64 skip=1 of=ramdisk.gz

3.3 将新的CPIO存档压缩到一个新创建的文件夹中

mkdir my_root

gunzip -c ramdisk.gz | sh -c ‘cd my_root/ && sudo cpio -i’

3.4 复制库与头文件(-P保存链接)

sudo cp -p /opt/Xilinx/SDSoC/2015.4/SDK/2015.4/data/embeddedsw/ThirdParty/opencv/lib/* my_root/lib/

sudo cp -r /opt/Xilinx/SDSoC/2015.4/SDK/2015.4/data/embeddedsw/ThirdParty/opencv/include/* my_root/usr/include/

3.5 压缩到CPIO和GUNZIP

sudo sh -c ‘cd my_root/ && find 。 | cpio -H newc -o’ | gzip -9 》 my_ramdisk.image.gz

3.6 添加U-BOOT头文件

mkimage -A arm -T ramdisk -C gzip -d my_ramdisk.image.gz my_uramdisk.image.gz

这里需要确保文件的权限设置为755:

sudo chmod 755 。/my_uramdisk.image.gz

3.7 在平台中更换新创建的镜像

cp 。/my_uramdisk.image.gz /pathToZyboPlatform/boot/uramdisk.image.gz

在SDSoC中创建并配置一个新项目

4.1 添加包含路径

创建一个新项目,选择你修改后的平台,然后选择你想要使用Linux。在project explorer(左侧面板)中右键单击项目,然后点击属性。 进入“C/C ++ build” - 》“设置” - 》 “SDS ++编译器” - 》“目录”,为所选的“build/debug/estimate配置”添加OpenCV的包含路径(/opt/Xilinx/SDSoC/2015.4/SDK/2015.4/data/embeddedsw/ThirdParty/opencv/include),如下图所示:

4.2 链接库

完成后,转到SDS ++ linker‘s configuration,在“库”下,添加要在项目中使用的库及其所在的路径(我这里是:/opt/Xilinx/SDSoC/2015.4/SDK/2015.4/data/embeddedsw/ThirdParty/opencv/lib)

4.3 添加-RPATH-LINK

你需要指定路径,使得链接器能够搜索OpenCV所需的依赖关系(libs)。 转到SDS ++linker configuration,在“Miscellaneous” - 》“Linker Flag”下添加以下行(-Wl,-rpath-link = / opt / Xilinx / SDSoC / 2015.4 / SDK / 2015.4 / data / embeddedsw / ThirdParty / opencv /LIB)。 -Wl选项向工具链表明选项-rpath-link = 。。。将被提供给链接器。

进行测试

到这里,我们就要进行本文中最令人兴奋的部分:测试! 以下代码将对一张图像进行FAST特征点检测:

创建你的程序,完成之后将“sd_card”文件夹中的内容复制到目标SD卡中,这里不要忘记在根目录下添加一个测试图像(有兴趣尝试的朋友,可以点击阅读原文,获取本教程所使用的图像源文件)。

boot操作完成后,使用以下命令在目标上运行可执行文件:

cd /mnt

。/00_ocv_helloworld.elf Buildings.jpg ocv.jpg

如果一切顺利的话,则可执行文件会生成一个输出图像“ocv.jpg”,如下所示:

我们将构建的库添加到SDSoC平台中使用的Linux根文件系统中。然后,我们基于这个新的SDSoC平台配置了一个新的项目,其中包含正确的包含路径和链接。

到这里,你就可以随意使用OpenCV啦!

猜您喜欢


贴片电阻精度并非越高越好。精度指的是电阻实际阻值与标称阻值之间的偏差范围。高精度电阻偏差小,但成本也更高。大多数电路应用中,±1%或±5%精度的电阻就足够了。例...
2024-11-29 10:25:59
现代科技日益发展的今天,配件的选择愈发重要。其中,Accessories_15.65X9.75MM_TM凭借其独特的规格和功能,成为了众多设备的理想选择。本文将...
2025-04-23 23:31:14
贴片电阻阻值以数字和字母组合标记,方便识别和使用。三位数字表示法是最常见的,例如「102」代表1010²=1000Ω,即1kΩ。前两位是有效数字,第三位是10的...
2024-11-26 11:30:04
贴片电阻的读数方法主要有三种:**色环法:**早期贴片电阻采用色环标识阻值,与传统的色环电阻类似,通过不同颜色的色环组合代表不同的阻值。从电阻一端开始,依次读取...
2025-04-14 15:03:57
本篇主要介绍Xilinx FPGA的电源设计,主要包括电源种类、电压要求、功耗需求,上下电时序要求,常见的电源实现方案等。1、电压种类及要求随着FPGA的发...
2019-02-17 11:03:00
FPGA 是什么FPGA(Field Programmable Gate Array),现场可编程门阵列,一种半定制的数字集成电路。FPGA 凭借其灵活性高、...
2024-01-24 13:46:00
电子电路中,二极管和稳压管是两种常见的元器件。虽然在某些功能上有相似之处,但作用、工作原理和应用场景却有很大的区别。本文将详细探讨TVD二极管和稳压管之间的不同...
2025-04-04 21:30:35
电流源能短路吗?怎么判断?电流源在理想情况下是不能短路的,但在实际应用中要避免短路。1. 理想电流源 vs. 实际电流源:理想电流源: 理论上,理想电流源内阻无...
2024-04-09 00:00:00
塞规是用于测量和检验工件尺寸的工具,应用于机械制造和质量控制中。主要参数包括塞规的尺寸、精度、材料和形状。塞规的尺寸通常根据标准规定,分为不同的规格,以适应不同...
2018-09-17 00:00:00
电阻器作为电子元件中最基础且重要的组成部分,应用于各种电路中。电子行业的快速发展,市场上涌现出了许多电阻器生产厂家。选择合适的电阻器生产厂家,不仅能保证产品质量...
2025-03-17 09:00:35