python去除图像光照不均匀_python+opencv——去除图像光照不均匀

使用python版本的opencv去除图像中的光照不均匀

在图像处理中,如果图像中存在光照不均匀,则会影响图像处理的效果,比如在图像文本识别和图像分割中。本博客对于图像均衡化的处理主要参考文章:一种基于亮度均衡的图像阈值分割技术,以有关于C++的实现代码:opencv 一种不均匀光照的补偿方法

使用该方法主要的原因是最近在弄Tesseract的文字识别,需要识别拍摄照片中的字母,但是照片为室外拍摄,具有不同的光照影响,导致识别率很低,因此采用该方法进行处理,最后有效的提升了识别率,实现有光照影响的Tesseract文字识别。

全部代码如下:

import cv2

import numpy as np

def unevenLightCompensate(img, blockSize):

gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

average = np.mean(gray)

rows_new = int(np.ceil(gray.shape[0] / blockSize))

cols_new = int(np.ceil(gray.shape[1] / blockSize))

blockImage = np.zeros((rows_new, cols_new), dtype=np.float32)

for r in range(rows_new):

for c in range(cols_new):

rowmin = r * blockSize

rowmax = (r + 1) * blockSize

if (rowmax > gray.shape[0]):

rowmax = gray.shape[0]

colmin = c * blockSize

colmax = (c + 1) * blockSize

if (colmax > gray.shape[1]):

colmax = gray.shape[1]

imageROI = gray[rowmin:rowmax, colmin:colmax]

temaver = np.mean(imageROI)

blockImage[r, c] = temaver

blockImage = blockImage - average

blockImage2 = cv2.resize(blockImage, (gray.shape[1], gray.shape[0]), interpolation=cv2.INTER_CUBIC)

gray2 = gray.astype(np.float32)

dst = gray2 - blockImage2

dst = dst.astype(np.uint8)

dst = cv2.GaussianBlur(dst, (3, 3), 0)

dst = cv2.cvtColor(dst, cv2.COLOR_GRAY2BGR)

return dst

if __name__ == '__main__':

file = 'refined_receipt.jpg'

blockSize = 16

img = cv2.imread(file)

dst = unevenLightCompensate(img, blockSize)

result = np.concatenate([img, dst], axis=1)

cv2.imshow('result', result)

cv2.waitKey(0)

效果如下所示:

调节的参数有blockSize的尺寸,以及最后的高斯去噪GaussianBlur和其核的大小,本文取的3.

去除图像光照不均,可以使用一些图像处理技术。首先,你需要加载OpenCV-Python模块。可以使用pip进行安装,命令如下: ``` pip install -i https://pypi.tuna.tsinghua.edu.cn/simple opencv-python ``` 安装完成后,可以使用以下步骤去除图像光照不均: 1. 加载图像:使用`cv2.imread()`函数加载图像文件。 2. 将图像转换为灰度图像:使用`cv2.cvtColor()`函数将彩色图像转换为灰度图像。 3. 去除光照不均:有多种方法可以去除光照不均,一种常用的方法是使用自适应阈值处理。可以使用`cv2.adaptiveThreshold()`函数进行自适应阈值处理,通过调整参数来适应不同的图像。 4. 显示处理后的图像:使用`cv2.imshow()`函数显示处理后的图像。 下面是示例代码: ```python import cv2 # 加载图像 img = cv2.imread('image.jpg') # 转换为灰度图像 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 去除光照不均 # 使用自适应阈值处理 adaptive_threshold = cv2.adaptiveThreshold(gray, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2) # 显示处理后的图像 cv2.imshow('Processed Image', adaptive_threshold) cv2.waitKey(0) cv2.destroyAllWindows() ``` 这样就可以去除图像光照不均了。你可以根据需要调整自适应阈值处理的参数,以达到更好的效果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [jetson nano opencv 打开 CSI摄像头_opencv-python图形图像处理入门基础知识](https://blog.csdn.net/weixin_39775354/article/details/110121584)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [opencv-python图形图像处理入门基础知识](https://blog.csdn.net/LaoYuanPython/article/details/108015331)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值