图像处理------Mean Shift滤波(边缘保留的低通滤波)
一:Mean Shift算法介绍
Mean Shift是一种聚类算法,在数据挖掘,图像提取,视频对象跟踪中都有应用。本文
重要演示Mean Shift算法来实现图像的低通边缘保留滤波效果。其处理以后的图像有点
类似油画一样。Mean Shift算法的输入参数一般有三个:
1. 矩阵半径r,声明大小
2. 像素距离,常见为欧几里德距离或者曼哈顿距离
3. 像素差值value
算法大致的流程如下:
a. 输入像素点P(x, y)
b. 计算该点的像素值pixelv
c. 根据输入的半径r与差值value求出矩阵半径内满足差值像素平均值作为输出像素点值
d. 计算shift与repetition,如果满足条件
e. 继续c ~ d,直到条件不满足退出,得到最终的输出像素值
f. 对输入图像的每个像素重复a ~ e,得到图像输出像素数据
二:色彩空间转换
本文Mean Shift滤波在YIQ颜色空间上完成,关于RGB与YIQ颜色空间转换可以参考
这里:http://en.wikipedia.org/wiki/YIQ我google找来的转换公式截屏:

三:程序效果

滤镜源代码:
- package com.gloomyfish.filter.study;
- import java.awt.image.BufferedImage;
- public class MeanShiftFilter extends AbstractBufferedImageOp {
- private int radius;
- private float colorDistance;
- public MeanShiftFilter() {
- radius = 3; // default shift radius
- colorDistance = 25; // default color distance
- }
- public int getRadius() {
- return radius;
- }
- public void setRadius(int radius) {
- this.radius = radius;
- }
- public float getColorDistance() {
- return colorDistance;
- }
- public void setColorDistance(float colorDistance) {
- this.colorDistance = colorDistance;
- }
- @Override
- public BufferedImage filter(BufferedImage src, BufferedImage dest) {
- int width = src.getWidth();
- int height = src.getHeight();
- if ( dest == null )
- dest = createCompatibleDestImage( src, null );
- int[] inPixels = new int[width*height];
- int[] outPixels = new int[width*height];
- getRGB( src, 0, 0, width, height, inPixels);
- // convert RGB color space to YIQ color space
- float[][] pixelsf = new float[width*height][3];
- for(int i=0; i<inPixels.length; i++) {
- int argb = inPixels[i];
- int r = (argb >> 16) & 0xff;
- int g = (argb >> 8) & 0xff;
- int b = (argb) & 0xff;
- pixelsf[i][0] = 0.299f *r + 0.587f *g + 0.114f *b; // Y
- pixelsf[i][1] = 0.5957f *r - 0.2744f*g - 0.3212f *b; // I
- pixelsf[i][2] = 0.2114f *r - 0.5226f*g + 0.3111f *b; // Q
- }
- int index = 0;
- float shift = 0;
- float repetition = 0;
- float radius2 = radius * radius;
- float dis2 = colorDistance * colorDistance;
- for(int row=0; row<height; row++) {
- int ta = 255, tr = 0, tg = 0, tb = 0;
- for(int col=0; col<width; col++) {
- int xc = col;
- int yc = row;
- int xcOld, ycOld;
- float YcOld, IcOld, QcOld;
- index = row*width + col;
- float[] yiq = pixelsf[index];
- float Yc = yiq[0];
- float Ic = yiq[1];
- float Qc = yiq[2];
- repetition = 0;
- do {
- xcOld = xc;
- ycOld = yc;
- YcOld = Yc;
- IcOld = Ic;
- QcOld = Qc;
- float mx = 0;
- float my = 0;
- float mY = 0;
- float mI = 0;
- float mQ = 0;
- int num=0;
- for (int ry=-radius; ry <= radius; ry++) {
- int y2 = yc + ry;
- if (y2 >= 0 && y2 < height) {
- for (int rx=-radius; rx <= radius; rx++) {
- int x2 = xc + rx;
- if (x2 >= 0 && x2 < width) {
- if (ry*ry + rx*rx <= radius2) {
- yiq = pixelsf[y2*width + x2];
- float Y2 = yiq[0];
- float I2 = yiq[1];
- float Q2 = yiq[2];
- float dY = Yc - Y2;
- float dI = Ic - I2;
- float dQ = Qc - Q2;
- if (dY*dY+dI*dI+dQ*dQ <= dis2) {
- mx += x2;
- my += y2;
- mY += Y2;
- mI += I2;
- mQ += Q2;
- num++;
- }
- }
- }
- }
- }
- }
- float num_ = 1f/num;
- Yc = mY*num_;
- Ic = mI*num_;
- Qc = mQ*num_;
- xc = (int) (mx*num_+0.5);
- yc = (int) (my*num_+0.5);
- int dx = xc-xcOld;
- int dy = yc-ycOld;
- float dY = Yc-YcOld;
- float dI = Ic-IcOld;
- float dQ = Qc-QcOld;
- shift = dx*dx+dy*dy+dY*dY+dI*dI+dQ*dQ;
- repetition++;
- }
- while (shift > 3 && repetition < 100);
- tr = (int)(Yc + 0.9563f*Ic + 0.6210f*Qc);
- tg = (int)(Yc - 0.2721f*Ic - 0.6473f*Qc);
- tb = (int)(Yc - 1.1070f*Ic + 1.7046f*Qc);
- outPixels[index] = (ta << 24) | (tr << 16) | (tg << 8) | tb;
- }
- }
- setRGB( dest, 0, 0, width, height, outPixels );
- return dest;
- }
- public String toString() {
- System.out.println("Mean Shift Filter...");
- return "MeanShiftFilter";
- }
- }
图像处理------Mean Shift滤波(边缘保留的低通滤波)的更多相关文章
- 跟我学Python图像处理丨傅里叶变换之高通滤波和低通滤波
摘要:本文讲解基于傅里叶变换的高通滤波和低通滤波. 本文分享自华为云社区<[Python图像处理] 二十三.傅里叶变换之高通滤波和低通滤波>,作者:eastmount . 一.高通滤波 傅 ...
- OpenCV计算机视觉学习(10)——图像变换(傅里叶变换,高通滤波,低通滤波)
如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice 在数 ...
- python实现直方图均衡化,理想高通滤波与高斯低通滤波
写在前面 HIT大三上学期视听觉信号处理课程中视觉部分的实验二,经过和学长们实验的对比发现每一级实验要求都不一样,因此这里标明了是2019年秋季学期的视觉实验二. 由于时间紧张,代码没有进行任何优化, ...
- blur()低通滤波
blur()函数可以用标准化的盒式过滤器来平滑图像. C++ API: 相关官网资料: https://docs.opencv.org/3.4.1/d4/d86/group__imgproc__fil ...
- 机器学习进阶-直方图与傅里叶变换-傅里叶变换(高低通滤波) 1.cv2.dft(进行傅里叶变化) 2.np.fft.fftshift(将低频移动到图像的中心) 3.cv2.magnitude(计算矩阵的加和平方根) 4.np.fft.ifftshift(将低频和高频移动到原来位置) 5.cv2.idft(傅里叶逆变换)
1. cv2.dft(img, cv2.DFT_COMPLEX_OUTPUT) 进行傅里叶变化 参数说明: img表示输入的图片, cv2.DFT_COMPLEX_OUTPUT表示进行傅里叶变化的方法 ...
- OpenCV笔记(4)(直方图、傅里叶变换、高低通滤波)
一.直方图 用于统计图片中各像素值: # 画一个图像各通道的直方图 def draw_hist(img): color = ('b', 'g', 'r') for i, col in enumerat ...
- 9、OpenCV Python 边缘保留滤波
__author__ = "WSX" import cv2 as cv import numpy as np # 边缘保留滤波 十分重要(美颜的核心) # 高斯双边模糊(考虑到了像 ...
- opencv:边缘保留滤波
EPF滤波概述 均值与滤波的缺点:并没有考虑中心像素点对整个输出像素的贡献,实际上锚定的那个点贡献应该是最大的 高斯滤波的缺点:当边缘值梯度很大的时候,应减少中心像素点的权重,而高斯滤波没有考虑 边缘 ...
- opencv python:边缘保留滤波(EPF)
EPF:E边缘,P保留,F滤波 import cv2 as cv import numpy as np def bi_demo(image): # bilateralFilter(src, d, si ...
随机推荐
- 浅谈python的对象的三大特性之继承
前面我们定义了人的类,并用这个类实例化出两个人jack和lily,查看了它们的内存空间. 现在我们再来看看类中所存在的对向对象编程的三大特性之继承的一些特性. 前面定义了一个人的类,可是我们还知道,人 ...
- Python基础篇(一)
首先需要从Python的官网下载python的安装程序,下载地址为:www.python.org/downloads.最新的版本为3.4.1,下载和操作系统匹配的安装程序并安装即可. 安装好了后,在开 ...
- CodeChef Little Elephant and Movies [DP 排列]
https://www.codechef.com/FEB14/problems/LEMOVIE 题意: 对于一个序列,定义其“激动值”为序列中严格大于前面所有数的元素的个数.给定n个数p1;,p2.. ...
- 深度学习(一。深度学习概览)(mooc视频https://www.icourse163.org/learn/MSRA-1002255002?tid=1002370003#/learn/content?type=detail&id=1003271123)
一. 深度学习概览 1.为什么resnet应用在图像识别 因为传统神经网络精度有限,而只是增加层数无法提高精度.而resnet可以改变这个问题. 2.Microsoft SwitchBoard 在语音 ...
- 搭建SS服务器
体验: http://ss.ishadowx.com/ centos7 安装shadowsocks客户端 http://blog.csdn.net/guyan0319/article/details/ ...
- CentOS安装JDK 8
准备工作 首先,更新包: yum update 检查服务器上是否已安装旧版本的Java: java -version 如果有旧版本的Java则移除: yum remove java-1.6.0-ope ...
- Vuex源码解析
写在前面 因为对Vue.js很感兴趣,而且平时工作的技术栈也是Vue.js,这几个月花了些时间研究学习了一下Vue.js源码,并做了总结与输出. 文章的原地址:https://github.com/a ...
- [NOIP2001提高组]数的划分
题目描述 将整数n分成k份,且每份不能为空,任意两个方案不相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5; 1,5,1; 5,1,1; 问有多少种不同的分法. 输 ...
- hbase优化之region合并和压缩
HBASE操作:(一般先合并region然后再压缩) 一 .Region合并: merge_region 'regionname1','regionname2' ,'true' --true代表 ...
- java定时器schedule和scheduleAtFixedRate区别
package cn.lonecloud.test; import java.util.Date; import java.util.Timer; import java.util.TimerTask ...