WGS84大地坐标转目标椭球平面坐标完整代码和步骤___含高精度高斯投影(正算)

本文主要是介绍WGS84大地坐标转目标椭球平面坐标完整代码和步骤___含高精度高斯投影(正算),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

WGS84大地坐标转目标椭球平面坐标完整代码和步骤___含高精度高斯投影(正算)
最近摸索高精度坐标解算,从WGS84椭球大地坐标转换到目标椭球平面坐标,大都是四步,总结大多公式,如下:

1、从大地坐标转换到空间直角坐标,同椭球,公式基本一致。

VB代码:
Dim e2 As Double, N As Double
e2 = 1 - (1 - 1 / f) ^ 2 
N = a / Sqr(1 - e2 * Sin(B) ^ 2) '卯酉圈的曲率半径
X = (N + H) * Cos(B) * Cos(L)
Y = (N+ H) * Cos(B) * Sin(L)
Z = (N * (1 - e2) + H) * Sin(B)
'a为源椭球长半轴,1/f为源椭球扁率,e2为源椭球第一偏心率平方,B为GPS纬度,L为GPS经度,H为GPS海拔

2、从源空间直角坐标转换到目标空间直角坐标,异椭球,公式基本一致(七参数或三参数转换)。

VB代码:
X = dX + (1 + K * 0.000001) * X + wZ * Y - wY * Z
Y = dY + (1 + K * 0.000001) * Y - wZ * x + wX * Z
Z = dZ + (1 + K * 0.000001) * Z + Y * x - wX * Y
'dX、dY、dZ、wX、wY、wZ、K为七参数系数

3、从目标空间坐标转换到目标大地坐标,同椭球,公式基本一致。根据空间坐标,应用回归方程计算平面坐标。

VB代码:
L = Atn(Y/X)
B = 0
Dim CalcLat As Double '计算纬度
Dim N As Double,e2 As Double
e2 = 1 - (1 - 1 / f) ^ 2 
Do '回归计算纬度CalcLat = BN = a / Sqr(1 - e2 * Sin(B) ^ 2) '卯酉圈的曲率半径B = Atn(Z + N * e2 * Sin(CalcLat) / Sqr(X ^ 2 + Y ^ 2))
Loop While Abs(B - CalcLat) > 0.00000000000001If Lon < 0 ThenLon = Lon + Pi
End If
N = a / Sqr(1 - e2 * Sin(B) ^ 2)  '卯酉圈的曲率半径
H = Sqr(X ^ 2 + Y ^ 2)  / Cos(B) - N
'X、Y、Z为空间坐标,a为目标椭球长半轴,1/f为目标椭球扁率,e2为目标椭球第一偏心率平方

4、从目标大地坐标转换到目标平面坐标,同椭球,俗称投影,我国一般采用高斯投影,坐标转换计算的精度,关键在于投影的展开精度。

高精度高斯投影(正算),适应所有椭球,VB代码,通过计算验证,精度高,达到微米级,亲测代码非常可靠:
高精度高斯投影(正算)VB代码
高精度高斯投影(正算),适应所有椭球,C#代码,通过计算验证,精度高,达到微米级,亲测代码非常可靠:
高精度高斯投影(正算)C#代码
5、最后是一个WGS84椭球转目标平面坐标的简易集成模块,一个模块一步到位,合并所有步骤,通过代码优化,精度可以达到0.001米,毫米级,亲测代码可靠:

莫洛登斯基椭球转换和简易高斯投影。为简洁代码,使用参数类,EllipsoidParam 为自定义椭球参数类,SevenParam 为自定义七参数类,VB代码:
莫洛登斯基椭球转换和简易高斯投影,VB代码
6、程序中关于椭球的定义和常用公式,其中很多参数与公式,参照EXCEL坐标高精度转换,如下详图介绍:
EXCEL坐标转换
以上代码只要在单元格中加入另外4个参数的单元格,即可支持七参数。
在这里完善命令即可:
Private Sub CommandButton1_Click() '完整布尔莎七参数和简易布尔莎七参数转换,高斯投影


dx = Val(Range(“G2”)) '七参数
dy = Val(Range(“G3”))
dz = Val(Range(“G4”))
wx = Val(Range(“H2”))
wy = Val(Range(“H3”))
wz = Val(Range(“H4”))
K = Val(Range(“H5”))

ConvertSevenParam.dx = dx
ConvertSevenParam.dy = dy
ConvertSevenParam.dz = dz
ConvertSevenParam.wx = wx
ConvertSevenParam.wy = wy
ConvertSevenParam.wz = wz
ConvertSevenParam.K = K

在这里插入图片描述
初学者看代码要多研究、多测试。

这篇关于WGS84大地坐标转目标椭球平面坐标完整代码和步骤___含高精度高斯投影(正算)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/241942

相关文章

Window Server2016加入AD域的方法步骤

《WindowServer2016加入AD域的方法步骤》:本文主要介绍WindowServer2016加入AD域的方法步骤,包括配置DNS、检测ping通、更改计算机域、输入账号密码、重启服务... 目录一、 准备条件二、配置ServerB加入ServerA的AD域(test.ly)三、查看加入AD域后的变

Window Server2016 AD域的创建的方法步骤

《WindowServer2016AD域的创建的方法步骤》本文主要介绍了WindowServer2016AD域的创建的方法步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、准备条件二、在ServerA服务器中常见AD域管理器:三、创建AD域,域地址为“test.ly”

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

用Java打造简易计算器的实现步骤

《用Java打造简易计算器的实现步骤》:本文主要介绍如何设计和实现一个简单的Java命令行计算器程序,该程序能够执行基本的数学运算(加、减、乘、除),文中通过代码介绍的非常详细,需要的朋友可以参考... 目录目标:一、项目概述与功能规划二、代码实现步骤三、测试与优化四、总结与收获总结目标:简单计算器,设计

Python实现NLP的完整流程介绍

《Python实现NLP的完整流程介绍》这篇文章主要为大家详细介绍了Python实现NLP的完整流程,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 编程安装和导入必要的库2. 文本数据准备3. 文本预处理3.1 小写化3.2 分词(Tokenizatio

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是