【GDAL-Python】3-在Python中使用GDAL处理数字高程模型DEM

文章目录

  • 1-介绍
    • 1.1 主要内容
    • 1.2 坡度、坡向、山体阴影
  • 2-代码实现
    • 2.1 数据介绍
    • 2.2 代码实现
    • 2.3 效果显示
  • 3.参考资料
    • 3.1 使用richdem库中的TerrainAttribute计算坡度、坡向、山体阴影

1-介绍

1.1 主要内容

(1)教程内容:使用GDAL处理数字高程模型(DEM)得到一些分析的结果,如坡度(slope),坡向(aspect),山体阴影(hillshade)
(2)四种技术路线:
1) 终端运行gdal可执行命令;
2)在Python脚本中调用gdal可执行命令;
3)在Python脚本中调用gdal.DEMProcessing
4)使用richdem库中的TerrainAttribute计算

PS:Python脚本中调用gdal可执行命令有两种方式,比如利用os.system(cmd),或者子进程库subprocess.call(cmd.split())

(3)视频教程:B站对应教程:3-在Python中使用GDAL处理数字高程模型DEM

1.2 坡度、坡向、山体阴影

(1)坡度:坡度是指地表单元陡缓的程度,通常通过坡面的垂直高度与水平距离的比值来表示,这个比值可以用百分比或角度(正切值)来衡量。数值越低,表示地形越平坦;数值越高,表示地势越陡峭
(2)坡向:坡向则是指地形坡面的朝向,定义为坡面法线在水平面上的投影的方向,它用于识别表面上某一位置处的最陡下坡方向。
(3)山体阴影:山体阴影是一种技术,用于可视化由光源和高程表面的坡度和坡向确定的地形,通过模拟光线和阴影落在表面上的方式,在平面地图上描绘景观的3D表面

2-代码实现

2.1 数据介绍

(1)影像信息
在这里插入图片描述
(2)经过global mapper软件渲染显示效果,左侧颜色条表示高程信息。
在这里插入图片描述

2.2 代码实现

#!/usr/bin/env python3
# -*- coding:utf-8 -*-
import os
import subprocess
from osgeo import gdal
import matplotlib.pyplot as plt
#======================================1.计算坡度===============================
# 处理dem.tif生产坡度文件slope2.tif,采用python脚本中调用gdaldem可执行文件的形式
cmd='gdaldem slope Tile_+017_+010\Tile_+017_+010_dem.tif slope2.tif -compute_edges'
# 形式1
os.system(cmd)
# 形式2
# subprocess.call(cmd.split()))
#显示效果
slp2=gdal.Open('slope2.tif')
slp2Array=slp2.GetRasterBand(1).ReadAsArray()plt.figure()
plt.imshow(slp2Array)
plt.colorbar()
plt.show()#======================================2.计算坡向===============================
cmd='gdaldem aspect Tile_+017_+010\Tile_+017_+010_dem.tif aspect2.tif -compute_edges'
os.system(cmd)
# subprocess.call(cmd.split()))
aspect2=gdal.Open('aspect2.tif')
aspect2Array=slp2.GetRasterBand(1).ReadAsArray()
plt.imshow(aspect2Array,cmap='magma')
plt.colorbar()
plt.show()
#======================================3.计算山体阴影===============================
# 采用技术路线3实现:gdal.DEMProcessing
dem=gdal.Open('Tile_+017_+010\Tile_+017_+010_dem.tif')
hill=gdal.DEMProcessing('hillshade.tif',dem,'hillshade',computeEdges=True)
hillshade=gdal.Open('hillshade.tif')
hillArray=hillshade.GetRasterBand(1).ReadAsArray()
plt.imshow(hillArray,cmap='gray')
plt.colorbar()
plt.show()

2.3 效果显示

(1)坡度显示效果
在这里插入图片描述

(2)坡向显示效果
在这里插入图片描述

(3)山体阴影显示效果
在这里插入图片描述

3.参考资料

3.1 使用richdem库中的TerrainAttribute计算坡度、坡向、山体阴影

# using richdem
dem = rd.LoadGDAL("dem.tif")
slp3 = rd.TerrainAttribute(dem, attrib="slope_degrees") # replace "slope_degrees" with "slope_riserun",  "aspect" ...
rd.SaveGDAL("slope3.tif", slp3) visualize (example)
plt.figure()
plt.imshow(slp2Array)
plt.colorbar()
plt.show()

TODO:上传实验数据DEM.tif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/639952.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20240422,C++文件操作

停电一天之后&#xff0c;今天还有什么理由不学习呜呜……还是没怎么学习 一&#xff0c;文件操作 文件操作可以将数据持久化&#xff0c;对文件操作时须包含头文件<fstream> 两种文件类型&#xff1a;文本文件&#xff1a;文件以文本的ASCII码形式存储&#xff1b;二进…

Oracle21C 引入HR实例(linux)

1、下载资源 https://github.com/oracle-samples/db-sample-schemas点击code&#xff08;代码&#xff09;下载 2、上传Sql文件 解压之后将human_resources里的文件复制到demo\schema\目录&#xff08;具体目录前面的路径是你安装的路径&#xff09;下&#xff0c;如下图 3、…

李廉洋:4.23黄金休市之后大幅下跌,原油小幅度上涨。走势分析!

今年以来推动金价上涨的因素是亚洲的需求&#xff0c;很可能来自各国央行。最近又有零售买盘和一些金融买盘作为补充。目前的问题是&#xff0c;不断上升的债券收益率正在争夺资金。美国2年期国债的收益率接近5%&#xff0c;在美联储降息导致收益率开始下降之前&#xff0c;这仍…

软件公司:饥一顿饱一顿,咋办?试一试外部柔性产能。

有人开玩笑&#xff0c;软件公司最理想状态就是&#xff1a;项目来了&#xff0c;公司有足够的人力消化产能&#xff1b;项目没了&#xff0c;人员都走了&#xff0c;不会造成产能搁置。 以上是个理想状态&#xff0c;事实上单纯依靠一个公司是做不到的&#xff0c;所以一定建立…

网络常识!!!

网络常识!!! 一:网络的发展史二:关键的概念三:IP地址四:端口号二级目录二级目录二级目录二级目录三级目录 一:网络的发展史 从游戏方面发展历程进行理解: 从单机游戏-----游戏支持局域网对战-------游戏支持广域网对战-------移动端 (1)局域网对战:在同一个网吧里,不同的游戏…

【C++】---STL之vector详解

【C】---STL之vector详解 一、vector的介绍&#xff1a;二、vector的成员函数&#xff1a;1、vector类的构造函数2、vector的元素访问符3、vector的迭代器4、vector的模版5、vector的拷贝构造6、vector的容量&#xff08;1&#xff09;vector的增容机制&#xff08;2&#xff0…

计算机视觉 | 交通信号灯状态的检测和识别

Hi&#xff0c;大家好&#xff0c;我是半亩花海。本项目旨在使用计算机视觉技术检测交通信号灯的状态&#xff0c;主要针对红色和绿色信号灯的识别。通过分析输入图像中的像素颜色信息&#xff0c;利用OpenCV库实现对信号灯状态的检测和识别。 目录 一、项目背景 二、项目功能…

路由引入、路由策略、路由过滤实验

实验拓扑 实验思路 配置ip地址&#xff0c;配置RIP,OSPF;在R2上分别在RIP下引入OSPF&#xff0c;在OSPF下引入RIP;在R2上配置acl 2000,拒绝R4的业务网段&#xff0c;同时允许其他网段访问&#xff08;acl 2000 默认拒绝网段&#xff09;&#xff1b;通过配置路由过滤router-…

网络工程师----第九天

路由表解析 路由表&#xff1a;简单点说路由表就是路由器用于指导数据包如何转发的表项&#xff0c;记录了去往目的IP的下一跳去哪里。 路由&#xff1a;路由是网络中的基本概念&#xff0c;网络的基本功能就是使得处于网络中两个IP地址能够互相通信。 路由表作用&#xff1a…

YOLO算法改进Backbone系列之MogaNet:

卷积神经网络&#xff08;ConvNets&#xff09;一直是计算机视觉的首选方法。受灵长类视觉系统的启发&#xff0c;卷积层可以对具有区域密集连接和平移等方差约束的观测图像的邻域相关性进行编码。通过交错分层&#xff0c;ConvNets获得了被动增加的感受野&#xff0c;并善于识…

【C语言】strstr函数刨析-----字符串查找

目录 一、strstr 函数介绍 ✨函数头文件&#xff1a; ✨函数原型&#xff1a; ✨函数解读 ✨功能演示 二、函数的原理以及模拟实现 ✨函数原理 ✨函数的模拟实现 三、strstr函数的注意事项 四、共勉 一、strstr 函数介绍 strstr函数是在一个字符串中查找另一个字符…

基于ssm校园图书在线阅读系统的设计与实现

系统功能 系统设置管理员和用户两种权限。用户只能对个人信息的查阅&#xff0c;修改&#xff0c;图书资源的查询&#xff0c;而管理员则可以进行图书信息及阅读信息的管理。具体实现功能如下&#xff1a; 1&#xff09;安全管理&#xff1a;提供用户登录&#xff0c;修改密码…