图像阈值处理---移动平均法(python 实现)

2024-03-04 03:59

本文主要是介绍图像阈值处理---移动平均法(python 实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

  • 前几天在看那本比较经典的冈萨雷斯的《数字图像处理》,正看到图像分割一章中用移动平均法来进行分割。介绍该方法的时候用的章节较少,感觉看的不是很明白,于是在网上搜了一下发现该方法的介绍也很少,也没有找到python相关实现(找到一个不是免费的。。),只找到了matlab和C++的实现。所以根据代码又翻书理解了一下,简单写一下移动平均法,做个总结,后面有python的实现。

概念介绍

移动平均法是可变阈值处理的一种,可变阈值是相对于全局阈值处理来说的,全局阈值处理是指根据整张图片计算出一个固定的阈值,图片中的每个像素如果大于这个值就认为是前景,否则就是背景。而可变阈值是指图片中每个位置的像素点或像素块中有着不同的阈值,如果该像素点大于其对应的阈值则认为是前景。移动平均法是线性的z字形的扫描整个图片,每个点处都会产生一个阈值,用该点处的灰度值和该点处计算出阈值比较来分割图片。

方法

假设一幅5x5的图片如下所示,aij表示在位置(i, j)处的灰度值。

因为要按照z字形线性扫描,所以要把二维矩阵变成一维的行矩阵
在这里插入图片描述

移动平均算法中会用到两个参数n和b,n表示n个像素求平均,b是一个阈值系数。下面的一维矩阵可以作为滤波器对上面得到的图像的一维行矩阵进行滤波求平均
在这里插入图片描述
这样就可以得到每个点处的平均值mij,用参数b乘以mij就是这个像素点处的阈值
在这里插入图片描述

然后就可以把每个像素点的灰度和阈值进行比较得到最终的分割图像了。

python实现

import cv2
import numpy as np
from scipy.signal import lfilterN = 10
b = 0.5def max_min_value_filter(image, ksize=3, mode=1):img = image.copy()rows, cols = img.shape# if channels == 3:#     img = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)padding = (ksize-1) // 2new_img = cv2.copyMakeBorder(img, padding, padding, padding, padding, cv2.BORDER_CONSTANT, value=255)for i in range(rows):for j in range(cols):roi_img = new_img[i:i+ksize, j:j+ksize].copy()min_val, max_val, min_index, max_index = cv2.minMaxLoc(roi_img)if mode == 1:img[i, j] = max_valelif mode == 2:img[i, j] = min_valelse:raise Exception("please Select a Mode: max(1) or min(2)")return imgdef movingthreshold(f, n, k):shape = f.shapeassert n >= 1assert 0 < k < 1f[1:-1:2, :] = np.fliplr(f[1:-1:2, :])f = f.flatten()maf = np.ones(n) / nres_filter = lfilter(maf, 1, f)g = np.array(f > k * res_filter).astype(int)g = g.reshape(shape)g[1:-1:2, :] = np.fliplr(g[1:-1:2, :])g = g * 255# max value filter# g = max_min_value_filter(g, 3, 2)# cv2.blur(g, (3, 3))return gimg = cv2.imread('/path/to/image/file', 0)
res = movingthreshold(img, N, b)
cv2.imwrite('/path/to/results', res)

效果

原图
在这里插入图片描述
移动平均处理
在这里插入图片描述
最后再对结果进行一次最小值滤波
在这里插入图片描述
可以看到效果还是不错的!
在这里插入图片描述
最后贴一个风格迁移小程序,感兴趣可以玩一下。

这篇关于图像阈值处理---移动平均法(python 实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/771938

相关文章

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount