如何在OpenCV Python中执行矩阵变换?
cv2.transform() 函数对输入数组的每个元素执行矩阵变换。我们可以直接在图像上应用这个变换,因为在OpenCV中图像是NumPy ndarrays。为了使用这个函数,我们应该先定义一个变换矩阵m。输出的通道数将与变换矩阵m的行数相同。
步骤
要找到输入图像的矩阵变换,可以按照以下步骤操作-
- 导入所需的库 OpenCV 和 NumPy 。确保已经安装了它们。
-
使用 cv2.imread () 方法读取输入图像。指定图像的完整路径。
-
定义大小为(3,3)的变换矩阵m。您可以将变换矩阵生成为随机数字或定义自定义矩阵。
-
使用 cv2.transform() 找到图像的矩阵变换。将变换矩阵m作为参数传递给 cv2.transform() 函数。
-
显示变换后的图像。
让我们看下面的示例,对输入图像进行矩阵变换。
输入图像
我们将使用以下图像作为下面示例的输入文件。
示例
在这个示例中,我们找到输入图像的矩阵变换。我们将变换矩阵定义为一组随机数的3×3矩阵。
# 导入所需的libraries
import cv2
import numpy as np
# 读取输入图像
img = cv2.imread('leaf1.jpg')
# 定义变换矩阵
m = np.random.randn(3,3)
# 应用cv2.transform进行矩阵变换
img_tr = cv2.transform(img, m, None)
#显示变换后的图像
cv2.imshow("Transformed Image", img_tr)
cv2.waitKey(0)
cv2.destroyAllWindows()
输出
在执行上述代码时,它将产生以下输出窗口 –
注意 − 由于变换矩阵是使用随机数生成的,因此可能会获得具有不同颜色和亮度的输出图像。
示例
在这个示例中,我们找到输入图像的矩阵变换。我们将变换矩阵定义为全为1的3×3矩阵。
# 导入所需库
import cv2
import numpy as np
# 读取输入图像
img = cv2.imread('leaf1.jpg')
# 定义变换矩阵
m = np.ones((3,3))
# 应用cv2.transform执行矩阵变换
img_tr = cv2.transform(img, m, None)
# 显示变换后的图像
cv2.imshow("Transformed Image", img_tr)
cv2.waitKey(0)
cv2.destroyAllWindows()
输出
在执行上述代码时,它将产生以下 输出 窗口-