亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

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

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

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

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

電子工程師 ? 來源:CSDN技術(shù)社區(qū) ? 作者:weixin_39940788 ? 2021-04-15 14:23 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

二、MATLAB仿真

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

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

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

Matlab代碼實現(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);

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

原圖

旋轉(zhuǎn)后的圖像

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

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

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

在這種方案下,坐標(biāo)的對應(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 :對應(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)后的圖像

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

具體思路是,采用原圖像的長寬作為基準(zhǔn),再用坐標(biāo)轉(zhuǎn)換的關(guān)系,將長和寬轉(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)行逆向查找

% 計算原圖大小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;

% 初始化目標(biāo)畫布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);

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

原圖

旋轉(zhuǎn)后的圖像

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

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

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

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

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

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

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

四、效果展示(Results show)

0、原圖 (正常顯示)

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

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

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

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

五、說明

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

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

    關(guān)注

    1652

    文章

    22234

    瀏覽量

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

    關(guān)注

    4

    文章

    176

    瀏覽量

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

    關(guān)注

    0

    文章

    3

    瀏覽量

    2278

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    基于FPGA的CLAHE圖像增強(qiáng)算法設(shè)計

    CLAHE圖像增強(qiáng)算法又稱為對比度有限的自適應(yīng)直方圖均衡算法,其算法原理是通過有限的調(diào)整圖像局部對比度來增強(qiáng)有效信號和抑制噪聲信號。
    的頭像 發(fā)表于 10-15 10:14 ?249次閱讀
    基于<b class='flag-5'>FPGA</b>的CLAHE<b class='flag-5'>圖像</b>增強(qiáng)算法設(shè)計

    基于FPGA利用sm4進(jìn)行實時圖像加密

    求一份在fpga上利用sm4進(jìn)行實時圖像加密的文件
    發(fā)表于 09-15 19:05

    友思特方案 | FPGA 加持,友思特圖像采集卡高速預(yù)處理助力視覺系統(tǒng)運(yùn)行提速增效

    圖像預(yù)處理是圖像處理關(guān)鍵中間環(huán)節(jié),通過優(yōu)化傳感器到主機(jī)的數(shù)據(jù)傳輸處理為后續(xù)減負(fù)。其算法依托硬件執(zhí)行,搭載?FPGA?的友思特圖像采集卡以高速運(yùn)算和并行特性縮短處理時間、降低延遲并提升吞
    的頭像 發(fā)表于 08-20 09:18 ?527次閱讀
    友思特方案 | <b class='flag-5'>FPGA</b> 加持,友思特<b class='flag-5'>圖像</b>采集卡高速預(yù)處理助力視覺<b class='flag-5'>系統(tǒng)</b>運(yùn)行提速增效

    FPGA 加持,友思特圖像采集卡高速預(yù)處理助力視覺系統(tǒng)運(yùn)行提速增效

    圖像預(yù)處理是圖像處理關(guān)鍵環(huán)節(jié),可優(yōu)化數(shù)據(jù)傳輸、減輕主機(jī)負(fù)擔(dān),其算法可在FPGA等硬件上執(zhí)行。友思特FPGA圖像采集卡憑借
    的頭像 發(fā)表于 08-13 17:41 ?688次閱讀
    <b class='flag-5'>FPGA</b> 加持,友思特<b class='flag-5'>圖像</b>采集卡高速預(yù)處理助力視覺<b class='flag-5'>系統(tǒng)</b>運(yùn)行提速增效

    基于FPGA的數(shù)字識別系統(tǒng)設(shè)計

    圖像處理領(lǐng)域,圖像識別是較為困難而關(guān)鍵的技術(shù)。這項技術(shù)被廣泛的應(yīng)用到娛樂、工業(yè)、軍事等領(lǐng)域。本次設(shè)計數(shù)字識別系統(tǒng)已經(jīng)在車牌識別、運(yùn)動員號碼識別等多處運(yùn)用。本
    的頭像 發(fā)表于 07-16 14:28 ?1000次閱讀
    基于<b class='flag-5'>FPGA</b>的數(shù)字識別<b class='flag-5'>系統(tǒng)</b>設(shè)計

    itop-3588開發(fā)板Android系統(tǒng)開發(fā)筆記-旋轉(zhuǎn) Android系統(tǒng)

    系統(tǒng)顯示方向需要旋轉(zhuǎn) 90 度 修改 Android12 源碼的 device/rockchip/common/BoardConfig.mk 文件,修改主屏顯示的方向,角度可根據(jù)顯示需求,自定義修改 0
    發(fā)表于 05-19 11:04

    使用DPLC410進(jìn)行灰度圖像的顯示,顯示時有時圖像會抖動是怎么回事?

    編程一下APPSFPGA后,又能夠正常顯示灰度圖像。下面兩個視頻分別是顯示時有抖動和正常顯示的情況,APPSFPGA下載的同樣的固件 灰度顯示參考如下的方法: 這個8us的過程中可以加載數(shù)據(jù)嗎?
    發(fā)表于 02-26 06:08

    【國產(chǎn)FPGA入學(xué)必備】國產(chǎn)FPGA權(quán)威設(shè)計指南+配套FPGA圖像視頻教程

    》。 本書系統(tǒng)地介紹紫光同創(chuàng)FPGA的開發(fā)與應(yīng)用,詳細(xì)闡述FPGA開發(fā)的各個方面,從基礎(chǔ)原理到實際應(yīng)用,從設(shè)計流程到開發(fā)工具的使用,力求為讀者提供一套完整的學(xué)習(xí)和參考體系。通過閱讀本書,讀者不僅可以掌握紫光
    發(fā)表于 02-20 15:08

    導(dǎo)電滑環(huán)的原理與應(yīng)用

    導(dǎo)電滑環(huán)是一種關(guān)鍵的電力傳輸設(shè)備,廣泛應(yīng)用于各種旋轉(zhuǎn)系統(tǒng)中。本文將深入分析導(dǎo)電滑環(huán)的原理、結(jié)構(gòu)和應(yīng)用,介紹其在電力傳輸中的重要性和優(yōu)勢。
    的頭像 發(fā)表于 02-10 16:10 ?1323次閱讀

    基于FPGA圖像邊緣檢測設(shè)計

    今天給大俠帶來基于 FPGA圖像邊緣檢測設(shè)計,話不多說,上貨。 設(shè)計流程如下:mif文件的制作→?調(diào)用 ip 核生成rom以及仿真注意問題→?灰度處理→?均值濾波:重點是3*3 像素陣列的生成
    的頭像 發(fā)表于 02-10 11:30 ?989次閱讀
    基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>圖像</b>邊緣檢測設(shè)計

    FPGA圖像處理基礎(chǔ)----實現(xiàn)緩存卷積窗口

    像素行與像素窗口 一幅圖像是由一個個像素點構(gòu)成的,對于一幅480*272大小的圖片來說,其寬度是480,高度是272。在使用FPGA進(jìn)行圖像處理時,最關(guān)鍵的就是使用FPGA內(nèi)部的存儲資
    的頭像 發(fā)表于 02-07 10:43 ?1327次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>圖像</b>處理基礎(chǔ)----實現(xiàn)緩存卷積窗口

    基于FPGA的GigE Vision相機(jī)圖像采集方案設(shè)計

    1 概述 GigE Vision是一個比較復(fù)雜的協(xié)議,要在FPGA中完全實現(xiàn)具有較大的難度。如果FPGA作為接收端希望實現(xiàn)GigE Vision相機(jī)的配置和圖像采集功能,則只需要實現(xiàn)其中小部分功能
    的頭像 發(fā)表于 01-07 09:34 ?1723次閱讀
    基于<b class='flag-5'>FPGA</b>的GigE Vision相機(jī)<b class='flag-5'>圖像</b>采集方案設(shè)計

    基于FPGA實現(xiàn)圖像直方圖設(shè)計

    簡單,單采用FPGA來實現(xiàn)直方圖的統(tǒng)計就稍顯麻煩。若使用Xilinx和Altera的FPGA芯片,可以使用HLS來進(jìn)行圖像的加速處理。但這暫時不是我的重點。 用C語言實現(xiàn)直方圖統(tǒng)計:unsigned
    的頭像 發(fā)表于 12-24 10:24 ?1103次閱讀
    基于<b class='flag-5'>FPGA</b>實現(xiàn)<b class='flag-5'>圖像</b>直方圖設(shè)計

    FPGA 實時信號處理應(yīng)用 FPGA圖像處理中的優(yōu)勢

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

    百問FB顯示開發(fā)圖像處理 - 圖像調(diào)整

    free(pdwSrcXTable); 57. return 0; 58.} 2.4.2 圖像旋轉(zhuǎn) 2.4.2.1 圖像旋轉(zhuǎn)算法淺析 這里的
    發(fā)表于 12-02 09:34