R-如何在NC時(shí)間堆疊數(shù)據(jù)集中根據(jù)坐標(biāo)提取數(shù)據(jù)并展示其趨勢(shì)

目錄

  • 0.問(wèn)題導(dǎo)入
  • 1.示例數(shù)據(jù)
  • 2.導(dǎo)入NC數(shù)據(jù)與興趣點(diǎn)坐標(biāo)
  • 3.根據(jù)興趣點(diǎn)左邊范圍裁剪shp文件
  • 4.將興趣點(diǎn)轉(zhuǎn)化為SpatialPoints
  • 5.根據(jù)興趣點(diǎn)坐標(biāo)信息提取對(duì)應(yīng)位置sc-PDSI指標(biāo)時(shí)間序列
  • 6.sc-PDSI序列矩陣NA值檢查
  • 7.計(jì)算興趣點(diǎn)對(duì)應(yīng)序列的趨勢(shì)值
  • 8.空間可視化
  • 9.空間可視化優(yōu)化
  • 10.本文所用到的軟件包
  • 11.本文總結(jié)
  • 12.致謝

0. 問(wèn)題導(dǎo)入

當(dāng)我們拿到一個(gè)高維的NC數(shù)據(jù)的時(shí)候谣妻,可能有時(shí)候不需要對(duì)所有柵格值進(jìn)行計(jì)算,只是單純地想根據(jù)興趣點(diǎn)提取對(duì)應(yīng)位置的指標(biāo)時(shí)間序列,那么我們應(yīng)該怎樣處理呢僚匆?本篇文章給出解決方案。


同之前一樣韭山,本文所用軟件包附于文末


1. 示例數(shù)據(jù)

本篇所采用的NC示例數(shù)據(jù)與上一篇" R-ggplot2-說(shuō)說(shuō)繪圖中顏色的這點(diǎn)事-應(yīng)該是比較全的總結(jié)篇 "的示例數(shù)據(jù)一致箫章,同樣采用的是“全球sc-PDSI(干旱指數(shù))1901-2018年的月尺度數(shù)據(jù)”。數(shù)據(jù)信息如下:

  • 時(shí)間分辨率:月
  • 空間分辨率:0.5°×0.5°
  • 數(shù)據(jù)維度:360(行數(shù))×720(列數(shù))×1416(月份個(gè)數(shù)系谐,也稱(chēng)數(shù)據(jù)深度),儲(chǔ)存方式如圖1讨跟。

下載鏈接如下:
點(diǎn)我下載NC文件

圖1 NC文件數(shù)據(jù)儲(chǔ)存格式-吃貨解說(shuō)版

本篇采用示例坐標(biāo)數(shù)據(jù)為中國(guó)區(qū)域內(nèi)隨機(jī)生成的坐標(biāo),下載方式如下:
點(diǎn)我下載興趣點(diǎn)數(shù)據(jù)

本篇采用的世界大洲級(jí)地圖(shp文件)下載方式如下:
點(diǎn)我下載world.shp 文件

2. 導(dǎo)入NC數(shù)據(jù)與興趣點(diǎn)坐標(biāo)

input_nc = 'L:\\JianShu\\2019-12-07\\data\\scpdsi_1901_2018.nc'
nc_stack = stack(input_nc)

input_loc = 'L:\\JianShu\\2019-12-08\\data\\loc.csv'
loc = read.csv(input_loc,header = T)
loc = loc[,-1]

3. 根據(jù)興趣點(diǎn)左邊范圍裁剪shp文件

ex_crop = extent(min(loc[,1])-2,max(loc[,1])+2,min(loc[,2])-2,max(loc[,2])+2)
world = shapefile('L:\\JianShu\\2019-12-08\\data\\shp\\world_continent2.shp')
world_crop = crop(world,ex_crop)

4. 將興趣點(diǎn)轉(zhuǎn)化為SpatialPoints

sp = SpatialPoints(loc)

5. 根據(jù)興趣點(diǎn)坐標(biāo)信息提取對(duì)應(yīng)位置sc-PDSI指標(biāo)時(shí)間序列

df = extract(nc_stack,sp)
df = t(df)
print(ncol(df)) #列數(shù)對(duì)應(yīng)為點(diǎn)的個(gè)數(shù)

6. sc-PDSI序列矩陣NA值檢查

col_na = which(is.na(apply(df,2,mean)))
if(length(col_na) == 0){
    df_na_re = df
    loc_na_re = loc
}else{
    df_na_re = df[,-col_na]
    loc_na_re  = loc[,-col_na]
}

7. 計(jì)算興趣點(diǎn)對(duì)應(yīng)序列的趨勢(shì)值

趨勢(shì)值的計(jì)算我們采用的是改進(jìn)后的Mann-Kendall 趨勢(shì)分析方式, 詳細(xì)介紹可參照R-Modified Mann-Kendall 趨勢(shì)分析(改進(jìn)后MK趨勢(shì)分析)這篇博文, 里邊文末有附本文所用的mmkTrend函數(shù), 記住一定將其保存為R文件,然后在Rstudio中source一下,才能用哈~就像這樣:

 source('L:/JianShu/2019-12-08/mmkTrend.R')
mmk_cal<-function(x){
  temp_mk = mmkTrend(x)$Zc
  return(temp_mk)
}
mmk_box = apply(df_na_re,2,mmk_cal)

8. 空間可視化

df = data.frame(
long = loc_na_re[,1],
lat = loc_na_re[,2],
MMK = as.numeric(mmk_box)
)
df_m = melt(df,c('long','lat'))

df_m$cuts = cut(df_m$value,
breaks = seq(round((min(df_m$value)-1)),round((max(df_m$value)+1)),1))

df_m$size = df_m$cuts

world_crop_df = fortify(world_crop)

p = ggplot()+
  geom_polygon(data = world_crop_df,aes(x = long,y = lat, group = group),
               fill = 'transparent',color = 'black',size = 0.5)+
  geom_hline(aes(yintercept = 50),linetype = 'dashed',alpha = 0.5,lwd = 0.5,color = 'black')+
  geom_hline(aes(yintercept = 40),linetype = 'dashed',alpha = 0.5,lwd = 0.5,color = 'black')+
  geom_hline(aes(yintercept = 30),linetype = 'dashed',alpha = 0.5,lwd = 0.5,color = 'black')+
  geom_hline(aes(yintercept = 20),linetype = 'dashed',alpha = 0.5,lwd = 0.5,color = 'black')+
  geom_vline(aes(xintercept = 80),linetype = 'dashed',alpha = 0.5,lwd = 0.5,color = 'black')+
  geom_vline(aes(xintercept = 100),linetype = 'dashed',alpha = 0.5,lwd = 0.5,color = 'black')+
  geom_vline(aes(xintercept = 120),linetype = 'dashed',alpha = 0.5,lwd = 0.5,color = 'black')+
  
  geom_point(data = df_m,aes(x = long,y = lat, color = cuts,size= size))+
  theme(panel.background = element_rect(fill = 'transparent',color = 'black'),
        axis.text = element_text(face='bold',colour='black',size=fontsize,hjust=.5),
        axis.title = element_text(face='bold',colour='black',size=fontsize,hjust=.5),
        legend.position=c('bottom'),
        legend.direction = c('horizontal'))+
  scale_color_brewer(palette = 'Spectral')+
  scale_size_manual(values = 1:10)+
  coord_fixed(1.3)+
  
  guides(fill=guide_legend(nrow=2))+
  xlab('Longitude')+
  ylab('Latitude')


圖2 興趣點(diǎn)1901-2018年sc-PDSI MMK趨勢(shì)空間分布圖

但是纪他,大家有沒(méi)有覺(jué)得很別扭


嗯嗯, 是的A澜场2杼弧!又是一個(gè)逼死強(qiáng)迫癥患者的技術(shù)BUG凉馆,點(diǎn)大小的分級(jí)與顏色的分級(jí)沒(méi)有重合P皆ⅰM鲎省!是不是很難受向叉!

來(lái), 下邊我們一起來(lái)解決這個(gè)BUG!

9. 空間可視化優(yōu)化

首先, 問(wèn)題診斷. 出現(xiàn)以上問(wèn)題的原因呢是在這一句:

 geom_point(
data = df_m,
aes(x = long,y = lat, 
color = cuts,
size= size))+

很多時(shí)候,我們?yōu)榱死L圖理解的方便,會(huì)將color和size的分組在繪圖的data.frame中分開(kāi),盡管他們是一樣的锥腻。

head(df_m)
    long   lat variable      value    cuts    size
1 122.52 52.97      MMK  1.8868017   (1,2]   (1,2]
2 124.48 47.80      MMK  0.9688879   (0,1]   (0,1]
3 125.25 45.70      MMK -0.4857201  (-1,0]  (-1,0]
4  84.67 44.43      MMK  1.1515050   (1,2]   (1,2]
5  75.25 39.72      MMK  2.2346846   (2,3]   (2,3]
6 101.07 41.95      MMK -2.3940473 (-3,-2] (-3,-2]

但這正是導(dǎo)致問(wèn)題的癥結(jié)所在, 為了將兩組圖例合并在一起,我們應(yīng)該將出問(wèn)題的這一句繪圖函數(shù)更換成下式:

 geom_point(
data = df_m,
aes(x = long,y = lat, 
color = cuts,
size= cuts))+

然后,繪圖結(jié)果就如圖3所示, 將size與color的圖例合并為一個(gè),這樣看起來(lái)就舒服多了~~~


圖3 優(yōu)化后的圖件

10. 本文所用到的軟件包(沒(méi)有的記得用install.packages('package name')進(jìn)行安裝)

library(raster)
library(reshape2)
library(sp)
library(RColorBrewer)
library(ggplot2)

11. 總結(jié)

回顧一下, 本篇文章主要解決如下幾個(gè)問(wèn)題:

  1. 如何從NC時(shí)間堆疊數(shù)據(jù)集中根據(jù)坐標(biāo)提取數(shù)據(jù)?
  2. 如何計(jì)算各個(gè)興趣點(diǎn)的MMK趨勢(shì)值?
  3. 如何根據(jù)各點(diǎn)MMK趨勢(shì)值的大小繪制空間圖并體現(xiàn)其差異性母谎?
  4. 當(dāng)點(diǎn)的大小與顏色的圖例分開(kāi)時(shí)瘦黑,如何將其合并在一起?

12. 致謝

大家如果覺(jué)得有用奇唤,還麻煩大家關(guān)注點(diǎn)贊幸斥,也可以擴(kuò)散到朋友圈,幫助到繪圖中同樣陷入顏色選擇困難癥的TA

大家如果在使用本文代碼的過(guò)程有遇到問(wèn)題的咬扇,可以留言評(píng)論甲葬,也可以私信我哈~~

我的聯(lián)系方式
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市懈贺,隨后出現(xiàn)的幾起案子演顾,更是在濱河造成了極大的恐慌,老刑警劉巖隅居,帶你破解...
    沈念sama閱讀 217,542評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件钠至,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡胎源,警方通過(guò)查閱死者的電腦和手機(jī)棉钧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)涕蚤,“玉大人宪卿,你說(shuō)我怎么就攤上這事⊥蛘ぃ” “怎么了佑钾?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,912評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)烦粒。 經(jīng)常有香客問(wèn)我休溶,道長(zhǎng),這世上最難降的妖魔是什么扰她? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,449評(píng)論 1 293
  • 正文 為了忘掉前任兽掰,我火速辦了婚禮,結(jié)果婚禮上徒役,老公的妹妹穿的比我還像新娘孽尽。我一直安慰自己,他們只是感情好忧勿,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,500評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布杉女。 她就那樣靜靜地躺著瞻讽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪熏挎。 梳的紋絲不亂的頭發(fā)上速勇,一...
    開(kāi)封第一講書(shū)人閱讀 51,370評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音婆瓜,去河邊找鬼。 笑死贡羔,一個(gè)胖子當(dāng)著我的面吹牛廉白,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播乖寒,決...
    沈念sama閱讀 40,193評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼猴蹂,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了楣嘁?” 一聲冷哼從身側(cè)響起磅轻,我...
    開(kāi)封第一講書(shū)人閱讀 39,074評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎逐虚,沒(méi)想到半個(gè)月后聋溜,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,505評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡叭爱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,722評(píng)論 3 335
  • 正文 我和宋清朗相戀三年撮躁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片买雾。...
    茶點(diǎn)故事閱讀 39,841評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡把曼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出漓穿,到底是詐尸還是另有隱情嗤军,我是刑警寧澤,帶...
    沈念sama閱讀 35,569評(píng)論 5 345
  • 正文 年R本政府宣布晃危,位于F島的核電站叙赚,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏僚饭。R本人自食惡果不足惜纠俭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,168評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望浪慌。 院中可真熱鬧冤荆,春花似錦、人聲如沸权纤。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,783評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至外邓,卻和暖如春撤蚊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背损话。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,918評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工侦啸, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人丧枪。 一個(gè)月前我還...
    沈念sama閱讀 47,962評(píng)論 2 370
  • 正文 我出身青樓光涂,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親拧烦。 傳聞我的和親對(duì)象是個(gè)殘疾皇子忘闻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,781評(píng)論 2 354