基于VC++GPS高程曲面拟合方法实现.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于VCGPS高程曲面拟合方法实现

基于VC++GPS高程曲面拟合方法实现摘要:GPS定位测量技术可以得到高精度的平面位置和大地高差,但在实际应用中,地面点的高程常采用的是正常高高程系统,因此,需将GPS大地高转换成正常高。利用VC++6.0实现GPS高程多项式曲面拟合程序的实现。 关键词:GPS高程,高程拟合,VC++实现 一 前言 GPS以其全天候、高精度、自动化、高效率、多功能的显著特点已经广泛的应用于大地测量、工程测量、航空摄影测量等,给测绘领域带来一场深刻的革命。大量的实践数据表明,GPS测量的平面坐标精度是可靠的,能达到工程测量的要求,其平面相对定位的精度能够达到(0.1~1)10-6D mm甚至更高(D是基线长度)。对于G P S高程,为了满足工程的需要,须将GPS中的大地高转换为工程中直接应用的正常高,才能真正实现GPS的三维测量的目的。目前,多项式曲面拟合GPS水准高程,以其计算简单、容易编程实现,已经广泛应用于工程实践。 二GPS高程多项式曲面拟合原理 当测区GPS点布设成一定区域面时,用几何水准联测部分GPS点的正常高,用数值拟合的方法求出测区似大地水准面,计算出未联测几何水准GPS点的高程异常,即:根据测区已知点的平面坐标x,y(或大地坐标B,L)和ζ值,用数值拟合原理拟合出测区似大地水准面,再内插出待求点的ζ值,从而求出待求点的正常高。 则其高程异常一般表示为ξ=f(x,y),根据测区的实际情况,f(x,y)对应有平面拟合、二次曲面拟合、三次曲面拟合3种常用数学模型。 一般来说,根据测区实际情况,确定适宜的高程异常拟合数学模型,并根据已知联测控制点的高程异常,用最小二乘拟合法确定拟合数学模型的系数。 假设某GPS测区内有i个高程联测点,异常拟合数学模型采用多项式曲面拟合: f(x,y)= …….(1) 式中-------多项式系数,i=0,1,…,5;(x,y)-------GPS高程控制点的平面坐标。 根据n个GPS点的可以确定多项式(1)中的系数。当n≥3且n KNOWDATE; 定义待求数据类CDATEGPS,并定义数组储存数据。 class CDATEGPS : public CObject { public: BOOL ReaddategpsCASS(CString str);//读取数据 BOOL ReadDateGps(CString StrLine); double x,y,h,v,Hv; CString pro; CString Pointname ; CDATEGPS(); virtual ~CDATEGPS(); }; typedef CTypedPtrArray DATEGPS; 定义矩阵类CMatrix,用于矩阵计算。 class CMatrix { CMatrix(); CMatrix(int nRows, int nCols); // 指定行列构造函数 BOOLInit(int nRows, int nCols); // 初始化矩阵 BOOL SetElement(int nRow, int nCol, double value); // 设置指定元素的值 double GetElement(int nRow, int nCol) const; // 获取指定元素的值 voidSetData(double value[]); // 设置矩阵的值 int GetNumColumns() const; // 获取矩阵的列数 int GetNumRows() const; // 获取矩阵的行数 // 数学操作 CMatrix operator=(const CMatrix other); BOOL operator==(const CMatrix other) const; BOOL operator!=(const CMatrix other) const; CMatrix operator+(const CMatrix other) const; CMatrix operator-(const CMatrix other) const; CMatrix operator*(double value) const; CMatrix operator*(const CMatrix other) const; // 复矩阵乘法 BOOL CMul(const CMatrix AR, const CMatrix AI, const CMatrix BR

文档评论(0)

linsspace + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档