C语言间接平差程序_第1页
C语言间接平差程序_第2页
C语言间接平差程序_第3页
C语言间接平差程序_第4页
C语言间接平差程序_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精选优质文档-倾情为你奉上 教材误差理论与测量平差基础第二版武汉大学出版社P108页的例7-1的运行结果: 源程序: #define N 5 /*N是观测值个数*/#define T 3 /*T是必要观测数*/#include<stdio.h>#include<math.h>float NbbTT,NbTT,WT1,xT1;main() float D(float aTN,float bNN,float cNT); float K(float aTN,float bNN,float cN1); float G(float aTT); float F(float caT-

2、1T-1); float DM(float a1N,float bNN ,float cN1); int i,j,m,n; float BNT,BTTN,VN1,VT1N,PNN,CN1,BxN1,f,g,h,x1; printf("请输入V的系数BNT:n"); for(i=0;i<N;i+) for(j=0;j<T;j+) scanf("%8f",&Bij); printf("请输入观测值的权阵PNN:n"); for(i=0;i<N;i+) for(j=0;j<N;j+) scanf("

3、%8f",&Pij); printf("请输入常数CN1:n"); for(i=0;i<N;i+) for(j=0;j<1;j+) scanf("%8f",&Cij); for(i=0;i<N;i+) for(j=0;j<T;j+) BTji=Bij; g=D(BT, P, B); h=K(BT, P, C); f=G(Nbb); for(i=0;i<T;i+) for(j=0;j<1;j+) xij=Nbi0*W0j; for(m=1;m<T;m+) xij+=(Nbim*Wmj);

4、for(i=0;i<T;i+) xi0=xi0/f; for(i=0;i<N;i+) for(j=0;j<1;j+) Bxij=Bi0*x0j; for(m=1;m<T;m+) Bxij+=(Bim*xmj); for(i=0;i<N;i+) Vi0=(Bxi0-Ci0); for(i=0;i<N;i+) for(j=0;j<1;j+) VTji=Vij; x1=DM(VT,P,V); x1=x1/(N-T); printf("参数xT1=n"); for(i=0;i<T;i+) printf("%15f"

5、,xi0); printf("n"); printf("改正数VN1=n"); for(i=0;i<N;i+) printf("%15f",Vi0); printf("n单位权中误差x1=%15f",sqrt(x1); printf("n协因数阵QxxTT:n"); for(i=0;i<T;i+) for(j=0;j<T;j+) printf("%15f",Nbij/f); printf("n"); float G(float aTT)

6、int i,j,m,n; float cT-1T-1,y=0; for(i=0;i<T;i+) for(j=0;j<T;j+) for(m=0;m<T;m+) for(n=0;n<T;n+) if(m<i&&n<j) cmn=amn; if(m>i&&n<j) cm-1n=amn; if(m<i&&n>j) cmn-1=amn; if(m>i&&n>j) cm-1n-1=amn; if(i+j)%2=0) Nbji=F(c); else Nbji=(-1)*F

7、(c); for(m=0;m<T;m+) y+=(a0m*Nbm0); return (y); float F(float caT-1T-1) int i,j,m,n,s,t,k=1; float f=1,c,x,sn; for (i=0,j=0;i<T-1&&j<T-1;i+,j+) if (caij=0) for (m=i;camj=0;m+); if (m=T-1) sn=0; return (sn); else for (n=j;n<T-1;n+) c=cain; cain=camn; camn=c; k*=(-1); for (s=T-2;s&

8、gt;i;s-) x=casj; for (t=j;t<T-1;t+) cast-=cait*(x/caij); for (i=0;i<T-1;i+) f*=caii; sn=k*f; return (sn); float D(float aTN,float bNN ,float cNT) int i,j,m; float dTN; for(i=0;i<T;i+) for(j=0;j<N;j+) dij=ai0*b0j; for(m=1;m<N;m+) dij+=(aim*bmj); for(i=0;i<T;i+) for(j=0;j<T;j+) Nb

9、bij=di0*c0j; for(m=1;m<N;m+) Nbbij+=(dim*cmj); return (Nbb00); float K(float aTN,float bNN,float cN1) int i,j,m; float dTN; for(i=0;i<T;i+) for(j=0;j<N;j+) dij=ai0*b0j; for(m=1;m<N;m+) dij+=(aim*bmj); for(i=0;i<T;i+) for(j=0;j<1;j+) Wij=di0*c0j; for(m=1;m<N;m+) Wij+=(dim*cmj); return (W00); float DM(float a1N,float bNN ,float cN1) int i,j,m; float d1N,x; for(i=0;i<1;i+) for(j=0;j<N;j+) dij=ai0*b0j; for(m=1;m<N;m+) dij+=(aim*bmj); for(i=0;i<1;i+) for(j=0;j<1;j+) x=di0*c0j; for(m=1;m<N;m

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论