我想在pycharm2023版中用Python编码实现直方图均衡化,并比较前后两幅图片的灰度直方图,示例图像的文件地址为"C:\Users\27639\PycharmProjects\pythonProject\venv\class.jpg",请编码
时间: 2023-07-08 22:43:59 浏览: 154
好的,以下是您所需的代码:
```python
import cv2
import matplotlib.pyplot as plt
# 读取图像
img = cv2.imread("C:\\Users\\27639\\PycharmProjects\\pythonProject\\venv\\class.jpg")
# 转换为灰度图像
img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 直方图均衡化
img_eq = cv2.equalizeHist(img_gray)
# 计算直方图
hist_gray = cv2.calcHist([img_gray], [0], None, [256], [0, 256])
hist_eq = cv2.calcHist([img_eq], [0], None, [256], [0, 256])
# 绘制灰度直方图和均衡化后的直方图
plt.figure()
plt.plot(hist_gray, color='black')
plt.plot(hist_eq, color='red')
plt.xlim([0, 256])
plt.legend(['Gray Histogram', 'Equalized Histogram'])
plt.show()
# 显示图像
cv2.imshow("Original Image", img_gray)
cv2.imshow("Equalized Image", img_eq)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
我已经按照您的要求编写了一个程序,您可以直接复制到您的PyCharm中以运行它。注意要将文件路径"C:\\Users\\27639\\PycharmProjects\\pythonProject\\venv\\class.jpg"更改为您实际图像文件的路径。在这个程序中,我们首先读取图像,然后将其转换为灰度图像。接下来,我们使用cv2.equalizeHist()函数对图像进行直方图均衡化,并使用cv2.calcHist()函数计算原始图像和均衡化后的图像的灰度直方图。最后,我们使用matplotlib库绘制灰度直方图和均衡化后的直方图,并在窗口中显示原始图像和均衡化后的图像。
阅读全文