遥感指数生成(python

网友投稿 627 2022-11-23

遥感指数生成(python)

遥感指数生成(python)

文章目录

​​相关代码​​​​2. 生成NDVI​​​​3. 生成NDWI​​

相关代码

import os, sys, timeimport numpy as npfrom osgeo import ogrfrom osgeo import gdalfrom osgeo import gdal_array as gadef read_img(filename): dataset=gdal.Open(filename) im_width = dataset.RasterXSize im_height = dataset.RasterYSize im_geotrans = dataset.GetGeoTransform() im_proj = dataset.GetProjection() im_data = dataset.ReadAsArray(0,0,im_width,im_height) del dataset return im_proj,im_geotrans,im_width, im_height,im_datadef ndvi(im_geotrans,im_proj, im_redBand, im_nirBand, im_width, im_height, outfile): driver = gdal.GetDriverByName("GTiff") dataset = driver.Create(outfile, im_width, im_height, 1, gdal.GDT_Int16) dataset.SetGeoTransform(im_geotrans) dataset.SetProjection(im_proj) ga.numpy.seterr(all='ignore') ndvi = ((im_nirBand - im_redBand) * 1.0)/((im_nirBand + im_redBand) * 1.0) ndvi = ndvi.astype(np.float32) img_min = 0 img_max = 255 ndvi = stretch_n(ndvi, img_min, img_max) ndvi = ndvi.astype(np.uint8) dataset.GetRasterBand(1).WriteArray(ndvi) dataset.GetRasterBand(1).SetNoDataValue(0) return ndvi

2. 生成NDVI

if __name__ == "__main__": import glob imgList = ['new_area.tif'] for input in imgList: imgName = os.path.split(input)[-1].split('.')[0] im_proj, im_geotrans, im_width, im_height, im_data = read_img(input) data = gdal.Open(input) r = data.GetRasterBand(1).ReadAsArray() g = data.GetRasterBand(2).ReadAsArray() ir = data.GetRasterBand(4).ReadAsArray() ndvi_ = ndvi(im_geotrans, im_proj, r, ir, im_width, im_height, outfile=f'{imgName}_ndvi.tif')

3. 生成NDWI

if __name__ == "__main__": import glob imgList = ['new_area.tif'] for input in imgList: imgName = os.path.split(input)[-1].split('.')[0] im_proj, im_geotrans, im_width, im_height, im_data = read_img(input) data = gdal.Open(input) r = data.GetRasterBand(1).ReadAsArray() g = data.GetRasterBand(2).ReadAsArray() ir = data.GetRasterBand(4).ReadAsArray() ndwi_ = ndvi(im_geotrans, im_proj, g, ir, im_width, im_height, outfile=f'{imgName}_ndwi.tif')

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:遥感影像32位转8位(python)
下一篇:基于大幅遥感图像的目标检测划框预测过程(水平框)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~