空间密度计算

阅读 85

2022-03-12

        一些常用的空间密度统计方法。主要是cartopy新更新,而matplotlib旧有的hexbin图统计法;matplotlib提供的柱状图统计法;geoplot封装seaborn的kdeplot空间密度估计法。

一、hexbin图

这是一种matplotlib本身携带,但早期cartopy库包不能调用的命令。这个命令会将空间分割为合适大小的六边形,并统计落在该六边形的点的数量,以这个数量作为颜色映射的依据,为每个六边形填上颜色。

在最新的cartopy库包中,已经能够使用这个命令了。传入的值类似散点图命令。

df=pd.read_excel(filename)

lon=df['经度']

lat=df['纬度']

ah=ax.hexbin(lon,lat,gridsize=9,cmap='Blues')

ax.scatter(lon,lat,c='k')

cb=fig.colorbar(ah,ax=ax,pad=0.01)

二、柱状图统计

该命令仅能在PlateCarree投影下使用,通过直方统计出在经向和纬向上,数据的分布样式。可直接查阅matplotlib官网实例Scatter plot with histograms。

df=pd.read_excel(filename)

lon=df['经度']

lat=df['纬度']

data=df['rain']

def scatter_hist(x, y, ax, ax_histx, ax_histy):   

    ax_histx.tick_params(axis="x", labelbottom=False)   

    ax_histy.tick_params(axis="y", labelleft=False)   

    ax.scatter(x, y)   

    binwidth = 0.05#确定统计间隔,由于地图一度就是100km,所以一般可以取小一点   

    xymax = max(np.max(np.abs(x)), np.max(np.abs(y)))   

    lim = (int(xymax/binwidth) + 1) * binwidth   

    bins = np.arange(-lim, lim + binwidth, binwidth)   

    ax_histx.hist(x, bins=bins)   

    ax_histy.hist(y, bins=bins, orientation='horizontal')

left,width=0.1,0.65

bottom,height=0.1,0.65

spacing=0.005

rect_scatter=[left, bottom, width, height]

rect_histx=[left, bottom + height + spacing, width, 0.2]

rect_histy=[left + width + spacing, bottom, 0.2, height]

fig=plt.figure(figsize=(8, 8),dpi=200)

ax=fig.add_axes(rect_scatter)

ax.set_xlim(108.3,109.35)

ax.set_ylim(29.7,30.7)

ax.add_patch(patch)

ax_histx=fig.add_axes(rect_histx, sharex=ax)

ax_histy=fig.add_axes(rect_histy, sharey=ax)

scatter_hist(lon,lat,ax,ax_histx,ax_histy)

三、geoplot封装

这个命令其实是geoplot将seaborn里的KDEPLOT命令封装后的高级命令,使得仅能在sns里使用的二维密度估计能够使用到地图空间里。这时,任意投影都可以使用这个命令。

import geopandas as gpd

import geoplot as gplt

import geoplot.crs as gcrs

proj=gcrs.PlateCarree()

df=pd.read_excel(filename)

lon=df['经度']

lat=df['纬度']

geo=gpd.read_file(shp_path)

df_geo=gpd.GeoDataFrame(data,geometry=gpd.points_from_xy(lon,lat),crs='EPSG:4326')

fig=plt.figure(figsize=(6,6),dpi=200)

ax=plt.axes([0,0,1,0.78],projection=proj)

gplt.kdeplot(df_geo,   

           cmap='Reds',   

           projection=proj,   

           shade=True,

           shade_lowest=True,   

           clip=geo.geometry,   

           ax=ax,gridsize=100)

gplt.polyplot(geo.geometry,zorder=1,ax=ax)

三种空间密度都可以看出一定的规律,即中部地区密度最高。

精彩评论(0)

0 0 举报