基于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

相关文章

Python实现常用文本内容提取

《Python实现常用文本内容提取》在日常工作和学习中,我们经常需要从PDF、Word文档中提取文本,本文将介绍如何使用Python编写一个文本内容提取工具,有需要的小伙伴可以参考下... 目录一、引言二、文本内容提取的原理三、文本内容提取的设计四、文本内容提取的实现五、完整代码示例一、引言在日常工作和学

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

解决Java中基于GeoTools的Shapefile读取乱码的问题

《解决Java中基于GeoTools的Shapefile读取乱码的问题》本文主要讨论了在使用Java编程语言进行地理信息数据解析时遇到的Shapefile属性信息乱码问题,以及根据不同的编码设置进行属... 目录前言1、Shapefile属性字段编码的情况:一、Shp文件常见的字符集编码1、System编码

利用Python实现添加或读取Excel公式

《利用Python实现添加或读取Excel公式》Excel公式是数据处理的核心工具,从简单的加减运算到复杂的逻辑判断,掌握基础语法是高效工作的起点,下面我们就来看看如何使用Python进行Excel公... 目录python Excel 库安装Python 在 Excel 中添加公式/函数Python 读取

基于Python开发批量提取Excel图片的小工具

《基于Python开发批量提取Excel图片的小工具》这篇文章主要为大家详细介绍了如何使用Python中的openpyxl库开发一个小工具,可以实现批量提取Excel图片,有需要的小伙伴可以参考一下... 目前有一个需求,就是批量读取当前目录下所有文件夹里的Excel文件,去获取出Excel文件中的图片,并

详解如何使用Python提取视频文件中的音频

《详解如何使用Python提取视频文件中的音频》在多媒体处理中,有时我们需要从视频文件中提取音频,本文为大家整理了几种使用Python编程语言提取视频文件中的音频的方法,大家可以根据需要进行选择... 目录引言代码部分方法扩展引言在多媒体处理中,有时我们需要从视频文件中提取音频,以便进一步处理或分析。本文

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)

《CSS模拟html的title属性(鼠标悬浮显示提示文字效果)》:本文主要介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,详细内容请阅读本文,希望能对你有所帮助... 效

基于Python实现一个PDF特殊字体提取工具

《基于Python实现一个PDF特殊字体提取工具》在PDF文档处理场景中,我们常常需要针对特定格式的文本内容进行提取分析,本文介绍的PDF特殊字体提取器是一款基于Python开发的桌面应用程序感兴趣的... 目录一、应用背景与功能概述二、技术架构与核心组件2.1 技术选型2.2 系统架构三、核心功能实现解析

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常