当前位置: 首页 > news >正文

【数字图像处理系列笔记】Ch03:图像的变换

目录

一、图像的位置变换

平移

镜像

旋转

二、图像的形状变化

缩小

放大

错切

模拟哈哈镜

​编辑 ​编辑

三、图像的一些操作

 一、数值运算

1.1 基本算术运算

加法运算:

减法运算:

乘法运算:

除法运算:

1.1. 2. 混合运算

1.1.3. 非线性运算

二、逻辑运算

1. 2基本逻辑运算

与运算(AND):

或运算(OR):

非运算(NOT):

异或运算(XOR):

1.2.2 组合逻辑运算

形态学运算:

三、实际应用示例


一、图像的位置变换

★图像的平移、镜像、旋转

平移

定义:将图像中的所有像素点沿x轴和y轴方向移动指定的距离。

特点

  • 最简单的几何变换

  • 不改变图像内容,只改变位置

  • 平移后图像尺寸不变,边缘部分会缺失

镜像

旋转

定义:图像围绕某个中心点旋转一定角度。

特点

  • 旋转后图像尺寸通常会变大

  • 需要处理旋转后出现的空白区域

  • 可以选择不同的插值方法填补旋转后的像素

二、图像的形状变化

★图像的缩小、放大、错切

特点

  • s > 1时为放大,s < 1时为缩小

  • 可能导致图像信息丢失(缩小)或模糊(放大)

  • 需要选择合适的插值方法

缩小

图像的缩小一般分为按比例缩小和不按比例缩小两种。

图像缩小之后,因为承载的信息量小了,所以画布可相应缩小。

图像的缩小操作中,是在现有的信息里如何挑选所需要的有用信息。

图像的放大操作中,则需对尺寸放大后所多出来的空格填入适当的值。

这是信息的估计问题,所以较图像的缩小要难一些。

放大

错切

模拟哈哈镜

 

三、图像的一些操作

图像处理中的数值运算与逻辑运算

图像处理中的运算主要分为数值运算和逻辑运算两大类,它们在图像增强、分析和计算机视觉等领域有广泛应用。下面我将详细介绍这两类运算,并给出具体例子。

 一、数值运算

数值运算是对图像像素值进行数学计算的操作,通常用于图像增强、混合、变换等。

1.1 基本算术运算
加法运算:
  • 公式:C(x,y) = A(x,y) + B(x,y)

  • 应用:图像叠加、亮度增加、多帧降噪

  • 例子:将两张低曝光照片相加得到更清晰的图像

import cv2
img1 = cv2.imread('image1.jpg')
img2 = cv2.imread('image2.jpg')
result = cv2.add(img1, img2)  # 像素值相加
减法运算:
  • 公式:C(x,y) = A(x,y) - B(x,y)

  • 应用:背景消除、运动检测、变化检测

  • 例子:视频监控中通过帧差法检测运动物体

difference = cv2.subtract(img1, img2)  # 像素值相减
乘法运算:
  • 公式:C(x,y) = A(x,y) × B(x,y)

  • 应用:图像掩膜、局部增强

  • 例子:将图像与二值掩膜相乘实现ROI提取

mask = cv2.imread('mask.png', 0)  # 灰度掩膜
masked_img = cv2.multiply(img1, mask)  # 像素值相乘
除法运算:
  • 公式:C(x,y) = A(x,y) ÷ B(x,y)

  • 应用:归一化、图像校正

  • 例子:消除光照不均匀性

mask = cv2.imread('mask.png', 0)  # 灰度掩膜
masked_img = cv2.multiply(img1, mask)  # 像素值相乘
1. 2 混合运算

线性混合:

  • 公式:dst = α·img1 + β·img2 + γ

  • 例子:图像渐变过渡效果

alpha = 0.7  # img1的权重
beta = 0.3   # img2的权重
blended = cv2.addWeighted(img1, alpha, img2, beta, 0)
1.3.非线性运算

指数/对数运算:

  • 应用:伽马校正、动态范围压缩

  • 例子:增强暗部细节

gamma = 0.5
lookUpTable = np.empty((1,256), np.uint8)
for i in range(256):lookUpTable[0,i] = np.clip(pow(i / 255.0, gamma) * 255.0, 0, 255)
gamma_corrected = cv2.LUT(img1, lookUpTable)

二、逻辑运算

逻辑运算是基于布尔代数的像素级操作,主要用于二值图像处理。

2.1基本逻辑运算
与运算(AND):
  • 公式:C(x,y) = A(x,y) ∧ B(x,y)

  • 应用:掩膜应用、交集区域提取

  • 例子:提取两幅二值图像的共同前景

bitwise_and = cv2.bitwise_and(img1, img2)
或运算(OR):
  • 公式:C(x,y) = A(x,y) ∨ B(x,y)

  • 应用:区域合并

  • 例子:合并多个分割区域

bitwise_or = cv2.bitwise_or(img1, img2)
非运算(NOT):
  • 公式:C(x,y) = ¬A(x,y)

  • 应用:图像反相

  • 例子:将黑白图像反色

bitwise_not = cv2.bitwise_not(img1)
异或运算(XOR):
  • 公式:C(x,y) = A(x,y) ⊕ B(x,y)

  • 应用:差异检测、图像加密

  • 例子:检测两幅图像的差异区域

bitwise_xor = cv2.bitwise_xor(img1, img2)
2.2 组合逻辑运算
形态学运算:
  • 基于逻辑运算的组合操作

  • 例子:膨胀、腐蚀、开运算、闭运算

kernel = np.ones((5,5), np.uint8)
# 膨胀(扩大亮区)
dilation = cv2.dilate(img1, kernel, iterations=1)
# 腐蚀(缩小亮区)
erosion = cv2.erode(img1, kernel, iterations=1)
# 开运算(先腐蚀后膨胀,去除小噪点)
opening = cv2.morphologyEx(img1, cv2.MORPH_OPEN, kernel)
# 闭运算(先膨胀后腐蚀,填充小孔洞)
closing = cv2.morphologyEx(img1, cv2.MORPH_CLOSE, kernel)

三、实际应用示例

数值运算示例:图像增强

# 增加亮度
brightened = cv2.add(img1, 50)  # 所有像素值加50# 对比度拉伸
contrast = cv2.multiply(img1, 1.5)  # 所有像素值乘以1.5

逻辑运算示例:车牌提取

# 转换为灰度图
gray = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)
# 二值化
_, binary = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY+cv2.THRESH_OTSU)
# 定义车牌形状的结构元素
rect_kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (15, 3))
# 闭运算填充车牌字符
closed = cv2.morphologyEx(binary, cv2.MORPH_CLOSE, rect_kernel)

http://www.xdnf.cn/news/1249795.html

相关文章:

  • dify之推送飞书群消息工作流
  • selenium操作指南
  • python中的推导式
  • Linux Vi常用指令总结
  • AI 软件工程开发 AI 算法 架构与业务
  • AI+UI:如何用智能算法提升设计效率10倍?
  • 虚幻GAS底层原理解剖五 (AS)
  • 设计模式—桥梁模式(Bridge)
  • Spring Boot全局异常处理与日志监控实战指南
  • 华硕携多款明星电竞显示器亮相 ChinaJoy2025,联袂 TCL 华星打造沉浸体验
  • 鼠标下滑时回跳问题
  • 从 “认知优势” 到现实赋能:DPVR AI Glasses 重构智能穿戴价值
  • Chrontel昆泰-【CH7036A-BF】CH7036 LVDS to HDMI/VGA/LVDS Converter
  • 4、docker数据卷管理命令 | docker volume
  • docker run 入门到进阶:容器启动背后的门道
  • C++音视频流媒体开发面试题:音视频基础
  • 什么是RabbitMQ?
  • OpenObserve非sql模式 query editor 中 xx like ‘|’报错如何处理
  • mysql 8递归查询
  • 科技云报到:Agent应用爆发,谁成为向上托举的力量?
  • 网络编程epoll学习
  • UE编辑器相机窗口运行时相机fov 大小不一致
  • Vue Router 路由的创建和基本使用(超详细)
  • 手动开发一个TCP服务器调试工具(二):无界面 TCP 通信服最小实现
  • Linux网络编程基础-简易TCP服务器框架
  • 大前端游戏应用中 AI 角色行为智能控制
  • 网站、域名、IP在什么场景下需要备案
  • Fabric.js从入门学习到实现labelImg矩形多边形标注工具【上】
  • SmartMediaKit 模块化音视频框架实战指南:场景链路 + 能力矩阵全解析
  • ICCV 2025 | 视频生成迈入“多段一致”新时代!TokensGen用“压缩Token”玩转长视频生成