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

关于Matrix dimensions must agree错误的问题

[复制链接]
  • TA的每日心情
    难过
    2019-11-20 15:02
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2020-5-27 15:41 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

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

    x
    Matrix dimensions must agree错误的中文解释是:矩阵的维数必须一致 出错原因:这是由于运算符(= + - / * 等)两边的运算对象维数不匹配造成的,典型的出错原因是错用了矩阵运算符。matlab 通过“.”来区分矩阵运算和元素运算。 0 u3 H1 u4 P* L# k
    " x! d$ i$ c; D: B
    我看了一些论坛讨论的这个错误,一般都是“乘”和“点乘”弄错了,可是我下面的程序是涉及加法的,而且维数是直接把要相加的第一个矩阵的维数赋值给第二个矩阵,不知道为什么还会出错,请高手指点!
    - t% I: a; L  `5 |0 Z! i5 m6 i5 M5 m+ {7 p1 T" j2 Y( M
    shiyan.m的程序体为:
    : q3 b+ Z$ f  R8 [6 l  v6 G; y6 U; U4 l8 N3 Z
    [I,M]=imread('123.tif');7 ~/ S: l; w- I) e3 q+ h6 _% S
    [m,n]=size(imread('123.tif'));/ A, q5 ]  G3 [' |3 B
    J=imnoise(I,'gaussian',0,0.02);
    % Y4 n- h5 y* q' V4 fsubplot(1,3,1),imshow(I,M),title('original image');2 m/ @. B  W: m2 i2 J+ G
    subplot(1,3,2),imshow(J,M),title('managed image');' G; P1 a* T5 S9 [, ?
    K=ones(m,n);
    2 Y. u: _% r' ~8 u0 e: Hfor i=1:1:100( d2 V! g$ {# o( j4 u, W  B
        J=imnoise(I,'gaussian',0,0.02);6 C  ~0 m: L2 d+ M% ]
        J1=im2double(J);6 d4 M. F! Z2 W, f6 o' c; f
        K=K+J1;      %第10行5 N8 `3 P8 f/ @& ^2 R
    end
    2 s# m4 Z0 _. [; }/ kK=K/100;       %求图像的平均1 [, [& q/ x' {- G5 d" y, g6 G$ [. ^& b
    subplot(1,3,3),imshow(K),title('result image');
    ( y4 |) A: x8 Y5 q
    + ]4 o: o: _: G" ?' j+ L3 L) \2 n5 J* j* j
    运行的时候出现这个错误:
    " g* F7 O% g. }, o( M' @! `' U- _
    5 ]) e+ Z$ o& S8 \: p! F??? Error using ==> plus
    % ~3 e/ ^+ T: e. e. b! SMatrix dimensions must agree.! {( i# `: ~3 L$ _% \& v# ?
    Error in ==> shiyan at 10; x7 F; `1 L+ I( i1 W0 L
        K=K+J1;
    5 H  d) `: [$ D$ F, m2 H  _$ T: ]; |) B8 z' v8 Z) A' s- s2 \

    该用户从未签到

    2#
    发表于 2020-5-27 16:26 | 只看该作者

    - H" s  X; J3 ^3 Z& `0 \3 R) z+ xsize(K)
    $ O; h& ^7 C; G: i1 L' ^
    ; V$ f# ]1 b- _4 H8 i+ Z  rsize(J1)
    $ x3 s# Y! J( u' h$ d+ \
    & v. k# i% A  S2 n6 H看看显示什么

    点评

    多谢,明白了。原来它们两个的维数真的是不同的。 将程序改为如下形式就对了: %导入图像的同时将图像分为行和列元素 =imread('123.tif'); %对图像进行加噪声 J=imnoise(I,'gaussian',0,0.02); %显示图像 s  详情 回复 发表于 2020-5-27 16:27
  • TA的每日心情
    难过
    2019-11-20 15:02
  • 签到天数: 1 天

    [LV.1]初来乍到

    3#
     楼主| 发表于 2020-5-27 16:27 | 只看该作者
    NingW 发表于 2020-5-27 16:26% o5 K) i. K" P% C9 _
    size(K)
    6 j+ B$ n: H% `3 t: j' A' T3 n3 S2 |5 U* i& C% d3 H7 O
    size(J1)
    5 [8 I1 |$ f& l- T; o4 V% j* Q
    多谢,明白了。原来它们两个的维数真的是不同的。: i" ]' g2 p, z+ f# h: H& X& e

    8 ^( q* x3 o+ u* X5 w$ l& j/ w将程序改为如下形式就对了:0 g. J2 E% Z6 l% j5 D9 d
    %导入图像的同时将图像分为行和列元素6 g  I/ K" p/ U! _1 y2 k
    [I,M]=imread('123.tif');
    , N! c1 _, v( F8 M; O! y- m%对图像进行加噪声
    " @" ~/ w& @- E+ p1 b9 X/ gJ=imnoise(I,'gaussian',0,0.02);( b2 P0 ^+ n# F
    %显示图像# j( q/ c  v5 l! N' M
    subplot(1,3,1),imshow(I,M),title('original image');
    9 N/ N4 T+ _( e( ?% Jsubplot(1,3,2),imshow(J,M),title('managed image');
    : v- {  m& X. @0 F2 J7 p%创建与原图像一样维数的全0矩阵
    , F2 Q$ a2 H, d& gJ1=im2double(J);
    2 z  b% |; S" F0 Q8 KK=ones(size(J1));7 ^" o& u; ~3 o0 Z* [4 O: h* c0 H2 c
    %循环100对图像加噪声然后累加
    2 L6 m4 l" m( D6 f$ y, vfor i=1:1:100
    : n" p( q# Q: O# ^    J=imnoise(I,'gaussian',0,0.02);
    9 }! S4 \% a! k1 G3 i    J1=im2double(J);
    5 R. L" e( t* _4 M2 g! y9 j  ^    K=K+J1;
    " y; j" ~0 q  oend' D$ M$ W$ C5 ?1 X! L! t5 k$ q
    %求图像的平均
    ) c2 X' J! T) n! J4 q3 q5 \1 xK=K/100;
    ' [7 H1 J# W! L& @%显示处理过的图像9 D* R+ D- Y8 @$ W2 e
    subplot(1,3,3),imshow(K),title('result image');, C! Z# m4 D- x8 M4 q

    , Y) k2 I1 s7 Y5 S$ j  e再次感谢5 V, g# O9 ]0 A0 E( j; ^

    该用户从未签到

    4#
    发表于 2020-5-27 17:12 | 只看该作者
    来看看,学习学习
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

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

    EDA365公众号

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

    GMT+8, 2025-6-24 00:37 , Processed in 0.093750 second(s), 27 queries , Gzip On.

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

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

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