24小时热门版块排行榜    

查看: 2365  |  回复: 6

bian890

铜虫 (初入文坛)

[求助] matlab 不规则矩阵 求平均值

1.2183    1.747      1.8489      1.4564     0.73688     0.30712
0             1.5151    1.7323      1.5583    0.92972     0.47214
0             0              1.3433    1.3868       1.02        0.65397
0             0               0              0.7261    0.8505      0.73462
0             0               0              0.3687     0.48778   0.65311
0              0              0               0              0.3067     0.4287
0              0               0               0               0              0
请问怎么求非0处的平均值呢? 就相当于是不规则矩阵了
比如 第一行(1.2183+1.747+1.8489+1.4564+0.73688+0.30712)/6
第二行(1.5151+1.7323+1.5583+0.92972+0.47214)/5
可是 由于数据量很大 必须通过程序来实现
谢谢 急急急

[ Last edited by bian890 on 2011-6-30 at 15:54 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiaoqing8569

铁杆木虫 (著名写手)

奥林匹亚光学院院长

【答案】应助回帖

★ ★ ★
bian890(金币+5): 有点复杂 2011-07-01 16:40:04
sunyang1988(金币+3): 谢谢帮助 2011-07-01 18:05:04
mathematica代码
mma = {};
ma = {{1.2183 , 1.747, 1.8489, 1.4564, 0.73688, 0.30712}, {0, 1.5151 ,
     1.7323, 1.5583, 0.92972 , 0.47214}, {0 , 0 , 1.3433 , 1.3868 ,
    1.02 , 0.65397}, {0, 0 , 0 , 0.7261, 0.8505, 0.73462}, {0, 0 , 0 ,
     0.3687, 0.48778, 0.65311}, {0 , 0 , 0, 0, 0.3067 , 0.4287}, {0,
    0, 0, 0, 0 , 0}};
ma // MatrixForm
cK = Dimensions[ma];
For[k = 1, k <= cK[[1]], k++,
For[i = 1; j = 0, i <= cK[[2]], i++, If[ma[[k, i]] != 0, j++]];
If[j == 0, mma = Append[mma, 0],
  mma = Append[mma, Evaluate[Plus @@ ma[[k]]/j]]]]
mma
2楼2011-06-30 21:30:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiegangmai

版主 (职业作家)

我没头衔

优秀版主优秀版主优秀版主

【答案】应助回帖

引用回帖:
Originally posted by bian890 at 2011-06-30 15:49:30:
1.2183    1.747      1.8489      1.4564     0.73688     0.30712
0             1.5151    1.7323      1.5583    0.92972     0.47214
0             0              1.3433    1.3868       1.02        0 ...

楼主看看这样行不?
CODE:
aa = [ 1.2183    1.747      1.8489      1.4564     0.73688     0.30712
0             1.5151    1.7323      1.5583    0.92972     0.47214
0             0              1.3433    1.3868       1.02        0.65397
0             0               0              0.7261    0.8505      0.73462
0             0               0              0.3687     0.48778   0.65311
0              0              0               0              0.3067     0.4287
0              0               0               0               0              0 ];
A = sum( aa, 2 ); %  按行求和
[ m1, n1 ] = find( aa ~= 0 ); % 找出非零元素下标
[ m2, n2 ] = size( aa ); % 确定矩阵维度
a = zeros( m2, 1 );
for i = 1 : m2
    a( i ) = length( find( m == i ) ); % 找出每行非零元素个数
end
average_aa = A ./ a;  % 求每行非零元素的平均值

明德厚学、求是创新
3楼2011-07-01 09:05:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiaoqing8569

铁杆木虫 (著名写手)

奥林匹亚光学院院长

引用回帖:
Originally posted by xiegangmai at 2011-07-01 09:05:47:
楼主看看这样行不?

[code]aa = [ 1.2183    1.747      1.8489      1.4564     0.73688     0.30712
0             1.5151    1.7323      1.5583    0.92972     0.47214
0             0             ...

非零元素个数如果为0咋办?
   在判断一下就完整了。
4楼2011-07-01 09:21:22
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiegangmai

版主 (职业作家)

我没头衔

优秀版主优秀版主优秀版主

【答案】应助回帖

引用回帖:
Originally posted by xiaoqing8569 at 2011-07-01 09:21:22:
非零元素个数如果为0咋办?
   在判断一下就完整了。

更简洁的写法:
CODE:
sum( aa, 2 ) ./ sum( aa ~= 0, 2 )

非零元素为0个,在MATLAB里也能处理的,0 / 0 = nan。
明德厚学、求是创新
5楼2011-07-01 09:23:56
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiaoqing8569

铁杆木虫 (著名写手)

奥林匹亚光学院院长

引用回帖:
Originally posted by xiegangmai at 2011-07-01 09:23:56:
更简洁的写法:
CODE:
sum( aa, 2 ) ./ sum( aa ~= 0, 2 )

非零元素为0个,在MATLAB里也能处理的,0 / 0 = nan。


  那就ok了。
6楼2011-07-01 16:18:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

bian890

铜虫 (初入文坛)

谢谢 楼上 问题已经解决啦
楼上的代码 有点复杂
matlab 很好实现 nonzeros就行了
7楼2011-07-01 16:38:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 bian890 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 高分子化学与物理调剂 +3 好好好1233 2026-02-28 4/200 2026-02-28 17:13 by sandychj
[考研] 化工专硕348,一志愿985求调剂 +3 弗格个 2026-02-28 5/250 2026-02-28 17:04 by sandychj
[考博] 博士自荐 +3 kkluvs 2026-02-28 3/150 2026-02-28 16:59 by StarAura
[高分子] 求环氧树脂研发1名 +3 孙xc 2026-02-25 11/550 2026-02-28 16:57 by ichall
[考博] 博士推荐 +4 花儿笑? 2026-02-21 5/250 2026-02-28 16:55 by mumin1990
[考研] 0856材料求调剂 +8 hyf hyf hyf 2026-02-28 9/450 2026-02-28 16:27 by etapple
[考研] 265分求调剂不调专业和学校有行学上就 +4 礼堂丁真258 2026-02-28 6/300 2026-02-28 16:18 by 求调剂zz
[考研] 312求调剂 +4 吃宵夜1 2026-02-28 5/250 2026-02-28 16:11 by gjm133
[考博] 26申博 +3 想申博! 2026-02-26 3/150 2026-02-28 16:07 by nxgogo
[考研] 材料类求调剂 +3 wana_kiko 2026-02-28 3/150 2026-02-28 15:03 by lature00
[考研] 295求调剂 +4 19171856320 2026-02-28 4/200 2026-02-28 13:39 by ms629
[考研] 290求调剂 +4 材料专硕调剂; 2026-02-28 5/250 2026-02-28 13:32 by houyaoxu
[考研] 0856调剂 +3 刘梦微 2026-02-28 3/150 2026-02-28 13:22 by houyaoxu
[考研] 寻找调剂 +3 LYidhsjabdj 2026-02-28 3/150 2026-02-28 12:59 by miniwendy
[考研] 304求调剂 +5 曼殊2266 2026-02-28 6/300 2026-02-28 12:44 by 迷糊CCPs
[考研] 298求调剂 +4 axyz3 2026-02-28 4/200 2026-02-28 11:21 by wang_dand
[基金申请] 什么是人一生最重要的? +10 瞬息宇宙 2026-02-21 10/500 2026-02-27 08:46 by tfang
[基金申请] 面上可以超过30页吧? +12 阿拉贡aragon 2026-02-22 13/650 2026-02-26 22:09 by Hahaxia
[教师之家] 版面费该交吗 +14 苹果在哪里 2026-02-22 17/850 2026-02-26 11:55 by AGI智创机器人
[硕博家园] 【博士招生】太原理工大学2026化工博士 +4 N1ce_try 2026-02-24 8/400 2026-02-26 08:40 by N1ce_try
信息提示
请填处理意见