Как адаптировать размер нескольких участков? - PullRequest
0 голосов
/ 24 февраля 2019

Как я могу адаптировать размер следующих графиков с учетом их длины по оси X?

enter image description here

Ширина графиковследует ссылаться на длину соответствующего сечения оси X.Высота должна быть одинаковой для всех участков.

1 Ответ

0 голосов
/ 24 февраля 2019

Требуемая функция - базовая графическая функция help("layout").

Сначала я составлю набор данных, поскольку вы его еще не опубликовали.Я не буду рисовать линии регрессии, только точки.

Код создания данных.

fun <- function(X, A) {
  apply(X, 1, function(.x){
    xx <- seq(.x[1], .x[2], length.out = 100)
    y <- A[1]*xx + A[2] + rnorm(100, 0, 25)
    list(xx, y)
  })}

Coef <- matrix(c(0.24, 0.54, 
                 0.75, 0.54,
                 0.33, 2.17,
                 0.29, 3.3,
                 0.29, 4.41), byrow = TRUE, ncol = 2)

X <- matrix(c(0.1, 0.49,
              0.5, 2.49,
              2.5, 3.9,
              4.0, 5.9,
              6.0, 12.0), byrow = TRUE, ncol = 2)

set.seed(1234)
res <- fun(X, Coef)

Проблема.

Определить матрицу макета для каждого графика в последовательности от первого до пятого.И ширины, заданные диапазонами X.

layout_mat <- matrix(c(1, 2, 3, 4, 5), 1, 5, byrow = TRUE)
w <- apply(X, 1, diff)
l <- layout(layout_mat, widths = w)
layout.show(l)

Теперь освободите место для аннотации оси, сохранив графические параметры по умолчанию и построив 5 графиков.

om <- par(mar = c(3, 0.1, 0.1, 0.1),
          oma = c(3, 2, 0.1, 0.1))
for(i in 1:5) plot(res[[i]][[1]], res[[i]][[2]])
par(om)

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...