首页 > 技术 > 内容

关于利用FPGA做图像处理的相关知识盘点

时间:2025-12-07  作者:Diven  阅读:0

FPGA做图像处理最关键的一点优势就是:FPGA能进行实时流水线运算,能达到最高的实时性。因此在一些对实时性要求非常高的应用领域,做图像处理基本就只能用FPGA。例如在一些分选设备中图像处理基本上用的都是FPGA,因为在其中相机从看到物料图像到给出执行指令之间的延时大概只有几毫秒,这就要求图像处理必须很快且延时固定,只有FPGA进行的实时流水线运算才能满足这一要求。

所以要了解FPGA进行图像处理的优势就必须理解FPGA所能进行的实时流水线运算和DSP,GPU等进行的图像处理运算有何不同。DSP,GPU,CPU对图像的处理基本是以帧为单位的,从相机采集的图像数据会先存在内存中,然后GPU会读取内存中的图像数据进行处理。假如采集图像的帧率是30帧,那么DSP,GPU要是能在1/30秒内完成一帧图像的处理,那基本上就能算是实时处理。

FPGA对图像进行实时流水线运算是以行为单位的。FPGA可以直接和图像传感器芯片连接获得图像数据流,如果是RAW格式的则还可以进行差值以获得RGB图像数据。FPGA能进行实时流水线处理的关键是可以用其内部的Block RAM缓存若干行的图像数据。这个Block RAM可以说是类似于CPU里面的Cache,但Cache不是你能完全控制的,但Block Ram是完全可控的,可以用实现各种灵活的运算处理。这样FPGA通过缓存若干行图像数据就可以对图像进行实时处理,数据就这样一边流过就一边处理好了,不需要送入DDR缓存了之后再读出来处理。

这样的数据流处理显然是顺序读取数据的,那么也就只能实现那些顺序读取数据的算法,也就是图像处理中那一大类用3x3到NxN的算子进行的滤波、取边缘、膨胀腐蚀等算法。可能大家会觉得这些运算似乎都是最基本的图像处理运算,只是个前端的预处理,似乎用处不大。但问题是只有FPGA做这样的运算才是速度最快效率最高的,比如用CPU做一个取边缘的算法根本就达不到实时。另外别小看了这种NxN算子法,可以有各种组合和玩法,可以实现分选多种颜色,甚至分辨简单形状等功能。FPGA进行的这种算子法处理是并行流水线算法,其延时是固定的,比如用3x3的算子进行处理其给出结果的延时是两行图像的时间。还有这个算子法和现在卷积神经网络中最前面的卷积层运算是类似的。

FPGA中的Block Ram是重要和稀缺资源,能缓存的图像数据行数是有限的,所以这个NxN的算子中的N不能特别大。当然FPGA也可以接DDR把图像缓存到其中再读出来进行处理,但这种处理模式就和CPU差不多了,达不到最高的实时性。其实有些我们认为需要随机读取数据的图像处理算法也是可以并行流水线化的。

在密集运算中,耽误时间和消耗功耗的操作往往不是运算本身,而是把数据从内存中搬来搬去。GPU,CPU在进行运算时要把数据从内存中取出来,算好了在放回去。这样内存带宽往往成了运算速度的瓶颈,数据搬运过程中的功耗占的比重也不会小。FPGA则可以通过堆很多计算硬件的方法把要做的运算都展开,然后数据从中流过,完成一个阶段的运算之后就直接流入第二个阶段,不需要把一个计算阶段完成后的数据再送回内存中,再读出来交给下一个阶段的运算。这样就会节省很多时间和功耗。现在用FPGA做图像处理就是这样干的,比如先用一个3x3的算子进行滤波,再用一个3x3的算子进行取边缘,在FPGA流水线算法中,滤波处理完了数据立即就会进行取边缘处理,是不需要像CPU那样存回内存再读出来的。

FPGA进行图像处理的前景还是挺广阔的,越来越多的工业应用场合都要求更高的实时性,而这正是FPGA所适合的。还有机器学习领域,神经网络这种层状的,不需要很随机的读取数据的运算是比较适合用FPGA来做的。不过FPGA不擅长浮点运算,如果能整出不需要浮点运算的神经网络,那么FPGA在这方面的应用将会更大。

前些年用matlab和opencv做图像处理。近一段时间通过FPGA处理摄像头视频数据,有太多感触,复杂的算法先不提及,单是上面文章中提到的一些处理手段及策略,非常受用。

猜您喜欢


薄膜电阻作为电子元器件中的重要组成部分,受到了越来越多工程师和厂商的关注。Uniohnm(厚声)作为知名的薄膜电阻品牌,高品质的产品和稳定的性能在市场上占据一席...
2017-01-24 06:50:30
稳压二极管是专门用于电压稳压的电子元件,应用于电源电路、信号处理等领域。了解稳压二极管的型号对于选购和使用非常重要,能够帮助我们选择合适的产品以满足特定的电路需...
2025-04-02 22:00:34
贴片电阻作为基础且关键的元件,应用于各种电子设备中。正邦(JPCON)作为一家知名的贴片电阻品牌,稳定的性能和良好的品质赢得了众多客户的青睐。本文将围绕正邦(J...
2017-02-17 07:14:30
时钟消抖是电子电路设计中重要的一环,主要用于提高信号的稳定性和可靠性。根据不同的实现方式,时钟消抖可以分为几种主要分类。机械消抖是通过物理结构设计来减少信号抖动...
2013-08-11 00:00:00
合金贴片电阻作为电子元器件中的一种重要组成部分,应用于各种电子设备中,如手机、计算机、家电等。其优良的性能和稳定性使得合金贴片电阻在市场上备受青睐。科技的发展,...
2025-03-17 13:30:36
现代生活中,各种配件的使用已成为我们日常生活中不可少的一部分。无论是在家居、办公还是户外活动中,合适的配件都能显著提升我们的生活品质。本文将重点介绍“Acces...
2025-04-21 13:30:03
0201贴片电阻,以其仅为0.2mm x 0.1mm的微小尺寸,成为电子产品小型化和轻量化的关键元件。别看它身材迷你,却在电路中扮演着重要的角色,能够精确控制电...
2024-11-26 11:29:43
压接插针是重要的电子连接器件,应用于各种电子设备中。主要作用是实现电气连接,确保信号的稳定传输和电流的有效导通。通过压接插针,可以将电缆与电路板、模块或其组件牢...
2008-06-29 00:00:00
PTC热敏电阻作为重要的温度保护和调节元件,应用于家电、电子设备及汽车电子等领域。紫泰荆作为国内知名的PTC热敏电阻制造商,其产品在性能和质量上均有良好口碑。那...
2023-08-09 23:48:38
电子元器件中,电阻和排阻都是重要的组成部分,应用于电路设计和电子设备中。虽然的功能相似,但在结构、应用和特性上却存在很大的区别。本文将详细探讨排阻与电阻的区别,...
2025-03-17 13:30:03