0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀(guān)看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

詳解基于FPGA的圖像旋轉(zhuǎn)系統(tǒng)的運(yùn)用

電子工程師 ? 來(lái)源:CSDN技術(shù)社區(qū) ? 作者:weixin_39940788 ? 2021-04-15 14:23 ? 次閱讀

一、圖像旋轉(zhuǎn)原理

圖像旋轉(zhuǎn)是指圖像按照某個(gè)位置轉(zhuǎn)動(dòng)一定角度的過(guò)程,旋轉(zhuǎn)中圖像仍保持這原始尺寸。圖像旋轉(zhuǎn)后圖像的水平對(duì)稱(chēng)軸、垂直對(duì)稱(chēng)軸及中心坐標(biāo)原點(diǎn)都可能會(huì)發(fā)生變換,因此需要對(duì)圖像旋轉(zhuǎn)中的坐標(biāo)進(jìn)行相應(yīng)轉(zhuǎn)換。

如圖,原圖像經(jīng)過(guò)順時(shí)針旋轉(zhuǎn)角度為 θ 后,源圖像的坐標(biāo)為 P0 ( Xo, Yo ) 的點(diǎn)移動(dòng)到了 P1(X1, Y1)。

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

經(jīng)過(guò)推導(dǎo),可以得到上述的 P0 和P1 的坐標(biāo)變換關(guān)系式。

二、MATLAB仿真

方案一、【正向預(yù)設(shè)】從原圖映射到目標(biāo)圖像在此方案中,實(shí)現(xiàn)代碼的方式是正向的思路,將原圖中的像素點(diǎn)的坐標(biāo)進(jìn)行坐標(biāo)的旋轉(zhuǎn),然后直接幅值到輸出的圖像中,此方案旨在找到輸入坐標(biāo)與輸出坐標(biāo)之間的代數(shù)對(duì)應(yīng)關(guān)系。

在該方法中,首先將原始坐標(biāo)以及目標(biāo)坐標(biāo)放入了極坐標(biāo)中,并且通過(guò)在極坐標(biāo)中的關(guān)系,找到了同時(shí)滿(mǎn)足X0,Y0,X1,Y1四個(gè)參量的方程組,以此來(lái)解出對(duì)應(yīng)的坐標(biāo)關(guān)系,并以此為基礎(chǔ)得到了輸入與輸出之間的矩陣運(yùn)算關(guān)系如下:

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

Matlab代碼實(shí)現(xiàn)如下:

clear allclc

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

% 求出旋轉(zhuǎn)矩陣a = 40 / 180 * pi;R = [cos(a), -sin(a); sin(a), cos(a)];

% 求出圖片大小 ch為通道數(shù) h為高度 w為寬度sz = size(im);h = sz(1);w = sz(2);ch = sz(3);c = [h; w] / 2;

% 初始化結(jié)果圖像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);

但在實(shí)際的測(cè)試中發(fā)現(xiàn),這種方法所旋轉(zhuǎn)得到的圖像有著較為嚴(yán)重的失真現(xiàn)象,具體情況如下圖所示:

原圖

旋轉(zhuǎn)后的圖像

很明顯可以看到,在旋轉(zhuǎn)之后這兩張圖片出現(xiàn)了較大的差別,首先是原圖像被裁減了,其次是目標(biāo)圖像中有較多的瑕點(diǎn)(雜點(diǎn))。究其原因在于,從原圖旋轉(zhuǎn)后得到的目標(biāo)圖像的像素位置在原圖中找不到。另外就是邊緣被裁剪的問(wèn)題,由于在這個(gè)方案中約束了顯示區(qū)域,因此在旋轉(zhuǎn)的過(guò)程中,部分像素點(diǎn)就會(huì)由于超出邊界而被裁剪。針對(duì)以上的兩個(gè)問(wèn)題,進(jìn)行了如下改進(jìn)。

方案二、【逆向預(yù)設(shè)】從目標(biāo)圖像映射到原圖

由于在之前的方案中出現(xiàn)了雜點(diǎn)以及圖像邊緣裁剪的問(wèn)題,因此在本方案中,我們采用了逆向思維,用目標(biāo)圖像的坐標(biāo)去與原圖的坐標(biāo)進(jìn)行坐標(biāo)匹配,若在原圖像中能找到匹配的圖像,就顯示該點(diǎn)旋轉(zhuǎn)后的點(diǎn)坐標(biāo),若在原圖中找不到該點(diǎn),則不顯示該點(diǎn),通過(guò)這樣就解決了雜點(diǎn)的問(wèn)題。 其中,pp為旋轉(zhuǎn)在后的坐標(biāo)對(duì)應(yīng)矩陣,在if語(yǔ)句中限定了原圖的區(qū)域,用此區(qū)域則可以到原圖中的坐標(biāo)點(diǎn),以此來(lái)排除不在區(qū)域中的坐標(biāo)點(diǎn),這樣就可以解決雜點(diǎn)的問(wèn)題。

在這種方案下,坐標(biāo)的對(duì)應(yīng)關(guān)系如下:

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

MATLAB仿真代碼如下:

clear allclc

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

% 求出旋轉(zhuǎn)矩陣a = 20 / 180 * pi;R = [cos(a), sin(a); -sin(a), cos(a)];

% 求出圖片大小 ch為通道數(shù) h為高度 w為寬度

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

% 初始化結(jié)果圖像im2 = uint8(zeros(h, w, 3));for k = 1:ch %遍歷輸出圖像所有位置的像素 for i = 1:h for j = 1:w p = [j; i]; % p :輸出圖像的像素坐標(biāo) % round為四舍五入 pp = round(R*(p-c)+c); %pp :對(duì)應(yīng)到輸入圖像的像素坐標(biāo) %逆向進(jìn)行像素的查找 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);

這樣,該旋轉(zhuǎn)后的圖像就有了較好的還原度,達(dá)到了相應(yīng)的題目要求,具體的方案的效果如下圖所示:

原圖

旋轉(zhuǎn)后的圖像

如圖所示,相對(duì)方案一而言,圖像的效果就好了很多,但圖像邊緣仍然存在邊緣被切割的現(xiàn)象。 方案三:考慮到未對(duì)旋轉(zhuǎn)后的圖像進(jìn)行顯示區(qū)域的劃分,因此此類(lèi)旋轉(zhuǎn)只是對(duì)單一像素點(diǎn)的旋轉(zhuǎn),然后在原圖像的顯示區(qū)域上進(jìn)行坐標(biāo)點(diǎn)的重新組合,得到顯示的圖像。在解決的方法的思路上,采用目標(biāo)顯示區(qū)域的重新劃分來(lái)解決該問(wèn)題。

具體思路是,采用原圖像的長(zhǎng)寬作為基準(zhǔn),再用坐標(biāo)轉(zhuǎn)換的關(guān)系,將長(zhǎng)和寬轉(zhuǎn)換到旋轉(zhuǎn)后的坐標(biāo)系中,得到目標(biāo)圖像在旋轉(zhuǎn)后坐標(biāo)系中的顯示區(qū)域,代碼具體如下:

% 讀入圖片im = imread(‘1.jpg’);

figure;imshow(im);

% 求出旋轉(zhuǎn)矩陣a = 30 / 180 * pi;R = [cos(a), -sin(a); sin(a), cos(a)];R = R‘; % 求出旋轉(zhuǎn)矩陣的逆矩陣進(jìn)行逆向查找

% 計(jì)算原圖大小sz = size(im);h = sz(1);w = sz(2);ch = sz(3);c1 = [h; w] / 2;

% 計(jì)算顯示完整圖像需要的畫(huà)布大小hh = floor(w*sin(a)+h*cos(a))+1;ww = floor(w*cos(a)+h*sin(a))+1;c2 = [hh; ww] / 2;

% 初始化目標(biāo)畫(huà)布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); % 線(xiàn)性插值方法 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);

這樣,就解決了圖像邊緣被裁剪的問(wèn)題,是整個(gè)圖像得以完整的顯示,實(shí)際的效果如下:

原圖

旋轉(zhuǎn)后的圖像

從圖示的效果可以看出,邊緣區(qū)域被裁剪的問(wèn)題被解決了,但問(wèn)題是圖片加陰影的區(qū)域面積比原圖大很多。 綜合以上三種方案,結(jié)合實(shí)際需求,由于我們的顯示是在一塊固定大小的屏幕上進(jìn)行顯示,整個(gè)圖像的顯示范圍有限,采用CORDIC算法進(jìn)行坐標(biāo)變換產(chǎn)生的延時(shí)太大。最終基于處理速度和資源占用的均衡考慮,最終選擇方案二作為我們圖像旋轉(zhuǎn)的設(shè)計(jì)方案。

三、旋轉(zhuǎn)坐標(biāo)計(jì)算

在該設(shè)計(jì)中,要求圖像擁有0到360的任意角度的旋轉(zhuǎn),坐標(biāo)變換需要角度的正弦和余弦值。 利用matlab生成正余弦表,并將其擴(kuò)大256倍,打印到文件中。利用得到的正余弦表數(shù)值,將其寫(xiě)入verilog代碼中,生成正余弦查找表。通過(guò)輸入角度值來(lái)索引其正余弦數(shù)值。Matlab生成正余弦列表的代碼如下:

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

該正弦,余弦通過(guò)MATLAB計(jì)算得到,并預(yù)先儲(chǔ)存到FPGA的片上儲(chǔ)存空間中,在進(jìn)行坐標(biāo)變換時(shí),讀取對(duì)應(yīng)角度的正弦,余弦值,進(jìn)行坐標(biāo)變換。由于計(jì)算得到的正弦和余弦值為浮點(diǎn)數(shù),而FPGA擅長(zhǎng)于進(jìn)行整數(shù)運(yùn)算。故要進(jìn)行浮點(diǎn)數(shù)到整數(shù)的轉(zhuǎn)換,具體的實(shí)現(xiàn)方法是,將計(jì)算得到的浮點(diǎn)正弦,余弦值乘上 256 后再取整,計(jì)算得到的結(jié)果于原結(jié)果相比被擴(kuò)大了256倍,而在數(shù)字電路中,除法操作可以用移位來(lái)進(jìn)行。結(jié)果右移8位即等效于除于256 。 坐標(biāo)變換的核心代碼如下:

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

將坐標(biāo)變換計(jì)算模塊封裝為一個(gè)子模塊,輸入輸出圖像的坐標(biāo)和旋轉(zhuǎn)角度后,即可計(jì)算出對(duì)應(yīng)的輸入圖像對(duì)應(yīng)的像素的坐標(biāo)。然后讀取該坐標(biāo)的像素值,寫(xiě)入到旋轉(zhuǎn)重建的圖像對(duì)應(yīng)的坐標(biāo)位置即可。

四、效果展示(Results show)

0、原圖 (正常顯示)

1、順時(shí)針旋轉(zhuǎn)22度

2、順時(shí)針旋轉(zhuǎn)90度

3、順時(shí)針旋轉(zhuǎn)270度

4、順時(shí)針旋轉(zhuǎn)341度

五、說(shuō)明

在公眾號(hào)對(duì)話(huà)框回復(fù) FPGA2019 ,即可獲得該項(xiàng)目的工程源代碼,詳細(xì)的文檔說(shuō)明,MATLAB仿真代碼。
編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀(guān)點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1620

    文章

    21510

    瀏覽量

    599003
  • MATLAB仿真
    +關(guān)注

    關(guān)注

    4

    文章

    175

    瀏覽量

    19844
  • 圖像旋轉(zhuǎn)
    +關(guān)注

    關(guān)注

    0

    文章

    3

    瀏覽量

    2181

原文標(biāo)題:基于FPGA的圖像旋轉(zhuǎn)系統(tǒng)設(shè)計(jì)

文章出處:【微信號(hào):HXSLH1010101010,微信公眾號(hào):FPGA技術(shù)江湖】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    基于 FPGA 的會(huì)議系統(tǒng)設(shè)計(jì)

    。(5)系統(tǒng)支持現(xiàn)場(chǎng)錄入人員并學(xué)習(xí),且識(shí)別率較高。(6)基于 socket 通信,實(shí)現(xiàn)將圖像信息從 FPGA 中實(shí)時(shí)傳輸?shù)娇蛻?hù)端(PC 機(jī)等) 顯示的功能。(7)該會(huì)議系統(tǒng)功耗低、體積
    發(fā)表于 08-01 18:40

    基于FPGA圖像采集與顯示系統(tǒng)設(shè)計(jì)

    源和固有的并行處理能力,在數(shù)字信號(hào)處理、硬件加速、汽車(chē)電子等領(lǐng)域得到了廣泛應(yīng)用。在圖像采集與顯示系統(tǒng)中,FPGA能夠?qū)崿F(xiàn)高速、并行的數(shù)據(jù)處理,顯著提高系統(tǒng)的實(shí)時(shí)性和性能。本文設(shè)計(jì)了一個(gè)
    的頭像 發(fā)表于 07-17 10:58 ?1247次閱讀

    DSP教學(xué)實(shí)驗(yàn)箱_數(shù)字圖像處理_操作教程:5-1 圖像旋轉(zhuǎn)

    一、實(shí)驗(yàn)?zāi)康?學(xué)習(xí)圖像旋轉(zhuǎn)的原理,掌握圖像的讀取方法,并實(shí)現(xiàn)圖像旋轉(zhuǎn)。 二、實(shí)驗(yàn)原理 圖像
    發(fā)表于 06-14 14:03

    FPGA設(shè)計(jì)經(jīng)驗(yàn)之圖像處理

    系列:基于 FPGA圖像邊緣檢測(cè)系統(tǒng)設(shè)計(jì)(sobel算法) FPGA設(shè)計(jì)中 Verilog HDL實(shí)現(xiàn)基本的圖像濾波處理仿真 需
    發(fā)表于 06-12 16:26

    基于FPGA的實(shí)時(shí)邊緣檢測(cè)系統(tǒng)設(shè)計(jì),Sobel圖像邊緣檢測(cè),FPGA圖像處理

    摘要 :本文設(shè)計(jì)了一種 基于 FPGA 的實(shí)時(shí)邊緣檢測(cè)系統(tǒng) ,使用OV5640 攝像頭模塊獲取實(shí)時(shí)的視頻圖像數(shù)據(jù),提取圖像邊緣信息并通過(guò) VGA顯示。
    發(fā)表于 05-24 07:45

    全志T527芯片詳解:計(jì)算性能與高清圖像編解碼

    全志T527芯片詳解:計(jì)算性能與高清圖像編解碼
    的頭像 發(fā)表于 05-21 14:37 ?2118次閱讀
    全志T527芯片<b class='flag-5'>詳解</b>:計(jì)算性能與高清<b class='flag-5'>圖像</b>編解碼

    基于FPGA的常見(jiàn)的圖像算法模塊總結(jié)

    意在給大家補(bǔ)充一下基于FPGA圖像算法基礎(chǔ),于是講解了一下常見(jiàn)的圖像算法模塊,經(jīng)過(guò)個(gè)人的總結(jié),將知識(shí)點(diǎn)分布如下所示。
    的頭像 發(fā)表于 04-28 11:45 ?420次閱讀
    基于<b class='flag-5'>FPGA</b>的常見(jiàn)的<b class='flag-5'>圖像</b>算法模塊總結(jié)

    詳解FPGA六大應(yīng)用領(lǐng)域

    就可以使用 FPGA。還有一些智能機(jī)器人,需要對(duì)圖像進(jìn)行采集和處理,或者對(duì)聲音信號(hào)進(jìn)行處理都可以使用 FPGA 去完成,所以 FPGA 在人工智能
    發(fā)表于 01-17 17:03

    FPGA圖像處理之CLAHE算法

    FPGA圖像處理--CLAHE算法(一)中介紹了為啥要用CLAHE算法來(lái)做圖像增強(qiáng)。
    的頭像 發(fā)表于 01-04 12:23 ?2104次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>圖像</b>處理之CLAHE算法

    FPGA圖像處理方法

    圖像細(xì)節(jié)。 FPGA 圖像處理方法 1、圖像增強(qiáng) 兩大方法:空間域方法和時(shí)間域方法(以后再詳述) 2、圖像濾波 (1)平滑空間 濾波器 (2
    的頭像 發(fā)表于 12-02 13:15 ?913次閱讀

    一種FPGA+W5300架構(gòu)的C0FDM無(wú)線(xiàn)圖像傳輸系統(tǒng)設(shè)計(jì)

    基于FPGA的無(wú)線(xiàn)圖像傳輸系統(tǒng)硬件設(shè)計(jì)與實(shí)現(xiàn)
    的頭像 發(fā)表于 11-14 09:44 ?1539次閱讀
    一種<b class='flag-5'>FPGA</b>+W5300架構(gòu)的C0FDM無(wú)線(xiàn)<b class='flag-5'>圖像</b>傳輸<b class='flag-5'>系統(tǒng)</b>設(shè)計(jì)

    OpenCV中圖像旋轉(zhuǎn)函數(shù)操作原理及基本技巧

    旋轉(zhuǎn)涉及到兩個(gè)問(wèn)題,一個(gè)是圖像旋轉(zhuǎn)之后的大小會(huì)發(fā)生改變,會(huì)產(chǎn)生背景,通過(guò)背景填充方式都是填充黑色,此外旋轉(zhuǎn)還是產(chǎn)生像素的位置遷移,新的位置像素需要通過(guò)插值計(jì)算獲得,常見(jiàn)的插值方式有最近
    的頭像 發(fā)表于 11-14 09:40 ?714次閱讀
    OpenCV中<b class='flag-5'>圖像</b><b class='flag-5'>旋轉(zhuǎn)</b>函數(shù)操作原理及基本技巧

    基于 FPGA 的無(wú)線(xiàn)圖像傳輸系統(tǒng)硬 件設(shè)計(jì)與實(shí)現(xiàn)

    摘 要 針 對(duì) 圖 像 傳 輸 過(guò) 程 中 的 多 路 徑 、非 通 視 和 高 速 移 動(dòng) 等 特 點(diǎn) ,提 出 了 一 種 FPGA+ W5300 架 構(gòu) 的C0FDM 無(wú) 線(xiàn) 圖像 傳 輸
    發(fā)表于 11-07 11:33

    利用FPGA設(shè)計(jì)基于LVDS的圖像數(shù)據(jù)采集傳輸系統(tǒng)

    和狀態(tài)參數(shù)信號(hào)以及控制信號(hào)是獨(dú)立產(chǎn)生的,因此需要設(shè)計(jì)一種系統(tǒng)能夠?qū)⑼獠吭O(shè)備產(chǎn)生的圖像數(shù)據(jù)和狀態(tài)控制信號(hào)同步采集,并能長(zhǎng)距離高速傳輸,綜合考慮到圖像采集系統(tǒng)所要求的實(shí)時(shí)性,可靠性,以及
    的頭像 發(fā)表于 09-28 10:35 ?1447次閱讀

    基于ARM和FPGA設(shè)計(jì)高速圖像數(shù)據(jù)采集傳輸系統(tǒng)

    的靈活性和FPGA的并行性的特點(diǎn),設(shè)計(jì)了一種基于ARM+FPGA的高速圖像數(shù)據(jù)采集傳輸系統(tǒng)。所選用的ARM體系結(jié)構(gòu)是32位嵌入式RISC微處理器結(jié)構(gòu),該微處理器擁有豐富的指令集且編程靈
    的頭像 發(fā)表于 09-27 10:45 ?1144次閱讀