function [Feature,bmp,flag]=getFeature1(A)
% getFeature.m
% 提取64*64二值图像的特征向量
% input:
% A: 64*64矩阵
% output:
% Feature: 长度为14的特征向量
% bmp : 图像中的数字部分
% flag : 标志位,表示数字部分的宽高比
% 反色
A = ones(64) - A;
% 提取数字部分
[x, y] = find(A == 1);
% 截取图像中的数字部分
A = A(min(x):max(x),min(y):max(y));
% 计算宽高比和标志位
flag = (max(y)-min(y)+1)/(max(x)-min(x)+1);
if flag < 0.5
flag = 0;
elseif flag >=0.5 && flag <0.75
flag = 1;
elseif flag >=0.75 && flag <1
flag = 2;
else
flag = 3;
end
% 重新放大,将长或宽调整为64
rate = 64 / max(size(A));
% 调整尺寸
A = imresize(A,rate);
[x,y] = size(A);
% 不足64的部分用零填充
if x ~= 64
A = [zeros(ceil((64-x)/2)-1,y);A;zeros(floor((64-x)/2)+1,y)];
end;
if y ~= 64
A = [zeros(64,ceil((64-y)/2)-1),A,zeros(64,floor((64-y)/2)+1)];
end
%% 三条竖线与数字字符的交点个数 F(1)~F(3)
% 1/2 竖线交点数量
Vc = 32;
Num = 0;
for i = 1:64
Num = Num+A(i, Vc);
end
F(1) = Num;
% F(1) = sum(A(:,Vc));
% 5/12 竖线交点数量
Vc = round(64*3/12);
Num = 0;
for i = 1:64
Num = Num + A(i, Vc);
end
F(2) = Num;
% F(2) = sum(A(:,Vc));
% 7/12 竖线交点数量
Vc = round(64*9/12);
Num = 0;
for i = 1:64
Num = Num + A(i, Vc);
end
F(3)=Num;
% F(3) = sum(A(:,Vc));
%% 三条横线与数字字符的交点个数 F(4)~F(6)
% 1/2 水平线交点数量
Hc = 32;
Num = 0;
for i = 1:64
Num = Num + A(Hc, i);
end
F(4) = Num;
% F(4) = sum(A(Hc,:));
% 1/3 水平线处交点数量,
Hc = round(64/3);
Num = 0;
for i = 1:64
Num = Num + A(Hc, i);
end
F(5) = Num;
% F(5) = sum(A(Hc,:));
% 2/3水平线处交点数量
Hc = round(2*64/3);
Num = 0;
for i = 1:64
Num = Num + A(Hc, i);
end
F(6) = Num;
% F(6) = sum(A(Hc,:));
%% 两条对角线的交点数量
% 主对角线交点数,
x3 = 1;
y3 = 1;
Num = 0;
for i = 0:63
Num = Num+A(x3+i,y3+i);
end
F(7) = Num;
% F(7) = sum(diag(A));
% 次对角线交点数
x4 = 1;
y4 = 64;
Num = 0;
for i = 0:63
Num = Num + A(x4+i, y4-i);
end
F(8) = Num;
% F(8) = sum(diag(rot90(A)));
%% 小方块
% 右下角1/2小方块中的所有点
Num = 0;
for i = 32:64
for r = 32:64
Num = Num + A(i,r);
end
end
F(9) = Num/10;
% t = A(32:64,33:64);
% F(9) = sum(t(:))/10;
% 左上角1/2小方块中的所有点
Num = 0;
for i3 = 1:32
for r3 = 1:32
Num = Num + A(i3,r3);
end
end
F(10) = Num/10;
% t = A(1:32,1:32);
% F(10) = sum(t(:))/10;
% 左下角方块中的所有点
Num = 0;
for i4 = 1:32
for r4 = 32:64
Num = Num + A(i4,r4);
end
end
F(11) = Num/10;
% t = A(1:32,32:64);
% F(11) = sum(t(:))/10;
% 右上角方块中的所有点
Num = 0;
for i5 = 32:64
for r5 = 1:32
Num = Num + A(i5,r5);
end
end
F(12) = Num/10;
% t = A(32:64,1:32);
% F(12) = sum(t(:))/10;
% 下方2/3部分的所有像素点
Num = 0;
for i1 = 1:64
for r1 = 16:48
Num = Num + A(i1,r1);
end
end
F(13) = Num/20;
% t = A(1:64,16:64);
% F(13) = sum(t(:))/20;
% 右方2/3部分的所有像素点
Num = 0;
for i2 = 16:48
for r2 = 1:64
Num = Num + A(i2,r2);
end
end
F(14) = Num/20;
% t = A(16:48,1:64);
% F(14) = sum(t(:))/20;
Feature = F';
bmp = A;
没有合适的资源?快使用搜索试试~ 我知道了~
第13章 神经网络应用实例.zip
共1019个文件
bmp:1001个
m:14个
mat:2个
需积分: 5 0 下载量 14 浏览量
2023-05-26
10:43:42
上传
评论
收藏 593KB ZIP 举报
温馨提示
第13章 神经网络应用实例
资源推荐
资源详情
资源评论
收起资源包目录
第13章 神经网络应用实例.zip (1019个子文件)
lena.bmp 65KB
1_078.bmp 574B
4_083.bmp 574B
8_043.bmp 574B
9_078.bmp 574B
9_002.bmp 574B
2_093.bmp 574B
6_058.bmp 574B
2_029.bmp 574B
7_053.bmp 574B
2_096.bmp 574B
1_013.bmp 574B
2_095.bmp 574B
4_061.bmp 574B
1_082.bmp 574B
8_020.bmp 574B
4_007.bmp 574B
8_083.bmp 574B
3_048.bmp 574B
1_053.bmp 574B
3_097.bmp 574B
5_020.bmp 574B
7_050.bmp 574B
7_015.bmp 574B
9_079.bmp 574B
6_077.bmp 574B
9_009.bmp 574B
8_003.bmp 574B
3_058.bmp 574B
0_048.bmp 574B
2_018.bmp 574B
4_060.bmp 574B
2_030.bmp 574B
9_039.bmp 574B
5_009.bmp 574B
8_076.bmp 574B
1_100.bmp 574B
7_071.bmp 574B
3_015.bmp 574B
0_030.bmp 574B
9_049.bmp 574B
2_010.bmp 574B
6_051.bmp 574B
6_038.bmp 574B
7_064.bmp 574B
0_004.bmp 574B
1_044.bmp 574B
3_077.bmp 574B
8_088.bmp 574B
5_041.bmp 574B
3_033.bmp 574B
6_068.bmp 574B
0_002.bmp 574B
6_037.bmp 574B
4_002.bmp 574B
1_056.bmp 574B
5_005.bmp 574B
6_040.bmp 574B
8_032.bmp 574B
3_026.bmp 574B
1_075.bmp 574B
5_042.bmp 574B
4_055.bmp 574B
5_064.bmp 574B
0_076.bmp 574B
2_016.bmp 574B
0_047.bmp 574B
5_080.bmp 574B
2_044.bmp 574B
5_067.bmp 574B
3_007.bmp 574B
9_098.bmp 574B
5_014.bmp 574B
7_075.bmp 574B
5_065.bmp 574B
1_091.bmp 574B
5_061.bmp 574B
9_007.bmp 574B
3_049.bmp 574B
3_005.bmp 574B
4_040.bmp 574B
2_013.bmp 574B
1_063.bmp 574B
6_062.bmp 574B
5_027.bmp 574B
1_084.bmp 574B
1_012.bmp 574B
4_044.bmp 574B
8_014.bmp 574B
3_085.bmp 574B
9_096.bmp 574B
9_060.bmp 574B
8_033.bmp 574B
9_014.bmp 574B
9_083.bmp 574B
8_010.bmp 574B
1_043.bmp 574B
7_037.bmp 574B
5_035.bmp 574B
1_015.bmp 574B
共 1019 条
- 1
- 2
- 3
- 4
- 5
- 6
- 11
资源评论
一杯烟火
- 粉丝: 2212
- 资源: 1308
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- TbReactions(BaseModel)
- request-validator.cpython-37
- pygments.lexers.javascript ~~~~~~~~~~~~~~~~~~~~~~~~~~
- 简单小游戏制作-飞行棋
- Python数学建模例子.rar
- Java项目-基于SSM+JSP的校园外卖配送系统的设计与实现(源码+万字LW+部署视频+代码讲解视频+全套软件)
- Color-Transformer introduction
- FastStone Capture屏幕长截图软件包
- Table IoT物联网工具,简单快速的搭建物联网服务平台
- zheng2020 ecg new dataset-12 lead-add-label
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功