qq_37113761 2018-05-12 07:50 采纳率: 0%
浏览 1138
已结题

matlab实现BWT算法,对提取出来的链码进行BWT转换

图片说明

图片说明
用matlab实现,对提取出来的图像链码文件test.csv中的链码进行BWT转换。
提取链码的代码如下:
clc;clear;close all;
% 测试图像预处理
im0=imread('2.png');

im=im2bw(im0);%二值化

figure(1);imshow(im);title('原图')

[M,N]=size(im);
% 求轮廓
B=bwboundaries(im);%寻找轮廓,B为存储轮廓信息的结构体

im1=zeros(M,N);

for k=1:length(B)

boundary=B{k};%第k个轮廓,两列,存储轮廓各像素坐标

%标注第k个轮廓像素所在位置为1  
for l=1:length(boundary)  
    im1(boundary(l,1),boundary(l,2))=1;  
end  

end

figure(2);imshow(im1);title('轮廓图')%绘制轮廓图
% 求链码

[nr,nc]=size(B{1});

Code=size(1,nr);

for i=1:nr

if i==1  %起点到终点的链码特殊处理  
    x=B{1}(i,1)-B{1}(nr,1);   %x=-1,0,1  
    y=B{1}(i,2)-B{1}(nr,2);   %y=-1,0,1  
elseif i~=1  
    x=B{1}(i,1)-B{1}(i-1,1);   %x=-1,0,1  
    y=B{1}(i,2)-B{1}(i-1,2);   %y=-1,0,1  
end  

if x==1 && y==0  
    Code(i)=0;  
elseif x==1 && y==1  
    Code(i)=1;  
elseif x==0 && y==1  
    Code(i)=2;  
elseif x==-1 && y==1  
    Code(i)=3;  
elseif x==-1 && y==0  
    Code(i)=4;  
elseif x==-1 && y==-1  
    Code(i)=5;  
elseif x==0 && y==-1  
    Code(i)=6;  
elseif x==1 && y==-1  
    Code(i)=7;  
end    

end
csvwrite('test.csv',Code)

  • 写回答

1条回答 默认 最新

  • threenewbee 2018-05-12 09:22
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码