当前位置:首页 > 嵌入式 > 嵌入式硬件

  

 视频监控和安全行业正在经历着一场巨大的变革,正在从传统的模拟闭路电视摄像机向基于逻辑的数字摄像机的方向发展。更高的视频分辨率、图像信号处理、先进的视频分析、多摄像系统和数字视频压缩的发展趋势推动了这一转变。其结果是,在视频监控摄像机和数字视频录像机(DVR)设计中出现了新的挑战,包括增加使用CMOS传感器、网络IP摄像技术、增加系统的集成功能、更小尺寸的外形因子、采用先进的编解码器以及增加DSP功能。   由于视频监控/安全市场的多样性和竞争性,制造商往往很难在他们自己的产品中添加差异化的功能,使其产品有别于竞争对手的产品。因此,相似的摄像机和DVR产品非常普遍。然而,上面提到的趋势为视频安全/监控原始产品制造商创造了新的机会,可以实现产品的差异化。

  满足这些应用的要求需要额外的处理能力。目前的数码摄像机利用DSP芯片、专门的ASSP或ASIC来提供处理功能,但这些方案存在一些挑战。采用DSP芯片经常会出现性能瓶颈,因为这些芯片通常用串行方式处理图像信号处理任务。ASSP可能提供更多的性能,但往往是以设计的灵活性为代价。ASIC有更多的性能优化,但产量不够大,无法验证ASIC开发所需的费用和时间。设计人员需要一种灵活的方法,针对不同的细分市场提供从低端摄像机/DVR到高端应用所需的计算能力。

  实现方案的选择

  视频监控系统可分为两大类:摄像系统和DVR系统。摄像系统可整合单个摄像机或多个摄像机。有些系统则整合了DVR与单个摄像机或多个摄像机。

图1:多摄像机的DVR视频监控系统框图。

  图 1是一种通用的多摄像机的DVR视频监控系统。视频源来自CMOS视频传感器、CCD视频传感器或模拟视频源。专有的视频接口将输入视频流转换成普通的格式,然后对不同的视频流(以及音频)进行多路复用,在图像信号处理单元进行预处理。视频预处理的目的是降低噪声和消除像素缺陷。

  视频分析技术应用于检测在预定义画面中的运动。这个运动检测输出可减少所需的存储容量。在一些视频监控应用中,视频分析是必需的,如人/车统计、汽车的车牌号码识别和/或人脸识别。

  一个典型的具有多个摄像机视频源的视频监控系统总是会生成大量的数据,因此减少所需的存储容量非常重要。MPEG-4、H.264、和MJPEG被用来减少所需的存储容量。H.264是一种针对视频监控应用的流行压缩算法,因为它能以相当低的比特率(只有MPEG-2或MPEG-4第2部分一半或更低的比特率 )提供良好的视频质量的功能。

  经过压缩后的数据通过硬盘驱动器接口存储至视频存储服务器,或通过以太网网络发送。视频数据传送到显示器之前通常是取自硬盘驱动器,并经过了解码以及一些图像后处理,如缩放、色彩空间转换或覆盖应用。通常情况下,存储器接口(如DDR2)是用来存储视频帧。此外,某些系统要求视频内容的实时加密以确保安全和源/用户身份验证。最后,需要用处理器控制和协调/排定各种不同的任务。

图2:根据吞吐量、灵活性、批量和形状因子要求进行选择的步骤。

  图 2说明了系统的要求,如吞吐量、灵活性、预计批量和形状因子是如何推动不同的实现技术和器件的。对于低数据吞吐量的要求,DSP处理器是最节省成本的器件。然而,产品寿命期间的预计批量以及硬件的灵活性会大大响设计者在ASIC/ASSP和FPGA器件之间作出选择。如果是硬件灵活性低的系统要求和预计有大的批量,设计者则青睐于ASIC/ASSP解决方案;而对于硬件灵活性高的系统要求和较小的预期批量,设计者青睐FPGA解决方案。常见的小型视频监控摄像机有小尺寸的要求,设计者青睐采用非易失性FPGA ,因为它们不需要额外的外部非易失性配置存储器件。

  系统集成组合了不同器件的优势:DSP处理器有时集成了ASSP IP模块,ASSP/ASIC有时集成了处理器,FPGA有时集成了硬处理器和硬IP核。

  对于视频监控系统(图1),由于这些任务的时序性质,用DSP处理器可以有效实施视频分析功能和处理器块。然而在有些情况下,FPGA的加速功能有助于进行一些视频分析功能,如运动检测、面部识别等。

  如图1所示的H.264编码器是一个要求高吞吐量、硬件灵活性低、大且复杂的功能块,通常是用ASSP或ASIC来实现,以获得小尺寸的解决方案。

  但是ASIC和ASSP带来了高昂的非重复性工程费用成本,除非批量非常大。如果只有一小部分用户使用特殊的功能模块,那么FPGA解决方案可提供更好的回报。对于ASIC和ASSP,这些器件有限的功能和固有的不灵活性,不允许在设计完成后根据市场的要求改进或添加新的功能。FPGA却能提供广泛的功能和高度的灵活性。

  具有下列要求的视频监控系统模块将受益于FPGA的灵活性:(1)这视频和音频接口以及多路复用器需要硬件的灵活性,以支持不同的摄像机和不同数目的摄像机。(2)DDR接口必须支持不同的存储器总线宽度和不同的DDR标准。(3)支持各种图像信号处理算法 (二维FIR滤波器、二维中值滤波器、缩放、边缘检测、伽玛校正、alpha混合、白平衡、镜头阴影校正、缺陷像素校正、去马赛克、逐行扫描,彩色空间校正等),在一个特定的视频监控摄像机实施方案中可能需要各种算法的子集。这些算法结构的有效实现取决于吞吐量的要求,而吞吐量的要求又取决于系统中摄像机的数量和视频标准采样率。(4)在视频监控摄像系统中并非总是需要硬盘驱动器接口和以太网接口,但可作为选择方案。(5)并非总是需要显示器接口,当需要它时,有很多不同的可以实现的显示器接口可供选择。(6)只在某些系统中需要加密和认证。根据不同视频格式的不同的吞吐量要求,以及在一个特定的监控系统中不同的摄像机数量,最佳加密和认证系统可能需要不同的尺寸最优的实现架构。


  许多网络IP摄像机受到了非常紧凑的外形、功耗和成本的制约,特别是嵌入式摄像机/DVR系统。采用非易失FPGA作为一种解决方案能解决这些问题,并获得FPGA的传统优势。

  利用FPGA实现产品差异化

  采用FPGA实现视频监控系统具有许多优点,包括FPGA加速DSP处理的功能。非易失性FPGA可以使FPGA在视频监控摄像系统实现中更具吸引力,特别是对移动/交通运输系统中使用的嵌入式摄像机/DVR系统来说。这些系统对便携性、功耗和电路板面积有严格的要求。

  这些应用对灵活性和可扩展性也有很高的要求,但前提是不能降低对功耗、电路板面积和便携性的要求。例如,一些网络IP摄像系统有多个摄像机和传感器,即使电路板面积非常有限,也必须提供多个视频流的通道。其它网络IP摄像机往往采用非常小的外壳,电路板接近MicroSD卡的大小,这种系统的原始设备制造商所面临的挑战是用尽可能少的芯片实现多个系统,同时还能满足功能、外形和低功耗的要求。

  非易失性FPGA解决方案,如 LatticeXP2器件系列把基于SRAM FPGA的性能和灵活性,与非易失Flash技术固有的优点结合在一起。LatticeXP2系列在安全和监控应用方面有许多特点,包括该芯片支持 DDR/DDR2、针对低成本显示器的7:1 LVDS接口以及18×18位乘法的DSP模块,这些对在视频监控应用中经常需要的图像信号处理功能特别有用。当LatticeXP2-5和 LatticeXP2-8器件与低成本芯片级封装在一起时, LatticeXP2非易失FPGA器件系列为原始设备制造商提供很多价值,特别当设计紧凑的网络IP摄像机时。

图3:LatticeXP2非易失器件系列具有低成本的封装。

  本文小结

  对于大量的各种视频监控摄像机和DVR的应用,FPGA所具有硬件灵活性、并行处理能力以及零非重复性工程费优势。采用非易失FPGA不再需要外部引导芯片 PROM,可以构建一个提供瞬时启动功能的单芯片解决方案。带有片上密钥存储并支持内置的AES 128位加密技术的特性为保护FPGA编程位流、防止外部篡改提供了安全保障。许多安全摄像系统解决方案,包括嵌入式摄像机/DVR系统,都能从传统的基于SRAM的FPGA中受益,但当功耗、电路板面积、成本和集成度特性非常重要时,非易失FPGA是一个更具吸引力的替代方案。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在嵌入式系统开发、调试和测试过程中,J-Link作为一种高效的调试工具,为开发者提供了极大的便利。然而,要想充分发挥J-Link的功能,首先需要正确安装其驱动程序。本文将详细介绍J-Link驱动的安装过程,并深入解析其中...

关键字: jlink 嵌入式系统 嵌入式开发

与谷歌的合作使 Nordic 能够在 nRF Connect SDK 中嵌入开发人员软件,以构建与安卓移动设备兼容的谷歌Find My Device和未知跟踪器警报服务

关键字: 谷歌 SoC 嵌入式开发

嵌入式开发作为当今电子工程和信息技术领域的核心分支,涵盖了广泛的软硬件技术和系统集成方法,用于构建高性能、低成本、低功耗、体积小巧且功能专一的嵌入式系统。这些系统无处不在,从微型传感器节点到复杂的工业控制设备,从日常使用...

关键字: 嵌入式开发 Python

嵌入式开发是当今信息技术领域不可或缺的一部分,它融合了硬件设计、软件开发和系统集成等多个学科,专门用于创建那些被嵌入到特定设备或系统中的专用计算机系统。嵌入式开发的主要过程包括利用分立元件或集成器件进行电路设计、结构设计...

关键字: 嵌入式开发 硬件设计 软件开发

嵌入式开发作为一种专业且技术密集型的领域,涵盖了从硬件底层驱动、中间件到应用层软件开发等多个层面的工作,其所需的工具种类繁多,各有针对性,旨在提升开发效率、保证代码质量以及简化调试过程。

关键字: 嵌入式开发 keil

嵌入式开发作为信息技术领域的重要分支,其涉及的语言种类繁多,各具特色。这些语言的选择取决于目标平台的特性、性能需求、开发者的熟练程度以及项目的具体要求。本文将详细介绍几种常见的嵌入式开发语言,包括C语言、C++、汇编语言...

关键字: 嵌入式开发 C语言

嵌入式开发是一项综合了硬件设计、软件编程以及系统整合的技术活动,其目的是为了创造出能够在特定环境中高效、稳定运行的嵌入式系统。这一流程涵盖了多个紧密关联且不可或缺的阶段,从最初的客户需求分析到最终的产品测试和交付,每个环...

关键字: 嵌入式开发 硬件设计

嵌入式开发作为一个融合了计算机软硬件和系统工程的综合性领域,其成功与否往往取决于三个核心要素的有效整合与协调。这三个要素分别是:硬件平台的选择与设计、软件开发及其优化、以及系统级的设计与集成。深入理解并熟练掌握这三个方面...

关键字: 嵌入式开发 ARM

嵌入式开发作为信息技术的关键支柱,在全球数字化转型浪潮中扮演着无可替代的角色。从传统的嵌入式微控制器到如今先进的片上系统(SoC),再到与云计算、人工智能深度融合的智能终端,嵌入式系统的演进与发展始终紧跟时代脉搏。本文将...

关键字: 嵌入式开发 智能应用

嵌入式开发是一种专门针对特定硬件平台设计和实现软件系统的工程实践,它涵盖了从需求分析、系统设计、编程实现、调试测试直到产品部署及维护的全过程。本文将深入探讨嵌入式开发的主要阶段,分解其流程并阐述每个步骤的关键要点,以便于...

关键字: 嵌入式开发 嵌入式软件
关闭
关闭