- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 2024年职业院校技能大赛(新能源汽车维修赛项)考试题库(院校下发版) .docx VIP
- 建筑工程施工全过程跟踪审计实施方案.pdf
- AI助力英语高效课堂教学与个性化学习课件.pptx VIP
- 中国血脂管理指南(2023+年).pdf VIP
- 地下停车场车库设计规范.doc VIP
- 国家能源集团电力产业技术监督实施细则-第1部分 火电产业绝缘技术监督.pdf VIP
- 2025年吉林省初中学业水平考试(中考)语文真题(含答案).docx VIP
- 健身拉伸知识PPT课件.pptx VIP
- 地下停车场设计规范方案.pdf VIP
- Unit 4 Healthy food教案 人教PEP英语(2025)三年级下册.docx VIP
文档评论(0)