python 如何使用PyWavelets读取图像?

epggiuax  于 2023-09-29  发布在  Python
关注(0)|答案(5)|浏览(136)

我需要使用pyWavelet,即。pywt读取我的图像来做小波变换吧,下面的例子只用来加载相机图像,如何从我的电脑中使用另一个图像路径?

import pywt
import pywt.data

# Load image
original = pywt.data.camera()
dxxyhpgq

dxxyhpgq1#

我不确定你是否可以只使用pywt读取图像,但你可以使用OpenCV加载图像,然后将其转换为可用的格式,以便与pywt一起使用

import cv2
import numpy as np
import pywt

image = cv2.imread('1.png')
image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# Convert to float for more resolution for use with pywt
image = np.float32(image)
image /= 255

# ...
# Do your processing
# ...

# Convert back to uint8 OpenCV format
image *= 255
image = np.uint8(image)

cv2.imshow('image', image)
cv2.waitKey(0)
j2qf4p5b

j2qf4p5b2#

你可以使用matplotlib和numpy:

from matplotlib.image import imread
import numpy as np
import pywt
   
A = imread("1.jpg")
original = np.mean(A, -1)
#rest of your codes
pgccezyw

pgccezyw3#

我使用pandas读取图像,因为我使用hm3.6数据集进行运动预测,并应用小波变换作为预处理。
我的代码简单如下:

path = ".../your_path"
img = pd.read_csv(path + "h3.6m/dataset/S1/directions_1.txt") #read the image

#if you want to apply DWT you can continue with dataframe    
coeffs2 = dwt(image,  'bior1.3')
titles = ['Approximation', ' Horizontal detail',
              'Vertical detail', 'Diagonal detail']

LL, LH = coeffs2
2izufjch

2izufjch4#

OpenCV的一个替代品是scikit-image。

import pywt
from skimage import io, color

data = io.imread(filename)

# Process your image
gray = color.rgb2gray(data)
coeffs = pywt.dwt2(gray, 'haar')

# Or... process each channel separately
r, g, b = [c.T for c in data.T]
cr = pywt.dwt2(r, 'haar')
cg = pywt.dwt2(g, 'haar')
cb = pywt.dwt2(b, 'haar')

# output: PIL, matplotlib, dump to file...
wlzqhblo

wlzqhblo5#

您可以尝试以下操作。

import numpy as np
import matplotlib.pyplot as plt
import pywt
import pywt.data
# Load image
original = pywt.data.camera()
# Wavelet transform of image, and plot approximation and details
titles = ['Approximation', ' Horizontal detail', 'Vertical detail', 'Diagonal detail']
coeffs2 = pywt.dwt2(original, 'bior1.3')
LL, (LH, HL, HH) = coeffs2
fig = plt.figure(figsize=(12, 3))
for i, a in enumerate([LL, LH, HL, HH]):
ax = fig.add_subplot(1, 4, i + 1)
ax.imshow(a, interpolation="nearest", cmap=plt.cm.gray)
ax.set_title(titles[i], fontsize=10)
ax.set_xticks([])
ax.set_yticks([])
fig.tight_layout()
plt.show()

参考:https://pywavelets.readthedocs.io/en/latest/

相关问题