
- 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 - Otsu 方法
- Mahotas - 高斯濾波
- Mahotas - 擊中擊不中變換
- Mahotas - 標記最大陣列
- Mahotas - 影像均值
- Mahotas - SURF 密集點
- Mahotas - SURF 積分
- Mahotas - Haar 變換
- 突出顯示影像最大值
- 計算線性二值模式
- 獲取標籤邊界
- Haar 逆變換
- Riddler-Calvard 方法
- 標記區域的大小
- Mahotas - 模板匹配
- 加速魯棒特徵
- 去除帶邊框的標籤
- Mahotas - Daubechies 小波
- Mahotas - Sobel 邊緣檢測
Mahotas - Haar 逆變換
Haar 逆變換是指從 Haar 變換後的影像重建原始影像的技術。在瞭解 Haar 逆變換之前,讓我們先了解一下 Haar 變換。
Haar 變換是一種將影像從畫素強度值轉換為小波係數(表示影像不同頻率的值)的技術。
在 Haar 變換中,影像被分解成一組稱為 Haar 小波的 正交基函式。
Haar 逆變換透過以特定方式(如下所述)組合 Haar 小波,將小波係數轉換為畫素強度值。
在 Mahotas 中進行 Haar 逆變換
在 Mahotas 中,我們可以使用 **mahotas.ihaar()** 函式執行 Haar 逆變換。以下是執行逆 Haar 變換的基本方法:
首先,從 Haar 變換中獲取 Haar 小波係數。
接下來,將每個係數乘以一個縮放因子和 Haar 小波。對於 Haar 小波,近似係數的縮放因子通常為 $\mathrm{1/\sqrt{2}}$,細節係數的縮放因子為 1。
然後,將這些縮放後的係數對於高頻(細節)和低頻(近似)係數求和。
最後,組合重建的係數,如果畫素值不在 0 到 255 的範圍內,則執行歸一化。
完成這些步驟後,原始影像將從 Haar 變換後的影像中重建。
mahotas.ihaar() 函式
mahotas.ihaar() 函式以 Haar 變換後的影像作為輸入,並返回原始灰度影像作為輸出。
由於 Haar 變換是一個可逆過程,因此逆變換後的影像是對原始影像的完美重建。
語法
以下是 mahotas 中 ihaar() 函式的基本語法:
mahotas.ihaar(f, preserve_energy=True, inline=False)
其中,
**f** - 輸入影像。
**preserve_energy (可選)** - 指定是否保留輸出影像的能量(預設為 True)。
**inline (可選)** - 指定是返回新影像還是修改輸入影像(預設為 False)。
示例
在以下示例中,我們使用 mh.ihaar() 函式來反轉 Haar 變換對影像的影響。
import mahotas as mh import numpy as np import matplotlib.pyplot as mtplt # Loading the image image = mh.imread('sun.png') # Converting it to grayscale image = mh.colors.rgb2gray(image) # Applying Haar transformation haar_transform = mh.haar(image) # Reversing Haar transformation reverse_haar = mh.ihaar(haar_transform) # Creating a figure and axes for subplots fig, axes = mtplt.subplots(1, 3) # Displaying the original image axes[0].imshow(image, cmap='gray') axes[0].set_title('Original Image') axes[0].set_axis_off() # Displaying the Haar transformed image axes[1].imshow(haar_transform, cmap='gray') axes[1].set_title('Haar Transformed Image') axes[1].set_axis_off() # Displaying the reversed image axes[2].imshow(reverse_haar, cmap='gray') axes[2].set_title('Reverse Haar Image') axes[2].set_axis_off() # Adjusting spacing between subplots mtplt.tight_layout() # Showing the figures mtplt.show()
輸出
以下是上述程式碼的輸出:

不保留能量
我們還可以反轉 Haar 變換對影像的影響,而不保留其能量。影像的能量指的是其亮度,在影像變換時可能會發生變化。
在 mahotas 中,我們可以將 mh.ihaar() 函式中的 **preserve_energy** 引數設定為 'False' 以防止能量保留。因此,輸出影像的亮度將與原始輸入影像不同。
如果此引數設定為 True,則輸出影像和輸入影像將具有相同的亮度。
示例
在下面提到的示例中,我們正在對影像執行 Haar 逆變換,而不保留其能量。
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) # Applying Haar transformation haar_transform = mh.haar(image) # Reversing Haar transformation reverse_haar = mh.ihaar(haar_transform, preserve_energy=False) # Creating a figure and axes for subplots fig, axes = mtplt.subplots(1, 3) # Displaying the original image axes[0].imshow(image, cmap='gray') axes[0].set_title('Original Image') axes[0].set_axis_off() # Displaying the Haar transformed image axes[1].imshow(haar_transform, cmap='gray') axes[1].set_title('Haar Transformed Image') axes[1].set_axis_off() # Displaying the reversed image axes[2].imshow(reverse_haar, cmap='gray') axes[2].set_title('Reverse Haar Image') axes[2].set_axis_off() # Adjusting spacing between subplots mtplt.tight_layout() # Showing the figures mtplt.show()
輸出
上述程式碼的輸出如下:

內聯 Haar 逆變換
另一種執行 Haar 逆變換的方法是執行內聯 Haar 逆變換。內聯是指在原始影像本身上應用變換,而無需建立新影像,從而節省了變換過程中的空間。
在 mahotas 中,可以透過在 mh.ihaar() 函式中將 **inline** 引數設定為布林值 'True' 來實現內聯 Haar 逆變換。
示例
在這裡,我們對 Haar 變換後的影像執行內聯 Haar 逆變換。
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) # Reversing Haar transformation mh.ihaar(mh.haar(image), inline=True) # Creating a figure and axes for subplots fig, axes = mtplt.subplots(1, 1) # Displaying the reversed image axes.imshow(image, cmap='gray') axes.set_title('Reverse Haar Image') axes.set_axis_off() # Adjusting spacing between subplots mtplt.tight_layout() # Showing the figures mtplt.show()
輸出
執行上述程式碼後,我們將得到以下輸出:
