婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 使用Python中OpenCV和深度學(xué)習(xí)進(jìn)行全面嵌套邊緣檢測(cè)

使用Python中OpenCV和深度學(xué)習(xí)進(jìn)行全面嵌套邊緣檢測(cè)

熱門標(biāo)簽:公司電話機(jī)器人 騰訊外呼線路 白銀外呼系統(tǒng) 陜西金融外呼系統(tǒng) 唐山智能外呼系統(tǒng)一般多少錢 廣告地圖標(biāo)注app 激戰(zhàn)2地圖標(biāo)注 海南400電話如何申請(qǐng) 哈爾濱ai外呼系統(tǒng)定制

這篇博客將介紹如何使用OpenCV和深度學(xué)習(xí)應(yīng)用全面嵌套的邊緣檢測(cè)。并將對(duì)圖像和視頻流應(yīng)用全面嵌套邊緣檢測(cè),然后將結(jié)果與OpenCV的標(biāo)準(zhǔn)Canny邊緣檢測(cè)器進(jìn)行比較。

1. 效果圖

憤怒的小鳥——原始圖 VS Canny邊緣檢測(cè)圖 VS HED邊緣檢測(cè)圖


花朵——原始圖 VS Canny邊緣檢測(cè)圖 VS HED邊緣檢測(cè)圖

視頻效果圖GIF 如下

2. 全面嵌套邊緣檢測(cè)與Canny邊緣檢測(cè)

2.1 Hed與Canny邊緣檢測(cè)對(duì)比

Holistically-Nested Edge Detection (HED) 全面嵌套邊緣檢測(cè)

Canny Edge Detection Canny邊緣檢測(cè)

OpenCV 利用Canny邊緣檢測(cè)能夠找到圖像中對(duì)象的邊界。但是Canny邊緣檢測(cè)器存在一些問題,即:

  • 需要手動(dòng)驗(yàn)證(將下部和上值設(shè)置為滯后閾值,是一種需要實(shí)驗(yàn)和視覺驗(yàn)證的手動(dòng)過程);
  • 不具備通用性(對(duì)不同照明條件下捕獲的相同圖像,適用于一個(gè)圖像,卻不適用于另一個(gè)圖像);
  • 通常需要許多預(yù)處理步驟(即轉(zhuǎn)換為灰度,模糊/平滑等),以獲得良好的邊緣圖。

整體嵌套邊緣檢測(cè)(HED)試圖通過端到端深神經(jīng)網(wǎng)絡(luò)解決Canny邊緣檢測(cè)器的局限性。

該網(wǎng)絡(luò)接受RGB圖像作為輸入,然后將邊緣圖作為輸出產(chǎn)生。而且通過HED產(chǎn)生的邊緣圖在圖像中很好的保留了對(duì)象邊界。

2.2. 項(xiàng)目結(jié)構(gòu)

2.3 deploy.prototxt, hed_pretrained_bsds.caffemodel下載

執(zhí)行代碼的關(guān)鍵是獲取deploy.prototxt, hed_pretrained_bsds.caffemodel
https://github.com/opencv/opencv/blob/master/samples/dnn/edge_detection.py

https://github.com/seminar2012/hed

  • This sample shows how to define custom OpenCV deep learning layers in Python.
  • Holistically-Nested Edge Detection (https://arxiv.org/abs/1504.06375) neural network is used as an example model.
  • Find a pre-trained model at https://github.com/s9xie/hed. We provide the pretrained model and training/testing code for the edge detection framework Holistically-Nested Edge Detection (HED).
  • Please see the Arxiv or ICCV paper for technical details. The pretrained model (fusion-output) gives ODS=.790 and OIS=.808 result on BSDS benchmark dataset.
  • Download the pretrained model (56MB) from (http://vcl.ucsd.edu/hed/hed_pretrained_bsds.caffemodel) and place it in examples/hed/ folder.

3. 源碼

3.1 對(duì)圖像進(jìn)行HED檢測(cè)

# USAGE
# python detect_edges_image.py --edge-detector hed_model --image images/bird.jpg

# 導(dǎo)入必要的包
import argparse
import cv2
import os
import imutils

# 構(gòu)建命令行參數(shù)及解析
# --edge-detector Holistically-Nested Edge Detection檢測(cè)器模型路徑
# --image 圖片路徑
ap = argparse.ArgumentParser()
ap.add_argument("-d", "--edge-detector", type=str, required=True,
                help="path to OpenCV's deep learning edge detector")
ap.add_argument("-i", "--image", type=str, required=True,
                help="path to input image")
args = vars(ap.parse_args())


class CropLayer(object):
    def __init__(self, params, blobs):
        # 初始化剪切區(qū)域開始和結(jié)束點(diǎn)的坐標(biāo)
        self.xstart = 0
        self.ystart = 0
        self.xend = 0
        self.yend = 0

    # 計(jì)算輸入圖像的體積
    def getMemoryShapes(self, inputs):
        # 剪切類將接收倆個(gè)參數(shù)
        # 剪切第一個(gè)輸入blob以匹配第二個(gè)blob,保持批次和通道數(shù)
        # 輸出輸入容積的形狀及目標(biāo)形狀
        # 提取批量大小及通道數(shù)
        # 分別提取目標(biāo)形狀的高和寬
        (inputShape, targetShape) = (inputs[0], inputs[1])
        (batchSize, numChannels) = (inputShape[0], inputShape[1])
        (H, W) = (targetShape[2], targetShape[3])

        # 計(jì)算開始和結(jié)束剪切坐標(biāo)的值
        self.xstart = int((inputShape[3] - targetShape[3]) // 2)
        self.ystart = int((inputShape[2] - targetShape[2]) // 2)
        self.xend = self.xstart + W
        self.yend = self.ystart + H

        # 返回體積,接下來(lái)進(jìn)行實(shí)際裁剪
        return [[batchSize, numChannels, H, W]]

    def forward(self, inputs):
        return [inputs[0][:, :, self.ystart:self.yend, self.xstart:self.xend]]


# 從磁盤加載序列化的邊緣檢測(cè)器模型
print("[INFO] loading edge detector...")
protoPath = os.path.sep.join([args["edge_detector"],
                              "deploy.prototxt"])
modelPath = os.path.sep.join([args["edge_detector"],
                              "hed_pretrained_bsds.caffemodel"])
net = cv2.dnn.readNetFromCaffe(protoPath, modelPath)

# 綁定剪裁類到模型
cv2.dnn_registerLayer("Crop", CropLayer)

# 加載輸入圖像,獲取其維度
image = cv2.imread(args["image"])
image = imutils.resize(image, width=400)
(H, W) = image.shape[:2]

# 轉(zhuǎn)換圖像為灰度圖,高斯平滑,執(zhí)行Canny邊緣檢測(cè)
print("[INFO] performing Canny edge detection...")
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
blurred = cv2.GaussianBlur(gray, (5, 5), 0)
canny = cv2.Canny(blurred, 30, 150)

# 根據(jù)輸入圖像為全面的嵌套邊緣檢測(cè)器(Holistically-Nested Edge Detector)構(gòu)建一個(gè)輸出blob
blob = cv2.dnn.blobFromImage(image, scalefactor=1.0, size=(W, H),
                             mean=(104.00698793, 116.66876762, 122.67891434),
                             swapRB=False, crop=False)

# # 設(shè)置blob作為網(wǎng)絡(luò)的輸入并執(zhí)行算法以計(jì)算邊緣圖
print("[INFO] performing holistically-nested edge detection...")
net.setInput(blob)
hed = net.forward()
# 調(diào)整輸出為原始圖像尺寸的大小
hed = cv2.resize(hed[0, 0], (W, H))
# 將圖像像素縮回到范圍[0,255]并確保類型為“UINT8”
hed = (255 * hed).astype("uint8")

# 展示HED邊緣檢測(cè)的結(jié)果及Canny邊緣檢測(cè)的結(jié)果
cv2.imshow("Input", image)
cv2.imshow("Canny", canny)
cv2.imshow("HED", hed)
cv2.waitKey(0)

3.2 對(duì)視頻進(jìn)行HED檢測(cè)

# USAGE 默認(rèn)使用電腦自帶的攝像頭
# python detect_edges_video.py --edge-detector hed_model
# 使用視頻文件流
# python detect_edges_video.py --edge-detector hed_model --input xl.mp4

# 導(dǎo)入必要的包
from imutils.video import VideoStream
import argparse
import imutils
import time  # 此模塊允許放置睡眠命令以允許視頻流建立和“熱身”。
import cv2
import os

# 構(gòu)建命令行參數(shù)及解析
# --edge-detector Holistically-Nested Edge Detection檢測(cè)器模型路徑
# --input 視頻源:網(wǎng)絡(luò)攝像頭,視頻文件或其他源。
ap = argparse.ArgumentParser()
ap.add_argument("-d", "--edge-detector", type=str, required=True,
                help="path to OpenCV's deep learning edge detector")
ap.add_argument("-i", "--input", type=str,
                help="path to optional input video (webcam will be used otherwise)")
args = vars(ap.parse_args())


class CropLayer(object):
    def __init__(self, params, blobs):
        # 初始化剪切區(qū)域開始和結(jié)束點(diǎn)的坐標(biāo)
        self.xstart = 0
        self.ystart = 0
        self.xend = 0
        self.yend = 0

    # 計(jì)算輸入圖像的體積
    def getMemoryShapes(self, inputs):
        # 剪切類將接收倆個(gè)參數(shù)
        # 剪切第一個(gè)輸入blob以匹配第二個(gè)blob,保持批次和通道數(shù)
        # 輸出輸入容積的形狀及目標(biāo)形狀
        # 提取批量大小及通道數(shù)
        # 分別提取目標(biāo)形狀的高和寬
        (inputShape, targetShape) = (inputs[0], inputs[1])
        (batchSize, numChannels) = (inputShape[0], inputShape[1])
        (H, W) = (targetShape[2], targetShape[3])

        # 計(jì)算開始和結(jié)束剪切坐標(biāo)的值
        self.xstart = int((inputShape[3] - targetShape[3]) // 2)
        self.ystart = int((inputShape[2] - targetShape[2]) // 2)
        self.xend = self.xstart + W
        self.yend = self.ystart + H

        # 返回體積,接下來(lái)進(jìn)行實(shí)際裁剪
        return [[batchSize, numChannels, H, W]]

    def forward(self, inputs):
        # 使用派生(x,y)-oordinate來(lái)執(zhí)行裁剪
        return [inputs[0][:, :, self.ystart:self.yend, self.xstart:self.xend]]


# 初始化視頻流,腳本將動(dòng)態(tài)選取使用視頻文件流還是網(wǎng)絡(luò)攝像頭流
webcam = not args.get("input", False)

# 如果未提供視頻文件路徑,則使用電腦自帶攝像頭
if webcam:
    print("[INFO] starting video stream...")
    vs = VideoStream(src=0).start()
    time.sleep(2.0)
# 否則,獲取視頻文件流指針
else:
    print("[INFO] opening video file...")
    vs = cv2.VideoCapture(args["input"])

# 從磁盤加載序列化的HED檢測(cè)器模型
print("[INFO] loading edge detector...")
protoPath = os.path.sep.join([args["edge_detector"],
                              "deploy.prototxt"])
modelPath = os.path.sep.join([args["edge_detector"],
                              "hed_pretrained_bsds.caffemodel"])
net = cv2.dnn.readNetFromCaffe(protoPath, modelPath)

# 將剪裁類注冊(cè)到模型
cv2.dnn_registerLayer("Crop", CropLayer)

# 遍歷視頻流的幀
while True:
    # 獲取每一幀,如果使用網(wǎng)絡(luò)攝像頭,獲取下一幀
    frame = vs.read()
    frame = frame if webcam else frame[1]

    # 如果在處理視頻文件流,沒有獲取到幀則代表已經(jīng)到了文件尾部,則跳出循環(huán)
    if not webcam and frame is None:
        break

    # 等比例縮放幀為寬度500,并獲取其維度
    frame = imutils.resize(frame, width=300)
    (H, W) = frame.shape[:2]

    # 轉(zhuǎn)換灰度圖,高斯模糊并執(zhí)行Canny邊緣檢測(cè)
    gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
    blurred = cv2.GaussianBlur(gray, (5, 5), 0)
    canny = cv2.Canny(blurred, 30, 150)

    # 為HED邊緣檢測(cè)器構(gòu)建輸入幀的blob,設(shè)置blob,并執(zhí)行檢測(cè)以計(jì)算邊緣圖
    blob = cv2.dnn.blobFromImage(frame, scalefactor=1.0, size=(W, H),
                                 mean=(104.00698793, 116.66876762, 122.67891434),
                                 swapRB=False, crop=False)
    net.setInput(blob)
    hed = net.forward()
    hed = cv2.resize(hed[0, 0], (W, H))
    hed = (255 * hed).astype("uint8")

    # 展示Canny、HED的檢測(cè)結(jié)果
    cv2.imshow("Frame", frame)
    cv2.imshow("Canny", canny)
    cv2.imshow("HED", hed)
    key = cv2.waitKey(1)  0xFF
    # 按下‘q'鍵表示退出循環(huán)
    if key == ord("q"):
        break

# 如果在使用網(wǎng)絡(luò)攝像頭流,則終止相機(jī)視頻流
if webcam:
    vs.stop()
# 否則,釋放視頻文件流指針
else:
    vs.release()

# 關(guān)閉所有打開的window
cv2.destroyAllWindows()

參考

 https://www.pyimagesearch.com/2019/03/04/holistically-nested-edge-detection-with-opencv-and-deep-learning/

到此這篇關(guān)于使用Python中OpenCV和深度學(xué)習(xí)進(jìn)行全面嵌套邊緣檢測(cè)的文章就介紹到這了,更多相關(guān)OpenCV和深度學(xué)習(xí)全面嵌套邊緣檢測(cè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python OpenCV實(shí)現(xiàn)邊緣檢測(cè)
  • OpenCV中Canny邊緣檢測(cè)的實(shí)現(xiàn)
  • Python實(shí)現(xiàn)Opencv cv2.Canny()邊緣檢測(cè)
  • OpenCV實(shí)現(xiàn)灰度、高斯模糊、邊緣檢測(cè)的示例
  • Python使用Opencv實(shí)現(xiàn)邊緣檢測(cè)以及輪廓檢測(cè)的實(shí)現(xiàn)
  • 如何利用Python 進(jìn)行邊緣檢測(cè)
  • python實(shí)現(xiàn)canny邊緣檢測(cè)
  • OpenCV半小時(shí)掌握基本操作之邊緣檢測(cè)

標(biāo)簽:鷹潭 四川 黑龍江 黔西 常德 上海 惠州 益陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用Python中OpenCV和深度學(xué)習(xí)進(jìn)行全面嵌套邊緣檢測(cè)》,本文關(guān)鍵詞  使用,Python,中,OpenCV,和,深度,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用Python中OpenCV和深度學(xué)習(xí)進(jìn)行全面嵌套邊緣檢測(cè)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于使用Python中OpenCV和深度學(xué)習(xí)進(jìn)行全面嵌套邊緣檢測(cè)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美一区二区福利在线| 首页综合国产亚洲丝袜| 日韩亚洲电影在线| 成人欧美一区二区三区1314| 国产主播一区二区| 5858s免费视频成人| 亚洲男人的天堂在线观看| 久久99久久久欧美国产| 精品视频在线免费观看| 亚洲综合激情小说| 91精品国产全国免费观看| 香蕉久久夜色精品国产使用方法| 欧美日韩免费观看一区二区三区| 国产精品久久777777| 不卡一二三区首页| 国产精品沙发午睡系列990531| 亚洲va中文字幕| 日韩免费成人网| 亚洲人xxxx| 欧美一区二区免费视频| 美女网站视频久久| 中文字幕制服丝袜成人av| 欧美在线高清视频| 国产乱人伦偷精品视频免下载| 欧美一级在线免费| 国产不卡视频一区| 夜夜爽夜夜爽精品视频| 日韩一区二区高清| 99在线精品免费| 麻豆国产欧美日韩综合精品二区| 国产日韩视频一区二区三区| 91免费观看视频在线| 日本午夜一本久久久综合| 欧美一区二区三区四区久久| 日本乱人伦一区| 99国产精品国产精品久久| 久久精品国产亚洲5555| 日韩精品亚洲专区| 有坂深雪av一区二区精品| 久久久一区二区| 欧美久久一二区| 91黄色免费看| 91亚洲精品久久久蜜桃网站| 国产一区二区三区不卡在线观看| 亚洲成a人v欧美综合天堂下载 | 欧美一区三区二区| 精品一区二区三区在线观看国产 | 日本乱码高清不卡字幕| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 亚洲成a人片综合在线| 久久99热狠狠色一区二区| 欧美精品色综合| 在线播放中文一区| 91精品国产一区二区| 欧美日韩aaaaaa| 日韩写真欧美这视频| 欧美日产在线观看| 久久久一区二区三区| 亚洲成在人线免费| 国产激情一区二区三区四区| 国产成人av影院| 色av一区二区| 久久久亚洲午夜电影| 亚洲欧美日本在线| 日韩精品电影一区亚洲| 波波电影院一区二区三区| 国产精品18久久久久久久网站| 9191久久久久久久久久久| 国产精品无圣光一区二区| 成人欧美一区二区三区1314 | 色999日韩国产欧美一区二区| 精品国产免费视频| 亚洲免费资源在线播放| 极品销魂美女一区二区三区| 精品国产免费一区二区三区香蕉 | 自拍偷拍欧美精品| 久久综合久久鬼色| 亚洲视频在线一区观看| 欧美亚洲另类激情小说| 美国精品在线观看| 一区二区三区久久久| 91福利精品视频| 美国欧美日韩国产在线播放| 欧美成人三级在线| 日韩av一区二区在线影视| 91精品一区二区三区在线观看| 老司机免费视频一区二区三区| 91高清在线观看| 秋霞成人午夜伦在线观看| 欧美日韩一区二区在线观看视频| 亚洲综合色区另类av| 欧美日韩国产区一| 国产专区综合网| 中文字幕一区二区三区不卡| 欧美日韩国产精品成人| 日韩一区精品字幕| 国产欧美日韩在线| 欧美日韩不卡视频| 国产精品自产自拍| 丝袜诱惑亚洲看片| 中文字幕制服丝袜一区二区三区| 欧美一区二区三区播放老司机| 青青草91视频| 午夜亚洲福利老司机| 亚洲免费电影在线| 日韩欧美的一区| 宅男噜噜噜66一区二区66| 欧美色中文字幕| 国产成人午夜电影网| 日本不卡视频在线| 亚洲小少妇裸体bbw| 精品国产露脸精彩对白 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 久久久久一区二区三区四区| 成人黄色av电影| 精品一区二区三区在线观看国产| 亚洲香蕉伊在人在线观| 樱花草国产18久久久久| 中文字幕中文乱码欧美一区二区| 亚洲国产精品国自产拍av| 精品精品国产高清一毛片一天堂| 欧美xingq一区二区| 久久久久久久久久美女| 久久久高清一区二区三区| 国产精品久久久久久久久免费丝袜 | 国产精品1区2区| 国产一区二区在线影院| 色系网站成人免费| 日韩丝袜情趣美女图片| 亚洲婷婷综合色高清在线| 午夜亚洲国产au精品一区二区| 精久久久久久久久久久| 欧美精品v国产精品v日韩精品| 精品成人私密视频| 中文字幕av一区二区三区免费看| 91激情在线视频| 91老司机福利 在线| 另类小说色综合网站| 久久久蜜桃精品| 国产精品久久久久久久久图文区 | 欧美三级一区二区| 99久久久国产精品| 国产激情精品久久久第一区二区| 免费观看在线综合| 成人av网站在线观看免费| 国产91在线观看| 91成人看片片| 日韩一级免费观看| 亚洲精品国产精品乱码不99| 久久久久久久久久久久久久久99| 国产精品欧美久久久久无广告| 中文字幕日本不卡| 久久国产婷婷国产香蕉| 91色视频在线| 亚洲女厕所小便bbb| 99精品久久99久久久久| 国产精品色在线| 风流少妇一区二区| 日韩一区二区三区视频在线| 亚洲精品菠萝久久久久久久| 国产精品一区二区久久不卡| 日韩一区二区精品| 精品一区二区三区免费观看 | 亚洲欧美日韩国产综合| 国产成人一级电影| 久久久国产一区二区三区四区小说| 热久久国产精品| 精品日韩成人av| 国产精品原创巨作av| 久久午夜色播影院免费高清| 激情亚洲综合在线| 久久久不卡影院| 97aⅴ精品视频一二三区| 午夜精品一区二区三区三上悠亚| 91片黄在线观看| 亚洲国产精品一区二区www在线| 欧美日韩一卡二卡三卡 | 欧美一区二区三区啪啪| 美女性感视频久久| 国产精品欧美综合在线| 欧美三级日韩三级| 国产精品亚洲成人| 亚洲欧美日韩国产成人精品影院| 91精品国产麻豆国产自产在线 | 国产福利一区二区三区| 亚洲欧美日韩在线不卡| 久久亚洲一区二区三区明星换脸| 91亚洲国产成人精品一区二区三 | 91精品国产综合久久精品app| 国产精品1区二区.| 久久狠狠亚洲综合| 亚洲高清久久久| 亚洲永久免费视频| 亚洲欧洲一区二区在线播放| 欧美大片国产精品| 日韩欧美中文字幕一区| 5566中文字幕一区二区电影| 色av一区二区| 欧美精品电影在线播放| 欧美无砖专区一中文字|