圖片處理-opencv-11.圖像采樣、金字塔(向下取樣民褂、向上取樣)

圖像采樣處理

圖像采樣(Image Sampling)處理是將一幅連續(xù)圖像在空間上分割成M×N個網(wǎng)格茄菊,每個網(wǎng)格用一個亮度值或灰度值來表示.

圖像采樣的間隔越大,所得圖像像素數(shù)越少赊堪,空間分辨率越低面殖,圖像質(zhì)量越差,甚至出現(xiàn)馬賽克效應(yīng)哭廉;相反脊僚,圖像采樣的間隔越小,所得圖像像素數(shù)越多遵绰,空間分辨率越高辽幌,圖像質(zhì)量越好,但數(shù)據(jù)量會相應(yīng)的增大椿访。

import cv2  
import numpy as np  
import matplotlib.pyplot as plt

#讀取原始圖像
img = cv2.imread('data/test3.jpg')
src = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

#獲取圖像高度和寬度
height = src.shape[0]
width = src.shape[1]

#采樣轉(zhuǎn)換成8*8區(qū)域
numHeight = height//16
numwidth = width//16

#創(chuàng)建一幅圖像
new_img = np.zeros((height, width, 3), np.uint8)

#圖像循環(huán)采樣16*16區(qū)域
for i in range(16):
    #獲取Y坐標(biāo)
    y = i*numHeight
    for j in range(16):
        #獲取X坐標(biāo)
        x = j*numwidth
        #獲取填充顏色 左上角像素點
        b = src[y, x][0]
        g = src[y, x][1]
        r = src[y, x][2]
        
        #循環(huán)設(shè)置小區(qū)域采樣
        for n in range(numHeight):
            for m in range(numwidth):
                new_img[y+n, x+m][0] = np.uint8(b)
                new_img[y+n, x+m][1] = np.uint8(g)
                new_img[y+n, x+m][2] = np.uint8(r)

#顯示圖像
titles = ['src', 'Sampling']
images = [src, new_img]
plt.figure(figsize=(10, 4))
for i in range(2):
    plt.subplot(1, 2, i+1)
    plt.imshow(images[i], 'gray')
    plt.title(titles[i])
    plt.xticks([]), plt.yticks([])
plt.show()

# 上述代碼存在一個問題乌企,當(dāng)圖像的長度和寬度不能被采樣區(qū)域整除時,輸出圖像的最右邊和最下邊的區(qū)域沒有被采樣處理
image.png

圖像金字塔

圖像金字塔是指由一組圖像且不同分別率的子圖集合成玫,它是圖像多尺度表達的一種加酵,以多分辨率來解釋圖像的結(jié)構(gòu)拳喻,主要用于圖像的分割或壓縮。一幅圖像的金字塔是一系列以金字塔形狀排列的分辨率逐步降低猪腕,且來源于同一張原始圖的圖像集合冗澈。如圖所示,它包括了四層圖像码撰,將這一層一層的圖像比喻成金字塔渗柿。圖像金字塔可以通過梯次向下采樣獲得,直到達到某個終止條件才停止采樣脖岛,在向下采樣中朵栖,層級越高,則圖像越小柴梆,分辨率越低陨溅。

image.png

生成圖像金字塔主要包括兩種方式——向下取樣、向上取樣绍在。在上圖中门扇,將圖像G0轉(zhuǎn)換為G1、G2偿渡、G3臼寄,圖像分辨率不斷降低的過程稱為向下取樣;將G3轉(zhuǎn)換為G2溜宽、G1吉拳、G0,圖像分辨率不斷增大的過程稱為向上取樣适揉。

圖像向下取樣

在圖像向下取樣中留攒,使用最多的是高斯金字塔。它將對圖像Gi進行高斯核卷積嫉嘀,并刪除原圖中所有的偶數(shù)行和列炼邀,最終縮小圖像。其中剪侮,高斯核卷積運算就是對整幅圖像進行加權(quán)平均的過程拭宁,每一個像素點的值,都由其本身和鄰域內(nèi)的其他像素值(權(quán)重不同)經(jīng)過加權(quán)平均后得到瓣俯。

高斯核卷積讓臨近中心的像素點具有更高的重要度红淡,對周圍像素計算加權(quán)平均值.原始圖像具有M×N個像素,進行向下取樣之后降铸,所得到的圖像具有M/2×N/2個像素,只有原圖的四分之一摇零。通過對輸入的原始圖像不停迭代以上步驟就會得到整個金字塔推掸。注意,由于每次向下取樣會刪除偶數(shù)行和列,所以它會不停地丟失圖像的信息谅畅。

dst = pyrDown(src[, dst[, dstsize[, borderType]]])

  • src表示輸入圖像登渣,
  • dst表示輸出圖像,和輸入圖像具有一樣的尺寸和類型
  • dstsize表示輸出圖像的大小毡泻,默認值為Size()
  • borderType表示像素外推方法
import cv2  
import numpy as np  
import matplotlib.pyplot as plt

#讀取原始圖像
img = cv2.imread('data/test3.jpg')
src = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

#圖像向下取樣
r = cv2.pyrDown(src)

#顯示圖像
titles = ['src', 'Sampling']
images = [src, r]
plt.figure(figsize=(10, 4))
for i in range(2):
    plt.subplot(1, 2, i+1)
    plt.imshow(images[i], 'gray')
    plt.title(titles[i])
#     plt.xticks([]), plt.yticks([])
plt.show()
image.png

圖像向上取樣

在圖像向上取樣是由小圖像不斷放圖像的過程胜茧。它將圖像在每個方向上擴大為原圖像的2倍,新增的行和列均用0來填充仇味,并使用與“向下取樣”相同的卷積核乘以4呻顽,再與放大后的圖像進行卷積運算,以獲得“新增像素”的新值丹墨。

dst = pyrUp(src[, dst[, dstsize[, borderType]]])

  • src表示輸入圖像廊遍,
  • dst表示輸出圖像,和輸入圖像具有一樣的尺寸和類型
  • dstsize表示輸出圖像的大小贩挣,默認值為Size()
  • borderType表示像素外推方法
import cv2  
import numpy as np  
import matplotlib.pyplot as plt

#讀取原始圖像
img = cv2.imread('data/test3.jpg')
src = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

#圖像向上取樣
r = cv2.pyrUp(src)

#顯示圖像
titles = ['src', 'pyrUp']
images = [src, r]
plt.figure(figsize=(10, 4))
for i in range(2):
    plt.subplot(1, 2, i+1)
    plt.imshow(images[i], 'gray')
    plt.title(titles[i])
#     plt.xticks([]), plt.yticks([])
plt.show()
image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末喉前,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子王财,更是在濱河造成了極大的恐慌卵迂,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件绒净,死亡現(xiàn)場離奇詭異见咒,居然都是意外死亡,警方通過查閱死者的電腦和手機疯溺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進店門论颅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人囱嫩,你說我怎么就攤上這事恃疯。” “怎么了墨闲?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵今妄,是天一觀的道長。 經(jīng)常有香客問我鸳碧,道長盾鳞,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任瞻离,我火速辦了婚禮腾仅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘套利。我一直安慰自己推励,他們只是感情好鹤耍,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著验辞,像睡著了一般稿黄。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上跌造,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天杆怕,我揣著相機與錄音,去河邊找鬼壳贪。 笑死陵珍,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的撑碴。 我是一名探鬼主播撑教,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼醉拓!你這毒婦竟也來了伟姐?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤亿卤,失蹤者是張志新(化名)和其女友劉穎愤兵,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體排吴,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡秆乳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了钻哩。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片屹堰。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖街氢,靈堂內(nèi)的尸體忽然破棺而出扯键,到底是詐尸還是另有隱情,我是刑警寧澤珊肃,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布荣刑,位于F島的核電站,受9級特大地震影響伦乔,放射性物質(zhì)發(fā)生泄漏厉亏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一烈和、第九天 我趴在偏房一處隱蔽的房頂上張望爱只。 院中可真熱鬧,春花似錦招刹、人聲如沸恬试。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忘渔。三九已至,卻和暖如春缰儿,著一層夾襖步出監(jiān)牢的瞬間畦粮,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工乖阵, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留宣赔,地道東北人。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓瞪浸,卻偏偏與公主長得像儒将,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子对蒲,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348