ArcGIS建筑物简化和建筑物群聚合算法实验
一、下载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建筑物简化和建筑物群聚合算法实验的更多相关文章
- smoj2806建筑物
题面 有R红色立方体,G绿色立方体和B蓝色立方体.每个立方体的边长是1.现在有一个N × N的木板,该板被划分成1×1个单元.现在要把所有的R+G+B个立方体都放在木板上.立方体必须放置在单元格内,单 ...
- ArcGIS空间分析工具
1. 3D分析 1.1. 3D Features toolset 工具 工具 描述 3D Features toolset (3D 要素工具集) Add Z Information 添加 Z 信息 添 ...
- Java编程思想—八皇后问题(数组法、堆栈法)
Java编程思想-八皇后问题(数组法.堆栈法) 实验题目:回溯法实验(八皇后问题) 实验目的: 实验要求: 实验内容: (1)问题描述 (2)实验步骤: 数组法: 堆栈法: 算法伪代码: 实验结果: ...
- 如何建立一个完整的游戏AI
http://blog.friskit.me/2012/04/how-to-build-a-perfect-game-ai/ 人工智能(Artificial Intelligence)在游戏中使用已经 ...
- UVA 221 城市化地图(离散化思想)
题意: 给出若干个栋楼俯视图的坐标和面积,求从俯视图的南面(可以视为正视图)看过去到底能看到多少栋楼. 输入第一个n说明有n栋楼,然后输入5个实数(注意是实数),分别是楼的左下角坐标(x,y), 然后 ...
- GIS和视频监控的集成
本文讨论了使用增强现实(AR)技术的三维(3D)地理信息系统(GIS)和视频监视系统的集成.进行这种集成的动机是要克服常规视频监视系统面临的问题.关于哪个摄像机当前监视此类系统中哪个区域的明确信息:因 ...
- mapboxgl 中插值表达式的应用场景
目录 一.前言 二.语法 三.对地图颜色进行拉伸渲染 1. 热力图 2. 轨迹图 2. 模型网格渲染 四.随着地图缩放对图形属性进行插值 五.interpolate的高阶用法 六.总结 一.前言 in ...
- UVa 221城市正视图(离散化)
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- HDU 5033 Building
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5033 解题报告:在一条x轴上有n个建筑物,每个建筑物有一个高度h,然后现在有q次查询,查询的内容是假设 ...
随机推荐
- css--BFC是什么,有什么用,怎么用?
前言 作为前端开发人员或者学生,你一定知道BFC这个关键词,但是你是否具体了解过什么是BFC?BFC有什么用?BFC怎么用些问题呢?本文就来总结一下相关的知识点,希望对阅读到的小伙伴在面试.学习.开发 ...
- 在Windows11使用WSA运行Google play会遇到的问题
前提一是要有adb工具 网盘链接:https://pan.baidu.com/s/1MAdq4GsxkW7dqq689d_gQw 提取码:24q2 前提二是会使用 MagiskOnWSA--解决了两个 ...
- ElasticSearch7.3学习(十五)----中文分词器(IK Analyzer)及自定义词库
1. 中文分词器 1.1 默认分词器 先来看看ElasticSearch中默认的standard 分词器,对英文比较友好,但是对于中文来说就是按照字符拆分,不是那么友好. GET /_analyze ...
- 记-beego项目调用Jenkins API获取job信息
type JenkinsController struct { beego.Controller } type Job struct { Name string `json:"name&qu ...
- 从查询重写角度理解elasticsearch的高亮原理
一.高亮的一些问题 elasticsearch提供了三种高亮方式,前面我们已经简单的了解了elasticsearch的高亮原理; 高亮处理跟实际使用查询类型有十分紧密的关系,其中主要的一点就是muti ...
- 如果一个 linux 新手想要知道当前系统支持的所有命令的列表,他需要怎么做?
使用命令 compgen -c,可以打印出所有支持的命令列表. [root@localhost ~]$ compgen -cl.lllswhichifthen elseelifficaseesacfo ...
- 生命周期内create和mounted的区别?
created: 在模板渲染成html前调用,即通常初始化某些数据,然后再渲染成视图. mounted: 在模板渲染成html后调用,通常是初始化页面完成后,再对html的dom节点进行一些需要的操作 ...
- Mysql的索引及优化
一:四种存储引擎: mysql使用 show engines查询其存储引擎: 功 能 MYISAM Memory InnoDB Archive 存储限制 256TB RAM 64TB None 支持 ...
- java-流式编程
流式编程 流的一个核心好处是,它使得程序更加短小并且更易理解. public class Demo1 { public static void main(String[] args) { new Ra ...
- Python的数据基础库Numpy怎样对数组进行排序
Numpy怎样对数组排序 Numpy给数组排序的三个方法: numpy.sort:返回排序后数组的拷贝 array.sort:原地排序数组而不是返回拷贝 numpy.argsort:间接排序,返回的是 ...