ggpubr-專為學術繪圖而生(二)

作者:白介素2
相關閱讀:
ggpubr-專為學術繪圖而生(二)
ggstatsplot-專為學術繪圖而生(一)
R語言生存分析-02-ggforest
R語言生存分析-01
生存曲線
R語言GEO數(shù)據(jù)挖掘01-數(shù)據(jù)下載及提取表達矩陣
R語言GEO數(shù)據(jù)挖掘02-解決GEO數(shù)據(jù)中的多個探針對應一個基因
R語言GEO數(shù)據(jù)挖掘03-limma分析差異基因
R語言GEO數(shù)據(jù)挖掘04-功能富集分析

如果沒有時間精力學習代碼傻昙,推薦了解:零代碼數(shù)據(jù)挖掘課程

ggpubr-專為學術繪圖而生(二)

由Hadley Wickham創(chuàng)建的ggplot2非常好用的可視化包了崔泵,但是由ggplot2繪制的圖形通常不能直接用于發(fā)表蚓庭,還需要經(jīng)過一定程度的編輯,對于不少那么會編程的研究人員而言可能并不是特別友好膀懈。
因此顿锰,ggpubr應運而生,它提供了簡單易用的函數(shù)启搂,用于繪制定制的高質(zhì)量圖硼控,可以直接用于發(fā)表。
以下演示官方教程:

Sys.setlocale('LC_ALL','C')
library(ggpubr)
set.seed(1234)
wdata = data.frame(
   sex = factor(rep(c("F", "M"), each=200)),
   weight = c(rnorm(200, 55), rnorm(200, 58)))
dim(wdata)
head(wdata, 4)
#>   sex   weight
#> 1   F 53.79293
#> 2   F 55.27743
#> 3   F 56.08444
#> 4   F 52.65430

density plot-ggdensity

color設置輪廓顏色,fill填充顏色設置
palette 顏色設置

ggdensity(wdata, x = "weight",
   add = "mean", rug = TRUE,
   color = "sex",fill = "sex",
   palette = c("#00AFBB", "#E7B800"))
image.png

頻數(shù)分布圖

gghistogram

gghistogram(wdata, x = "weight",
   add = "mean", rug = TRUE,
   color = "sex", fill = "sex",
   palette = c("#00AFBB", "#E7B800"))
image.png

箱線圖與小提琴圖

# Load data
data("ToothGrowth")
df <- ToothGrowth
head(df, 4)
#>    len supp dose
#> 1  4.2   VC  0.5
#> 2 11.5   VC  0.5
#> 3  7.3   VC  0.5
#> 4  5.8   VC  0.5
p <- ggboxplot(df, x = "dose", y = "len",
                color = "dose", palette =c("#00AFBB", "#E7B800", "#FC4E07"),
                add = "jitter", shape = "dose")
p
image.png

my_comparisons:指定比較方式和Pvaue
stat_compare_means增加global pvalue

# Add p-values comparing groups
 # Specify the comparisons you want
my_comparisons <- list( c("0.5", "1"), c("1", "2"), c("0.5", "2") )
p + stat_compare_means(comparisons = my_comparisons)+ # Add pairwise comparisons p-value
  stat_compare_means(label.y = 50)            
image.png

含有boxplot的小提琴圖-ggviolin

label="p.signif"以星號展示pvalue
add="boxplot"在小提琴中增加箱線圖

ggviolin(df, x = "dose", y = "len", fill = "dose",
         palette = c("#00AFBB", "#E7B800", "#FC4E07"),
         add = "boxplot", add.params = list(fill = "white"))+
  stat_compare_means(comparisons = my_comparisons, label = "p.signif")+ # Add significance levels
  stat_compare_means(label.y = 50)        
image.png

柱狀圖

data("mtcars")
dfm <- mtcars
# 將cyl轉(zhuǎn)換為因子
dfm$cyl <- as.factor(dfm$cyl)
# Add the name colums
dfm$name <- rownames(dfm)
# Inspect the data
head(dfm[, c("name", "wt", "mpg", "cyl")])
#>                                name    wt  mpg cyl
#> Mazda RX4                 Mazda RX4 2.620 21.0   6
#> Mazda RX4 Wag         Mazda RX4 Wag 2.875 21.0   6
#> Datsun 710               Datsun 710 2.320 22.8   4
#> Hornet 4 Drive       Hornet 4 Drive 3.215 21.4   6
#> Hornet Sportabout Hornet Sportabout 3.440 18.7   8
#> Valiant                     Valiant 3.460 18.1   6

對barplot排序

按顏色填充時,并不會按分組來排序狐血,只會進行整體排序

ggbarplot(dfm, x = "name", y = "mpg",
          fill = "cyl",               # 按cyl填充顏色
          color = "white",            # 柱子的邊界顏色設置
          palette = "jco",            # jco雜志的顏色板
          sort.val = "desc",          # 降序排列
          sort.by.groups = FALSE,     # 不按分組排序
          x.text.angle = 90           # x軸字體旋轉(zhuǎn)90度
          )
image.png

按分組降序排列

sort.by.groups=TRUE 參數(shù)
這個比較適用于繪制GO的富集情況

ggbarplot(dfm, x = "name", y = "mpg",
          fill = "cyl",               # change fill color by cyl
          color = "white",            # Set bar border colors to white
          palette = "jco",            # jco journal color palett. see ?ggpar
          sort.val = "asc",           # Sort the value in dscending order
          sort.by.groups = TRUE,      # 按分組內(nèi)進行排序
          x.text.angle = 90           # Rotate vertically x axis texts
          )
image.png

偏差圖-deviation plot

deviation plot會展示定量數(shù)值偏差一個參考值的淀歇,相當于對數(shù)據(jù)進行中心化的處理
以下繪制mpg的z-score,這個過程比較簡單匈织,換上自己的數(shù)據(jù)計算即可


#計算mpg的zscore
dfm$mpg_z <- (dfm$mpg -mean(dfm$mpg))/sd(dfm$mpg)
#按zscore分為high, low兩組
dfm$mpg_grp <- factor(ifelse(dfm$mpg_z < 0, "low", "high"), 
                     levels = c("low", "high"))
# Inspect the data
head(dfm[, c("name", "wt", "mpg", "mpg_z", "mpg_grp", "cyl")])
#>                                name    wt  mpg      mpg_z mpg_grp cyl
#> Mazda RX4                 Mazda RX4 2.620 21.0  0.1508848    high   6
#> Mazda RX4 Wag         Mazda RX4 Wag 2.875 21.0  0.1508848    high   6
#> Datsun 710               Datsun 710 2.320 22.8  0.4495434    high   4
#> Hornet 4 Drive       Hornet 4 Drive 3.215 21.4  0.2172534    high   6
#> Hornet Sportabout Hornet Sportabout 3.440 18.7 -0.2307345     low   8
#> Valiant                     Valiant 3.460 18.1 -0.3302874     low   6

創(chuàng)建一個根據(jù)mpg的值排序的barplot

ggbarplot(dfm, x = "name", y = "mpg_z",
          fill = "mpg_grp",           # 根據(jù)mpg值的高低填充
          color = "white",            # Set bar border colors to white
          palette = "jco",            # jco journal color palett. see ?ggpar
          sort.val = "asc",           # 升序排列
          sort.by.groups = FALSE,     # Don't sort inside each group
          x.text.angle = 90,          # Rotate vertically x axis texts
          ylab = "MPG z-score",       # y軸名稱
          xlab = FALSE,               #x軸名稱
          legend.title = "MPG Group"  # 圖注名稱
          )
image.png

旋轉(zhuǎn)圖形

ggtheme參數(shù)設置主題
rotate=TRUE參數(shù)設置圖形旋轉(zhuǎn)

ggbarplot(dfm, x = "name", y = "mpg_z",
          fill = "mpg_grp",           # change fill color by mpg_level
          color = "white",            # Set bar border colors to white
          palette = "jco",            # jco journal color palett. see ?ggpar
          sort.val = "desc",          # Sort the value in descending order
          sort.by.groups = FALSE,     # Don't sort inside each group
          x.text.angle = 90,          # Rotate vertically x axis texts
          ylab = "MPG z-score",
          legend.title = "MPG Group",
          rotate = TRUE,
          ggtheme = theme_minimal()
          )
image.png

點圖

Lollipop chart-棒棒糖圖

棒棒糖圖比較適用于有大量值需要可視化的情況
ggdotchart函數(shù)
add="segments"增加從0到點的棒子

ggdotchart(dfm, x = "name", y = "mpg",
           color = "cyl",                                # Color by groups
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # Custom color palette
           sorting = "ascending",                        # 升序排列
           add = "segments",                             # 增加棒棒
           ggtheme = theme_pubr()                        # ggplot2 theme
           )
image.png

1.降序 sorting = “descending”.
2.垂直旋轉(zhuǎn) rotate = TRUE.
3.按分組排序 group = “cyl”.
4.改變點的大小浪默,dot.soze=6.

  1. mpg值作為標簽 label = “mpg” or label = round(dfm$mpg).
ggdotchart(dfm, x = "name", y = "mpg",
           color = "cyl",                                # 按分組改變顏色
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # 顏色
           sorting = "descending",                       # 降序
           add = "segments",                             # 增加棒棒
           rotate = TRUE,                                # 旋轉(zhuǎn)
           group = "cyl",                                # 按分組排序
           dot.size = 6,                                 # 調(diào)整點大小
           label = round(dfm$mpg),                      # 增加值作為標簽 
           font.label = list(color = "white", size = 9, 
                             vjust = 0.5),               # 調(diào)整標簽
           ggtheme = theme_pubr()                        # 主題
           )
image.png

Deviation graph

Use y = “mpg_z” 計算zscore
改變棒棒的顏色和大小 add.params = list(color = “l(fā)ightgray”, size = 2)

ggdotchart(dfm, x = "name", y = "mpg_z",
           color = "cyl",                                # Color by groups
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # Custom color palette
           sorting = "descending",                       # Sort value in descending order
           add = "segments",                             # Add segments from y = 0 to dots
           add.params = list(color = "lightgray", size = 2), # Change segment color and size
           group = "cyl",                                # Order by groups
           dot.size = 6,                                 # Large dot size
           label = round(dfm$mpg_z,1),                        # Add mpg values as dot labels
           font.label = list(color = "white", size = 9, 
                             vjust = 0.5),               # Adjust label parameters
           ggtheme = theme_pubr()                        # ggplot2 theme
           )+
  geom_hline(yintercept = 0, linetype = 2, color = "lightgray")
image.png

Cleveland 點圖

文字顏色也按分組調(diào)整 y.text.col=TRUE

ggdotchart(dfm, x = "name", y = "mpg",
           color = "cyl",                                # Color by groups
           palette = c("#00AFBB", "#E7B800", "#FC4E07"), # Custom color palette
           sorting = "descending",                       # Sort value in descending order
           rotate = TRUE,                                # Rotate vertically
           dot.size = 2,                                 # Large dot size
           y.text.col = TRUE,                            # y軸文字的顏色 
           ggtheme = theme_pubr()                        # ggplot2 theme
           )+
  theme_cleveland()             
image.png

用簡單的函數(shù)即可對圖形進行高度的定制,熟悉這些參數(shù)缀匕,然后調(diào)整自己的數(shù)據(jù)格式纳决,繪制各種高級的圖,R真是包羅萬象
參考資料

本期內(nèi)容就到這里乡小,我是白介素2阔加,下期再見

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市满钟,隨后出現(xiàn)的幾起案子胜榔,更是在濱河造成了極大的恐慌,老刑警劉巖湃番,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夭织,死亡現(xiàn)場離奇詭異,居然都是意外死亡吠撮,警方通過查閱死者的電腦和手機尊惰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人弄屡,你說我怎么就攤上這事题禀。” “怎么了膀捷?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵迈嘹,是天一觀的道長。 經(jīng)常有香客問我担孔,道長江锨,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任糕篇,我火速辦了婚禮,結果婚禮上酌心,老公的妹妹穿的比我還像新娘拌消。我一直安慰自己,他們只是感情好安券,可當我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布墩崩。 她就那樣靜靜地躺著,像睡著了一般侯勉。 火紅的嫁衣襯著肌膚如雪鹦筹。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天址貌,我揣著相機與錄音铐拐,去河邊找鬼。 笑死练对,一個胖子當著我的面吹牛遍蟋,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播螟凭,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼虚青,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了螺男?” 一聲冷哼從身側響起棒厘,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎下隧,沒想到半個月后奢人,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡汪拥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年达传,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡宪赶,死狀恐怖宗弯,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情搂妻,我是刑警寧澤蒙保,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站欲主,受9級特大地震影響邓厕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜扁瓢,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一详恼、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧引几,春花似錦昧互、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至楣铁,卻和暖如春玖雁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背盖腕。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工赫冬, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人赊堪。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓面殖,卻偏偏與公主長得像,于是被迫代替她去往敵國和親哭廉。 傳聞我的和親對象是個殘疾皇子脊僚,可洞房花燭夜當晚...
    茶點故事閱讀 45,675評論 2 359