【图像处理实战】去除光照不均(Python)

这篇文章主要是对参考文章里面实现一种小拓展:

  • 可处理彩色图片(通过对 HSV 的 V 通道进行处理)
  • 本来想将嵌套循环改成矩阵运算的,但是太麻烦了,而且代码也不好理解,所以放弃了。

代码

import cv2
import numpy as np


def light_compensate_hsv(src, grid_num):
    src_hsv = cv2.cvtColor(src, cv2.COLOR_BGR2HSV)
    src_v = src_hsv[:, :, 2]

    avg = np.mean(src_v)
    h, w = src_v.shape[:2]
    grid_row, grid_col = np.ceil(np.asarray([h, w]) / grid_num).astype(int)
    img_grid = np.zeros((grid_row, grid_col, 1), dtype=np.float32)

    for row in range(grid_row):
        for col in range(grid_col):
            img_roi = src_v[row * grid_num:                                           # row start
                            (row + 1) * grid_num if (row + 1) * grid_num < h else h,  # row end
                            col * grid_num:                                           # col start
                            (col + 1) * grid_num if (col + 1) * grid_num < w else w]  # col end

            img_grid[row, col] = np.mean(img_roi) - avg

    mask = cv2.resize(img_grid, (w, h), interpolation=cv2.INTER_CUBIC)
    mask = cv2.GaussianBlur(mask, (3, 3), 0)
    dst_v = np.uint8(np.float32(src_v) - mask)

    src_hsv[:, :, 2] = dst_v
    return cv2.cvtColor(src_hsv, cv2.COLOR_HSV2BGR)


def display(img):
    cv2.namedWindow('img', cv2.WINDOW_NORMAL)
    cv2.imshow('img', img)
    cv2.waitKey()


if __name__ == '__main__':
    image = cv2.imread(r'light_compensate_test_2.png')
    image_res = light_compensate_hsv(image, 16)

    res = np.hstack([image, image_res])
    display(res)

效果图

图也是用的参考文章里面的原图进行处理的。

在这里插入图片描述
在这里插入图片描述
最后一张是我自己的测试图,对于某些图来说效果比较好,可以用在文档阴影去除上。

在这里插入图片描述

参考文章

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-11 02:12:02       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-11 02:12:02       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-11 02:12:02       57 阅读
  4. Python语言-面向对象

    2024-07-11 02:12:02       68 阅读

热门阅读

  1. 无题:天选之子?

    2024-07-11 02:12:02       24 阅读
  2. Flutter——最详细(GestureDetector)使用教程

    2024-07-11 02:12:02       23 阅读
  3. Jenkins构建python项目

    2024-07-11 02:12:02       19 阅读
  4. 使用nodejs进行截图

    2024-07-11 02:12:02       18 阅读
  5. nginx部署vue项目

    2024-07-11 02:12:02       24 阅读
  6. 【网络】SCTP协议概念

    2024-07-11 02:12:02       27 阅读
  7. Git 完整的提交规范教程

    2024-07-11 02:12:02       20 阅读