遥感数据处理系列

一些项目及科研中遇到的小需求,一方面记录自己的学习历程,另一方面帮助大家学习。

ArcPy批量计算栅格数据平均值GLDAS数据下载及处理(NC转TIF)ArcGIS批量裁剪栅格数据ArcPy批量栅格重采样ArcPy批量裁剪栅格数据

IDL多进程批处理遥感数据ArcPy批量拼接栅格数据



文章目录

  • 遥感数据处理系列
  • 前言
  • 一、栅格数据平均值
  • 1. 原理简介
  • 2. 代码
  • 总结
  • 后记



前言


在使用ArcGIS的开发包函数进行栅格数据平均值计算时发现,在结果影像出现了好多的异常值?经过查看发现是因为ArcGIS算法的问题,所以,用IDL写了下自己的栅格平均值计算逻辑。


一、栅格数据平均值

1. 原理简介

使用ArcGIS进行栅格数据平均值计算时,出现异常值的原因如下图所示:

Python栅格计算器参数 栅格计算器求均值_遥感


那么问题来了:如果每个像元都有一个NoData出现过,那岂不是OutRas里面全部都是NoData了?

我脑海里的栅格数据平均值:对于N景影像,在(a,b)坐标处有 t 景影像存在有效像元,那么其平均值应该是多景影像在(a,b)坐标处DN值的累加 除以 t

2. 代码

文件组织架构:


inws 
    
      MYD09.2011.001.tif 
    
      MYD09.2011.002.tif 
    
      ... 
    
      outs 
    
     输出到

输入:
一个含有若干栅格数据的文件夹 inws(本例为“.tif”格式)

代码实例:

pro Average_Batch

  ;计算输入文件夹内的 所有栅格数据的 平均值
  ;算整个文件夹的

  compile_opt strictarr
  COMPILE_OPT idl2

  envi, /restore_base_save_files
  envi_batch_init, log_file='batch.txt',/NO_STATUS_WINDOW

  dir0='F:\LE-daily-LMB\2017'   ; 输入路径

  out_dir='F:\LMB\LE-year'  ; 输出路径

  files=file_search(dir0,'*.tif')

  ; 读取文件信息。先获取个行列数
  ENVI_OPEN_FILE, files[0], r_fid=fid,  /no_realize
  ENVI_FILE_QUERY, fid,  nl=nl, ns=ns,dims=dims,nb=nb
  mapinfo=envi_get_map_info(fid=fid)
  file=ENVI_GET_DATA(fid=fid,dims=dims,pos=0)
  low_row=N_elements(file[0,*]);获取行数
  low_col=N_elements(file[*,0]);获取列数

  Sum = make_array(low_col,low_row,value=0.0);存有效像元的累加值
  count = make_array(low_col,low_row,value=0.0);存有效像元的出现次数
  Average = make_array(low_col,low_row,value=0.0);存平均值

  ; 遍历文件夹内的所有栅格数据
  for i=0,n_elements(files)-1 do begin
    ENVI_OPEN_FILE, files[i], r_fid=fid,  /no_realize
    ENVI_FILE_QUERY, fid,  nl=nl, ns=ns,dims=dims,nb=nb
    file=ENVI_GET_DATA(fid=fid,dims=dims,pos=0)

    ; 单景影像的逻辑
    for a=0,low_col-1 do begin;获取列数
      for b=0,low_row-1 do begin;获取行数,应该是先列后行

        if  file[a,b] GT  0 then begin    ;GE 大于等于运算符,左边大于右边则为真;GT 大于运算符;LE:小于等于运算符;LT:小于运算符
          Sum[a,b] = Sum[a,b] + file[a,b]   ; 有效值累加,每个像元的
          count[a,b] = count[a,b] + 1 ;累加次数计数器
        endif

      endfor
    endfor

  endfor
  
  Average = Sum / count

  outfile8 = out_dir + '\' + strmid(file_basename(files[0]),0,25) + '.Average.tif'    ;16  25
  ENVI_WRITE_ENVI_FILE , Average , r_fid=fid , map_info=mapinfo , out_name=outfile8

end

上例可实现对输入路径文件夹下的所有栅格数据的平均栅格计算。

总结

ArcPy牛皮!毕业万岁!中期快乐!
批量计算平均栅格数据,接下来要继续探索下IDL语言,虽然它的语法有些…,同时,学习下python + GDAL,这一大杀器