日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

 豆寶有蟲(chóng)吃 2019-09-24

在通常情況下,圖片是否清晰是個(gè)感性認(rèn)識(shí),同一個(gè)圖,有可能你覺(jué)得還過(guò)得去,而別人會(huì)覺(jué)得不清晰,缺乏一個(gè)統(tǒng)一的標(biāo)準(zhǔn)。然而有一些算法可以去量化圖片的清晰度,做到有章可循。

原理

如果之前了解過(guò)信號(hào)處理,就會(huì)知道最直接的方法是計(jì)算圖片的快速傅里葉變換,然后查看高低頻分布。如果圖片有少量的高頻成分,那么該圖片就可以被認(rèn)為是模糊的。然而,區(qū)分高頻量多少的具體閾值卻是十分困難的,不恰當(dāng)?shù)拈撝祵?huì)導(dǎo)致極差的結(jié)果。

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

我們期望的是一個(gè)單一的浮點(diǎn)數(shù)就可以表示圖片的清晰度。 Pech-Pacheco 在 2000 年模式識(shí)別國(guó)際會(huì)議提出將圖片中某一通道(一般用灰度值)通過(guò)拉普拉斯掩模做卷積運(yùn)算,然后計(jì)算標(biāo)準(zhǔn)差,出來(lái)的值就可以代表圖片清晰度。

這種方法奏效的原因就在于拉普拉斯算子定義本身。它被用來(lái)測(cè)量圖片的二階導(dǎo)數(shù),突出圖片中強(qiáng)度快速變化的區(qū)域,和 Sobel 以及 Scharr 算子十分相似。并且,和以上算子一樣,拉普拉斯算子也經(jīng)常用于邊緣檢測(cè)。此外,此算法基于以下假設(shè):如果圖片具有較高方差,那么它就有較廣的頻響范圍,代表著正常,聚焦準(zhǔn)確的圖片。但是如果圖片具有有較小方差,那么它就有較窄的頻響范圍,意味著圖片中的邊緣數(shù)量很少。正如我們所知道的,圖片越模糊,其邊緣就越少。

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

有了代表清晰度的值,剩下的工作就是設(shè)定相應(yīng)的閥值,如果某圖片方差低于預(yù)先定義的閾值,那么該圖片就可以被認(rèn)為是模糊的,高于閾值,就不是模糊的。

實(shí)操

原理看起來(lái)比較復(fù)雜,涉及到很多信號(hào)啊圖片處理的相關(guān)知識(shí),下面我們來(lái)實(shí)操一下,直觀感受下。

由于人生苦短,以及我個(gè)人是朋友圈第一 Python 吹子,我選擇使用 Python 來(lái)實(shí)現(xiàn),核心代碼簡(jiǎn)單到令人發(fā)指:

import cv2
def getImageVar(imgPath):
image = cv2.imread(imgPath);
img2gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
imageVar = cv2.Laplacian(img2gray, cv2.CV_64F).var()
return imageVar

真是人生苦短啊,核心代碼就三行,簡(jiǎn)單解釋下。

import cv2使用了一個(gè)著名的圖像處理庫(kù) OpenCV,關(guān)于 OpenCV 的安裝這里不多贅述,需要注意的是它依賴 numpy。

image = cv2.imread(imgPath)使用 OpenCV 提供的方法讀取圖片。img2gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)轉(zhuǎn)化為灰度圖。如下圖:

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

原圖是這樣的:

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

cv2.Laplacian(img2gray, cv2.CV_64F)對(duì)圖片用 3x3 拉普拉斯算子做卷積,這里的cv2.CV_64F就是拉普拉斯算子。

原理部分說(shuō)過(guò),拉普拉斯算子經(jīng)常用于邊緣檢測(cè),所以這里經(jīng)過(guò)拉普拉斯算子之后,留下的都是檢測(cè)到的邊緣。上圖經(jīng)過(guò)這步處理之后是這樣的:

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

可以看到這里圖片人物大致還是比較清晰的。

cv2.Laplacian(img2gray, cv2.CV_64F).var()計(jì)算出方差,并最后返回。

上面那張圖按這個(gè)計(jì)算出來(lái)時(shí) 3170 多,這個(gè)就是最后我們用來(lái)判斷清晰度的值。

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

可以再找一張看看:

原圖:

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

做灰度和經(jīng)過(guò)拉普拉斯算子之后,可以看到人物部分已經(jīng)不是很清晰了。

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

最后算出來(lái)的方差只有 530

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

剩下的工作就是根據(jù)整體圖片質(zhì)量確定閥值了。

局限性

通過(guò)上面的實(shí)操,我們知道這個(gè)算法的技巧在于設(shè)置合適的閥值,閾值太低會(huì)導(dǎo)致正常圖片被誤斷為模糊圖片,閾值太高會(huì)導(dǎo)致模糊圖片被誤判為正常圖片。閥值依賴于你實(shí)際應(yīng)用的業(yè)務(wù)場(chǎng)景,需要根據(jù)使用場(chǎng)景的不同做不同的定制。

真正的銀彈并不存在。除了需要定個(gè)閥值外,有些圖片可能會(huì)故意做個(gè)背景模糊或者背景虛化,這種圖片很容易被誤殺。

比如:

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

計(jì)算出來(lái)是這樣的,后面一大片都是黑的。

3行代碼Python搞定圖片清晰度識(shí)別,原來(lái)我們看到的不一定是這樣

這個(gè)圖前景其實(shí)看著還行,但是背景有大片的虛化和模糊,這種情況下比較容易被誤殺。

所以最好還是在了解原理之后,根據(jù)實(shí)際場(chǎng)景來(lái)使用。

最后寫(xiě)了個(gè)簡(jiǎn)單的腳本,對(duì)傳入的圖片路徑的圖片進(jìn)行計(jì)算,然后返回一個(gè) json 字符串。

用法python getRank.py --imgs=./1.jpg,./2.jpg

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多