在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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
    +關注

    關注

    1630

    文章

    21759

    瀏覽量

    604378
  • MATLAB仿真
    +關注

    關注

    4

    文章

    176

    瀏覽量

    19945
  • 圖像旋轉
    +關注

    關注

    0

    文章

    3

    瀏覽量

    2207

原文標題:基于FPGA的圖像旋轉系統設計

文章出處:【微信號:HXSLH1010101010,微信公眾號:FPGA技術江湖】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    基于FPGA的GigE Vision相機圖像采集方案設計

    1 概述 GigE Vision是一個比較復雜的協議,要在FPGA中完全實現具有較大的難度。如果FPGA作為接收端希望實現GigE Vision相機的配置和圖像采集功能,則只需要實現其中小部分功能
    的頭像 發表于 01-07 09:34 ?94次閱讀
    基于<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 ?144次閱讀
    基于<b class='flag-5'>FPGA</b>實現<b class='flag-5'>圖像</b>直方圖設計

    FPGA 實時信號處理應用 FPGA圖像處理中的優勢

    現場可編程門陣列(FPGA)是一種高度靈活的硬件平臺,它允許開發者根據特定應用需求定制硬件邏輯。在實時信號處理和圖像處理領域,FPGA因其獨特的優勢而受到青睞。 1. 并行處理能力 FPGA
    的頭像 發表于 12-02 10:01 ?687次閱讀

    FPGA圖像處理領域的優勢有哪些?

    語言編程的,因此可以根據圖像處理的實際需求,動態地調整硬件資源的使用。這使得FPGA在處理圖像時能夠實現更高的能效比,從而降低系統的功耗。這對于需要長時間運行的
    發表于 10-09 14:36

    基于 FPGA 的會議系統設計

    。(5)系統支持現場錄入人員并學習,且識別率較高。(6)基于 socket 通信,實現將圖像信息從 FPGA 中實時傳輸到客戶端(PC 機等) 顯示的功能。(7)該會議系統功耗低、體積
    發表于 08-01 18:40

    基于FPGA的CCD工業相機系統設計

    基于FPGA的CCD工業相機系統設計是一個綜合性的項目,它結合了硬件電路設計、FPGA編程以及圖像處理技術。以下是一個詳細的系統設計方案,包
    的頭像 發表于 07-17 11:24 ?1256次閱讀

    基于FPGA圖像采集與顯示系統設計

    源和固有的并行處理能力,在數字信號處理、硬件加速、汽車電子等領域得到了廣泛應用。在圖像采集與顯示系統中,FPGA能夠實現高速、并行的數據處理,顯著提高系統的實時性和性能。本文設計了一個
    的頭像 發表于 07-17 10:58 ?1975次閱讀

    DSP教學實驗箱_數字圖像處理_操作教程:5-1 圖像旋轉

    一、實驗目的 學習圖像旋轉的原理,掌握圖像的讀取方法,并實現圖像旋轉。 二、實驗原理 圖像
    發表于 06-14 14:03

    FPGA設計經驗之圖像處理

    系列:基于 FPGA圖像邊緣檢測系統設計(sobel算法) FPGA設計中 Verilog HDL實現基本的圖像濾波處理仿真 需
    發表于 06-12 16:26

    基于FPGA的實時邊緣檢測系統設計,Sobel圖像邊緣檢測,FPGA圖像處理

    摘要 :本文設計了一種 基于 FPGA 的實時邊緣檢測系統 ,使用OV5640 攝像頭模塊獲取實時的視頻圖像數據,提取圖像邊緣信息并通過 VGA顯示。
    發表于 05-24 07:45

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

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

    基于FPGA的常見的圖像算法模塊總結

    意在給大家補充一下基于FPGA圖像算法基礎,于是講解了一下常見的圖像算法模塊,經過個人的總結,將知識點分布如下所示。
    的頭像 發表于 04-28 11:45 ?620次閱讀
    基于<b class='flag-5'>FPGA</b>的常見的<b class='flag-5'>圖像</b>算法模塊總結

    RFID血液智能流轉系統在赤峰市中心血站正式啟動

    1月25日,RFID血液智能流轉系統在赤峰市中心血站隆重舉行了啟動儀式,標志著赤峰市血液全程安全監管進入了信息化、標準化、智慧化的新時期。赤峰市中心血站領導班子成員及全體職工出席了由赤峰市中心血站副
    的頭像 發表于 03-07 16:49 ?370次閱讀
    RFID血液智能流<b class='flag-5'>轉系統</b>在赤峰市中心血站正式啟動

    FPGA圖像處理—VESA標準與視頻流介紹

    VESA 視頻標準同步信號產生器,是從事FPGA圖像領域工程師經常使用到的模塊。
    的頭像 發表于 02-29 09:56 ?3749次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>圖像</b>處理—VESA標準與視頻流介紹

    詳解FPGA六大應用領域

    就可以使用 FPGA。還有一些智能機器人,需要對圖像進行采集和處理,或者對聲音信號進行處理都可以使用 FPGA 去完成,所以 FPGA 在人工智能
    發表于 01-17 17:03
    主站蜘蛛池模板: 天天干天天干| 高清成年美女黄网站色大| 藏经阁在线| 波多野结衣在线观看一区二区三区| 成年在线视频| 一级在线观看视频| 天天躁日日躁狠狠躁中文字幕老牛| 天天干天天射天天插| 最好看的最新中文字幕2018免费视频 | 黄色录像欧美| 天天射天| 欧美全免费aaaaaa特黄在线| 在线jlzzjlzz免费播放| 午夜无码国产理论在线| 片黄免费| 日本高清视频色视频kk266| 狠狠操狠狠干| 欧美在线天堂| 国产精品美女www爽爽爽视频| 1000部又爽又黄的做黄禁片| 国内精品网站| 久久大综合| 久久天天躁狠狠躁夜夜爽| 日本天天射| 天天干天天谢| 久操视频在线观看| xx日韩| 在线观看精品视频看看播放| 四虎影院免费视频| 色综合天天综久久久噜噜噜久久〔 | 成人午夜网站| 亚洲欧美视频在线播放| 69中国xxxxxxxx18| 91精品国产亚洲爽啪在线影院| 男人的午夜| 欧美夜夜夜| 亚洲综合国产一区二区三区| 中文字幕亚洲一区| 日韩孕交| 四虎4545www国产精品| 四虎国产在线|