24小时热门版块排行榜    

Znn3bq.jpeg
查看: 2401  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 293调剂 +23 yj1221 2026-04-08 24/1200 2026-04-09 23:26 by may_新宇
[考研] 化工调剂求导师收留!一志愿失利,踏实肯干,有植物提取科研经历 +7 yzyzx 2026-04-09 7/350 2026-04-09 23:21 by may_新宇
[考研] 283求调剂 +19 那个噜子 2026-04-09 19/950 2026-04-09 20:59 by 286640313
[考研] 材料化工总分334求调剂 +16 Riot2025 2026-04-08 17/850 2026-04-09 20:19 by maddjdld
[考研] 348求调剂 +3 candyyyi 2026-04-09 3/150 2026-04-09 17:20 by 段伟艳
[考研] 262求调剂 +10 天下第一文 2026-04-04 13/650 2026-04-09 15:16 by 探123
[考研] 283电子信息求调剂 +4 三石WL 2026-04-08 4/200 2026-04-09 10:21 by wp06
[考研] 331求调剂 +5 luoxin0706. 2026-04-08 5/250 2026-04-08 22:15 by zhouyuwinner
[考研] 专硕085403,291分,有两篇专利,一国一奖 +3 哈吉咪哈吉咪 2026-04-07 3/150 2026-04-07 18:21 by 蓝云思雨
[考研] 081700学硕,323分,一志愿中国海洋大学求调剂学校 +19 披星河 2026-04-04 19/950 2026-04-07 15:00 by 上岸快快
[考研] 华南理工0703化学,总分336求调剂 +10 手机用户 2026-04-03 11/550 2026-04-06 22:20 by michael2011
[考研] 一志愿北交大材料工程总分358求调剂 +10 cs0106 2026-04-05 12/600 2026-04-06 19:41 by 无际的草原
[考研] 一志愿C9的化学工程(085602) 340分,感觉校内调剂无望,求调剂 +12 万事宜臻 2026-04-04 12/600 2026-04-06 07:46 by 无际的草原
[考研] 生物与医药调剂 +4 十七sa 2026-04-05 4/200 2026-04-05 20:05 by lys0704
[考研] 315求调剂 +5 &123456789 2026-04-05 5/250 2026-04-05 19:55 by nepu_uu
[考研] 调剂 +3 李广火 2026-04-05 3/150 2026-04-05 18:57 by 蓝云思雨
[考研] 求调剂到0856材料工程 +3 程9915 2026-04-05 3/150 2026-04-05 18:15 by 蓝云思雨
[考研] 322求调剂 +6 FZAC123 2026-04-03 6/300 2026-04-03 22:23 by 科研小专家
[考研] 工科341分调剂 +3 洛多罗 2026-04-03 3/150 2026-04-03 14:20 by 1753564080
[考研] 0705理学294求调剂 +3 成果成果cg5 2026-04-03 3/150 2026-04-03 14:04 by simons1972
信息提示
请填处理意见