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著

技术博客,转载请注明。

https://www.cnblogs.com/pingwen/p/12495168.html

OpenCV3入门(十三)图像运动模糊的更多相关文章

  1. Win8 Metro(C#)数字图像处理--2.50图像运动模糊

    原文:Win8 Metro(C#)数字图像处理--2.50图像运动模糊  [函数名称] 图像运动模糊算法    MotionblurProcess(WriteableBitmap src,int  ...

  2. 维纳滤波和编码曝光PSF去除运动模糊【matlab】

    编码曝光知识 - ostartech - 博客园 https://www.cnblogs.com/wxl845235800/p/8276362.html %%%%%%%%%%%%%%%%%%%%%%% ...

  3. 从单幅图像高质量去除运动模糊——读JiaYaJia同名英文论文总结

    原始论文在这里 http://www.cse.cuhk.edu.hk/leojia/projects/motion_deblurring/ 一.概述 论文根据以下的基本模糊图像模型建立 其中I是我们观 ...

  4. Java 运动模糊

    Java 运动模糊代码 想用Java 写个运动模糊的效果,无奈本人水平有限,国内也没找到资源,于是Google到了一个文档,特地分享出来! 本代码源自 http://www.jhlabs.com/ip ...

  5. 使用 canvas 画图时图像文字模糊的解决办法

    最近在使用 canvas 画图的时候,遇到了图像文字模糊的问题,解决思路就是根据分辨率创建不同尺寸的画布.以下是创建高分辨率画布的代码: /** * 创建高分辨率画布 * @param w 画布宽 * ...

  6. Unity shader学习之屏幕后期处理效果之运动模糊

    运动模糊,代码如下: using UnityEngine; public class MotionBlurRenderer : PostEffectRenderer { [Range(0.1f, 0. ...

  7. OpenCV3入门(六)图像滤波

    1.图像滤波理论 1.1图像滤波理论 图像滤波即在尽量保留图像细节特征的条件下对目标图像的噪声进行抑制,是图像预处理中不可缺少的操作.消除图像中的噪声又叫做图像滤波或平滑,滤波的目的有两个,一是突出特 ...

  8. OpenCV3入门(七)图像形态学

    1.膨胀 所谓的图片的膨胀处理,其实就是在图像的边缘添加像素值,使得整体的像素值扩张,进而达到图像的膨胀效果. 对Z2上元素集合A和结构体元素S,使用S对A进行腐蚀,记作: A⊕S={z|(S)z ∩ ...

  9. OpenCV3入门(四)图像的基础操作

    1.访问图像像素 1)灰度图像 2)彩色图像 OpenCV中的颜色顺序是BGR而不是RGB. 访问图像的像素在OpenCV中就是访问Mat矩阵,常用的有三种方法. at定位符访问 Mat数据结构,操作 ...

随机推荐

  1. 阿里云系统安装部署Freeswitch

    1.安装vim apt-get install vim 2.修改镜像源 将/etc/apt/source.list的原有源注释掉,添加下面的源: deb http://mirrors.163.com/ ...

  2. [洛谷P3806] [模板] 点分治1

    洛谷 P3806 传送门 这个点分治都不用减掉子树里的了,直接搞就行了. 注意第63行 if(qu[k]>=buf[j]) 不能不写,也不能写成>. 因为这个WA了半天...... 如果m ...

  3. Java IO: Reader和Writer

    作者: Jakob Jenkov 译者: 李璟(jlee381344197@gmail.com) Reader 原文链接 Reader是Java IO中所有Reader的基类.Reader与Input ...

  4. 吴裕雄--天生自然Android开发学习:android开发知识学习思维导图

  5. cesium入门示例-测量工具

    作为cesium入门示例级别的最后一篇,参考cesium-长度测量和面积测量实现测量工具封装,修改了其中的距离测量函数,计算贴地距离,并对事件内部处理做了调整.包括贴地距离测量.面积测量.结果清除. ...

  6. 仿射密码Python实现

    算法分析 仿射密码结合了移位密码和乘数密码的特点,是移位密码和乘数密码的组合. 仿射密码的加密算法就是一个线性变化,即对明文字符x,对应的密文字符为y=ax+b(mod26)其中,a, b属于Z26且 ...

  7. html中的锚点介绍和使用

    以下资料整理自网路 1.锚点是网页制作中超级链接的一种,又叫命名锚记.命名锚记像一个迅速定位器一样是一种页面内的超级链接,运用相当普遍. 英文名:anchor 使用命名锚记可以在文档中设置标记,这些标 ...

  8. 4-CSS规范

    4.1 命名规范:4.1.1 css文件命名 reset.css 重置样式,重置元素默认样式,使得页面在所有浏览器中有统一的外观 global.css 全局样式,全站公用,定义页面基础样式(常见的公共 ...

  9. 20. API概览 Schemas

    能被机器所理解的概要, 描述了通过api可得到的资源, URL, 表示方式以及支持的操作. API概要在很多使用场景下都是有用的工具, 例如生成参考文档, 或者驱动可以与API交互的动态客户端库. r ...

  10. MIUI 7 会是小米的救命稻草吗?

    7 会是小米的救命稻草吗?" title="MIUI 7 会是小米的救命稻草吗?"> 花无百日红,人无千日好.再绚烂的曾经,或许一朝不慎,就会成为过去.在科技圈,诺 ...