Многосюжетное изображение ggplot и Gridextra

Я пытаюсь создать изображение трех графиков ggplot друг над другом с помощью пакета gridExtra.

Я использую следующий код:

require(ggplot2)
library(gridExtra)
library(scales)
library(ggpubr)
library(tidyr)
library(reshape)
library(dplyr)

## GRAPHS

# yearly funding required
yearly1 <- ggplot(yearly, aes(x=year, y=Total_US_required/1000000)) + 
  ggtitle("Total Funding Required") + 
  geom_line(color="darkblue") + 
  labs(y="In Million USD", x="") + xlim(2006,2017)

# yearly funding received
yearly2 <- ggplot(yearly, aes(x=year, y=Total_US_received/1000000)) + 
  ggtitle("Total Funding Received") + 
  geom_line(color="darkblue") + 
  labs(y="", x="") + xlim(2006,2017)

# Yealy funding CERF
yearly3 <- ggplot(yearly, aes(x=year, y=Total_US_received_from.CERF/1000000)) + 
  ggtitle("Total Funding Received CERF") + 
  geom_line(color="darkblue") + 
  labs(y="", x="") + xlim(2006,2017)

## COMBINED PICTURES

tiff('fig1a.tiff', units="in", width=5, height=8.3, res=300)        
grid.arrange(yearly1, yearly2, yearly3, nrow=3, 
             left = textGrob("In Million USD", rot = 90, vjust = 1, hjust=0, 
                             gp = gpar(fontsize = 10)))
dev.off()

Я получаю следующее сообщение об ошибке:

Error in grid::textGrob(label = label, just = just, hjust = hjust, vjust = vjust,  : 
formal argument "gp" matched by multiple actual arguments

Есть предложения, как создать эту картинку? Чем легче, тем лучше.

Вот мои данные (сжатые):

structure(list(year = 2006:2010, Total_US_received_from.CERF = c(65091455.5, 
    204409211, 200351170.5, 180924822, 290493687.5), Total_US_required = c(828538873.5, 
    2986369814, 1554939106, 2144420061, 7724926517), Total_US_received = c(215790327.5, 
    1988581112, 1698825389, 1509823414, 4975642034)), row.names = c(NA, 
    5L), class = "data.frame")

person JanC    schedule 10.09.2018    source источник
comment
Привет, я думаю, это опечатка (nmrow в grid.arrange() должно быть nrow)? В противном случае я не смогу воспроизвести вашу ошибку с помощью предоставленного кода.   -  person Z.Lin    schedule 10.09.2018
comment
@ Z.Lin, под редакцией. Однако по-прежнему возникает та же ошибка.   -  person JanC    schedule 10.09.2018


Ответы (1)


Использование ggarrange из ggpubr:

yearly1 <- ggplot(yearly, aes(x=year, y=Total_US_required/1000000)) + ggtitle("Total Funding Required") + geom_line(color="darkblue") + labs(y="In Million USD", x="") + xlim(2006,2017)

yearly2 <- ggplot(yearly, aes(x=year, y=Total_US_received/1000000)) + ggtitle("Total Funding Received") + geom_line(color="darkblue") + labs(y="In Million USD", x="") + xlim(2006,2017)

yearly3 <- ggplot(yearly, aes(x=year, y=Total_US_received_from.CERF/1000000)) + ggtitle("Total Funding Received CERF") + geom_line(color="darkblue") + labs(y="In Million USD", x="") + xlim(2006,2017)

ggarrange(yearly1, yearly2, yearly3, 
          ncol = 1, nrow = 3)

введите здесь описание изображения

person tmfmnk    schedule 10.09.2018
comment
Благодарность! Один текст In Million USD слева, похоже, тоже не сработал. - person JanC; 10.09.2018
comment
Честно говоря, я так не пробовал. - person tmfmnk; 10.09.2018