python图像处理模糊_Python+OpenCV图像处理之模糊操作

模糊操作是图像处理中最简单和常用的操作之一,该使用的操作之一原因就为了给图像预处理时减低噪声,基于数学的卷积操作

均值模糊,函数 cv2.blur(image,(5,5)),这是一个平滑图片的函数,它将一个区域内所有点的灰度值的平均值作为这个点的灰度值。像该函数对领域点的灰度值进行权重相加最后设置灰度值,这样的操作又叫卷积,这样的滤波器叫线性滤波器。

中值模糊,函数cv2.medianBlur(image,5),该函数不同于上一个函数,它是非线性滤波器,它是取领域的中值作为当前点的灰度值。,上面函数就是选取了5*5大小的矩阵,必须为奇数,处理有椒盐噪声(就像烧烤撒很多孜然,图片上有很多点)有很好的效果

自定义模糊(锐化),函数filter2D():定义为cv2.filter2D(src,ddepth,kernel)

锐化就是突出图像细节或者增强图像被模糊的地方,锐化原理就是细节增强,图像的导数就是图像的细节,随着导数阶数升高,能代表的东西也不同。

均值模糊、中值模糊、自定义模糊的python代码

importcv2importnumpy as np__author__ = "boboa"

#均值模糊 去随机噪声有很好的去燥效果

defblur_demo(image):

dst= cv2.blur(image, (5, 5))

cv2.imshow("blur_demo", dst)#中值模糊去除椒盐噪声

defmedian_blur_demo(image):

dst= cv2.medianBlur(image, 5)

cv2.imshow("median_blur_demo", dst)#自定义模糊

defcustom_blur_demo(image):#kernels = np.ones([5, 5], np.float32)/25

kernels = np.array([[0, -1, 0], [-1, 5, -1], [0, -1, 0]], np.float32)

dst= cv2.filter2D(image, -1, kernel=kernels)

cv2.imshow("custom_blur_demo", dst)if __name__ == "__main__":

img= cv2.imread("img3.jpg")

cv2.namedWindow("input image", cv2.WINDOW_AUTOSIZE)

cv2.imshow("input image", img)

blur_demo(img)

median_blur_demo(img)

cv2.waitKey(0)

cv2.destroyAllWindows()

均值模糊运行效果

4da23da46b55f94e4892559b2ddb51af.png

中值模糊运行结果

7ab5b5fccbc01b0c7170b6d9a0e98b94.png

自定义运行结果

5a57355b03e4586d5687600406989630.png

高斯模糊本质上是低通滤波器,输出图像的每个像素点是原图像上对应像素点与周围像素点的加权和,原理并不复杂,就是用高斯分布权值矩阵与原始图像矩阵做卷积运算而已。

高斯模糊的python代码

importcv2importnumpy as np"""高斯模糊/噪声

轮廓还在,保留图像的主要特征

高斯模糊比均值模糊去噪效果好"""

defclamp(pv):if pv > 255:return 255

if pv <0:return0else:returnpvdefgaussian_noise(image):

h, w, c=image.shapefor row inrange(h):for col inrange(w):

s= np.random.normal(0, 20, 3)

b= image[row, col, 0] #blue

g = image[row, col, 1] #green

r = image[row, col, 2] #red

image[row, col, 0] = clamp(b +s[0])

image[row, col,1] = clamp(g + s[1])

image[row, col,2] = clamp(r + s[2])

cv2.imshow("noise image", image)if __name__ == "__main__":

img= cv2.imread("img5.jpg")

cv2.namedWindow("input image", cv2.WINDOW_AUTOSIZE)

cv2.imshow("input image", img)#gaussian_noise(img)

#高斯模糊抑制高斯噪声

dst = cv2.GaussianBlur(img, (5, 5), 0)

cv2.imshow("Gaussian Blur", dst)

cv2.waitKey(0)

cv2.destroyAllWindows()

运行结果

90f4ddef4341cb79dd885729c3062e17.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574338.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javascript Date类型 学习笔记

1 创建一个新的日期对象&#xff0c;如果不带参数&#xff0c;则对象自动获得当前的日期和时间 var d new Date() 2 如果需要指定特定的日期&#xff0c;则可以通过Date.parse() 或者 Date().UTC(),返回时间戳作为 new Date()的参数 Date.parse() 用法&#xff1a; var time…

python如何访问私有变量_python – 从类访问私有模块变量

我正在尝试理解python范围规则.为此,我尝试从同一模块中的类访问“非常私有”变量bar "bar"_bar "underscore"__bar "double underscore"def foo():print barprint _barprint globals()["__bar"]print __barclass Foo:def __init__…

高斯消元学习

1. 证明XOR满足交换律&#xff0c;结合律&#xff0c;是自身的逆运算。比如说&#xff0c;1^0 1 1^1 0 0^1 1 0^0 01^1^0 0 1^0^1 0.a^b^ab 即一个数异或两次相当于无效 2. 从N个数中选出两个数&#xff0c;使XOR和最大。解法&#xff1a;我们知道两个数字之间的异或…

java经纬度格式_java经纬度格式转换

在数学中&#xff0c;表示角度的度、分、秒分别使用、′、″符号进行表示。160′&#xff0c;1′60″ &#xff0c;13600″。由上述可知度分秒转换度的计算公式为&#xff1a;(ddmm′ss″) ddmm/60ss/3600如&#xff1a;11330′10.25″ 11330/6010.25/3600 ≈113.502847度分秒…

Android GPS及地磁传感器 API

Android 提供的位置包括经纬度和时间戳&#xff0c;可选地包含高度和方位&#xff0c;高度以WGS84椭球体为参照&#xff0c;方位以真北为参考。 地磁传感器以磁北为北。有2种传感器可提供方位信息&#xff1a;地磁场&#xff08;Geomagnetic&#xff09;传感器和方向&#xff0…

e3是合法浮点数吗_下面4个选项中,均是合法浮点数的选项是?

选B。b中的123是整数&#xff0c;不是浮点数&#xff0c;2e4.2的指数是4.2不满足浮点数的规则必须是整数&#xff0c;e5中的e不满足浮点数的规则&#xff0c;所以b中3个数均不是浮点数。a中的160、0.12是正确的&#xff0c;c中的123e4、0.0是正确的&#xff0c;d中的234、1e3是…

winform 菜单激发窗体切换做法

经常会用到类似于下图这样的winform窗体&#xff0c;其中点击各个菜单时于鏊做到内容窗体的切换&#xff0c;今天也记录一直切换的方法 在主窗体放置一个panal&#xff0c;所有的内容窗体均在改panal上呈现&#xff0c;实现以下方法 ///实例化主窗体 private void FrmSetup_Loa…

java 正则表达式 反向_正则表达式中的数量表示符、反向引用、零宽断言、以及java中的用法...

在表示数量时&#xff0c;如果一个正则表达式X&#xff0c;后面没有加表示数量的符号&#xff0c;那就默认出现一次。如果指定需要出现n次&#xff0c;那就用{n}&#xff0c;例如a{n},就是匹配a出现n次的。a{n,}表示a出现至少n次的&#xff0c;而这个时候就会默认是贪婪模式&am…

cocos2d-x Lua与OC互相调用

1. Lua 调用OC 先看例子&#xff1a; hello.lua: -- 点击回调函数local function notifymenuCallbackTest()local luaoc require(luaoc)local ok, ret luaoc.callStaticMethod("RemoteRequestRouter", "notifyWatch", {params1 "NOTIFICATION_TO_H…

coldwallet java eth_wallet-eth 以太坊代币钱包 助记词 私钥 keystore 转账

wallet-eth-androidwallet-eth 以太坊代币钱包 助记词 私钥 keystore 转账(bip39、bip32、bip44、web3j)生成钱包地址// 生成钱包地址Wallet wallet WalletManager.generateWalletAddress();// 根据助记词获取地址WalletManager.generateAddress(wallet.getMnemonic());// 通过…

Uva 10004(二分图的判定)

这题其实很简单的说&#xff0c;第一次用邻接表来存图 首先图的储存结构是结构体head数组。。。其实head数组保存的 struct node {int v;int next; }V[200*200]; 假设现在有u节点&#xff0c;v表示的是和他邻接的点&#xff0c;next保存的是v对应的编号&#xff0c;head数组保…

django配置在MySQL_怎么在Django中安装与配置mysql

怎么在Django中安装与配置mysql发布时间&#xff1a;2021-02-26 17:42:11来源&#xff1a;亿速云阅读&#xff1a;57作者&#xff1a;Leah本篇文章为大家展示了怎么在Django中安装与配置mysql&#xff0c;内容简明扼要并且容易理解&#xff0c;绝对能使你眼前一亮&#xff0c;通…

php 返回数组元素函数_php array_values 返回数组的所有值详解及实例

php array_valuesphp array_values 函数用于返回数组中所有的值&#xff0c;注意该函数将为新数组建立数组索引&#xff0c;原来的文字索引将不存在。本文章向大家讲解array_values函数的基本语法及使用实例。array_values 返回数组中所有的值基本语法&#xff1a;array array_…

0909 粗浅的认识编译原理

经过相关网页的浏览&#xff0c;也看到了各大网站中各方牛人的回答&#xff0c;我似乎对编译原理有了自己一点粗浅的认识。首先&#xff0c;编译原理及技术从根本上来讲就是对算法问题进行求解&#xff0c;这个问题十分复杂&#xff0c;更不用说其解决算法。 而本学期开的算法分…

PHP点歌插件,斗鱼弹幕点歌插件_小葫芦社区_小葫芦插件交流 - Powered by Discuz!

更新版本&#xff1a;3.3.7更新日期&#xff1a;2017-04-25更新日志&#xff1a;1. 修复 部分斗鱼房间无法连接弹幕的问题(主要是参与主播带你嗨购活动的主播)2. 修复 其他已知问题更新版本&#xff1a;3.2.16更新日期&#xff1a;2017-03-01更新日志&#xff1a;1. 修复 斗鱼弹…

Java字符串找出4个字节长度的字符

不解释&#xff0c;直接上代码&#xff1a; 由于Iteye代码贴四个字节的&#xff35;&#xff34;&#xff26;&#xff0d;&#xff18;字符出错&#xff0c;特能图的方式发布几个特殊字符&#xff1a; Java代码 public class Byte4Check { public static void main…

java编写sql语句,java实现简单的给sql语句赋值的示例

代码本身很简单。拼接sql的时候&#xff1f;不好数&#xff0c;简单的用来赋值。/*** TODO 循环赋值,缺少的类型可随时添加* author Lucius* param pt* param list* throws SQLException*/public static void setParam(PreparedStatement pt, List list) throws SQLException{f…

div 左右并排,使用CSS如何让两个div并排显示

用CSS如何让两个DIV盒子并排体现呢&#xff1f;各人知道默认情况下DIV是独占一排的&#xff0c;DIV不设置任何CSS格局&#xff0c;这个DIV盒子都邑独有一行踊跃换行。运用CSS让两个DIV并排闪现&#xff0c;排成一排显示思空见贯方式有两种&#xff1a;1、运用display:inline2、…

ASP.NET MVC5 与EF6学习系列

最近学习使用MVC5和EF6&#xff0c;博客园搜索了一番&#xff0c;写下这篇文章记录&#xff0c;以便学习使用。 一、ASP.NET MVC5 网站开发 洞庭夕照写的博客系列 ASP.NET MVC5 网站开发实践 - 概述 ASP.NET MVC5 网站开发实践(一) - 项目框架 ASP.NET MVC5 网站开发实践(一) -…

耦合度和聚合度

简单地说&#xff0c;对象之间的耦合度就是对象之间的依赖性。指导使用和维护对象的主要问题是对象之间的多重依赖性。对象之间的耦合越高&#xff0c;维护成本越高。因此对象的设计应使类和构件之间的耦合最小. 耦合性是程序结构中各个模块之间相互关联的度量.它取…