0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

详解基于FPGA的图像旋转系统的运用

电子工程师 ? 来源:CSDN技术社区 ? 作者:weixin_39940788 ? 2021-04-15 14:23 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

一、图像旋转原理

图像旋转是指图像按照某个位置转动一定角度的过程,旋转中图像仍保持这原始尺寸。图像旋转后图像的水平对称轴、垂直对称轴及中心坐标原点都可能会发生变换,因此需要对图像旋转中的坐标进行相应转换。

如图,原图像经过顺时针旋转角度为 θ 后,源图像的坐标为 P0 ( Xo, Yo ) 的点移动到了 P1(X1, Y1)。

70096670-9dac-11eb-8b86-12bb97331649.png

经过推导,可以得到上述的 P0 和P1 的坐标变换关系式。

二、MATLAB仿真

方案一、【正向预设】从原图映射到目标图像在此方案中,实现代码的方式是正向的思路,将原图中的像素点的坐标进行坐标的旋转,然后直接幅值到输出的图像中,此方案旨在找到输入坐标与输出坐标之间的代数对应关系。

在该方法中,首先将原始坐标以及目标坐标放入了极坐标中,并且通过在极坐标中的关系,找到了同时满足X0,Y0,X1,Y1四个参量的方程组,以此来解出对应的坐标关系,并以此为基础得到了输入与输出之间的矩阵运算关系如下:

701757ee-9dac-11eb-8b86-12bb97331649.png

Matlab代码实现如下:

clear allclc

% 读入图片im = imread(‘1.jpg’);figure;imshow(im);

% 求出旋转矩阵a = 40 / 180 * pi;R = [cos(a), -sin(a); sin(a), cos(a)];

% 求出图片大小 ch为通道数 h为高度 w为宽度sz = size(im);h = sz(1);w = sz(2);ch = sz(3);c = [h; w] / 2;

% 初始化结果图像im2 = uint8(zeros(h, w, 3));

for k = 1:ch for i = 1:h for j = 1:w p = [i; j]; % round为四舍五入 pp = round(R*(p-c)+c); if (pp(1) 》= 1 && pp(1) 《= h && pp(2) 》= 1 && pp(2) 《= w) im2(pp(1), pp(2), k) = im(i, j, k); end end endend

% 显示图像figure;imshow(im2);

但在实际的测试中发现,这种方法所旋转得到的图像有着较为严重的失真现象,具体情况如下图所示:

原图

旋转后的图像

很明显可以看到,在旋转之后这两张图片出现了较大的差别,首先是原图像被裁减了,其次是目标图像中有较多的瑕点(杂点)。究其原因在于,从原图旋转后得到的目标图像的像素位置在原图中找不到。另外就是边缘被裁剪的问题,由于在这个方案中约束了显示区域,因此在旋转的过程中,部分像素点就会由于超出边界而被裁剪。针对以上的两个问题,进行了如下改进。

方案二、【逆向预设】从目标图像映射到原图

由于在之前的方案中出现了杂点以及图像边缘裁剪的问题,因此在本方案中,我们采用了逆向思维,用目标图像的坐标去与原图的坐标进行坐标匹配,若在原图像中能找到匹配的图像,就显示该点旋转后的点坐标,若在原图中找不到该点,则不显示该点,通过这样就解决了杂点的问题。 其中,pp为旋转在后的坐标对应矩阵,在if语句中限定了原图的区域,用此区域则可以到原图中的坐标点,以此来排除不在区域中的坐标点,这样就可以解决杂点的问题。

在这种方案下,坐标的对应关系如下:

70cce06e-9dac-11eb-8b86-12bb97331649.png

MATLAB仿真代码如下:

clear allclc

% 读入图片im = imread(‘1.jpg’);figure;imshow(im);

% 求出旋转矩阵a = 20 / 180 * pi;R = [cos(a), sin(a); -sin(a), cos(a)];

% 求出图片大小 ch为通道数 h为高度 w为宽度

sz = size(im);h = sz(1);w = sz(2);ch = sz(3);c = [w;h] /2;

% 初始化结果图像im2 = uint8(zeros(h, w, 3));for k = 1:ch %遍历输出图像所有位置的像素 for i = 1:h for j = 1:w p = [j; i]; % p :输出图像的像素坐标 % round为四舍五入 pp = round(R*(p-c)+c); %pp :对应到输入图像的像素坐标 %逆向进行像素的查找 if (pp(1) 》= 1 && pp(1) 《= w && pp(2) 》= 1 && pp(2) 《= h) im2(i, j, k) = im(pp(2), pp(1), k); end end endend

% 显示图像figure;imshow(im2);

这样,该旋转后的图像就有了较好的还原度,达到了相应的题目要求,具体的方案的效果如下图所示:

原图

旋转后的图像

如图所示,相对方案一而言,图像的效果就好了很多,但图像边缘仍然存在边缘被切割的现象。 方案三:考虑到未对旋转后的图像进行显示区域的划分,因此此类旋转只是对单一像素点的旋转,然后在原图像的显示区域上进行坐标点的重新组合,得到显示的图像。在解决的方法的思路上,采用目标显示区域的重新划分来解决该问题。

具体思路是,采用原图像的长宽作为基准,再用坐标转换的关系,将长和宽转换到旋转后的坐标系中,得到目标图像在旋转后坐标系中的显示区域,代码具体如下:

% 读入图片im = imread(‘1.jpg’);

figure;imshow(im);

% 求出旋转矩阵a = 30 / 180 * pi;R = [cos(a), -sin(a); sin(a), cos(a)];R = R‘; % 求出旋转矩阵的逆矩阵进行逆向查找

% 计算原图大小sz = size(im);h = sz(1);w = sz(2);ch = sz(3);c1 = [h; w] / 2;

% 计算显示完整图像需要的画布大小hh = floor(w*sin(a)+h*cos(a))+1;ww = floor(w*cos(a)+h*sin(a))+1;c2 = [hh; ww] / 2;

% 初始化目标画布im2 = uint8(ones(hh, ww, 3)*128);for k = 1:ch for i = 1:hh for j = 1:ww p = [i; j]; pp = (R*(p-c2)+c1); mn = floor(pp); ab = pp - mn; a = ab(1); b = ab(2); m = mn(1); n = mn(2); % 线性插值方法 if (pp(1) 》= 2 && pp(1) 《= h-1 && pp(2) 》= 2 && pp(2) 《= w-1) im2(i, j, k) = (1-a)*(1-b)*im(m, n, k) + a*(1-b)*im(m+1, n, k)。.. + (1-a)*b*im(m, n, k) + a*b*im(m, n, k); end end endend

% 显示图像figure;imshow(im2);

这样,就解决了图像边缘被裁剪的问题,是整个图像得以完整的显示,实际的效果如下:

原图

旋转后的图像

从图示的效果可以看出,边缘区域被裁剪的问题被解决了,但问题是图片加阴影的区域面积比原图大很多。 综合以上三种方案,结合实际需求,由于我们的显示是在一块固定大小的屏幕上进行显示,整个图像的显示范围有限,采用CORDIC算法进行坐标变换产生的延时太大。最终基于处理速度和资源占用的均衡考虑,最终选择方案二作为我们图像旋转的设计方案。

三、旋转坐标计算

在该设计中,要求图像拥有0到360的任意角度的旋转,坐标变换需要角度的正弦和余弦值。 利用matlab生成正余弦表,并将其扩大256倍,打印到文件中。利用得到的正余弦表数值,将其写入verilog代码中,生成正余弦查找表。通过输入角度值来索引其正余弦数值。Matlab生成正余弦列表的代码如下:

71bcdbc8-9dac-11eb-8b86-12bb97331649.png

该正弦,余弦通过MATLAB计算得到,并预先储存到FPGA的片上储存空间中,在进行坐标变换时,读取对应角度的正弦,余弦值,进行坐标变换。由于计算得到的正弦和余弦值为浮点数,而FPGA擅长于进行整数运算。故要进行浮点数到整数的转换,具体的实现方法是,将计算得到的浮点正弦,余弦值乘上 256 后再取整,计算得到的结果于原结果相比被扩大了256倍,而在数字电路中,除法操作可以用移位来进行。结果右移8位即等效于除于256 。 坐标变换的核心代码如下:

7265e100-9dac-11eb-8b86-12bb97331649.png

将坐标变换计算模块封装为一个子模块,输入输出图像的坐标和旋转角度后,即可计算出对应的输入图像对应的像素的坐标。然后读取该坐标的像素值,写入到旋转重建的图像对应的坐标位置即可。

四、效果展示(Results show)

0、原图 (正常显示)

1、顺时针旋转22度

2、顺时针旋转90度

3、顺时针旋转270度

4、顺时针旋转341度

五、说明

在公众号对话框回复 FPGA2019 ,即可获得该项目的工程源代码,详细的文档说明,MATLAB仿真代码。
编辑:lyn

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1646

    文章

    22098

    浏览量

    620807
  • MATLAB仿真
    +关注

    关注

    4

    文章

    176

    浏览量

    20454
  • 图像旋转
    +关注

    关注

    0

    文章

    3

    浏览量

    2249

原文标题:基于FPGA的图像旋转系统设计

文章出处:【微信号:HXSLH1010101010,微信公众号:FPGA技术江湖】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    FPGA 加持,友思特图像采集卡高速预处理助力视觉系统运行提速增效

    图像预处理是图像处理关键环节,可优化数据传输、减轻主机负担,其算法可在FPGA等硬件上执行。友思特FPGA图像采集卡凭借
    的头像 发表于 08-13 17:41 ?190次阅读
    <b class='flag-5'>FPGA</b> 加持,友思特<b class='flag-5'>图像</b>采集卡高速预处理助力视觉<b class='flag-5'>系统</b>运行提速增效

    基于FPGA的数字识别系统设计

    图像处理领域,图像识别是较为困难而关键的技术。这项技术被广泛的应用到娱乐、工业、军事等领域。本次设计数字识别系统已经在车牌识别、运动员号码识别等多处运用。本
    的头像 发表于 07-16 14:28 ?662次阅读
    基于<b class='flag-5'>FPGA</b>的数字识别<b class='flag-5'>系统</b>设计

    【国产FPGA入学必备】国产FPGA权威设计指南+配套FPGA图像视频教程

    》。 本书系统地介绍紫光同创FPGA的开发与应用,详细阐述FPGA开发的各个方面,从基础原理到实际应用,从设计流程到开发工具的使用,力求为读者提供一套完整的学习和参考体系。通过阅读本书,读者不仅可以掌握紫光
    发表于 02-20 15:08

    导电滑环的原理与应用

    导电滑环是一种关键的电力传输设备,广泛应用于各种旋转系统中。本文将深入分析导电滑环的原理、结构和应用,介绍其在电力传输中的重要性和优势。
    的头像 发表于 02-10 16:10 ?896次阅读

    基于FPGA图像边缘检测设计

    今天给大侠带来基于 FPGA图像边缘检测设计,话不多说,上货。 设计流程如下:mif文件的制作→?调用 ip 核生成rom以及仿真注意问题→?灰度处理→?均值滤波:重点是3*3 像素阵列的生成
    的头像 发表于 02-10 11:30 ?767次阅读
    基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>图像</b>边缘检测设计

    FPGA图像处理基础----实现缓存卷积窗口

    像素行与像素窗口 一幅图像是由一个个像素点构成的,对于一幅480*272大小的图片来说,其宽度是480,高度是272。在使用FPGA进行图像处理时,最关键的就是使用FPGA内部的存储资
    的头像 发表于 02-07 10:43 ?972次阅读
    <b class='flag-5'>FPGA</b><b class='flag-5'>图像</b>处理基础----实现缓存卷积窗口

    基于FPGA的GigE Vision相机图像采集方案设计

    1 概述 GigE Vision是一个比较复杂的协议,要在FPGA中完全实现具有较大的难度。如果FPGA作为接收端希望实现GigE Vision相机的配置和图像采集功能,则只需要实现其中小部分功能
    的头像 发表于 01-07 09:34 ?1188次阅读
    基于<b class='flag-5'>FPGA</b>的GigE Vision相机<b class='flag-5'>图像</b>采集方案设计

    基于FPGA实现图像直方图设计

    简单,单采用FPGA来实现直方图的统计就稍显麻烦。若使用Xilinx和Altera的FPGA芯片,可以使用HLS来进行图像的加速处理。但这暂时不是我的重点。 用C语言实现直方图统计:unsigned
    的头像 发表于 12-24 10:24 ?885次阅读
    基于<b class='flag-5'>FPGA</b>实现<b class='flag-5'>图像</b>直方图设计

    FPGA 实时信号处理应用 FPGA图像处理中的优势

    现场可编程门阵列(FPGA)是一种高度灵活的硬件平台,它允许开发者根据特定应用需求定制硬件逻辑。在实时信号处理和图像处理领域,FPGA因其独特的优势而受到青睐。 1. 并行处理能力 FPGA
    的头像 发表于 12-02 10:01 ?1970次阅读

    百问FB显示开发图像处理 - 图像调整

    free(pdwSrcXTable); 57. return 0; 58.} 2.4.2 图像旋转 2.4.2.1 图像旋转算法浅析 这里的
    发表于 12-02 09:34

    详解FPGA的基本结构

    ZYNQ PL 部分等价于 Xilinx 7 系列 FPGA,因此我们将首先介绍 FPGA 的架构。简化的 FPGA 基本结构由 6 部分组成,分别为可编程输入/输出单元、基本可编程逻辑单元、嵌入式块RAM、丰富的布线资源、底层
    的头像 发表于 10-25 16:50 ?3570次阅读
    <b class='flag-5'>详解</b><b class='flag-5'>FPGA</b>的基本结构

    旋转花键材质及运用场景

    旋转花键的材质有很多种,其材质选择是一个涉及多方面因素的重要决策,?主要取决于应用场景的具体要求,包括设备的运行环境、负载大小、运行速度以及所需的耐磨性和耐腐蚀性等因素。
    的头像 发表于 10-17 17:39 ?625次阅读
    <b class='flag-5'>旋转</b>花键材质及<b class='flag-5'>运用</b>场景

    FPGA图像处理领域的优势有哪些?

    语言编程的,因此可以根据图像处理的实际需求,动态地调整硬件资源的使用。这使得FPGA在处理图像时能够实现更高的能效比,从而降低系统的功耗。这对于需要长时间运行的
    发表于 10-09 14:36

    基于FPGA+GPU异构平台的遥感图像切片解决方案

    大型遥感图像分割成图像切片信息,以便更有效地处理和分析图像数据。中科亿海微自主研制的AI目标识别加速卡,基于FPGA+GPU异构并行计算处理架构设计,内嵌深度学习
    的头像 发表于 09-20 08:05 ?959次阅读
    基于<b class='flag-5'>FPGA</b>+GPU异构平台的遥感<b class='flag-5'>图像</b>切片解决方案

    ALINX FPGA+GPU异架构视频图像处理开发平台介绍

    Alinx 最新发布的新品 Z19-M 是一款创新的 FPGA+GPU 异构架构视频图像处理开发平台,它结合了 AMD Zynq UltraScale+ MPSoC(FPGA)与 NVIDIA Jetson Orin NX(GP
    的头像 发表于 08-29 14:43 ?2296次阅读