佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > OpenCV半小時掌握基本操作之分水嶺算法

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

熱門標簽:銀行業(yè)務 呼叫中心市場需求 檢查注冊表項 智能手機 美圖手機 服務器配置 網(wǎng)站文章發(fā)布 鐵路電話系統(tǒng)

【OpenCV】⚠️高手勿入! 半小時學會基本操作 ⚠️ 分水嶺算法

概述

OpenCV 是一個跨平臺的計算機視覺庫, 支持多語言, 功能強大. 今天小白就帶大家一起攜手走進 OpenCV 的世界.

分水嶺算法

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

分水嶺分割流程:

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

距離變換

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

連通域

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

格式:

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

參數(shù):

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

分水嶺

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

格式:

cv2.watershed(image, markers)

參數(shù):

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

代碼實戰(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)

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

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

    # 開運算
    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)

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

    # 分水嶺計算
    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")

    # 標題
    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))

    # 標題
    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)

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

輸出結果:

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

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

標簽:長治 樂山 上海 滄州 紅河 新疆 沈陽 河南

巨人網(wǎng)絡通訊聲明:本文標題《OpenCV半小時掌握基本操作之分水嶺算法》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    柳江县| 湟源县| 南平市| 红安县| 濉溪县| 阿拉善右旗| 灵寿县| 洛浦县| 朝阳县| 宁南县| 桦甸市| 雷州市| 喀什市| 盘山县| 石首市| 佛山市| 山东| 睢宁县| 石楼县| 绩溪县| 苍山县| 屯昌县| 息烽县| 错那县| 惠来县| 永和县| 石首市| 潍坊市| 武宁县| 泽普县| 孟津县| 沁源县| 襄樊市| 论坛| 封开县| 五寨县| 凤阳县| 英山县| 盐津县| 玉门市| 永善县|