基于MATLAB的DEM读取显示以及山顶点提取

2023-11-09 17:50

本文主要是介绍基于MATLAB的DEM读取显示以及山顶点提取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、山顶点提取原理
  • 二、MATLAB代码实现(亲测有效)
    • 1.程序以及程序清单
    • 2.运行结果以及分析


前言

利用MATLAB强大的数组运算的功能,我们可以利用其进行山顶点的提取。但由于知识比较薄弱,在MATLAB正确读取并显示DEM模型上还未能找到合适的方法,因此在下面我采用的是常规导入并进行拉伸显示。本篇文章只是一个小实验,希望读者能从中获益,若有不足之处,望能指出。

一、山顶点提取原理

所谓山顶点,即是该部分地形区域上的高程最大点,提取山顶点对地形研究有很重要的意义。通过提取山顶点来获取山顶点的几何位置,在GIS分析中可用来作为选址分析或者地形分析。下图是在arcmap中 提取山顶矢量点,可以看出,其提取的结果还是比较满意,但在边缘区域就会出现多余点的情况,而且还会出现多个山顶点重叠的情况。
在这里插入图片描述
下面我们就来谈一谈山顶点提取原理,我们利用的源数据是DEM图,其每个像元值代表的是一个高程值。那如何找到一定区域内的最高点呢,按照下述流程,我们可以得到差值矩阵图。

此差值矩阵中的零值就代表的是山顶点,其他值都是低于这个点的其他高程点。我们进行重分类,将零值换为0,其他值赋值为1,通过转换成double数组,就可以得到一个二值化图。

在这里插入图片描述

二、MATLAB代码实现(亲测有效)

1.程序以及程序清单

程序清单:
geotiffread:用于读取地理tiff文件
padarray:用于在原矩阵四周扩充零矩阵
deal:用于分身
reshape:改变数组的维度不改变数值
flip:颠倒数组
find:查找数组某值得具体行列位置
numel:计算数组的元素个数

clc;
clear all;
%geotiffread函数可用于读取地理tiff文件格式图片
% data变量存储坐标或是像元数据,info变量用于存储数据的一些详细信息
[data,info]=geotiffread("DEM1.tif");
%拉伸图像,由于dem数据中边缘存在异常值,因此一般要进行拉伸才能够显示,拉伸的大小视实际情况而定
image=data.*30;
%-------------------------%
imshow(image);
colorbar;
title('DEM image')
%-------------------------%
%padarrary函数用于给图像四周扩充零矩阵,扩充的具体范围视窗口大小而定
image1=padarray(image,[7,7]);
%deal函数用于将数组赋给两个变量,其继承了原矩阵的所有属性值,目的是保证后续不会被迭代改变
[x1,x2]=deal(image1);
[rows,cols]=size(image1);
%采用15*15的窗口遍历每一个像元,将窗口内的最大值赋值给该像元
for i=1:rows-14for j=1:cols-14NR=x1(i:i+14,j:j+14);ER=reshape(NR,[1,15*15]);MAX_NR=max(ER);x2(i+6,j+6)=MAX_NR;end
end
diff_image=image1-x2;
[xx1,xx2]=deal(diff_image);
for ii=1:rowsfor jj=1:colsif xx1(ii,jj)<0xx2(ii,jj)=0;elsexx2(ii,jj)=1;endend
end
top=double(xx2);
%------------------------------------------------------------%
%---------------------------------------%
%查找异常值,并对图像进行裁剪
[r,c]=size(data);
first_row_find=0;end_row_find=0;first_col_find=0;end_col_find=0;
first_row=data(1,1:c);
end_row=flip(data(r,1:c));
first_col=flip(data(1:r,1));
end_col=data(1:r,c);
for mm=1:cif first_row(mm)==max(data)first_row_find=first_row_find+1;elsebreakendif end_row(mm)==max(data)end_row_find=end_row_find+1;elsebreakend
end
for nn=1:rif first_col(nn)==max(data)first_col_find=first_col_find+1;elsebreakendif end_col(nn)==max(data)end_col_find=end_col_find+1;elsebreakend
end
%---------------------------------------%
%------------------------------------------------------------%
crop_top=top(7+first_col_find:rows-7-end_col_find,7+first_row_find:cols-7-end_row_find);
imshow(crop_top);
title('the crop top.point image')
%根据find函数查找corp_top图像上山顶点的行列坐标
[rows1,cols1]=find(crop_top==1);
[rows2,cols2]=size(data);
ol=data(first_col_find:rows2-end_col_find,first_row_find:cols2-end_row_find).*45;
imshow(ol);
title('the crop DEM image')
%------------------------------------------------------------%
png=data(first_col_find:rows2-end_col_find,first_row_find:cols2-end_row_find).*45;
png1=deal(png);
number=0;
for iii=1:size(rows1)number=number+1;png1(rows1(number),cols1(number))=1;
end
imshow(png1);
title('the mix top.point image');
%------------------------------------------------------------%
count=numel(find(crop_top==1))

2.运行结果以及分析

下图为源数据DEM图,该图的高程以灰白色条显示,数据类型为int16。由于我的源数据是掩膜提取的,所以该图的四周含有异常值,因此色条的范围很大,另外要在MATLAB中显示,则需要对图像进行拉伸才能显示正常。
在这里插入图片描述
针对上图的异常显示,我们需要对图像进行裁剪,去除四周的异常值,结果如下
在这里插入图片描述
本文主要采用的窗口大小为15*15,通过对源数据DEM进行遍历之后,再进行相减以及二值化处理,可以得到下面的图,图中的白色点即为山顶点,其高程在一定区域内最高。
在这里插入图片描述
下图即按照上图的白色点坐标,在the crop DEM image中显示的结果,不难看出,其山顶点的位置还是较为正确,而且不存在边缘多余山顶点的情况。
在这里插入图片描述

这篇关于基于MATLAB的DEM读取显示以及山顶点提取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/377660

相关文章

Springboot配置文件相关语法及读取方式详解

《Springboot配置文件相关语法及读取方式详解》本文主要介绍了SpringBoot中的两种配置文件形式,即.properties文件和.yml/.yaml文件,详细讲解了这两种文件的语法和读取方... 目录配置文件的形式语法1、key-value形式2、数组形式读取方式1、通过@value注解2、通过

Python自动化提取多个Word文档的文本

《Python自动化提取多个Word文档的文本》在日常工作和学习中,我们经常需要处理大量的Word文档,本文将深入探讨如何利用Python批量提取Word文档中的文本内容,帮助你解放生产力,感兴趣的小... 目录为什么需要批量提取Word文档文本批量提取Word文本的核心技术与工具安装 Spire.Doc

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

在C#中读取文件的六种主流方法详解

《在C#中读取文件的六种主流方法详解》在C#中读取文件有多种方法,不同方式适用于不同场景(小型文件、大型文件、文本文件或二进制文件),本文给大家介绍了6种主流方法以及其适用场景,需要的朋友可以参考下... 目录方法1:File.ReadAllText(读取整个文本文件)方法2:File.ReadAllLin

Java轻松实现在Excel中插入、提取或删除文本框

《Java轻松实现在Excel中插入、提取或删除文本框》在日常的Java开发中,我们经常需要与Excel文件打交道,当涉及到Excel中的文本框时,许多开发者可能会感到棘手,下面我们就来看看如何使用J... 目录Java操作Excel文本框的实战指南1. 插入Excel文本框2. 提取Excel文本框内容3

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

java读取excel文件为base64实现方式

《java读取excel文件为base64实现方式》文章介绍使用ApachePOI和EasyExcel处理Excel文件并转换为Base64的方法,强调EasyExcel适合大文件且内存占用低,需注意... 目录使用 Apache POI 读取 Excel 并转换为 Base64使用 EasyExcel 处