Hungryof 2016-03-23 00:32 采纳率: 100%
浏览 1606
已采纳

如何解决这个矩阵问题?

附带了测试用的matlab代码。
图片说明

 A = [0.8   0.25    0.18   0.1;
      0.1   0.7     0.12   0.4;
      0.1   0.05    0.7    0.2];
beta = [0.68  0.40  0.80  0.5;
        0.15  0.34  0.35  0.4;
        0.45  0.70  0.30  0.5;
        1     1     1     1];
y = A*beta;
% For convenience, I use the same y as input.

%---------------------Method One-------------------
AThreeInverse = inv(A(:,1:3));
tmp = -A(:,4);
AInverse1 = [AThreeInverse,tmp];
yTmp = [y; 1 1 1 1];
final1 = AInverse1*yTmp;
errors = final1 - beta(1:3,:);
disp(errors);

%-------------------Method Two---------------------
% This method seems bullshit.
AInverse2 = pinv(A);
final2 = AInverse2*y;
errors = final2(1:3,:) - beta(1:3,:);
disp(errors);

这个问题的简化版本就是,已知A和y2,求beta2. 其中beta2也是4x4的方阵,且最后一行为1.

如果A的主对角线的比重较小,那么第一种方法的误差会很大。如何得到精确或者误差较小的值?有没有通用的较好的方法?

  • 写回答

1条回答

  • Hungryof 2016-04-01 04:55
    关注

    已经解决了,当我提出该问题时,就觉得没戏

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 fesafe材料库问题
  • ¥35 beats蓝牙耳机怎么查看日志
  • ¥15 Fluent齿轮搅油
  • ¥15 八爪鱼爬数据为什么自己停了
  • ¥15 交替优化波束形成和ris反射角使保密速率最大化
  • ¥15 树莓派与pix飞控通信
  • ¥15 自动转发微信群信息到另外一个微信群
  • ¥15 outlook无法配置成功
  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统