是否可以在MODIS的NETCDF文件中插入savgol过滤器并在python中绘制空间平滑图?

这是我的示例代码

import matplotlib.pyplot as plt
import xarray as xr
import pandas as pd
import numpy as np

# open Netcdf file
ds = xr.open_dataset('MOD16A2.006_500m_aid20001.nc')

# show information in xarray dataset
ds

<xarray.Dataset>
Dimensions:     (lat: 2567, lon: 2739, time: 45)
Coordinates:
  * time        (time) object 2001-01-01 00:00:00 ... 2001-12-27 00:00:00
  * lat         (lat) float64 -7.348 -7.352 -7.356 ... -18.03 -18.04 -18.04
  * lon         (lon) float64 -61.64 -61.63 -61.63 ... -50.24 -50.23 -50.23
Data variables:
    crs         int8 ...
    ET_500m     (time, lat, lon) float32 ...
    ET_QC_500m  (time, lat, lon) float32 ...
Attributes:
    title:        MOD16A2.006 for aid0001
    Conventions:  CF-1.6
    institution:  Land Processes Distributed Active Archive Center (LP DAAC)
    source:       AppEEARS v2.36
    references:   See README.txt
    history:      See README.txt

# Get Variables
lat = ds.lat
lon = ds.lon
time = ds.time
data = ds.ET_500m[0,:,:]
units = ds.ET_500m[:,:,:].units


# Plot image
data.plot.imshow(cmap='viridis_r', figsize=(10,8))


由于云量会影响像素质量,因此我需要应用空间平滑方法来提高从MODIS导出的数据质量

我认为savgol过滤器适合这种情况,但我不知道如何在空间上使用它。我可能有另一种平滑方法,但我不知道。

最佳答案

是的,有可能,请下次提供工作代码示例。我建议在python中使用netCDF4或xarray,获取数据,并使用2d Savgol过滤器,如以下文档所示:

https://scipy.github.io/old-wiki/pages/Cookbook/SavitzkyGolay

这将执行平滑操作,然后将数据导出到netCDF文件中,您应该一切顺利。

另外,您还可以将xarray与cartopy结合使用以绘制数据:

http://xarray.pydata.org/en/stable/plotting.html

关于python - 在Python的Modis NETCDF中绘制平滑Savgol滤波器,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/60305861/

10-16 18:07