测量平差MATLAB方法

条件平差

P=input('请输入权阵 ');
A=input('请输入矩阵A ');
w=input('请输入矩阵w ');
n=A*inv(P)*A.';
k=-inv(n)*w;
v=inv(P)*A.'*k
disp('单位权中误差的估值为 ');
sqrt(v.' *P*v/size(w,1))
disp('观测值平差值的协因数阵为')
Qh=inv(P)-inv(P)*A.'*inv(n)*A*inv(P)
f=input('请输入平差值函数的权函数 ')
disp('平差值的权倒数为');
q=f*Qh*f.'

有参数的条件平差

P=input('请输入权阵 ');
A=input('请输入矩阵A');
B=input('请输入矩阵B');
w=input('请输入矩阵w ');
[c,u]=size(B);
Q=inv(P);
Na=A*Q*A.';
Nb=B.'*inv(Na)*B;
disp('参数解算')
x=-inv(Nb)*B.'*inv(Na)*w
K=-inv(Na)*(B*x+w);
disp('改正数v ');
v=Q*A.'*K
disp('单位权中误差的估值o为 ');
o=sqrt(v.' *P*v/(c-u))
disp('观测值平差值的协因数阵为');
Qll=Q-Q*A.'*(inv(Na)-inv(Na)*B*inv(Nb)*B.'*inv(Na))*A*Q
disp('观测值平差值的中误差oLL为');
oLL=o*sqrt(diag(Qll))

间接平差

P=input('请输入权阵 ');
B=input('请输入矩阵B');
l=input('请输入矩阵误差方程常数项向量值l ');
[n,t]=size(B);
Nb=B.'*P*B;
W=B.'*P*l;
disp('参数解算')
x=inv(Nb)*W
disp('改正数v ');
v=B*x-l
disp('单位权中误差的估值o为 ');
o=sqrt(v.' *P*v/(n-t))
disp('观测值平差值的协因数阵为');
QLL=B*inv(Nb)*B.'

有限制条件的间接平差

P=input('请输入权阵 ');
B=input('请输入矩阵B');
c=input('请输入矩阵c');
w=input('请输入矩阵w');
l=input('请输入矩阵误差方程常数项向量值l ');
[n,u]=size(B);
s=size(c,1);
Nb=B.'*P*B;
W=B.'*P*l;
Nc=c*inv(Nb)*c.';
K=inv(Nc)*(c*inv(Nb)*W+w);
disp('参数解算')
x=inv(Nb)*(c.'*K-W)
disp('改正数v ');
v=B*x-l
disp('单位权中误差的估值o为 ');
o=sqrt(v.' *P*v/(n-u+s))
disp('参数平差值的协因数阵为');
Qx=inv(Nb)-inv(Nb)*c.'*inv(Nc)*c*inv(Nb)

(本方法不提供观测方程的线性结算)系数矩阵,常数矩阵需要自行解决。

  • 11
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值