热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

椭球体上某区域面积的求算,及该区域兰伯特投影与墨卡托投影到二维平面后面积对比

hello,最近yogurt给大家的更新很频繁哦~~今天要分享的内容是紧接着前面两篇的内容做的扩展~~我们不仅要求取某地区在地球椭球体这个三维空间中的面积,还要与该地区投影到二维空间

    hello,最近yogurt给大家的更新很频繁哦~~今天要分享的内容是紧接着前面两篇的内容做的扩展~~

    我们不仅要求取某地区在地球椭球体这个三维空间中的面积,还要与该地区投影到二维空间后平面多边形的面积进行对比。怎么求取二维平面多边形的面积,大家可以看看我之前写过的《求解多边形面积2S= Σ【Xi (Yi+1-Yi-1)】,(i属于1~n),公式解析及编程实现》http://www.cnblogs.com/to-sunshine/p/7642222.html。至于怎么进行兰伯特投影墨卡托投影,大家可以参考我之前写过的《.gen地图文件的投影编程实现(以墨卡托投影和兰伯特投影为例)》http://www.cnblogs.com/to-sunshine/p/6048438.html。

============================yogurt小课堂开课了===========================

    下面yogurt要跟大家分享这次需要用到的知识点:

    地球椭球体表面上的梯形面积:

    取长度很小很小的一个长和一个宽,组成的梯形是非常小的,近似可以看作矩形。那么 S = 长 X 宽 ,如下图:

(图来自我老师的PPT)

        我们知道 AB = CD ,是南北方向上的边长,假设与任意一条经线平行。由上节的知识,我们不难知道: AB = CD = M X dφ (dφ是AD所在纬线与BC所在纬线的纬度间隔,很小);

    同样,由于纬度间隔非常小,可以近似看作 BC ≈ AD ,是东西方向上的边长,假设与任意一条纬线平行。由上节的知识,我们也不难知道: BC ≈ AD = r X dλ (dλ是AB所在经线与CD所在经线的经度间隔,很小),而 r = N X cosφ(φ看作AD所在纬线或者BC所在纬线的纬度,由于间隔很小,所以只要所有梯形统一用上边的或者统一都用下边的纬度即可)。因此,BC = AD = N X cosφ X dλ 。

    综上,便能够得到地球椭球体上梯形的面积 dS = (M X dφ) X (N X cosφ X dλ)= M N cosφ dλ dφ ,那么 S = 

    对于每一个小梯形,用前后两个点的平均纬度作为 φ2,以该区域的最低纬度作为 φ1,dφ = φ2 - φ1 ;前后两个点的经度对应 λ1、λ2,再利用积分的原理就可以计算得到椭球体上的某区域的面积啦!

=================================下课了================================

    假设我们拿到的数据是某区域墨卡托投影后的二维平面上一系列的区域边界点数据,那么我接下来的步骤将分为六步:1、计算二维平面上的墨卡托投影后的平面面积 S1  -->  2、墨卡托投影反算,得到每个点在地球椭球体上对应的经纬度坐标  -->  3、计算地球椭球体上该区域的面积 S2 --> 4、把该区域进行兰伯特投影得到二维平面上又一系列的区域边界点数据  -->  5、计算二维平面上的兰伯特投影后的平面面积 S3 -->  6、对比三种面积的区别。

     

1、计算二维平面上的墨卡托投影后的平面面积 S1

程序如下:

 

 

2、墨卡托投影反算,得到每个点在地球椭球体上对应的经纬度坐标

    先利用墨卡托投影反解公式,计算B、L,其中对于求解 L 需要用到 K ,K 的值由公式求出;对于求解 B,则需要设定一个初始值,然后进行迭代求解,直到前后两次计算出的 B 之差小于0.00000000001,则认为后一次计算的 B 的值为最终解。

程序如下:

 

 

在ArcGIS中查看墨卡托反算前后的数据,对比显示如下:

                 反算前                                    反算后

 

3、计算地球椭球体上该区域的面积 S2

    因为ds足够小,所以把梯形近似看做一个矩形来计算,矩形的长为东西方向的弧长,宽为南北方向的弧长。根据弧长计算公式:弧长=半径*弧度,涉及到子午圈曲率半径M和主法截面曲率半径N的计算公式。通过查阅资料,可知:

南北方向上的弧长d=M*d;东西方向上的弧长d=N*d

    对于每一个小梯形,用前后两个点的平均纬度作为 φ2,以该区域的最低纬度作为 φ1,前后两个点的经度对应 λ1、λ2,再利用积分的原理来计算得到椭球体上的该区域面积。

程序如下:

先声明和赋值程序中将会用到的基本数据长半轴a、第一偏心率e、基准纬度(江苏省最低纬度)B;并通过指向矢量文件的指针获得前后两点的纬度B1、B2和经度L1、L2。用TB来代替2-1,用AB来代替(1+2)/2:

计算小梯形的面积积分公式所需要用到的参数K、A、B、C、D,带入公式进行计算面积:

 

4、把该区域进行兰伯特投影得到二维平面上又一系列的区域边界点数据

这里参考《.gen地图文件的投影编程实现(以墨卡托投影和兰伯特投影为例)》http://www.cnblogs.com/to-sunshine/p/6048438.html。

 

5、计算二维平面上的兰伯特投影后的平面面积 S3

方法同第一步,只是带入的数据不同。

 

6、对比三种面积的区别

整个程序主函数如下:

运行后结果如下:

可见,进行Albers等积投影之后,矢量面的面积变化误差相比之整体面积来说较小,所以视为等积投影是成功的。

 


推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 尽管某些细分市场如WAN优化表现不佳,但全球运营商路由器和交换机市场持续增长。根据最新研究,该市场预计在2023年达到202亿美元的规模。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
author-avatar
赵乙潘_107
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有