Я хотел бы разместить четыре сюжета на одной странице. Этикетки осей должны быть напечатаны только на самом ободе, то есть на осях оси X только для нижних диаграмм, и на оси y для левых диаграмм. Это происходит как для названия оси в целом, так и для отдельных меток. Я могу сгенерировать что-то в этих строках, используя следующий код:
pdf(file = "ExampleOutput.pdf",
width = 6.61,
height = 6.61,
pointsize = 10
)
set.seed(42)
catA <- factor(c("m100", "m500", "m1000", "m2000", "m3000", "m5000"))
catB <- factor(20:28)
samples <- 100
rsample <- function(v) v[ceiling(runif(samples, max=length(v)))]
Tab <- data.frame(catA = rsample(catA),
catB = rsample(catB),
valA = rnorm(samples, 150, 8),
valB = pmin(1,pmax(0,rnorm(samples, 0.5, 0.3))))
par(mfrow = c(2,2))
for (i in 0:3) {
x <- Tab[[1 + i %% 2]]
plot(x, Tab[[3 + i %/% 2]],
xlab = if (i %/% 2 == 1) "Some Categories" else NULL,
ylab = if (i %% 2 == 0) "Some Values" else NULL,
axes = FALSE
)
axis(side = 1,
at=1:nlevels(x),
labels = if (i %/% 2 == 1) levels(x) else FALSE)
axis(side = 2, labels = (i %% 2 == 0))
box(which = "plot", bty = "l")
}
par(mfrow = c(1,1))
dev.off()
Я буду приветствовать предложения о том, как улучшить мои команды построения графиков, возможно, избегать опускания осей и L в левом нижнем углу вручную. Но это только кроме того.
Результат этой последовательности выглядит следующим образом:
Проблема здесь в огромном количестве потраченных впустую пробелов. У меня сложилось впечатление, что R резервирует пространство для меток оси и тика, даже если они не используются. Вследствие этого потраченного пространства, для левой нижней диаграммы, только каждый второй x-тик фактически получает помеченную, что здесь действительно плохо.
Я бы хотел создать подобный сюжет без такого большого пробела. Фактические графики должны быть одинакового размера, поэтому они выравниваются правильно, но пространство для этикеток должно быть только снаружи. Я предполагаю, что такой макет (макет, созданный в GIMP):
Как я могу достичь такого макета?