matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例


Posted in Python onApril 22, 2020

一阶矩,定义了每个颜色分量的平均强度

matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例

二阶矩,反映待测区域颜色方差,即不均匀性

matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例

三阶矩,定义了颜色分量的偏斜度,即颜色的不对称性

matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例

close all;clear all;clc;
J = imread('lena.jpg');
K = imadjust(J,[70/255 160/255],[]);
figure;
subplot(121),imshow(J);
subplot(122),imshow(K);
[m,n] = size(J);
mm = round(m/2);
mn = round(n/2);
[p,q] = size(K);
pp = round(p/2);
qq = round(q/2);
J = double(J);
K = double(K);
colorsum = 0.0;
Javg = mean2(J) %求原图像一阶矩
Kavg = mean2(K) %求增强对比度后的图像一阶矩
Jstd = std(std(J)) %求原图像的二阶矩,因为一次std函数表示按列求标准差,两次std表示求整个矩阵的标准差
Kstd = std(std(K)) %求增强对比度后的图像二阶矩
for i=1:mm
 for j=1:mn
  colorsum = colorsum+(J(i,j)-Javg)^3;
 end
end
Jske = (colorsum/(mm*mn))^(1/3) %求原图像的三阶矩
colorsum = 0.0;
for i=1:pp
 for j=1:qq
  colorsum = colorsum + (J(i,j)-Kavg)^3;
 end
end
Kske = (colorsum/(pp*qq))^(1/3) %求增强对比度后的图像三阶矩

部分函数说明:

mean2(A) : 求矩阵A的均值

std(x,flag,dim): 求x的标准偏差

std(x,0,1) : 0表示求标准差时除n-1,1表示按列划分

std(x,1,2) : 1表示求标准差时除n,2表示按行划分

补充知识:图像的重心和二阶矩

图像的重心

图像实际上就是个矩阵,每个位置的元素就是该处的像素。 这里碰到了求图像重心的问题,特此总结:

计算公式:

matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例

其中(xi,yi)是像素点的坐标,pi是该点的像素值。

以下是利用matlab求图像重心

I = imread(‘1.jpg');
I = rgb2gray(I);
imshow(I);
I = double(I);
[rows,cols] = size(I);
x = ones(rows,1)*[1:cols];
y = [1:rows]'*ones(1,cols);
area = sum(sum(I));
meanx = sum(sum(I.*x))/area;
meany = sum(sum(I.*y))/area;
hold on;
plot(meanx,meany,'r+'); %十字标出重心位置

图像的二阶矩

我们这里只讨论二阶矩的问题。

二阶矩最终是形成了一个二阶矩阵,如下:

matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例

计算方法:

matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例

其中(r0,c0)是重心坐标。

以上这篇matlab 计算灰度图像的一阶矩,二阶矩,三阶矩实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
合并Excel工作薄中成绩表的VBA代码,非常适合教育一线的朋友
Apr 09 Python
python方向键控制上下左右代码
Jan 20 Python
Python实现登陆文件验证方法
Oct 06 Python
使用Python检测文章抄袭及去重算法原理解析
Jun 14 Python
python选取特定列 pandas iloc,loc,icol的使用详解(列切片及行切片)
Aug 06 Python
画pytorch模型图,以及参数计算的方法
Aug 17 Python
python+tkinter实现学生管理系统
Aug 20 Python
Python3常见函数range()用法详解
Dec 30 Python
Win10下安装并使用tensorflow-gpu1.8.0+python3.6全过程分析(显卡MX250+CUDA9.0+cudnn)
Feb 17 Python
pytorch学习教程之自定义数据集
Nov 10 Python
python RSA加密的示例
Dec 09 Python
Python实现自动整理文件的脚本
Dec 17 Python
python根据完整路径获得盘名/路径名/文件名/文件扩展名的方法
Apr 22 #Python
matlab中二维插值函数interp2的使用详解
Apr 22 #Python
python 一维二维插值实例
Apr 22 #Python
Numpy一维线性插值函数的用法
Apr 22 #Python
python数据处理——对pandas进行数据变频或插值实例
Apr 22 #Python
利用4行Python代码监测每一行程序的运行时间和空间消耗
Apr 22 #Python
Jupyter Notebook折叠输出的内容实例
Apr 22 #Python
You might like
PHP安全性漫谈
2012/06/28 PHP
javascript比较文档位置
2008/04/08 Javascript
JavaScrip单线程引擎工作原理分析
2010/09/04 Javascript
JS弹出层的显示与隐藏示例代码
2013/12/27 Javascript
JQuery异步获取返回值中文乱码的解决方法
2015/01/29 Javascript
原生js获取iframe中dom元素--父子页面相互获取对方dom元素的方法
2016/08/05 Javascript
canvas实现手机端用来上传用户头像的代码
2016/10/20 Javascript
Angular.js组件之input mask对input输入进行格式化详解
2017/07/10 Javascript
基于滚动条位置判断的简单实例
2017/12/14 Javascript
用 Vue.js 递归组件实现可折叠的树形菜单(demo)
2017/12/25 Javascript
ionic3实战教程之随机布局瀑布流的实现方法
2017/12/28 Javascript
JS设计模式之状态模式概念与用法分析
2018/02/05 Javascript
利用React Router4实现的服务端直出渲染(SSR)
2019/01/07 Javascript
小程序中canvas的drawImage方法参数使用详解
2019/07/04 Javascript
layui点击左侧导航栏,实现不刷新整个页面,只刷新局部的方法
2019/09/25 Javascript
p5.js码绘“跳动的小正方形”的实现代码
2019/10/22 Javascript
Python2.x版本中基本的中文编码问题解决
2015/10/12 Python
Python实现文件内容批量追加的方法示例
2017/08/29 Python
Python实现可设置持续运行时间、线程数及时间间隔的多线程异步post请求功能
2018/01/11 Python
Python中的defaultdict与__missing__()使用介绍
2018/02/03 Python
python找出一个列表中相同元素的多个索引实例
2019/06/11 Python
python pandas生成时间列表
2019/06/29 Python
python不到50行代码完成了多张excel合并的实现示例
2020/05/28 Python
Python爬虫抓取指定网页图片代码实例
2020/07/24 Python
纯css3实现的鼠标悬停动画按钮
2014/12/23 HTML / CSS
HTML5各种头部meta标签的功能(推荐)
2017/03/13 HTML / CSS
ManoMano英国:欧洲第一家专注于DIY和园艺市场的电商平台
2020/03/12 全球购物
Java面试笔试题大全
2016/11/23 面试题
数控加工专业毕业生自荐信
2013/09/27 职场文书
计算机毕业大学生推荐信
2013/12/01 职场文书
教师通用专业自荐书范文
2014/02/11 职场文书
合作协议书
2014/04/23 职场文书
中学生社会实践活动总结
2014/07/03 职场文书
编写python程序的90条建议
2021/04/14 Python
Java后台生成图片的完整步骤
2021/08/04 Java/Android
SQL Server内存机制浅探
2022/04/06 SQL Server