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

主頁 > 知識庫 > 使用Python中OpenCV和深度學習進行全面嵌套邊緣檢測

使用Python中OpenCV和深度學習進行全面嵌套邊緣檢測

熱門標簽:公司電話機器人 騰訊外呼線路 白銀外呼系統 陜西金融外呼系統 唐山智能外呼系統一般多少錢 廣告地圖標注app 激戰2地圖標注 海南400電話如何申請 哈爾濱ai外呼系統定制

這篇博客將介紹如何使用OpenCV和深度學習應用全面嵌套的邊緣檢測。并將對圖像和視頻流應用全面嵌套邊緣檢測,然后將結果與OpenCV的標準Canny邊緣檢測器進行比較。

1. 效果圖

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


花朵——原始圖 VS Canny邊緣檢測圖 VS HED邊緣檢測圖

視頻效果圖GIF 如下

2. 全面嵌套邊緣檢測與Canny邊緣檢測

2.1 Hed與Canny邊緣檢測對比

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

Canny Edge Detection Canny邊緣檢測

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

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

整體嵌套邊緣檢測(HED)試圖通過端到端深神經網絡解決Canny邊緣檢測器的局限性。

該網絡接受RGB圖像作為輸入,然后將邊緣圖作為輸出產生。而且通過HED產生的邊緣圖在圖像中很好的保留了對象邊界。

2.2. 項目結構

2.3 deploy.prototxt, hed_pretrained_bsds.caffemodel下載

執行代碼的關鍵是獲取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 對圖像進行HED檢測

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

# 導入必要的包
import argparse
import cv2
import os
import imutils

# 構建命令行參數及解析
# --edge-detector Holistically-Nested Edge Detection檢測器模型路徑
# --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):
        # 初始化剪切區域開始和結束點的坐標
        self.xstart = 0
        self.ystart = 0
        self.xend = 0
        self.yend = 0

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

        # 計算開始和結束剪切坐標的值
        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

        # 返回體積,接下來進行實際裁剪
        return [[batchSize, numChannels, H, W]]

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


# 從磁盤加載序列化的邊緣檢測器模型
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]

# 轉換圖像為灰度圖,高斯平滑,執行Canny邊緣檢測
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)

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

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

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

3.2 對視頻進行HED檢測

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

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

# 構建命令行參數及解析
# --edge-detector Holistically-Nested Edge Detection檢測器模型路徑
# --input 視頻源:網絡攝像頭,視頻文件或其他源。
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):
        # 初始化剪切區域開始和結束點的坐標
        self.xstart = 0
        self.ystart = 0
        self.xend = 0
        self.yend = 0

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

        # 計算開始和結束剪切坐標的值
        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

        # 返回體積,接下來進行實際裁剪
        return [[batchSize, numChannels, H, W]]

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


# 初始化視頻流,腳本將動態選取使用視頻文件流還是網絡攝像頭流
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檢測器模型
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)

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

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

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

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

    # 為HED邊緣檢測器構建輸入幀的blob,設置blob,并執行檢測以計算邊緣圖
    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的檢測結果
    cv2.imshow("Frame", frame)
    cv2.imshow("Canny", canny)
    cv2.imshow("HED", hed)
    key = cv2.waitKey(1)  0xFF
    # 按下‘q'鍵表示退出循環
    if key == ord("q"):
        break

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

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

參考

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

到此這篇關于使用Python中OpenCV和深度學習進行全面嵌套邊緣檢測的文章就介紹到這了,更多相關OpenCV和深度學習全面嵌套邊緣檢測內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

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

標簽:鷹潭 四川 黑龍江 黔西 常德 上海 惠州 益陽

巨人網絡通訊聲明:本文標題《使用Python中OpenCV和深度學習進行全面嵌套邊緣檢測》,本文關鍵詞  使用,Python,中,OpenCV,和,深度,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用Python中OpenCV和深度學習進行全面嵌套邊緣檢測》相關的同類信息!
  • 本頁收集關于使用Python中OpenCV和深度學習進行全面嵌套邊緣檢測的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91精品欧美久久久久久动漫| 国产v综合v亚洲欧| 亚洲欧美激情在线| 国产精品国产自产拍高清av王其| 国产亚洲综合在线| 国产校园另类小说区| 久久精品人人做| 亚洲欧洲精品天堂一级 | 色伊人久久综合中文字幕| 成人动漫中文字幕| 91蜜桃视频在线| 欧美午夜理伦三级在线观看| 欧美精品久久天天躁| 精品久久一区二区三区| 国产女同性恋一区二区| 亚洲另类中文字| 肉丝袜脚交视频一区二区| 麻豆成人久久精品二区三区红| 极品瑜伽女神91| proumb性欧美在线观看| 在线免费一区三区| 日韩三级在线免费观看| 国产精品视频一二| 亚洲国产一区视频| 国产乱人伦精品一区二区在线观看| 国产剧情一区二区| 欧美在线|欧美| 精品99一区二区三区| 中文字幕视频一区| 麻豆成人免费电影| 色噜噜久久综合| 久久嫩草精品久久久精品一| 亚洲欧美日韩一区二区三区在线观看| 亚洲福中文字幕伊人影院| 国产原创一区二区| 欧美色国产精品| 国产精品久久久久毛片软件| 日本少妇一区二区| 91丝袜美腿高跟国产极品老师| 91精品国产91久久久久久一区二区 | 91猫先生在线| 久久嫩草精品久久久久| 亚洲mv在线观看| hitomi一区二区三区精品| 日韩免费观看高清完整版| 亚洲精品视频在线看| 国产成人av一区二区三区在线观看| 色综合色狠狠综合色| 久久久久国产免费免费| 日韩av不卡在线观看| 91麻豆文化传媒在线观看| 国产清纯白嫩初高生在线观看91 | 国产精品午夜在线观看| 男人操女人的视频在线观看欧美| 91小视频在线免费看| 国产婷婷色一区二区三区四区| 亚洲国产wwwccc36天堂| 色婷婷狠狠综合| 亚洲同性同志一二三专区| 国产麻豆一精品一av一免费| 欧美一区二区性放荡片| 亚洲成人av资源| 欧美日韩在线播放三区四区| 亚洲男同1069视频| 91色porny蝌蚪| 日韩理论片在线| 91在线精品一区二区| 一区免费观看视频| 成人永久aaa| 中文字幕日韩av资源站| aaa亚洲精品| 日韩一区中文字幕| 色综合色狠狠天天综合色| 亚洲人妖av一区二区| eeuss鲁一区二区三区| 国产精品国产成人国产三级 | 7777精品伊人久久久大香线蕉经典版下载| 亚洲视频在线观看三级| 色婷婷综合视频在线观看| 亚洲在线免费播放| 欧美日韩视频在线第一区| 亚洲va欧美va国产va天堂影院| 欧美日韩一区精品| 日本视频一区二区三区| 欧美videossexotv100| 国产老妇另类xxxxx| 国产日本欧美一区二区| 97精品电影院| 亚洲成av人片一区二区梦乃| 3d动漫精品啪啪| 激情综合色综合久久综合| 久久亚洲综合色| 99久久夜色精品国产网站| 一区二区在线观看视频在线观看| 欧美日本高清视频在线观看| 国内成人精品2018免费看| 国产精品视频看| 欧美日韩在线播放| 国产精品综合一区二区| 一区二区在线观看av| 日韩一二在线观看| av激情综合网| 日本成人在线看| 国产精品色婷婷久久58| 欧美精品777| 国产精品中文字幕一区二区三区| 亚洲精品视频一区二区| 亚洲精品一线二线三线无人区| eeuss鲁片一区二区三区在线看| 天天亚洲美女在线视频| 久久精品夜夜夜夜久久| 欧美日韩久久久久久| 国产精品一卡二| 亚洲成a人片综合在线| 中文幕一区二区三区久久蜜桃| 欧美性色黄大片| 成人中文字幕合集| 裸体歌舞表演一区二区| 一区二区三区四区精品在线视频| 精品国产乱码久久久久久图片| 91成人免费网站| 成人白浆超碰人人人人| 美女视频黄久久| 一区二区三区四区在线免费观看| 久久色.com| 在线不卡的av| 在线观看国产日韩| thepron国产精品| 国内外成人在线视频| 日韩专区一卡二卡| 亚洲一区二区三区中文字幕| 国产精品国产三级国产普通话三级| 精品少妇一区二区三区在线播放| 欧美日韩视频一区二区| 91行情网站电视在线观看高清版| 国产成人在线视频网站| 国产精一区二区三区| 美女任你摸久久| 日本中文字幕一区二区视频 | 国产精品乡下勾搭老头1| 日韩电影免费在线观看网站| 夜夜嗨av一区二区三区中文字幕| 国产精品伦理在线| 国产女主播在线一区二区| 国产午夜精品福利| 欧美国产日韩在线观看| 久久精品亚洲精品国产欧美 | 一区二区三区蜜桃| 亚洲欧美一区二区三区孕妇| 亚洲天堂福利av| 自拍偷拍欧美精品| 亚洲欧美日韩精品久久久久| 日韩一区中文字幕| 亚洲免费高清视频在线| 亚洲精品日日夜夜| 亚洲成年人网站在线观看| 日产精品久久久久久久性色| 免费在线看成人av| 久久99精品国产91久久来源| 国产一区二区在线视频| 国产xxx精品视频大全| 成人黄动漫网站免费app| 色综合天天视频在线观看| 欧美在线制服丝袜| 欧美一区中文字幕| 国产日韩精品一区| 亚洲伦在线观看| 日产国产高清一区二区三区| 国产乱淫av一区二区三区| 成人高清在线视频| 欧美日韩亚洲综合一区| 日韩欧美中文字幕一区| 国产色婷婷亚洲99精品小说| 国产精品短视频| 日韩国产高清在线| 国产一区二区三区综合| 国产jizzjizz一区二区| 在线观看精品一区| 久久色.com| 亚洲综合在线观看视频| 日本强好片久久久久久aaa| 国产不卡免费视频| 欧美欧美午夜aⅴ在线观看| 久久久久久一级片| 亚洲最大成人网4388xx| 国内成+人亚洲+欧美+综合在线| hitomi一区二区三区精品| 69堂成人精品免费视频| 亚洲国产成人在线| 看片的网站亚洲| 欧美伊人久久大香线蕉综合69| 欧美成人激情免费网| 一区二区三区久久久| 粉嫩av亚洲一区二区图片| 欧美色倩网站大全免费| 国产精品入口麻豆原神| 玖玖九九国产精品| 欧美色图在线观看| 1000部国产精品成人观看| 韩国精品主播一区二区在线观看|