• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    OpenCV半小时掌握基本操作之傅里叶变换

    概述

    OpenCV 是一个跨平台的计算机视觉库, 支持多语言, 功能强大. 今天小白就带大家一起携手走进 OpenCV 的世界. 

    高频 vs 低频

    高频 vs 低频:

    滤波:

    傅里叶变换

    傅里叶变化 (Fourier Transform) 是一种分析信号的方法. 傅里叶变化可分析信号的成分, 也可以用这些成分合成信号.

    效果:

    傅里叶变换:

    傅里叶逆变换:

    在 OpenCV 中实现傅里叶变换的函数是cv2.dft()cv2.idft()(傅里叶逆变化)

    代码详解

    输入转换

    傅里叶变换支持的输入格式是np.float32, 所以我们需要先把图像转换到要求的格式.

    代码实现:

    import numpy as np
    import cv2
    
    # 读取图片, 并转换成灰度图
    img = cv2.imread("Mona_Lisa.jpg", cv2.IMREAD_GRAYSCALE)
    print(img.dtype)  # unit8数据类型
    
    # 转换成np.float32
    img_float32 = np.float32(img)
    print(img_float32.dtype)  # float32数据类型
    

    输出结果:

    uint8
    float32

    傅里叶变换

    格式:

    cv2.dft(src, dst=None, flags=None, nonzeroRows=None)
    

    参数:

    返回值:

    代码实现:

    # 傅里叶变换
    dft = cv2.dft(img_float32, flags=cv2.DFT_COMPLEX_OUTPUT)
    
    # 中心转换, 将低频挪到中心
    dft_shift = np.fft.fftshift(dft)
    

    获取幅度谱

    幅度谱 (Magnitude Spectrum), 即从构成波形的频率侧面看过去, 每一个频率分量都会在侧面的投影, 如图:

    通过```cv2.magnitude``我们可以极端二维矢量的幅值.

    格式:

    cv2.magnitude(x, y, magnitude=None)
    

    参数:

    代码实现:

    # 获取幅度谱, 映射到灰度空间 [0, 255]
    magnitude_spectrum = 20 * np.log(cv2.magnitude(dft_shift[:, :, 0], dft_shift[:, :, 1]))
    
    # 幅度谱展示
    combine = np.hstack((img, magnitude_spectrum.astype(np.uint8)))
    cv2.imshow("combine", combine)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    

    输出结果:

    傅里叶逆变换

    格式:

    cv2.idft(src, dst=None, flags=None, nonzeroRows=None)
    

    参数:

    返回值:

    代码实现:

    # 获取中心位置
    rows, cols = img.shape
    crow, ccol = int(rows / 2), int(cols / 2)
    
    # 低通滤波
    mask = np.zeros((rows, cols, 2), np.uint8)
    mask[crow - 30:crow + 30, ccol - 30:ccol + 30] = 1
    
    # 傅里叶逆变换
    fshidt = dft_shift * mask
    f_ishift = np.fft.ifftshift(fshidt)
    img_back = cv2.idft(f_ishift)
    

    获取低频

    import numpy as np
    import cv2
    
    # 读取图片, 并转换成灰度图
    img = cv2.imread("Mona_Lisa.jpg", cv2.IMREAD_GRAYSCALE)
    print(img.dtype)  # unit8数据类型
    
    # 转换成np.float32
    img_float32 = np.float32(img)
    print(img_float32.dtype)  # float32数据类型
    
    # 傅里叶变换
    dft = cv2.dft(img_float32, flags=cv2.DFT_COMPLEX_OUTPUT)
    
    # 中心转换, 将低频挪到中心
    dft_shift = np.fft.fftshift(dft)
    
    # 获取幅度谱
    magnitude_spectrum = 20 * np.log(cv2.magnitude(dft_shift[:, :, 0], dft_shift[:, :, 1]))
    
    # 幅度谱展示
    combine = np.hstack((img, magnitude_spectrum.astype(np.uint8)))
    cv2.imshow("combine", combine)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    
    # 获取中心位置
    rows, cols = img.shape
    crow, ccol = int(rows / 2), int(cols / 2)
    
    # 低通滤波
    mask = np.zeros((rows, cols, 2), np.uint8)
    mask[crow - 30:crow + 30, ccol - 30:ccol + 30] = 1
    fshidt = dft_shift * mask
    f_ishift = np.fft.ifftshift(fshidt)
    
    # 傅里叶逆变换, 获取低频图像
    img_back = cv2.idft(f_ishift)
    img_back = cv2.magnitude(img_back[:, :, 0], img_back[:, :, 1])
    
    # 结果展示
    img_back = 255 * cv2.normalize(img_back, None, norm_type=cv2.NORM_MINMAX, dtype=cv2.CV_32F)  # 标准化
    result = np.hstack((img, img_back.astype(np.uint8)))
    cv2.imshow("result", result)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    

    输出结果:

    获取高频

    import numpy as np
    import cv2
    
    # 读取图片, 并转换成灰度图
    img = cv2.imread("Mona_Lisa.jpg", cv2.IMREAD_GRAYSCALE)
    print(img.dtype)  # unit8数据类型
    
    # 转换成np.float32
    img_float32 = np.float32(img)
    print(img_float32.dtype)  # float32数据类型
    
    # 傅里叶变换
    dft = cv2.dft(img_float32, flags=cv2.DFT_COMPLEX_OUTPUT)
    
    # 中心转换, 将低频挪到中心
    dft_shift = np.fft.fftshift(dft)
    
    # 获取幅度谱
    magnitude_spectrum = 20 * np.log(cv2.magnitude(dft_shift[:, :, 0], dft_shift[:, :, 1]))
    
    # 幅度谱展示
    combine = np.hstack((img, magnitude_spectrum.astype(np.uint8)))
    cv2.imshow("combine", combine)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    
    # 获取中心位置
    rows, cols = img.shape
    crow, ccol = int(rows / 2), int(cols / 2)
    
    # 高通滤波
    mask = np.ones((rows, cols, 2), np.uint8)
    mask[crow - 30:crow + 30, ccol - 30:ccol + 30] = 0
    fshidt = dft_shift * mask
    f_ishift = np.fft.ifftshift(fshidt)
    
    # 傅里叶逆变换, 获取高频图像
    img_back = cv2.idft(f_ishift)
    img_back = cv2.magnitude(img_back[:, :, 0], img_back[:, :, 1])
    
    # 结果展示
    img_back = 255 * cv2.normalize(img_back, None, norm_type=cv2.NORM_MINMAX, dtype=cv2.CV_32F)  # 标准化
    result = np.hstack((img, img_back.astype(np.uint8)))
    cv2.imshow("result", result)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    

    输出结果:

    到此这篇关于OpenCV半小时掌握基本操作之傅里叶变换的文章就介绍到这了,更多相关OpenCV傅里叶变换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • OpenCV半小时掌握基本操作之图像裁剪融合
    • OpenCV半小时掌握基本操作之图像处理
    • opencv-python基本图像处理详解
    • OpenCV图像处理基本操作详解
    • Opencv图像处理之详解掩膜mask
    • 基于python的opencv图像处理实现对斑马线的检测示例
    • Python+OpenCV图像处理——图像二值化的实现
    • OpenCV半小时掌握基本操作之分水岭算法
    • OpenCV半小时掌握基本操作之图像轮廓
    • OpenCV半小时掌握基本操作之直方图
    • OpenCV半小时掌握基本操作之模板匹配
    • OpenCV半小时掌握基本操作之圆圈检测
    • OpenCV半小时掌握基本操作之对象测量
    • OpenCV半小时掌握基本操作之图像基础操作
    上一篇:python中re.findall函数实例用法
    下一篇:OpenCV半小时掌握基本操作之高斯双边
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    OpenCV半小时掌握基本操作之傅里叶变换 OpenCV,半小时,掌握,基本操作,