
- Mahotas 教程
- Mahotas - 首頁
- Mahotas - 簡介
- Mahotas - 計算機視覺
- Mahotas - 歷史
- Mahotas - 特性
- Mahotas - 安裝
- Mahotas 處理影像
- Mahotas - 處理影像
- Mahotas - 載入影像
- Mahotas - 載入灰度影像
- Mahotas - 顯示影像
- Mahotas - 顯示影像形狀
- Mahotas - 儲存影像
- Mahotas - 影像質心
- Mahotas - 影像卷積
- Mahotas - 建立 RGB 影像
- Mahotas - 影像尤拉數
- Mahotas - 影像中零值的比例
- Mahotas - 獲取影像矩
- Mahotas - 影像區域性最大值
- Mahotas - 影像橢圓軸
- Mahotas - 影像拉伸 RGB
- Mahotas 顏色空間轉換
- Mahotas - 顏色空間轉換
- Mahotas - RGB 到灰度轉換
- Mahotas - RGB 到 LAB 轉換
- Mahotas - RGB 到 Sepia 轉換
- Mahotas - RGB 到 XYZ 轉換
- Mahotas - XYZ 到 LAB 轉換
- Mahotas - XYZ 到 RGB 轉換
- Mahotas - 增加伽馬校正
- Mahotas - 拉伸伽馬校正
- Mahotas 標記影像函式
- Mahotas - 標記影像函式
- Mahotas - 標記影像
- Mahotas - 過濾區域
- Mahotas - 邊界畫素
- Mahotas - 形態學操作
- Mahotas - 形態學運算子
- Mahotas - 查詢影像平均值
- Mahotas - 裁剪影像
- Mahotas - 影像偏心率
- Mahotas - 影像疊加
- Mahotas - 影像圓度
- Mahotas - 調整影像大小
- Mahotas - 影像直方圖
- Mahotas - 膨脹影像
- Mahotas - 腐蝕影像
- Mahotas - 分水嶺演算法
- Mahotas - 影像開運算
- Mahotas - 影像閉運算
- Mahotas - 填充影像孔洞
- Mahotas - 條件膨脹影像
- Mahotas - 條件腐蝕影像
- Mahotas - 影像條件分水嶺
- Mahotas - 影像區域性最小值
- Mahotas - 影像區域最大值
- Mahotas - 影像區域最小值
- Mahotas - 高階概念
- Mahotas - 影像閾值化
- Mahotas - 設定閾值
- Mahotas - 軟閾值
- Mahotas - Bernsen 區域性閾值化
- Mahotas - 小波變換
- 製作影像小波中心
- Mahotas - 距離變換
- Mahotas - 多邊形工具
- Mahotas - 區域性二值模式
- 閾值鄰域統計
- Mahotas - Haralick 特徵
- 標記區域的權重
- Mahotas - Zernike 特徵
- Mahotas - Zernike 矩
- Mahotas - 排序濾波器
- Mahotas - 2D 拉普拉斯濾波器
- Mahotas - 多數濾波器
- Mahotas - 均值濾波器
- Mahotas - 中值濾波器
- Mahotas - 大津法
- Mahotas - 高斯濾波
- Mahotas - 擊中或錯過變換
- Mahotas - 標記最大陣列
- Mahotas - 影像平均值
- Mahotas - SURF 密集點
- Mahotas - SURF 積分
- Mahotas - Haar 變換
- 突出顯示影像最大值
- 計算線性二值模式
- 獲取標籤的邊界
- 反轉 Haar 變換
- Riddler-Calvard 方法
- 標記區域的大小
- Mahotas - 模板匹配
- 加速魯棒特徵
- 去除帶邊框的標籤
- Mahotas - Daubechies 小波
- Mahotas - Sobel 邊緣檢測
Mahotas - 大津法
大津法是一種用於影像分割的技術,用於將前景與背景分離。它透過找到最大化類間方差的閾值來工作。
類間方差是衡量前景和背景區域之間分離程度的指標。
最大化類間方差的閾值被認為是影像分割的最佳閾值。
Mahotas 中的大津法
在 Mahotas 中,我們可以利用 **thresholding.otsu()** 函式使用大津法計算閾值。該函式以以下方式執行 -
首先它找到影像的直方圖。直方圖是影像中每個灰度級畫素數量的圖。
接下來,閾值設定為影像的平均灰度值。
然後,計算當前閾值的類間方差。
然後增加閾值,並重新計算類間方差。
重複步驟 2 到 4,直到達到最佳閾值。
mahotas.thresholding.otsu() 函式
mahotas.thresholding.otsu() 函式以灰度影像作為輸入,並返回使用大津法計算的閾值。然後將灰度影像的畫素與閾值進行比較以建立分割影像。
語法
以下是 mahotas 中 otsu() 函式的基本語法 -
mahotas.thresholding.otsu(img, ignore_zeros=False)
其中,
**img** - 輸入灰度影像。
**ignore_zeros(可選)** - 一個標誌,指定是否忽略零值畫素(預設為 false)。
示例
在下面的示例中,我們使用 mh.thresholding.otsu() 函式查詢閾值。
import mahotas as mh import numpy as np import matplotlib.pyplot as mtplt # Loading the image image = mh.imread('sea.bmp') # Converting it to grayscale image = mh.colors.rgb2gray(image).astype(np.uint8) # Calculating threshold value using Otsu method otsu_threshold = mh.thresholding.otsu(image) # Creating image from the threshold value final_image = image > otsu_threshold # Creating a figure and axes for subplots fig, axes = mtplt.subplots(1, 2) # Displaying the original image axes[0].imshow(image, cmap='gray') axes[0].set_title('Original Image') axes[0].set_axis_off() # Displaying the threshold image axes[1].imshow(final_image, cmap='gray') axes[1].set_title('Otsu Threshold Image') axes[1].set_axis_off() # Adjusting spacing between subplots mtplt.tight_layout() # Showing the figures mtplt.show()
輸出
以下是上述程式碼的輸出 -

忽略零值畫素
我們還可以透過忽略零值畫素來找到大津閾值。零值畫素是指強度值為 0 的畫素。
它們通常表示影像的背景畫素,但在某些影像中,它們也可能表示噪聲。
在灰度影像中,零值畫素由顏色“黑色”表示。
要排除 mahotas 中的零值畫素,我們可以將 **ignore_zeros** 引數設定為布林值“True”。
示例
在下面提到的示例中,我們在使用大津法計算閾值時忽略了值為零的畫素。
import mahotas as mh import numpy as np import matplotlib.pyplot as mtplt # Loading the image image = mh.imread('tree.tiff') # Converting it to grayscale image = mh.colors.rgb2gray(image).astype(np.uint8) # Calculating threshold value using Otsu method otsu_threshold = mh.thresholding.otsu(image, ignore_zeros=True) # Creating image from the threshold value final_image = image > otsu_threshold # Creating a figure and axes for subplots fig, axes = mtplt.subplots(1, 2) # Displaying the original image axes[0].imshow(image, cmap='gray') axes[0].set_title('Original Image') axes[0].set_axis_off() # Displaying the threshold image axes[1].imshow(final_image, cmap='gray') axes[1].set_title('Otsu Threshold Image') axes[1].set_axis_off() # Adjusting spacing between subplots mtplt.tight_layout() # Showing the figures mtplt.show()
輸出
執行上述程式碼後,我們得到以下輸出 -

廣告