# 珠海科技学院

# 毕业设计

## 基于 FPGA 的 JPEG 图像编解码系统设计

学 院: 电子信息工程学院

专 业 名 称: 微电子科学与工程

学 生 姓 名: 黄智为

学 号: 03210828

指导老师姓名、职称: 孙永坚 讲师

完成日期: 2025年2月14日

#### 摘 要

随着近几十年来多媒体技术、图像扫描技术、移动终端、通信技术的不断发展,数字图像和视频数据的广泛使用,图像数据的数量呈指数机增加。于此对图像数据的存储以及传输的需求日益严峻。一味地添加设备的存储容量和信道的带宽是不现实的,对此使用图像压缩技术来减少图像数据的数据量。而作为静态图像压缩国际标准格式的 JPEG(Joint Photographic Experts Group),因具有压缩率高、失真率小等特点。在国际上取得广泛的应用。

目前大多数的 JPGE 格式图像数据编解码系统都是基于软件编程从而运行在通用计算机上。这种方式存在计算效率低、实时性低、运行功耗高等诸多缺点。于此同时具有对硬件可编程、运行功耗低的 FPGA (Field Programmable Gate Array) 芯片的规模不断增加,在 FPGA 芯片内实现复杂的数字信号处理系统已成为现实。因此本设计将 JPEG 压缩技术和 FPGA 相结合提升系统的性能,并从实际工程出发,设计出一套 JPEG 编解码系统。完成 JPEG 编解码在 FPGA 上的实现。

本论文的结构首先阐述了 JPEG 格式的编解码 FPGA 实现的研究背景与意义国内外研究现状,并以此提出了一种新型的基于脉动阵列实现 DCT 算法的流水线结构。接着描述了 JPEG 格式编码和解码算法的实现步骤。然后采用 SOC 的设计思想,给出整个硬件系统的内部结构、层次划分,对每个运算步骤进行了详细的描述。最后完成整体的验证。

本设计基于 Xilinx 的 Zynq 系列的 FPGA 的硬件平台,对 CMOS 图像传感器 OV5640 采集的图像数据进行采集和压缩,再通过使用低速串行通信协议传输压缩数据。在 EDA 工具 vivado2019.1 中完成综合仿真、布局布线以及码流生成。

关键词: FPGA; 图像压缩; JPEG

#### **ABSTRACT**

this is adstract

keywords: FPGA,JPEG

## 目 录

| 1 ½ | 绪 论               | 1 |
|-----|-------------------|---|
|     | 1.1 研究背景及研究意义     | 1 |
|     | 1.1.1 选题背景        | 1 |
|     | 1.1.2 研究意义        | 1 |
|     | 1.2 国内外研究现状       | 1 |
|     | 1.3 使用芯片简介        | 2 |
|     | 1.4 开发环境          | 2 |
|     | 1.4.1 Vivado 简介   | 2 |
| 2 J | IPEG 图像压缩相关理论     | 3 |
|     | 2.1 彩色空间变换及逆变换    | 3 |
|     | 2.2 离散余弦变换及逆变换    | 4 |
|     | 2.3 量化及反量化        | 4 |
|     | 2.4 ZigZag 扫描及反扫描 | 4 |
|     | 2.5 熵编码及熵解码       | 4 |
|     | 2.5.1 DC 系数差分脉冲编码 | 4 |
|     | 2.5.2 AC 系数游程编码   | 4 |
|     | 2.5.3 霍夫曼编码       | 4 |
|     | 2.6 JPEG 文件格式     | 4 |
|     | 2.7 本章总结          | 4 |
| 3 J | IPEG 编码系统硬件结构设计   | 5 |
|     | 3.1 设计思想          | 5 |
|     | 3.1.1 流水线         | 5 |
|     | 3.1.2 脉动阵列        | 5 |
|     | 3.1.3 乒乓操作        | 5 |
|     | 3.2 编码模块划分        | 5 |
|     | 3.3 DCT 模块        | 5 |
|     | 3.4 DA 算法         | 5 |

|   | 3.5 DA 算法的硬件实现         | 5 |
|---|------------------------|---|
|   | 3.6 数据预处理模块            | 5 |
|   | 3.7 熵编码模块              | 5 |
|   | 3.8 JPEG 文件格式生成模块      | 5 |
| 4 | JPEG 编解码系统 FPGA 实现以及验证 | 6 |
|   | 4.1 验证系统模块划分           | 6 |

#### 1 绪 论

#### 1.1 研究背景及研究意义

#### 1.1.1 选题背景

图像数据作为信息的重要载体,在如今这个信息化的社会扮演着不可欠缺的角色相对与 文本,图像具有强大的表达能力,通过像素、色彩及形状结构等元素传递出大量的信息。随 着高清图像和视频的普及,图像数据的数量呈指数级增长。对高存储空间传输带宽的需求日 益严峻。一味地添加设备的存储容量和信道的带宽是不现实的,因此图像压缩技术孕育而生。

目前图像压缩格式应用最广的是 JPGE 压缩格式。它运用图像数据在空间上的冗余性以及人眼对图像的辨别度有限等特性来减少图像的数据量。目前 JPEG 图像大多数使用软件进行编解码。但对于医疗器械、自动驾驶、视频监控等对视频画面逐帧处理要求高的场景,这种方式有着效率低、运行功耗高等诸多缺点。

#### 1.1.2 研究意义

本设计采用 FPGA 高并行计算能力和低功耗的特性设计出一套高效运行的 JPGE 格式编解码系统。该系统能保证图像数据高实时传输地同时保持较低的功耗,适合运它运用在嵌入式系统或边缘计算设备。通过对算法进行硬件级优化,FPGA 能够对 JPGE 压缩的各个环节进行流水线和并行处理。相对于传统的软件开发方式极大地提升了系统的吞吐量和响应速度,同时保持较低的运行功耗。此外这种编解码系统作为软核结合 FPGA 使用使用具有较强的可扩展性,可与大多数视频图像处理系统相结合,助力更多地创新应用开发。

#### 1.2 国内外研究现状

随着近几十年来信息技术地不断发展,图像和视频数据被广泛运用。因此如何降低数据的存储大小和传输系统的负担一直是研究的问题。现如今图像数据压缩编码主要分为两种,一种是针对静止图像在空间在空间的纬度上进行压缩编码的压缩方式,如 JPEG、JPEG-2000、JPEG-LS。另一种是针对多个数据帧在时间纬度上进行压缩的方式如 H.264、H.256等。其中 JPEG(Joint Photographic Exprts Group,联合专家组)标准有 ISO 在 1991 年提出,之后有相继提出了 JPEG-L、JPEG-MOTION、JPEG2000 三个图像标准,JPEG-LS 是一种接近无损压缩的压缩格式,其工作简单高效,但是输出的编码率随原图像的改变存在较大的波动。PEG-MONTION 是基于 JPEG 发展起来的,可用于动态图像的压缩,但是压缩率比较低。JPEG2000是用小波变换代替 JPEG 的离散余弦变换(DCT),在低比特率下,有更良好的图像压缩性能,但是算法的复杂度高,因此在一下追求低负责度的实时应用中,JPEG2000 无法替代 JPEG,在大多数的场合之下,使用 JPEG 就能满足需要了。

国内在 JPEG 的研究和应用方向上主要都是通过软件编程运行在 CPU 实现的。在应用方面,为了解决胶囊内窥镜有效空间和电池容量以及传输实时性要求高的场景,上海交通大学的赵恒阳、刘华使用 fpga 芯片对图像进行 JPEG 格式的编码,以 2Mbps 的数据速率进行传输,可以达到 30fps 的视频刷新率。在算法改进方面杜英杰针对传统 JPEG 使用固定量表,在压缩图像的视觉质量和压缩率的制衡不能灵活调节的问题。提出了一种基于感知量化和统计量化的自适应量化算法,可以根据在不同频率信息中应用不同量化步长的方法,实现更高的压缩比和更优的图像压缩效果,并使用 FPGA 进行硬件实现。

国外在 JPEN 格式编解码 FPGA 实现的研究现状有: 里斯本高级工程学院的学者利用 FPGA 独有的硬件结构可编程的特点,使用了 FPGA 动态局部可重构技术,根据编码的流程对 FPGA 硬件逻辑资源进行分时复用,实现硬件资源利用最大化。采用该方案相对使用传统的静态解决方案在资源占用上节省了 60%,但代价是是运行速度上慢了 9 倍。Shan 等人通过行列分解的方式实现 2D-DCT(二维离散余弦变换),并在设计中引入乒乓缓存器。在运行在 100MHZ 的时钟信号下,针对 1920\*1080 的图像,最快解码率可达到 30fps 的视频刷新率。Teja 等人针对 2D-IDCT(二维离散余弦逆变换)设计了一种全流水的硬件结构,同时不使用乘法器,降低了 2D-IDCT 模块的资源利用。

#### 1.3 使用芯片简介

本设计使用的芯片型号是 Xilinx 公司 Zynq-7000 系列的 XC7Z020-CLG484。Zynq-7000 系列是 Xilinx 公司推出的全可编程片上系统(All Programmable SOC), 其中包含了 PS (Processing System,处理器系统)和 PL (Programmable Logic,可编程逻辑)两部分。

Zynq SoC 整合了 ARM 双核 cortex-A9 处理器和 FPGA 架构,实际上是一个片上系统 (System on Chip, SoC),因此使得它不仅具有 FPGA 在能耗、性能、硬件可编程的优点,同时具有处理器软件可编程的优点,以提供强大的系统性能、灵活性与可扩展性。该芯片的可编程逻辑部分基于 Xilinx 28nm 工艺的 7 系列 FPGA。

#### 1.4 开发环境

本设计使用的开发环境是 EDA 工具 Vivado2019.2。

#### 1.4.1 Vivado 简介

Vivado 是 Xilinx 公司开发的集成开发环境,用于数字设计、验证和实现 FPGA 和 SoC 解决方案。Vivado 提供了一个全面的工具集,帮助设计者从硬件设计到软件开发的整个流程,包括:设计与综合、FPGA 的布局布线、仿真和验证、码流生成、ILA(Integrated Logic Anglzer)在线调试、PS 端的软件开发、IP 核集成。Vivado 旨在提示 FPGA 设计的效率,特别是在复杂的系统级集成和高性能应用中。它广泛运用在通信、自动化、医疗、汽车、芯片设计等领域。

#### 2 JPEG 图像压缩相关理论

要对一张静态图像数据进行 JPEG 编解码从而做到压缩和解压,需要经历多个过程。如图 2-1 所示。



图 2-1 JPEG 的编码和解码流程

JPEG 格式的图像压缩流程为: 首先将图像每个像素点的 R、G、B 颜色分量通过色彩空间变换转换成色度分量 Cr、Cb 以及亮度分量 Y。之后将图片划分为若干个 8\*8 的数据单元每个单元包含 64 个像素点,再对每个数据单元进行二维离散余弦变换(DCT),将二维的空间域数据变成二维的频域数据。再根据量化表对对应的频域分量进行量化处理。再通过 Zig-Zag 扫描将二维的频域数据转换成一维的序列。最后,依次通过游程编码和霍夫曼编码将冗余的数据压缩 JPEG 图像数据。

解压缩流程的流程与压缩的各个流程相反,除了量化和彩色空间变换这一过程会丢失一定的信息之外,其他的步骤都可以无损还原原数据,因此 JPEG 是一种有损压缩技术。

下面依次对各个步骤做详细的描述。

#### 2.1 彩色空间变换及逆变换

绝大多数的颜色都可以使用 R、G、B 三种颜色分量的线性组合进行合成。因此大多图像数据每个像素点都是以 RGB 分量表示。特别是再计算机视频技术中,不管使用哪种形式的彩色空间表示,最后一定要转换为 RGB 彩色空间显示。

相关研究表明,人类的视觉系统有分别对红绿蓝三种颜色敏感层度的三种锥体细胞以及对明暗程度敏感的锥体细胞。其中对明暗程度的锥体细胞的数量大于对颜色敏感层度锥体细胞的数量。因此人类对是对色度辨识度大概是对明暗变换的辨识度的四分之一,因此可以利用对颜色感知强度的不同,将 RGB 彩色空间变换到 YCrCb 彩色空间再根据感知能力做对应的处理。

ITU-R601 建议规定的 RGB 彩色空间到 YCbCr 彩色空间变换关系如下式:

$$\begin{bmatrix} Y \\ Cr \\ Cb \end{bmatrix} = \begin{bmatrix} 0.299 & 0.587 & 0.144 \\ 0.500 & -0.419 & -0.081 \\ -0.169 & -0.331 & 0.500 \end{bmatrix} \begin{bmatrix} R \\ G \\ B \end{bmatrix} + \begin{bmatrix} 0 \\ 128 \\ 128 \end{bmatrix}$$
(1)

- 2.2 离散余弦变换及逆变换
- 2.3 量化及反量化
- 2.4 ZigZag 扫描及反扫描
- 2.5 熵编码及熵解码
- 2.5.1 DC 系数差分脉冲编码
- 2.5.2 AC 系数游程编码
- 2.5.3 霍夫曼编码
- 2.6 JPEG 文件格式
- 2.7 本章总结

### 3 JPEG 编码系统硬件结构设计

- 3.1 设计思想
- 3.1.1 流水线
- 3.1.2 脉动阵列
- 3.1.3 乒乓操作
- 3.2 编码模块划分
- 3.3 DCT 模块
- 3.4 DA 算法
- 3.5 DA 算法的硬件实现
- 3.6 数据预处理模块
- 3.7 熵编码模块
- 3.8 JPEG 文件格式生成模块

### 4 JPEG 编解码系统 FPGA 实现以及验证

4.1 验证系统模块划分