找回密码
 注册
关于网站域名变更的通知
查看: 474|回复: 3
打印 上一主题 下一主题

写了一个寻找欧式距离最大的像元坐标程序,运行中却报错,请大神指导

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-8-14 14:29 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
/ k3 C( N* O! F- @0 c
写了一个程序,用来寻找欧式距离最大的像元坐标,运行中却报错:赋值具有的非单一 rhs 维度多于非单一下标数,报错代码为:D(i,j)=h*(oj-1)+oi;希望大家指点一下错误,谢谢!代码如下:
/ d$ ]3 v& c+ @! ]
  • clc;
  • close all;
  • %%
  • load test2.mat;
  • data=s;
  • [h,w,c]=size(data);
  • f=reshape(data,[h*w,c]);%重塑矩阵
  • MEI=zeros(h*w,1);%MEI矩阵
  • C=zeros(h,w);%距离矩阵
  • D=zeros(h,w);%存放d(x,y)
  • E=zeros(h,w);%存放e(x,y)
  • A=pdist2(f,f);%计算1像元到其他像元距离 边界
  • for i=2:h-2
  •     for j=2:w-2
  •         %计算每个像元到其他八个像元的累积距离
  • C(i-1,j-1)=A((j-2)*h+i-1,(j-1)*h+i-1)+A((j-2)*h+i-1,j*h+i-1)+A((j-2)*h+i-1,(j-2)*h+i)+A((j-2)*h+i-1,(j-1)*h+i)+A((j-2)*h+i-1,j*h+i)+A((j-2)*h+i-1,(j-2)*h+i+1)+A((j-2)*h+i-1,(j-1)*h+i+1)+A((j-2)*h+i-1,j*h+i+1);
  • C(i-1,j)=A((j-1)*h+i-1,(j-2)*h+i-1)+A((j-1)*h+i-1,j*h+i-1)+A((j-1)*h+i-1,(j-2)*h+i)+A((j-1)*h+i-1,(j-1)*h+i)+A((j-1)*h+i-1,j*h+i)+A((j-1)*h+i-1,(j-2)*h+i+1)+A((j-1)*h+i-1,(j-1)*h+i+1)+A((j-1)*h+i-1,j*h+i+1);
  • C(i-1,j+1)=A(j*h+i-1,(j-2)*h+i-1)+A(j*h+i-1,(j-1)*h+i-1)+A(j*h+i-1,j*h+i-1)+A(j*h+i-1,(j-2)*h+i)+A(j*h+i-1,(j-1)*h+i)+A(j*h+i-1,j*h+i)+A(j*h+i-1,(j-2)*h+i+1)+A(j*h+i-1,(j-1)*h+i+1)+A(j*h+i-1,j*h+i+1);
  • C(i,j-1)=A((j-2)*h+i,(j-2)*h+i-1)+A((j-2)*h+i,(j-1)*h+i-1)+A((j-2)*h+i,j*h+i-1)+A((j-2)*h+i,(j-2)*h+i)+A((j-2)*h+i,(j-1)*h+i)+A((j-2)*h+i,j*h+i)+A((j-2)*h+i,(j-2)*h+i+1)+A((j-2)*h+i,(j-1)*h+i+1)+A((j-2)*h+i,j*h+i+1);
  • C(i,j)=A((j-1)*h+i,(j-2)*h+i-1)+A((j-1)*h+i,(j-1)*h+i-1)+A((j-1)*h+i,j*h+i-1)+A((j-1)*h+i,(j-2)*h+i)+A((j-1)*h+i,(j-1)*h+i)+A((j-1)*h+i,j*h+i)+A((j-1)*h+i,(j-2)*h+i+1)+A((j-1)*h+i,(j-1)*h+i+1)+A((j-1)*h+i,j*h+i+1);
  • C(i,j+1)=A(j*h+i,(j-2)*h+i-1)+A(j*h+i,(j-1)*h+i-1)+A(j*h+i,j*h+i-1) +A(j*h+i,(j-2)*h+i)+A(j*h+i,(j-1)*h+i) +A(j*h+i,(j-2)*h+i+1)+A(j*h+i,(j-1)*h+i+1)+A(j*h+i,j*h+i+1);
  • C(i+1,j-1)=A((j-2)*h+i+1,(j-2)*h+i-1)+A((j-2)*h+i+1,(j-1)*h+i-1)+A((j-2)*h+i+1,j*h+i-1)+A((j-2)*h+i+1,(j-2)*h+i)+A((j-2)*h+i+1,(j-1)*h+i)+A((j-2)*h+i+1,j*h+i)+A((j-2)*h+i+1,(j-1)*h+i+1)+A((j-2)*h+i+1,j*h+i+1);
  • C(i+1,j)=A((j-1)*h+i+1,(j-2)*h+i-1)+A((j-1)*h+i+1,(j-1)*h+i-1)+A((j-1)*h+i+1,j*h+i-1)+A((j-1)*h+i+1,(j-2)*h+i)+A((j-1)*h+i+1,(j-1)*h+i)+A((j-1)*h+i+1,j*h+i) +A((j-1)*h+i+1,(j-2)*h+i+1)+A((j-1)*h+i+1,j*h+i+1);
  • C(i+1,j+1)=A(j*h+i+1,(j-2)*h+i-1)+A(j*h+i+1,(j-1)*h+i-1)+A(j*h+i+1,j*h+i-1)+A(j*h+i+1,(j-2)*h+i)+A(j*h+i+1,(j-1)*h+i)+A(j*h+i+1,j*h+i)+A(j*h+i+1,(j-2)*h+i+1)+A(j*h+i+1,(j-1)*h+i+1)+A(j*h+i+1,j*h+i+1);
  • %截取子矩阵
  • data1=C(i-1:i+1,j-1:j+1);
  • %找距离最大像元并赋值
  • maxdata=max(max(data1));
  • [rows,cols]=find(data1==maxdata);
  • ti=i-1:i+1;
  •         oi=ti(rows);
  •         tj=j-1:j+1;
  •         oj=tj(cols);
  •         D(i,j)=h*(oj-1)+oi;
  • %找距离最小像元并赋值
  • mindata=min(min(data1));
  • [rows1,cols1]=find(data1==mindata);
  • ti=i-1:i+1;
  •         oi=ti(rows1);
  •         tj=j-1:j+1;
  •         oj=tj(cols1);
  •         E(i,j)=h*(oj-1)+oi;
  •     end
  • end
    , e) N" r7 F: D- l( Z  w* _$ ]
) T5 y5 x( m0 j7 s& y7 ~
0 v3 n' x4 ]6 O9 E0 m& N/ t

. W& ]9 F3 j! k) W( w8 x% f
8 S2 \; ^; ~7 V4 }. r& _4 t: c! {& S1 `% B- h
+ J5 U8 p/ e; `9 P! u9 e2 ^4 U
% g0 J# K* f* Z9 ?: d5 `8 C

该用户从未签到

2#
发表于 2020-8-14 15:06 | 只看该作者
这个程序好复杂啊
  • TA的每日心情

    2019-11-20 15:22
  • 签到天数: 2 天

    [LV.1]初来乍到

    3#
    发表于 2020-8-14 16:21 | 只看该作者
    你的oj和oi都是1行9列,h是标量,导致 h*(oj-1)+oi 整个计算结果还是1行9列啊;可是D(i,j)仅仅是矩阵中的1个元素,你非要用多个元素给它赋值,那肯定报错啊。请重新回去反思自己设计的计算步骤到底想要实现什么功能,为什么会把大脚强往小鞋里面塞吧。

    点评

    谢谢,我再改改程序看看  详情 回复 发表于 2020-8-14 16:24

    该用户从未签到

    4#
     楼主| 发表于 2020-8-14 16:24 | 只看该作者
    mutougeda 发表于 2020-8-14 16:21
    . a+ y! k5 ^9 J. N' x" v你的oj和oi都是1行9列,h是标量,导致 h*(oj-1)+oi 整个计算结果还是1行9列啊;可是D(i,j)仅仅是矩阵中的1 ...

    ! {5 f6 n6 K( R2 h( w. M谢谢,我再改改程序看看1 F. u6 F8 e0 Q
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-6-22 21:45 , Processed in 0.078125 second(s), 30 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表