python-opencv-使图片更清晰的几种方法

2023/3/6更新

很久没搞图像这块了,这个以后再改吧。全灰是因为读图像的时候就是读的灰的。。
img = cv2.imread(source, cv2.IMREAD_GRAYSCALE)

哪天想起来再改这篇吧。


所有代码已测试通过。

import cv2
import numpy as np

def gamma(source,out):
    img = cv2.imread(source, cv2.IMREAD_GRAYSCALE)
    # 归1
    Cimg = img / 255
    # 伽玛变换
    gamma = 0.7
    O = np.power(Cimg, gamma)
    O = O * 255
    # 效果
    cv2.imwrite(out, O, [int(cv2.IMWRITE_PNG_COMPRESSION), 0])
    
def hist(source):
    img = cv2.imread(source, cv2.IMREAD_GRAYSCALE)
    # 求出img 的最大最小值
    Maximg = np.max(img)
    Minimg = np.min(img)
    # 输出最小灰度级和最大灰度级
    Omin, Omax = 0, 255
    # 求 a, b
    a = float(Omax - Omin) / (Maximg - Minimg)
    b = Omin - a * Minimg
    # 线性变换
    O = a * img + b
    O = O.astype(np.uint8)
    cv2.imshow('enhance', O)
    #cv2.imwrite('hist.png', O, [int(cv2.IMWRITE_PNG_COMPRESSION), 0])
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    
def hist_auto(source):
    img = cv2.imread(source, 0)
    img = cv2.resize(img, None, fx=0.5, fy=0.5)
    # 创建CLAHE对象
    clahe = cv2.createCLAHE(clipLimit=2.0, tileGridSize=(8, 8))
    # 限制对比度的自适应阈值均衡化
    dst = clahe.apply(img)
    # 使用全局直方图均衡化
    equa = cv2.equalizeHist(img)
    # 分别显示原图,CLAHE,HE
    #cv.imshow("img", img)
    #cv2.imshow("dst", dst)
    cv2.imwrite('hist_auto.png', dst, [int(cv2.IMWRITE_PNG_COMPRESSION), 0])
    
def calcGrayHist(I):
    # 计算灰度直方图
    h, w = I.shape[:2]
    grayHist = np.zeros([256], np.uint64)
    for i in range(h):
        for j in range(w):
            grayHist[I[i][j]] += 1
    return grayHist
    
def equalHist(img):
    import math
    # 灰度图像矩阵的高、宽
    h, w = img.shape
    # 第一步:计算灰度直方图
    grayHist = calcGrayHist(img)
    # 第二步:计算累加灰度直方图
    zeroCumuMoment = np.zeros([256], np.uint32)
    for p in range(256):
        if p == 0:
            zeroCumuMoment[p] = grayHist[0]
        else:
            zeroCumuMoment[p] = zeroCumuMoment[p - 1] + grayHist[p]
    # 第三步:根据累加灰度直方图得到输入灰度级和输出灰度级之间的映射关系
    outPut_q = np.zeros([256], np.uint8)
    cofficient = 256.0 / (h * w)
    for p in range(256):
        q = cofficient * float(zeroCumuMoment[p]) - 1
        if q >= 0:
            outPut_q[p] = math.floor(q)
        else:
            outPut_q[p] = 0
    # 第四步:得到直方图均衡化后的图像
    equalHistImage = np.zeros(img.shape, np.uint8)
    for i in range(h):
        for j in range(w):
            equalHistImage[i][j] = outPut_q[img[i][j]]
    return equalHistImage
    
def linear(source):
    img = cv2.imread(source, 0)
    # 使用自己写的函数实现
    equa = equalHist(img)
    cv2.imshow("equa", equa)
    cv2.imwrite('temp.png', equa, [int(cv2.IMWRITE_PNG_COMPRESSION), 0])
    cv2.waitKey()
    
source = "raw.jpg"
#gamma(source)
hist(source)
#hist_auto(source)
#linear(source)
#gamma('temp.png','g2.png')

  • 10
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
【课程简介】 本课程基于面向PythonOpenCV,以OpenCV的官方文档的知识脉络为主线,介绍了OpenCV函数的具体使用方法、函数所使用的算法的具体原理。 在介绍函数使用时,提供了大量的程序案例演示。 在介绍具体原理时,采用了通俗易懂的语言和贴近生活的示例来说明问题,尽量避免涉及过于复杂抽象的公式。 课程包含数字图像处理的常用知识点,覆盖面全,方便学员系统深入全面地掌握OpenCV。 【你将收获什么】 1.  掌握数字图像的在计算机内表示的方法和处理的基本原理。掌握数字图像的表示方法是进行图像处理的前提和基础,能够为后续的智能图像处理打下坚实基础。 2.  使用好OpenCV开源库对于提升工作效率具有很大的帮助。OpenCV是优秀的开源库,提供了大量的函数帮助我们提升工作效率。大多数情况下,我们直接调用函数就能够满足我们的需求。同时,它的函数具有较好的交互性,能够根据需要好地掌控图像处理的具体细节。 3.  学习图像处理的常用算法。课程不仅介绍函数的具体使用,也介绍了常用算法的基本原理,帮助学习者好地理解图像处理的基本逻辑、方法,快速入门图像处理领域。 【我将如何教你】 1)在“黑盒”和“白盒“之间取得平衡  可以将OpenCV看成“黑盒”,不用关心其函数是如何实现的。在需要实现某一个功能时,直接调用其对应的函数即可,像使用Photoshop的各种功能一样。也可以将OpenCV看成“白盒”,关注其每一个函数的具体实现,认真研究每一个函数的具体实现方法和实现细节。这两种方式都是学习图像处理的很好方式,但是大多数课程过于强调其中某一种,要么忽略了算法的实现、要么忽略了使用方法。本课程尽量将OpenCV在“黑盒”和“白盒”之间取得平衡。既介绍算法的原理和方法,又将重点放在如何调用函数上,让学习者能够加游刃有余地在计算机视觉项目中使用OpenCV来解决具体的问题。 2)将枯燥的算法采用具体的案例介绍  在图像处理中,有大量的算法保证了图像处理的准确、高效。OpenCV将一些常用的算法进行了封装,我们可以直接调用OpenCV的函数来使用对应的算法。但是,深入地理解算法能够帮助学习者好地使用OpenCV函数。本课程尝试抛弃传统的使用复杂公式介绍算法的形式,尽量通过简单、通俗易懂的生活中实例来帮助学习者理解算法的基本逻辑 3)案例驱动、强调实战 OpenCV是一个庞大的资源库,提供了非常多的函数帮助我们高效地处理问题。初学者使用OpenCV的最大困惑就是熟练地掌握了每一个函数的调用方法,但是在解决实际问题时,不知道具体应该使用哪个函数。本课程通过大量的具体案例帮助学习快速掌握每个函数的应用场景,快速掌握OpenCV的核心使用方法和技巧。
SFR(Spatial Frequency Response)是衡量图像清晰度的一种方法,MTF(Modulation Transfer Function)是SFR的频域表示。通过SFR测试可以得到图像在不同空间频率下的分辨率,进而生成MTF曲线图。 下面是使用PythonOpenCV实现SFR测试并生成MTF曲线图的简单步骤: 1.拍摄测试图像 使用相机拍摄一张测试图像,需要注意以下几点: - 选择一个高对比度的测试图案,例如棋盘格或分辨率测试板。 - 使用适当的照明条件,保证图像亮度均匀。 - 将相机固定在一个位置,保证测试图像的稳定性。 2.计算SFR曲线 计算SFR曲线可以借助OpenCV的函数实现。下面是一个简单的计算SFR曲线的代码示例: ```python import cv2 import numpy as np # 读取测试图像 img = cv2.imread('test_image.jpg', cv2.IMREAD_GRAYSCALE) # 计算图像梯度 dx = cv2.Sobel(img, cv2.CV_64F, 1, 0, ksize=3) dy = cv2.Sobel(img, cv2.CV_64F, 0, 1, ksize=3) grad = cv2.magnitude(dx, dy) # 计算SFR曲线 sfr = [] for f in range(0, 30, 1): freq = f / 10.0 kernel = np.sin(np.pi * freq * np.arange(-5, 6)) / (np.pi * freq * np.arange(-5, 6)) kernel[5] = 1 - 2 * freq row = np.convolve(grad[grad.shape[0]//2, :], kernel, mode='same') col = np.convolve(grad[:, grad.shape[1]//2], kernel, mode='same') sfr.append(max(row.max(), col.max())) # 绘制SFR曲线 import matplotlib.pyplot as plt plt.plot(sfr) plt.show() ``` 3.计算MTF曲线 MTF曲线是SFR曲线的频域表示,可以使用快速傅里叶变换(FFT)实现。下面是一个简单的计算MTF曲线的代码示例: ```python # 计算MTF曲线 mtf = np.abs(np.fft.fft(sfr)) freqs = np.fft.fftfreq(len(sfr), d=0.1) # 绘制MTF曲线 plt.plot(freqs[:len(freqs)//2], mtf[:len(mtf)//2]) plt.show() ``` 通过以上步骤,我们就可以得到测试图像的MTF曲线图了。需要注意的是,MTF曲线的横轴是空间频率,纵轴是相对幅度,因此需要对MTF曲线进行归一化处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值