欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    C语言间接平差程序(共6页).doc

    • 资源ID:13856579       资源大小:43.50KB        全文页数:6页
    • 资源格式: DOC        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    C语言间接平差程序(共6页).doc

    精选优质文档-倾情为你奉上 教材误差理论与测量平差基础第二版武汉大学出版社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-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("%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); 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",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) 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(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>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+) Nbbij=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+) x+=(dim*cmj); return (x); 程序说明: 1) 用该程序前,根据具体情况输入N和T; 2) 该程序中的(N-T)自由度(即多余观测数)必须大于等于2,不然程序运行时会出错,原因在于求行列式的逆时,有语句for (s=R-2;s>i;s-),R=1时s=-1。专心-专注-专业

    注意事项

    本文(C语言间接平差程序(共6页).doc)为本站会员(飞****2)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开