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

主頁(yè) > 知識(shí)庫(kù) > OpenCV半小時(shí)掌握基本操作之分水嶺算法

OpenCV半小時(shí)掌握基本操作之分水嶺算法

熱門標(biāo)簽:B52系統(tǒng)電梯外呼顯示E7 沈陽(yáng)防封電銷電話卡 企業(yè)微信地圖標(biāo)注 銀川電話機(jī)器人電話 高德地圖標(biāo)注收入咋樣 怎么辦理400客服電話 鶴壁手機(jī)自動(dòng)外呼系統(tǒng)違法嗎 萊蕪電信外呼系統(tǒng) 地圖標(biāo)注多個(gè)

【OpenCV】⚠️高手勿入! 半小時(shí)學(xué)會(huì)基本操作 ⚠️ 分水嶺算法

概述

OpenCV 是一個(gè)跨平臺(tái)的計(jì)算機(jī)視覺(jué)庫(kù), 支持多語(yǔ)言, 功能強(qiáng)大. 今天小白就帶大家一起攜手走進(jìn) OpenCV 的世界.

分水嶺算法

分水嶺算法 (Watershed Algorithm) 是一種圖像區(qū)域分割算法. 在分割的過(guò)程中, 分水嶺算法會(huì)把跟臨近像素間的相似性作為重要的根據(jù).

分水嶺分割流程:

  1. 讀取圖片
  2. 轉(zhuǎn)換成灰度圖
  3. 二值化
  4. 距離變換
  5. 尋找種子
  6. 生成 Marker
  7. 分水嶺變換

距離變換

距離變換 (Distance Transform)通過(guò)計(jì)算圖像中非零像素點(diǎn)到最近像素的距離, 實(shí)現(xiàn)了像素與圖像區(qū)域的距離變換.

連通域

連通域 (Connected Components) 指的是圖像中具有相同像素且位置相鄰的前景像素點(diǎn)組成的圖像區(qū)域.

格式:

cv2.connectedComponents(image, labels=None, connectivity=None, ltype=None)

參數(shù):

  • image: 輸入圖像, 必須是 uint8 二值圖像
  • labels 圖像上每一像素的標(biāo)記, 用數(shù)字 1, 2, 3 表示

分水嶺

算法會(huì)根據(jù) markers 傳入的輪廓作為種子, 對(duì)圖像上其他的像素點(diǎn)根據(jù)分水嶺算法規(guī)則進(jìn)行判斷, 并對(duì)每個(gè)像素點(diǎn)的區(qū)域歸屬進(jìn)行劃定. 區(qū)域之間的分界處的值被賦值為 -1.

格式:

cv2.watershed(image, markers)

參數(shù):

  • image: 輸入圖像
  • markers: 種子, 包含不同區(qū)域的輪廓

代碼實(shí)戰(zhàn)

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


def watershed(image):
    """分水嶺算法"""

    # 卷積核
    kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (3, 3))

    # 均值遷移濾波
    blur = cv2.pyrMeanShiftFiltering(image, 10, 100)

    # 轉(zhuǎn)換成灰度圖
    image_gray = cv2.cvtColor(blur, cv2.COLOR_BGR2GRAY)

    # 二值化
    ret1, thresh1 = cv2.threshold(image_gray, 0, 255, cv2.THRESH_OTSU)

    # 開運(yùn)算
    open = cv2.morphologyEx(thresh1, cv2.MORPH_OPEN, kernel, iterations=2)

    # 膨脹
    dilate = cv2.dilate(open, kernel, iterations=3)

    # 距離變換
    dist = cv2.distanceTransform(dilate, cv2.DIST_L2, 3)
    dist = cv2.normalize(dist, 0, 1.0, cv2.NORM_MINMAX)
    print(dist.max())

    # 二值化
    ret2, thresh2 = cv2.threshold(dist, dist.max() * 0.6, 255, cv2.THRESH_BINARY)
    thresh2 = np.uint8(thresh2)

    # 分水嶺計(jì)算
    unknown = cv2.subtract(dilate, thresh2)
    ret3, component = cv2.connectedComponents(thresh2)
    print(ret3)

    # 分水嶺計(jì)算
    markers = component + 1
    markers[unknown == 255] = 0
    result = cv2.watershed(image, markers=markers)
    image[result == -1] = [0, 0, 255]

    # 圖片展示
    image_show((image, blur, image_gray, thresh1, open, dilate), (dist, thresh2, unknown, component, markers, image))

    return image


def image_show(graph1, graph2):
    """繪制圖片"""

    # 圖像1
    original, blur, gray, binary1, open, dilate = graph1

    # 圖像2
    dist, binary2, unknown, component, markers, result = graph2

    f, ax = plt.subplots(3, 2, figsize=(12, 16))

    # 繪制子圖
    ax[0, 0].imshow(cv2.cvtColor(original, cv2.COLOR_BGR2RGB))
    ax[0, 1].imshow(cv2.cvtColor(blur, cv2.COLOR_BGR2RGB))
    ax[1, 0].imshow(gray, "gray")
    ax[1, 1].imshow(binary1, "gray")
    ax[2, 0].imshow(open, "gray")
    ax[2, 1].imshow(dilate, "gray")

    # 標(biāo)題
    ax[0, 0].set_title("original")
    ax[0, 1].set_title("image blur")
    ax[1, 0].set_title("image gray")
    ax[1, 1].set_title("image binary1")
    ax[2, 0].set_title("image open")
    ax[2, 1].set_title("image dilate")

    plt.show()

    f, ax = plt.subplots(3, 2, figsize=(12, 16))

    # 繪制子圖
    ax[0, 0].imshow(dist, "gray")
    ax[0, 1].imshow(binary2, "gray")
    ax[1, 0].imshow(unknown, "gray")
    ax[1, 1].imshow(component, "gray")
    ax[2, 0].imshow(markers, "gray")
    ax[2, 1].imshow(cv2.cvtColor(result, cv2.COLOR_BGR2RGB))

    # 標(biāo)題
    ax[0, 0].set_title("image distance")
    ax[0, 1].set_title("image binary2")
    ax[1, 0].set_title("image unknown")
    ax[1, 1].set_title("image component")
    ax[2, 0].set_title("image markers")
    ax[2, 1].set_title("result")

    plt.show()


if __name__ == "__main__":
    # 讀取圖片
    image = cv2.imread("coin.jpg")

    # 分水嶺算法
    result = watershed(image)

    # 保存結(jié)果
    cv2.imwrite("result.jpg", result)

輸出結(jié)果:

到此這篇關(guān)于OpenCV半小時(shí)掌握基本操作之分水嶺算法的文章就介紹到這了,更多相關(guān)OpenCV分水嶺算法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • OpenCV半小時(shí)掌握基本操作之圖像裁剪融合
  • OpenCV半小時(shí)掌握基本操作之圖像處理
  • opencv-python基本圖像處理詳解
  • OpenCV圖像處理基本操作詳解
  • Opencv圖像處理之詳解掩膜mask
  • 基于python的opencv圖像處理實(shí)現(xiàn)對(duì)斑馬線的檢測(cè)示例
  • Python+OpenCV圖像處理——圖像二值化的實(shí)現(xiàn)
  • OpenCV半小時(shí)掌握基本操作之傅里葉變換
  • OpenCV半小時(shí)掌握基本操作之圖像輪廓
  • OpenCV半小時(shí)掌握基本操作之直方圖
  • OpenCV半小時(shí)掌握基本操作之模板匹配
  • OpenCV半小時(shí)掌握基本操作之圓圈檢測(cè)
  • OpenCV半小時(shí)掌握基本操作之對(duì)象測(cè)量
  • OpenCV半小時(shí)掌握基本操作之圖像基礎(chǔ)操作

標(biāo)簽:葫蘆島 湘西 三亞 銀川 烏魯木齊 呼倫貝爾 呼倫貝爾 安慶

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《OpenCV半小時(shí)掌握基本操作之分水嶺算法》,本文關(guān)鍵詞  OpenCV,半小時(shí),掌握,基本操作,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《OpenCV半小時(shí)掌握基本操作之分水嶺算法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于OpenCV半小時(shí)掌握基本操作之分水嶺算法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩黄色免费网站| 日韩一区二区三区精品视频| 91在线观看成人| 51精品国自产在线| 香蕉av福利精品导航 | 性做久久久久久免费观看| 日韩中文字幕一区二区三区| 国产一区福利在线| 91高清视频在线| 久久久久久久久97黄色工厂| 亚洲精品va在线观看| 不卡av电影在线播放| 欧美精品xxxxbbbb| 国产精品情趣视频| 不卡区在线中文字幕| 欧美激情中文字幕一区二区| 奇米精品一区二区三区在线观看一| 91蜜桃网址入口| 一区二区三区中文字幕在线观看| 成年人国产精品| 亚洲精品一卡二卡| 色天使色偷偷av一区二区| 亚洲国产视频直播| 成人午夜碰碰视频| 亚洲欧美综合网| 欧美无砖专区一中文字| 久久丁香综合五月国产三级网站| 精品少妇一区二区三区日产乱码| 成人av影视在线观看| 日日夜夜精品视频天天综合网| 精品国产一区二区三区不卡 | 亚洲r级在线视频| 日韩一区二区三免费高清| 国产精品69毛片高清亚洲| 亚洲国产精品嫩草影院| 日本一区二区三区在线观看| 精品视频1区2区3区| 国产成人免费在线观看不卡| 亚洲r级在线视频| 亚洲精品一二三区| 亚洲欧美日韩一区二区三区在线观看| 欧美一区二区三区在线电影| 欧美老年两性高潮| 在线观看网站黄不卡| 丁香六月综合激情| 国产精品18久久久久久久久| 国内精品伊人久久久久影院对白| 三级不卡在线观看| 久久不见久久见免费视频7| 日本不卡一区二区三区| 日韩av成人高清| 国产一区二区在线电影| 免费观看在线综合| 国产综合久久久久久鬼色| 国产一区二区电影| 成人午夜激情视频| 91福利精品第一导航| 欧美一区二区三区小说| 国产精品私房写真福利视频| 国产精品久久三| 日本成人在线一区| 北条麻妃国产九九精品视频| 色狠狠色狠狠综合| 久久精品亚洲精品国产欧美| 亚洲在线中文字幕| 国产精品一区二区无线| 91极品视觉盛宴| 久久久久久久一区| 一区二区三区 在线观看视频 | 精品国产伦一区二区三区观看体验 | 国产精品高潮久久久久无| 伊人性伊人情综合网| 美女高潮久久久| 欧美探花视频资源| 亚洲欧美日韩在线| 蜜桃av噜噜一区| 91国产视频在线观看| 久久久久国产免费免费| 麻豆精品一区二区av白丝在线| 91丨九色porny丨蝌蚪| 久久久亚洲欧洲日产国码αv| 亚洲一区二区三区三| 91精品办公室少妇高潮对白| 国产精品电影一区二区三区| 国产资源在线一区| 日韩午夜av一区| 精品亚洲免费视频| 国产欧美精品国产国产专区| 国产激情一区二区三区四区| 久久久久国色av免费看影院| 国产成人精品综合在线观看 | 国产精品女同一区二区三区| 成人免费视频国产在线观看| 亚洲精品久久久蜜桃| 欧美日韩一级黄| 国产一区二区日韩精品| 成人免费一区二区三区视频 | 国产乱码精品一品二品| 久久免费精品国产久精品久久久久| 亚洲国产视频一区| 制服视频三区第一页精品| 亚洲国产精品麻豆| 51午夜精品国产| 国产成人三级在线观看| 一区二区三区精品| 精品国产自在久精品国产| 国产成人99久久亚洲综合精品| 亚洲精品大片www| 久久久久97国产精华液好用吗| 欧美综合在线视频| 成人性生交大片免费看视频在线| 日韩va亚洲va欧美va久久| 国产精品第一页第二页第三页| 欧美一级精品在线| 欧美一区二区免费| 欧亚洲嫩模精品一区三区| 成人美女视频在线观看18| 亚洲午夜在线电影| 依依成人综合视频| 亚洲女爱视频在线| 亚洲精品成人精品456| 国产午夜亚洲精品理论片色戒| 日韩你懂的电影在线观看| 欧美日韩一区三区四区| 欧美私人免费视频| 69久久夜色精品国产69蝌蚪网| 精品视频一区二区不卡| 在线观看亚洲精品| 欧美日本韩国一区二区三区视频| 9191久久久久久久久久久| 欧美理论片在线| 久久久一区二区三区捆绑**| 久久久精品日韩欧美| 国产精品电影院| 日韩电影在线一区二区三区| 久久99最新地址| 99久久精品免费看国产| 欧美影片第一页| 国产夜色精品一区二区av| 国产精品国产三级国产普通话99 | 56国语精品自产拍在线观看| 日韩欧美在线一区二区三区| 日本一区二区三区四区| 综合久久国产九一剧情麻豆| 日精品一区二区| 91丝袜国产在线播放| 精品国产一区二区三区不卡| 亚洲v中文字幕| 91麻豆国产自产在线观看| 日韩免费看的电影| 午夜精品久久久久久久99水蜜桃| 国产二区国产一区在线观看| 正在播放亚洲一区| 亚洲高清久久久| 在线视频你懂得一区| 亚洲色图19p| 欧美午夜片在线观看| 日韩精品乱码av一区二区| 成人avav影音| 一区二区三区.www| 91精品啪在线观看国产60岁| 人妖欧美一区二区| 日韩欧美亚洲另类制服综合在线| 日本vs亚洲vs韩国一区三区| 日韩欧美视频在线| 国产电影精品久久禁18| 亚洲欧洲日韩av| 欧美日韩精品福利| 国产一本一道久久香蕉| 最新中文字幕一区二区三区| 99在线精品视频| 丝袜美腿亚洲色图| 国产精品久久久久桃色tv| 成人久久视频在线观看| 一区二区三区精品久久久| 欧美一级免费大片| 成人动漫精品一区二区| 亚洲一二三专区| 国产亚洲一区二区三区四区| 99久久精品费精品国产一区二区| 中文一区二区在线观看| 粉嫩aⅴ一区二区三区四区五区| 亚洲色欲色欲www| 欧美日韩免费一区二区三区视频| 久久精品国产色蜜蜜麻豆| 国产精品蜜臀av| 日韩一区二区三区电影| 欧美中文字幕久久| 国产精品系列在线观看| 亚洲精选一二三| 久久美女艺术照精彩视频福利播放| jizzjizzjizz欧美| 国产91露脸合集magnet| 国产精品免费视频一区| 久久久精品2019中文字幕之3| 色猫猫国产区一区二在线视频| 精品一区二区免费视频| 免费在线观看精品| 偷拍亚洲欧洲综合| 日韩综合小视频|