一、下载OSM数据

首先从OpenStreetMap官网下载我们需要的实验数据,这里我选择清华和北大校园作为本次实验数据

二、数据处理

将我们下载的实验数据导入ArcGIS。由于OSM数据是.osm格式,因此导入ArcGIS之前需要将其转换为.shp格式,具体方法见:关于openstreet map的osm文件转shp文件方法(附arcgis10.2插件)

可以看到,面状数据中除了建筑物之外还有植被、水体等。因此为了实现对建筑物的简化,我们需要将建筑物单独从面状数据中筛选出来。

打开面状数据的属性表,不难发现building字段可以反应每个面是否为建筑物。因此,我们打开Select by Attribute面板,buiding <>'' 找出buiding字段不为空的记录,再将这些记录导出就能得到只包含建筑物的面状数据了。

三、算法实验

建筑物简化:

ArcGIS 10.2的建筑物简化工具位于Toolboxes->Cartography Tools->Generalization->Simplify Building,但我们暂时还不能进行简化。

巨坑警告!在进行建筑物简化之前,请务必确认数据的参考坐标系和投影坐标系!ArcGIS 10.2似乎不能对 **没有投影坐标系的经纬度坐标(Decimal Degrees) **下的建筑进行简化,而下载的OSM数据一般是基于WGS-84坐标系,本身没有进行地图投影,因此没有投影坐标。如果直接使用经纬度进行建筑物简化可能得到错误结果(例如下图所有建筑物变成三角形,且与容差设置无关)

因此,建议先进行下面两个步骤:

1. 改变数据的坐标系。

打开Toolboxes->Data Management Tools->Projections and Transformation->Feature->Project 工具。

其中Input Coordinate System 选项可以看到当前数据的坐标系,如果仅仅只有参考坐标系则需要进行投影。Output Coordinate System选项代表我们将要变更到的坐标系,选择Projected Coordinate System中的一种投影坐标系就好,这里我选择了Mercator投影坐标系。

现在我们得到了一个Mercator投影的建筑物面状数据。

2. 改变Data Frame的坐标系

其实完成上一步,就已经可以正常进行建筑物简化了,只需要在Simplify Building工具中导入刚才得到数据,再Simplification Tolerance选项将单位改成Meters即可。(注意:必须使用有投影坐标系的数据,再改变这里的单位,否则也可能得到错误的简化结果)。

PS:虽然经过我的测试,只要数据是Project之后的,并且容差值合适(对于经纬度而言,例如0.001),即使容差单位选择Decimal degrees,也能得到正确的简化结果。不过鉴于建筑简化工具还有关于面积的Minimum Area等参数,不太推荐使用经纬度进行简化。

因此,为了便于对简化算法结果的量算和分析,最好是在菜单栏View-Data Frame Properties中更改数据框架显示的Coordinate System,这里我把他设置成Mercator投影。这样就能够在Measure工具中以米为单位量算距离和面积了。

现在就可以正常使用Simplify Building工具对我们的建筑物数据进行简化了,让我们看看使用10m作为容差的结果。接下来只要再对结果进行分析就能完成实验啦,这里就不作讨论了。

建筑物群聚合:

ArcGIS 10.2似乎并没有直接的建筑物群聚合工具,因此,要实现建筑物群简化我们需要借助聚合面工具。

首先,需要在菜单栏的Customize-Extensions中打开Spatial Analyst功能。

然后再工具箱中找到Toolboxes->Cartography Tools->Generalization->Aggregate Polygons工具,这就是我们需要的聚合面工具。

从ArcGIS官网上我们能够了解到每个参数和选项的含义,根据我们实验的情况选择使用合适的参数即可完成建筑物群的聚合。

参数 说明 数据类型
in_features 要聚合的面要素。如果这是一个引用某个制图表达的图层,并且在输入要素中存在形状覆盖,则在聚合处理中将采用这些覆盖的形状、而不是要素形状。 Feature Layer
out_feature_class 要创建的输出要素类。 Feature Class
aggregation_distance 聚合时面要素边界间要满足的距离。必须指定一个距离,且此距离必须大于零。可以选择首选单位;默认为要素单位。 Linear Unit
minimum_area(可选) 聚合面得以保留的最小面积。默认值为零,即保留所有面。可以指定首选单位;默认为要素单位。 Areal Unit
minimum_hole_size(可选) 面要素中的孔洞得以保留的最小大小。默认值为零,即保留所有面要素中的孔洞。可以指定首选单位;默认为要素单位。 Areal Unit
orthogonality_option(可选) 指定构造聚合边界时输出要素的特征。NON_ORTHOGONAL —将创建有机形状的输出要素。这适用于自然要素,例如,植被或土壤多边形。这是默认设置。ORTHOGONAL —将创建正交形状的输出要素。此选项适用于保留人为输入要素的几何特性,例如,建筑物轮廓线。 Boolean
barrier_features[barrier_features,...](可选) 包含在输入要素中作为聚合障碍的线要素或面要素的图层。要素不会跨障碍要素聚合。与输入要素存在几何冲突的障碍要素将被忽略。 Feature Layer
out_table(可选) 将聚合的面连接到其源面要素的一对多关系表。该表包含两个字段(OUTPUT_FID 和 INPUT_FID),分别用于存储聚合要素 ID 和其源要素 ID。使用此表根据源要素派生输出要素的必要属性。该表的默认名称为输出要素类名称加上 _tbl。默认路径与输出要素类相同。当该参数留空时,不创建任何表。 Table

最后,我们来看一下容差为30m的建筑物群聚合结果,然后对结果进行分析就好啦!

ArcGIS建筑物简化和建筑物群聚合算法实验的更多相关文章

  1. smoj2806建筑物

    题面 有R红色立方体,G绿色立方体和B蓝色立方体.每个立方体的边长是1.现在有一个N × N的木板,该板被划分成1×1个单元.现在要把所有的R+G+B个立方体都放在木板上.立方体必须放置在单元格内,单 ...

  2. ArcGIS空间分析工具

    1. 3D分析 1.1. 3D Features toolset 工具 工具 描述 3D Features toolset (3D 要素工具集) Add Z Information 添加 Z 信息 添 ...

  3. Java编程思想—八皇后问题(数组法、堆栈法)

    Java编程思想-八皇后问题(数组法.堆栈法) 实验题目:回溯法实验(八皇后问题) 实验目的: 实验要求: 实验内容: (1)问题描述 (2)实验步骤: 数组法: 堆栈法: 算法伪代码: 实验结果: ...

  4. 如何建立一个完整的游戏AI

    http://blog.friskit.me/2012/04/how-to-build-a-perfect-game-ai/ 人工智能(Artificial Intelligence)在游戏中使用已经 ...

  5. UVA 221 城市化地图(离散化思想)

    题意: 给出若干个栋楼俯视图的坐标和面积,求从俯视图的南面(可以视为正视图)看过去到底能看到多少栋楼. 输入第一个n说明有n栋楼,然后输入5个实数(注意是实数),分别是楼的左下角坐标(x,y), 然后 ...

  6. GIS和视频监控的集成

    本文讨论了使用增强现实(AR)技术的三维(3D)地理信息系统(GIS)和视频监视系统的集成.进行这种集成的动机是要克服常规视频监视系统面临的问题.关于哪个摄像机当前监视此类系统中哪个区域的明确信息:因 ...

  7. mapboxgl 中插值表达式的应用场景

    目录 一.前言 二.语法 三.对地图颜色进行拉伸渲染 1. 热力图 2. 轨迹图 2. 模型网格渲染 四.随着地图缩放对图形属性进行插值 五.interpolate的高阶用法 六.总结 一.前言 in ...

  8. UVa 221城市正视图(离散化)

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  9. HDU 5033 Building

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5033 解题报告:在一条x轴上有n个建筑物,每个建筑物有一个高度h,然后现在有q次查询,查询的内容是假设 ...

随机推荐

  1. 14图像边缘检测的sobel_ctrl控制模块

    一设计功能 计算得到的dxy,再通过和阈值比较大小,输出po_sum作为VGA的输入,在显示器器上显示图像的轮廓. 二设计思路 根据前一篇博客对sobel算法的介绍,先通过FIFO的双流水线操作采集到 ...

  2. 有没有想过String为什么设计为不可变对象

    1.声明为final类的目的: 主要目的就是保证String是不可变(immutable).不可变就是第二次给一个String 变量赋值的时候,不是在原内存地址上修改数据,而是重新指向一个新对象,新地 ...

  3. jinja2.exceptions.TemplateNotFound 报错处理

    一.检查模板文件夹是否正确. 遇到这个问题,首先需要检查你的模板文件夹命名是否规范,Flask默认会在工程下寻找templates文件夹,这个是默认配置,不能写成template或者其他名字.当然,如 ...

  4. vue解除双向绑定?

    let obj = JSON.parse(JSON.stringify(this.temp1));

  5. 详解AOP——用配置文件的方式实现AOP

    AOP概念 1.AOP:面向切面(方面)编程,扩展功能不修改源代码实现 AOP原理 AOP采用横向抽取机制,取代了传统纵向继承体系重复性代码 传统的纵向抽取机制: 横向抽取机制: AOP操作术语 1. ...

  6. http和https到底区别在哪

    一.Http和Https的基本概念 Http:超文本传输协议(Http,HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议.设计Http最初的目的是为了提供一 ...

  7. 网络协议之:socket协议详解之Socket和Stream Socket

    目录 简介 Socket是什么 Stream Socket 使用socat创建一个TCP服务器 使用ss检查TCP连接 使用nc连接socket 总结 简介 不管是在普通的网络编程中还是在netty中 ...

  8. Numpy实现SVD矩阵分解

    1. 引入包 2. 实现矩阵分解 3. 从分量还原矩阵

  9. 【精】多层PCB层叠结构

    在设计多层PCB电路板之前,设计者需要首先根据电路的规模.电路板的尺寸和电磁兼容(EMC)的要求来确定所采用的电路板结构,也就是决定采用4层,6层,还是更多层数的电路板.确定层数之后,再确定内电层的放 ...

  10. vue双向绑定、Proxy、defineproperty

    本文原链接:https://www.jianshu.com/p/2df6dcddb0d7 前言 双向绑定其实已经是一个老掉牙的问题了,只要涉及到MVVM框架就不得不谈的知识点,但它毕竟是Vue的三要素 ...