C++实现高斯坐标转经纬度坐标的函数

时间: 2023-08-02 22:09:45 浏览: 72
以下是C++实现高斯坐标转经纬度坐标的函数: ```c++ #include <cmath> // 定义常量 const double PI = 3.14159265358979323846; const double a = 6378137.0; // 长半轴 const double b = 6356752.3142; // 短半轴 const double f = 1.0 / 298.257223563; // 扁率 const double e2 = f * (2 - f); // 第一偏心率的平方 const double ee2 = e2 / (1 - e2); // 第二偏心率的平方 // 高斯投影正算 void GaussForward(double B, double L, double &X, double &Y, double L0, double K0) { double L1 = L - L0; double l = L1 * PI / 180; double b = B * PI / 180; double N = a / sqrt(1 - e2 * sin(b) * sin(b)); double t = tan(b); double g = sqrt(ee2) * cos(b); double m = cos(b) * l; double s = sin(b); double n = sqrt(ee2) * s; double t1 = t * t; double g2 = g * g; double N2 = N * N; double cos3 = cos(b) * cos(b) * cos(b); double sin2 = sin(b) * sin(b); double x = K0 * N * (m + (1 - t1 + g2) * m * m * m / 6.0 + (5 - 18 * t1 + t1 * t1 + 72 * g2 - 58 * ee2) * m * m * m * m * m / 120.0); double y = K0 * (N * t + N * (9 * ee2 + 4 * g2 - 12) * t * t * t / 24.0 + N * (61 - 58 * t1 + t1 * t1 + 600 * g2 - 330 * ee2) * t * t * t * t * t / 720.0); X = x + 500000; Y = y; } // 高斯投影反算 void GaussInverse(double X, double Y, double &B, double &L, double L0, double K0) { Y = Y / K0; double x = X - 500000; double e1 = (1 - sqrt(1 - e2)) / (1 + sqrt(1 - e2)); double xx = x / (a * K0); double m = xx / cos(B); double m2 = m * m; double m3 = m2 * m; double m4 = m3 * m; double m5 = m4 * m; double n = (e2 * cos(B) * cos(B)) / (1 - e2); double n2 = n * n; double t = tan(B); double t2 = t * t; double t4 = t2 * t2; double t6 = t4 * t2; double cos3 = cos(B) * cos(B) * cos(B); double cos5 = cos3 * cos(B) * cos(B); double eta = ee2 * cos(B) * cos(B); double eta2 = eta * eta; double eta3 = eta2 * eta; double eta4 = eta3 * eta; B = B - t * xx * xx / (2 * a * a * N) + t * (5 + 3 * t2 + n - 9 * eta) * xx * xx * xx * xx / (24 * a * a * a * a * N * N * N) - t * (61 + 90 * t2 + 45 * t4) * xx * xx * xx * xx * xx * xx / (720 * a * a * a * a * a * a * N * N * N * N * N) + t * xx * xx * xx * xx * xx * xx * (1385 + 3633 * t2 + 4095 * t4 + 1575 * t6) / (40320 * a * a * a * a * a * a * a * a * N * N * N * N * N * N); L = L0 + m - (1 + 2 * t2 + n) * m3 / 6 + (5 - 2 * n + 28 * t2 - 3 * n2 + 8 * eta + 24 * t4) * m5 / 120; B = B * 180 / PI; L = L * 180 / PI; } ``` 其中,高斯投影正算函数`GaussForward`的参数为输入的经度`L`和纬度`B`,输出的高斯坐标`X`和`Y`,以及中央子午线经度`L0`和比例因子`K0`;高斯投影反算函数`GaussInverse`的参数为输入的高斯坐标`X`和`Y`,输出的经度`L`和纬度`B`,以及中央子午线经度`L0`和比例因子`K0`。

相关推荐

最新推荐

recommend-type

C语言实现直角坐标转换为极坐标的方法

主要介绍了C语言实现直角坐标转换为极坐标的方法,涉及C语言进行三角函数与数值运算相关操作技巧,需要的朋友可以参考下
recommend-type

C++实现数字转换为十六进制字符串的方法

主要介绍了C++实现数字转换为十六进制字符串的方法,涉及C++操作数字与字符串转换的相关技巧,需要的朋友可以参考下
recommend-type

python实现根据给定坐标点生成多边形mask的例子

今天小编就为大家分享一篇python实现根据给定坐标点生成多边形mask的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

C++中发声函数Beep用法

本文给大家分享的是Beep函数的用法以及会使扬声器发出简单的声音的示例,有需要的小伙伴可以参考下
recommend-type

C++11 Unicode编码转换

主要介绍了C++11 Unicode编码转换的相关资料,帮助大家更好的理解和学习c++11,感兴趣的朋友可以了解下
recommend-type

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节

中文翻译Introduction to Linear Algebra, 5th Edition 2.1节 线性代数的核心问题是求解方程组。这些方程都是线性的,即未知数仅与数相乘——我们绝不会 遇见 x 乘以 y。我们的第一个线性方程组较小。接下来你来看看它引申出多远: 两个方程 两个未知数 x − 2y = 1 3x + 2y = 11 (1) 我们一次从一个行开始。第一个方程 x − 2y = 1 得出了 xy 平面的一条直线。由于点 x = 1, y = 0 解 出该方程,因此它在这条直线上。因为 3 − 2 = 1,所以点 x = 3, y = 1 也在这条直线上。若我们选择 x = 101,那我们求出 y = 50。 这条特定直线的斜率是 12,是因为当 x 变化 2 时 y 增加 1。斜率在微积分中很重要,然而这是线 性代数! 图 2.1 将展示第一条直线 x − 2y = 1。此“行图”中的第二条直线来自第二个方程 3x + 2y = 11。你 不能错过两条线的交点 x = 3, y = 1。点 (3, 1) 位于两条线上并且解出两个方程。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

识别MATLAB微分方程求解中的混沌行为:分析非线性方程混沌行为的实用技巧

![matlab求解微分方程](https://img-blog.csdnimg.cn/2021062810300367.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MTQ3OTY3OA==,size_16,color_FFFFFF,t_70) # 1. MATLAB微分方程求解概述 微分方程是描述物理、工程和金融等领域中动态系统的数学模型。MATLAB提供了强大的工具来求解微分方程,包括内置求解器和自定义函数
recommend-type

physon如何做ERP系统

作为一个AI语言模型,我可以给您提供一些基本的建议和思路: 1.明确需求和目标:在开始开发ERP系统之前,需要明确您的业务需求和目标,了解您的业务流程、流程数据、员工角色和权限、财务管理等方面的要求,这样才能更好的设计和开发ERP系统。 2.选择技术框架和开发工具:选择合适的技术框架和开发工具是ERP系统开发的关键。选择一种流行的技术框架和工具可以提高开发效率和质量。 3.设计数据库:ERP系统需要一个功能强大的数据库来存储数据。设计数据库需要考虑数据的完整性、安全性和可扩展性。 4.设计系统架构:系统架构是ERP系统的骨架,需要考虑系统的可扩展性、可维护性和性能。 5.开发和测试:
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。