24小时热门版块排行榜    

查看: 2372  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 265求调剂 +8 梁梁校校 2026-03-17 8/400 2026-03-20 14:40 by 27道科特
[考研] 求调剂 +4 Mqqqqqq 2026-03-19 4/200 2026-03-20 14:15 by 星空星月
[考研] 一志愿 南京航空航天大学大学 ,080500材料科学与工程学硕 +4 @taotao 2026-03-20 4/200 2026-03-20 10:37 by EBSD
[考研] 0703化学调剂 +10 妮妮ninicgb 2026-03-15 14/700 2026-03-19 22:59 by 学员8dgXkO
[考研] 307求调剂 +9 冷笙123 2026-03-17 9/450 2026-03-19 22:44 by 学员8dgXkO
[考博] 申博26年 +3 八6八68 2026-03-19 3/150 2026-03-19 19:43 by nxgogo
[考研] 一志愿天津大学化学工艺专业(081702)315分求调剂 +11 yangfz 2026-03-17 11/550 2026-03-19 15:06 by houyaoxu
[考研] 295求调剂 +3 一志愿京区211 2026-03-18 5/250 2026-03-18 17:03 by zhaoqian0518
[考研] 化学工程321分求调剂 +15 大米饭! 2026-03-15 18/900 2026-03-18 14:52 by haxia
[考研] 0854可跨调剂,一作一项核心论文五项专利,省、国级证书40+数一英一287 +8 小李0854 2026-03-16 8/400 2026-03-18 14:35 by 搏击518
[考研] 303求调剂 +4 睿08 2026-03-17 6/300 2026-03-18 11:01 by Iveryant
[考研] 材料,纺织,生物(0856、0710),化学招生啦 +3 Eember. 2026-03-17 9/450 2026-03-18 10:28 by Eember.
[考研] 考研化学学硕调剂,一志愿985 +4 张vvvv 2026-03-15 6/300 2026-03-17 17:15 by ruiyingmiao
[考研] 一志愿,福州大学材料专硕339分求调剂 +3 木子momo青争 2026-03-15 3/150 2026-03-17 07:52 by laoshidan
[考研] 283求调剂 +3 听风就是雨; 2026-03-16 3/150 2026-03-17 07:41 by 热情沙漠
[考研] 药学383 求调剂 +3 药学chy 2026-03-15 4/200 2026-03-16 20:51 by 元子^0^
[考研] 080500,材料学硕302分求调剂学校 +4 初识可乐 2026-03-14 5/250 2026-03-14 21:08 by peike
[考研] 本科南京大学一志愿川大药学327 +3 麦田耕者 2026-03-14 3/150 2026-03-14 20:04 by 外星文明
[考研] 289求调剂 +4 这么名字咋样 2026-03-14 6/300 2026-03-14 18:58 by userper
[考研] 330求调剂 +3 ?酱给调剂跪了 2026-03-13 3/150 2026-03-14 10:13 by JourneyLucky
信息提示
请填处理意见