如何调整多个地块的大小?

How to adapt the size of multiple plots?

如何根据 x 轴的长度调整以下绘图的大小?

图的宽度应指 x 轴各自部分的长度。所有地块的高度应该相同。

您需要的函数是基本图形函数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)