OpenCV3入门(十三)图像运动模糊
1、原理
运动模糊产生: 由于相机传感器或物体相对运动, 按快门瞬间造成图像产生运动模糊。
在用摄像机获取景物图像时,如果在相机曝光期间景物和摄像机之间存在相对运动,例如用照相机拍摄快速运动的物体,或者从行驶中的汽车上拍摄外面静止不动的景物时,拍得的照片都可能存在模糊的现象,这种由于相对运动造成图像模糊现象就是运动模糊。运动模糊是一种图片“退化”现象,无法反应真实的场景。
假设图像f(x,y)进行平面运动,x(t0)和y(t0)分别是在x和y方向上随时间变化的量。那么介质上(如胶片或数字存储器)上任意点的曝光总数是通过对时间间隔内瞬间曝光量的积分得到的, 图像系统的快门在该段时间是开着的。假设快门开关所用的时间很短,因此光学成像过程不会受到图像运动干扰。运动模糊产生式:

g(x,y): 代表运动模糊后在坐标(x,y)的结果
T:代表曝光时间
2、实现过程
1)对图像方向分解为x和y方向;
2)因为图像Mat坐标对应图像的正下,所以翻转Y轴;
3)分别计算图像位移;
4)合并多个像素,防止溢出求平均值。
3、代码实例
实验代码如下。只是简单的实现了模糊原理,没有考虑加性噪声n(x)。
void MotionBlur(Mat& img, Mat& dst, int angle, int distance)
{
angle = -*angle % ;
double radian = ((double)angle + 180.0) / 180.0*3.1415926;
int dx = (int)((double)distance* cos(radian) + 0.5);
int dy = (int)((double)distance* sin(radian) + 0.5); int sign = ;
int height = img.rows;
int width = img.cols;
int chns = img.channels(); if (dst.empty()) dst.create(height, width, img.type());
int i, j, k;
int i0=, j0=, p, sum, count;
for (i = ; i < height; i++)
{
unsigned char* dstData = (unsigned char*)dst.data + dst.step*i;
for (j = ; j < width; j++)
{
for (k = ; k < chns; k++)
{
sum = , count = ;
sign = (dx > ) ? : -;
for (p = ; p < abs(dx); p++)
{
i0 = i;
j0 = j+p * sign;
if (i0 >= && i0 < height && j0 >= && j0 < width)
{
count++;
sum += img.at<Vec3b>(i0, j0)[k];
}
}
sign = (dy > ) ? : -;
for (p = ; p < abs(dy); p++)
{
i0 = i + p * sign;
j0 = j;
if (i0 >= && i0 < height && j0 >= && j0 < width)
{
count++;
sum += img.at<Vec3b>(i0, j0)[k];
}
} if (count == )
{
dstData[j*chns + k] = img.at<Vec3b>(i0, j0)[k];
}
else
{
dstData[j*chns + k] = saturate_cast<uchar>(sum / (double)count + 0.5);
} }
}
}
} void test_motion()
{
Mat src_img = imread("D:\\WORK\\5.OpenCV\\LeanOpenCV\\pic_src\\pic14.bmp");
imshow("原图", src_img); Mat dst_img;
MotionBlur(src_img, dst_img, , );
imshow("motion", dst_img);
}
4、测试
测试1:验证模糊的方向,输入棋盘格图,输出为不同方向的模糊效果图。

输出效果图如下。

测试2:模糊效果如下图。

测试3:模糊效果如下图。

5、参考文献
1、Motion Deblur Filter
https://docs.opencv.org/3.4/d1/dfd/tutorial_motion_deblur_filter.html
2、图像复原与重建篇——运动模糊
https://blog.csdn.net/jmu201521121021/article/details/80634361
3、PhotoShop算法实现进阶-模糊滤镜-运动模糊(二十四)
https://blog.csdn.net/kezunhai/article/details/41757681
4、《OpenCV3 编程入门》,电子工业出版社,毛星雨著
5、《学习OpenCV》,清华大学出版社,Gary Bradski, Adrian kaehler著
技术博客,转载请注明。
OpenCV3入门(十三)图像运动模糊的更多相关文章
- Win8 Metro(C#)数字图像处理--2.50图像运动模糊
原文:Win8 Metro(C#)数字图像处理--2.50图像运动模糊 [函数名称] 图像运动模糊算法 MotionblurProcess(WriteableBitmap src,int ...
- 维纳滤波和编码曝光PSF去除运动模糊【matlab】
编码曝光知识 - ostartech - 博客园 https://www.cnblogs.com/wxl845235800/p/8276362.html %%%%%%%%%%%%%%%%%%%%%%% ...
- 从单幅图像高质量去除运动模糊——读JiaYaJia同名英文论文总结
原始论文在这里 http://www.cse.cuhk.edu.hk/leojia/projects/motion_deblurring/ 一.概述 论文根据以下的基本模糊图像模型建立 其中I是我们观 ...
- Java 运动模糊
Java 运动模糊代码 想用Java 写个运动模糊的效果,无奈本人水平有限,国内也没找到资源,于是Google到了一个文档,特地分享出来! 本代码源自 http://www.jhlabs.com/ip ...
- 使用 canvas 画图时图像文字模糊的解决办法
最近在使用 canvas 画图的时候,遇到了图像文字模糊的问题,解决思路就是根据分辨率创建不同尺寸的画布.以下是创建高分辨率画布的代码: /** * 创建高分辨率画布 * @param w 画布宽 * ...
- Unity shader学习之屏幕后期处理效果之运动模糊
运动模糊,代码如下: using UnityEngine; public class MotionBlurRenderer : PostEffectRenderer { [Range(0.1f, 0. ...
- OpenCV3入门(六)图像滤波
1.图像滤波理论 1.1图像滤波理论 图像滤波即在尽量保留图像细节特征的条件下对目标图像的噪声进行抑制,是图像预处理中不可缺少的操作.消除图像中的噪声又叫做图像滤波或平滑,滤波的目的有两个,一是突出特 ...
- OpenCV3入门(七)图像形态学
1.膨胀 所谓的图片的膨胀处理,其实就是在图像的边缘添加像素值,使得整体的像素值扩张,进而达到图像的膨胀效果. 对Z2上元素集合A和结构体元素S,使用S对A进行腐蚀,记作: A⊕S={z|(S)z ∩ ...
- OpenCV3入门(四)图像的基础操作
1.访问图像像素 1)灰度图像 2)彩色图像 OpenCV中的颜色顺序是BGR而不是RGB. 访问图像的像素在OpenCV中就是访问Mat矩阵,常用的有三种方法. at定位符访问 Mat数据结构,操作 ...
随机推荐
- svn使用2(转)
首先打开VisualSVN Server Manager,如图: 可以在窗口的右边看到版本库的一些信息,比如状态,日志,用户认证,版本库等.要建立版本库,需要右键单击左边窗口的Repositores, ...
- 第一课 安装wamp环境
1.准备 怎样选择PHP的版本 IIS 如果想使用IIS配置PHP的话,那么需要选择Non-Thread Safe(NTS)版本的PHP Apache 如果你是用的Apache的版本来自Apache ...
- markdown直接粘贴截图
通过代码方式 cmd markdown粘贴截图 https://www.jianshu.com/p/ae048b5090f8
- JVM核心组成部分与作用介绍
jvm由多个部分组成运作的 1.class loader类加载器: 加载类到内存里面,Class loader只需负责加载. 符合条件结构就加载到里面跑, 是否能运行顺利或者有没有错误异常,则需要Ex ...
- 合并cookie,提取json数据
发送的第3个请求需要前两个请求的cookie,需要对cookie进行合并 发送的请求数据来自于json数据中的某个键值. 这里是删除所有的对话主题目录,每一个目录有一个id,发起删除对话主题目录的请求 ...
- 修改 commit message
本文为原创文章,转载请标明出处 目录 修改上一条提交的 commit message 修改之前提交的 commit message 1. 修改上一条提交的 commit message git com ...
- R语言的xtabs函数
今天在做一个列联表独立性检验的时候,总是无法处理好要求的数据类型,偶然的机会,看到了xtabs()函数,感觉很适合用来做列联表,适合将一列数据转换成列联表. shifou <- c(" ...
- Angular系列一:Angular程序架构
Angular程序架构 Angular程序架构 组件:一段带有业务逻辑和数据的Html服务:用来封装可重用的业务逻辑指令:允许你向Html元素添加自定义行为模块: 环境搭建 安装nodeJs安装好no ...
- 使用 Git 删除本地仓库和远端仓库文件
使用 git bash 来删除 一.将文件(夹)添加到暂存区 这里假设本地和远端都有一个 test.txt 文件先在本地删除,通过 ·git status 查看通过git add test.txt 添 ...
- Center Loss - A Discriminative Feature Learning Approach for Deep Face Recognition
URL:http://ydwen.github.io/papers/WenECCV16.pdf这篇论文主要的贡献就是提出了Center Loss的损失函数,利用Softmax Loss和Center ...