%**************************************************************************
% 图像检索——形状特征提取
%利用HU的七个不变矩作为形状特征向量
%Image : 输入图像数据
%n : 返回七维形状特征行向量
%**************************************************************************
%function n = Shape(Image)
Dir=dir('D:\自己重要的文件整理\沈阳农业大学学习\毕业相关\Code\特征提取\250212765Shape_程序计算图像的七个不变矩,提取出图像的形状特征_haoyong\Image_yezi\*.JPG');%---------------------------显示目录文件列表的函数,应用:从一个文件夹中连续自动地读取多幅图片
[num1,num2]=size(Dir);
for t=1:num1
filename = strcat('D:\自己重要的文件整理\沈阳农业大学学习\毕业相关\Code\特征提取\250212765Shape_程序计算图像的七个不变矩,提取出图像的形状特征_haoyong\Image_yezi\',Dir(t).name);%---------------------------字符串连接函数
Image= imread(filename);
[M,N] = size(Image);
N=N/3;
%M = 256;
%N = 256;
%--------------------------------------------------------------------------
%彩色图像灰度化
%--------------------------------------------------------------------------
Gray = double(0.3*Image(:,:,1)+0.59*Image(:,:,2)+0.11*Image(:,:,3));
%--------------------------------------------------------------------------
%用Canny边缘检测提取边缘保留边缘灰度图像
%--------------------------------------------------------------------------
% BW = uint8(edge(Gray,'canny'));
Egray = uint8(edge(Gray,'canny'));
for i = 1:M
for j = 1:N
if Egray(i,j)==0
Gray(i,j)=0;
end
end
end
%--------------------------------------------------------------------------
%Otsu提出的类判别分析法自动为每一幅廓图像选定阈值,然后用该阈值对图像二值化
%--------------------------------------------------------------------------
%计算灰度级归一化直方图
for i = 0:255
h(i+1) = size(find(Gray==i),1);
end
p = h/sum(h);
%计算灰度均值
ut = 0;
for i = 0:255
ut = i*p(i+1)+ut;
end
%计算直方图的零阶累积矩和一阶累积矩:
for k = 0:254
w(k+1) = sum(p(1:k+1));
u(k+1) = sum((0:k).*p(1:k+1));
end
%计算类分离指标
deltaB = zeros(1,255);
for k = 0:254
if w(k+1)~=0&w(k+1)~=1
deltaB(k+1) = (ut*w(k+1)-u(k+1))^2/(w(k+1)*(1-w(k+1)));
end
end
[value,thresh] = max(deltaB);
% deltaB = zeros(1,255);
% delta1 = zeros(1,255);
% delta2 = zeros(1,255);
% deltaW = zeros(1,255);
% for k = 0:254
% if w(k+1)~=0&w(k+1)~=1
% deltaB(k+1) = (ut*w(k+1)-u(k+1))^2/(w(k+1)*(1-w(k+1)));
% delta1(k+1) = 0;
% delta2(k+1) = 0;
% for i = 0:k
% delta1(k+1) = (i-u(k+1)/w(k+1))^2*p(i+1)+delta1(k+1);
% end
% for i = k+1:255
% delta2(k+1) = (i-(ut-u(k+1))/(1-w(k+1)))^2*p(k+1)+delta2(k+1);
% end
% deltaW(k+1) = delta1(k+1)+delta2(k+1);
% end
% end
% for i = 1:255
% if deltaB==0
% yita=0;
% else
% yita(i) = 1/(1+deltaW(i)./deltaB(i));
% end
% end
% % D的最大值作为最佳阈值
% [value,thresh] = max(yita);
%对图像二值化
for i = 1:M
for j = 1:N
if Gray(i,j)>=thresh
BW(i,j) = 1;
else
BW(i,j) = 0;
end
end
end
%--------------------------------------------------------------------------
%计算图像质心:(I,J)
%--------------------------------------------------------------------------
m00 = sum(sum(BW)); %零阶矩
m01 = 0; %一阶矩
m10 = 0; %一阶矩
for i = 1:M
for j = 1:N
m01 = BW(i,j)*j+m01;
m10 = BW(i,j)*i+m10;
end
end
I = (m10)/(m00);
J = m01/m00;
%--------------------------------------------------------------------------
%中心矩:
%--------------------------------------------------------------------------
u11 = 0;
u20 = 0; u02 = 0;
u30 = 0; u03 = 0;
u12 = 0; u21 = 0;
for i = 1:M
for j = 1:N
u20 = BW(i,j)*(i-I)^2+u20;
u02 = BW(i,j)*(j-J)^2+u02;
u11 = BW(i,j)*(i-I)*(j-J)+u11;
u30 = BW(i,j)*(i-I)^3+u30;
u03 = BW(i,j)*(j-J)^3+u03;
u12 = BW(i,j)*(i-I)*(j-J)^2+u12;
u21 = BW(i,j)*(i-I)^2*(j-J)+u21;
end
end
u20 = u20/m00^2;
u02 = u02/m00^2;
u11 = u11/m00^2;
u30 = u30/m00^(5/2);
u03 = u03/m00^(5/2);
u12 = u12/m00^(5/2);
u21 = u21/m00^(5/2);
%--------------------------------------------------------------------------
%7个Hu不变矩:
%--------------------------------------------------------------------------
n(1) = u20+u02;
n(2) = (u20-u02)^2+4*u11^2;
n(3) = (u30-3*u12)^2+(u03-3*u21)^2;
n(4) = (u30+u12)^2+(u03+u21)^2;
n(5) = (u30-3*u12)*(u30+u12)*((u30+u12)^2-3*(u03-3*u21)^2)+(u03-3*u21)*(u03+u21)*((u03+u21)^2-3*(u30+u12)^2);
n(6) = (u20-u02)*((u30+u12)^2-(u03+u21)^2)+4*u11*(u30+u12)*(u03+u21);
n(7) = (3*u21-u03)*(u30+u12)*((u30+u12)^2-3*(u03-3*u21)^2)+(u30-3*u21)*(u03+u21)*((u03+u21)^2-3*(u30+u12)^2);
n
% %--------------------------------------------------------------------------
% %内部归一化:
% %--------------------------------------------------------------------------
% en = mean(n);
% delta = sqrt(cov(n));
% n = abs(n-en)/(3*delta);
end
Shape_程序计算图像的七个不变矩.zip_Shape_程序计算图像的七个不变矩
版权申诉
55 浏览量
2022-09-20
23:53:01
上传
评论
收藏 695KB ZIP 举报
APei
- 粉丝: 63
- 资源: 1万+
最新资源
- 基于FPGA实验板的多功能数字时钟 利用Quartus实现设计与仿真(课程设计含实验报告)
- 基于CNN的人体姿态和动作识别python源码+项目说明文档.zip
- tensorflow-2.3.0-cp37-none-linux.zip
- 基于VisionTransformer的图像去雾算法研究与实现python源码+项目说明+数据集.zip
- hckdydydykddgjxjgxgj
- python 数据科学手册
- Java项目之jspm网上书店销售管理系统(源码 + 说明文档)
- 基于Pytorch实现对偶生成对抗网络来实现图像去雾python源码+项目说明+代码注释.zip
- 放疗物理师上岗证考试资料
- Java项目之jspm青少年体质健康数据管理与分析系统(源码 + 说明文档)
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈