一、下载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. 三分钟掌控Actor模型和CSP模型

    回顾一下前文<三分钟掌握共享内存模型和 Actor模型> Actor vs CSP模型 传统多线程的的共享内存(ShareMemory)模型使用lock,condition等同步原语来强行 ...

  3. XML技术的作用?

    XML技术用于数据存储.信息配置.数据交换三方面. 可以将数据存储在XML中,通过节点.元素内容.属性标示数据内容及关系. 可以使用XML很方便的做信息配置,软件的各种配置参数和对象关系都存贮在XML ...

  4. C# winform自己的窗体不抢夺其他窗体的光标

    在你的form里加入: protected override CreateParams CreateParams { get { var result = base.CreateParams; ; r ...

  5. memcached 是怎么工作的?

    Memcached 的神奇来自两阶段哈希(two-stage hash).Memcached 就像一 个巨大的.存储了很多<key,value>对的哈希表.通过 key,可以存储或查询任意 ...

  6. WebSQL是什么?

    WebSQL是客户浏览器端的结构化的关系数据库.这是浏览器内部的本地RDBMS,你可以在这个本地RDBMS上执行SQL查询.

  7. 怎么创建maven项目

    1.Eclipse中用Maven创建项目 2.点击[next] 3.选maven-archetype-webapp后,next 4.填写相应的信息,Packaged是默认创建一个包,不写也可以 4右击 ...

  8. springboot+shiro 01 - 实现权限控制

    sb_shiro_session <?xml version="1.0" encoding="UTF-8"?> <project xmlns= ...

  9. 百度移动统计调用api教程,少进坑(82001错误)

    相信很多小伙伴使用了百度统计,来查看自己应用使用的情况,但是会发现百度移动统计在官网没有api调用取数据的接口, 现在我就以自己成功调用api并且成功拿到数据,将这个步骤给大家参考,(末尾有调用移动统 ...

  10. 玩别人玩剩下的:canvas大雪纷飞

    canvas大雪纷飞 前言:正好业务触及到canvas,看完api顺手写个雪花效果,因为之前看到过很多次这个,主要看思路,想象力好的可以慢慢去创作属于自己的canvas效果 思路: 利用画圆arc() ...