python實(shí)現(xiàn)ROA算子邊緣檢測算法
python實(shí)現(xiàn)ROA算子邊緣檢測算法的具體代碼,供大家參考,具體內(nèi)容如下
代碼
import numpy as np import cv2 as cv def ROA(image_path, save_path, threshold): img = cv.imread(image_path) image = cv.cvtColor(img, cv.COLOR_RGB2GRAY) new = np.zeros((512, 512), dtype=np.float64) # 開辟存儲(chǔ)空間 width = img.shape[0] heigh = img.shape[1] for i in range(width): for j in range(heigh): if i == 0 or j == 0 or i == width - 1 or j == heigh - 1: new[i, j] = image[i, j] continue print(image[i, j]) if image[i, j] < 60: continue num_sum = 0.0 u1 = (image[i - 1, j - 1] + image[i, j - 1] + image[i + 1, j - 1]) / 3 u2 = (image[i - 1, j + 1] + image[i, j + 1] + image[i + 1, j + 1]) / 3 r12 = 1.0 if float(u2) - 0.0 > 1e6: r12 = float(u1) / float(u2) if float(u1) - 0.0 > 1e6: r12 = float(u2) / float(u1) num_sum += r12 u1 = (image[i - 1, j - 1] + image[i, j - 1] + image[i - 1, j]) / 3 u2 = (image[i + 1, j] + image[i + 1, j + 1] + image[i, j + 1]) / 3 r12 = 1.0 if float(u2) - 0.0 > 1e6: r12 = float(u1) / float(u2) if float(u1) - 0.0 > 1e6: r12 = float(u2) / float(u1) num_sum += r12 u1 = (image[i - 1, j - 1] + image[i - 1, j] + image[i - 1, j + 1]) / 3 u2 = (image[i + 1, j - 1] + image[i + 1, j] + image[i + 1, j + 1]) / 3 r12 = 1.0 if float(u2) - 0.0 > 1e6: r12 = float(u1) / float(u2) if float(u1) - 0.0 > 1e6: r12 = float(u2) / float(u1) num_sum += r12 u1 = (image[i - 1, j] + image[i - 1, j + 1] + image[i, j + 1]) / 3 u2 = (image[i, j - 1] + image[i + 1, j - 1] + image[i + 1, j]) / 3 r12 = 1.0 if float(u2) - 0.0 > 1e6: r12 = float(u1) / float(u2) if float(u1) - 0.0 > 1e6: r12 = float(u2) / float(u1) num_sum += r12 new[i, j] = num_sum / 4.0 if new[i, j] > threshold: new[i, j] = 100 print(new[i, j]) print(new) cv.imwrite(save_path, new) if __name__ == "__main__": image_path = r"" save_path = r"" threshold = ROA(image_path, save_path, threshold)
運(yùn)算結(jié)果
運(yùn)算前

運(yùn)算后

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python基于內(nèi)置函數(shù)type創(chuàng)建新類型
這篇文章主要介紹了Python基于內(nèi)置函數(shù)type創(chuàng)建新類型,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10
Python編程利用科赫曲線實(shí)現(xiàn)三維飄雪效果示例過程
這篇文章主要介紹了Python編程實(shí)現(xiàn)三維飄雪效果示例過程,通過本示例你可以自己做出一個(gè)浪漫的雪花飄落效果,有需要的朋友可以借鑒參考下2021-10-10
python 命名規(guī)范知識(shí)點(diǎn)匯總
這里給大家分享的是在python開發(fā)過程中需要注意的命名的規(guī)范的知識(shí)匯總,有需要的小伙伴可以查看下2020-02-02
python隨機(jī)種子ranrandom seed的使用
本文介紹了在Python中設(shè)置隨機(jī)種子random seed的方法,可以使用seed()函數(shù)設(shè)置隨機(jī)種子,確保你的隨機(jī)數(shù)生成過程是可重復(fù)的,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-12-12
Python爬蟲之超級(jí)鷹驗(yàn)證碼應(yīng)用
眾所周知python是一個(gè)很強(qiáng)大的語言,它擁有眾多的庫,今天我嘗試了使用超級(jí)鷹第三方平臺(tái)進(jìn)行驗(yàn)證碼的開發(fā),需要的朋友可以參考下2022-08-08
Tensorflow讀取并輸出已保存模型的權(quán)重?cái)?shù)值方式
今天小編就為大家分享一篇Tensorflow讀取并輸出已保存模型的權(quán)重?cái)?shù)值方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看不看2020-01-01

