李丰同学建议在《现代统计图形》书稿中插入一些彩蛋,我想第一颗蛋就用这些杂乱无章的彩色点线吧。不过小的实在拿不定哪一幅图看着更“艺术”一些,因此请路人帮忙挑选一下。下图只是众多可能的随机图中的一幅,更多图形请运行下面的完整代码。挑好之后把图中的起始数字告诉小的,小的会在书稿的致谢部分说明您的贡献。

如果客观关心这些图是如何画出来的,这里有代码有真相:
devAskNewPage(TRUE)
par(mar = c(0.2, 0.2, 0.2, 0.2), mfrow = c(2, 2))
for (n in 41:200) {
set.seed(711)
plot.new()
size = c(replicate(n, 1/rbeta(2, 1.5, 4)))
center = t(replicate(n, runif(2)))
center = center[rep(1:n, each = 2), ]
color = apply(replicate(2 * n, sample(c(0:9, LETTERS[1:6]),
8, replace = TRUE)), 2, function(x) sprintf("#%s", paste(x,
collapse = "")))
points(center, cex = size, pch = rep(20:21, n), col = color)
box()
text(0.5, 0.5, n)
}
用作桌面
如果有客官想用这样的图形作桌面的话,也不是件难事:用png()设备把图形记录下来,然后将图形文件设为桌面即可。以我的显示器为例,我的分辨率是1366x768,那么:
# 为了保证高质量的PNG图片,这里用附加包cairoDevice
# 如果读者对图片质量要求不高,也可以用R自带的png()设备
# 即png("points-desktop.png", width = 1366, height = 768)
library(cairoDevice)
Cairo_png("points-desktop.png", width = 13.66 * 1.39,
height = 7.68 * 1.39)
par(mar = c(0, 0, 0, 0))
n = 76
set.seed(711)
plot.new()
size = c(replicate(n, 1/rbeta(2, 1.5, 4)))
center = t(replicate(n, runif(2)))
center = center[rep(1:n, each = 2), ]
color = apply(replicate(2 * n, sample(c(0:9, LETTERS[1:6]),
8, replace = TRUE)), 2, function(x) sprintf("#%s", paste(x,
collapse = "")))
points(center, cex = size, pch = rep(20:21, n), col = color)
dev.off()
这样,我们打开文件points-desktop.png(它在当前工作目录下getwd()),设定为桌面就可以了。
赞赏
作为一名没有固定工作的自由职业者,我非常感谢您通过捐赠的方式来支持我的写作和开源软件开发。当然,捐赠纯属自愿。无论金额多少,都是一片诚挚的心意。支付方式如下:
| 微信 | ← 奋力支开它俩 → | 支付宝 |
|---|---|---|
![]() |
其它爱心通道 ↓ Venmo: @yihui_xie Zelle: xie@yihui.name PayPal: xie@yihui.name |
![]() |
若使用 Venmo/Zelle/Paypal,请添加备注“gift”或“donation”,以免捐赠被视为我的可税收入。若使用 Paypal,支付类型请选 Family and Friends,而不要选 Goods and Services。
在不影响生活的前提下,我会将收到的捐赠以尽量大的比例回馈给开源社区和慈善机构。作为参考,2024-25 年间我共收到约三万美元捐赠,完税后我转手捐出了一万五千美元。

