7

我有我的轴刻度:

axis(4,at=c(1.6526,1.9720,2.6009,3.3403),las=1)

现在我想给它们贴上标签。文本应该是这样的:

labels=c("alpha=0.1","alpha=0.05","alpha=0.01","alpha=.001")

但我希望 alpha 看起来像希腊字符。谢谢!

4

2 回答 2

8

您可以使用expression而无需使用paste

axis(4,at=c(0.75,1.75),labels=c(expression(alpha==0.1),expression(alpha==0.2)),las=1)
于 2012-10-25T12:32:03.240 回答
5

如果有几个标签,手工制作这些是可以的,但是很乏味而且不是自动化的。有一些方法可以将单个表达式组合成一个表达式“向量”,我们可以自动构建单个表达式。这是一种方法,我忘记了是否有其他方法,或者即使这是规范的方法(以前在 StackOverflow [包括我!] 上已经询问并回答了一般问题,但我无法在非常快速的搜索中找到它)。

op <- par(mar = c(5,4,4,6) + 0.1)
plot(1:10)
axis(1)
labs <- lapply(alpha, function(x) bquote(alpha == .(x)))
axis(4, at = seq(1, by = 2, length = 5),
     labels = do.call(expression, labs), las = 1)
par(op)

哪个生产

在此处输入图像描述

我分开了展览的舞台。第一个是

> labs <- lapply(alpha, function(x) bquote(alpha == .(x)))
> labs
[[1]]
alpha == 0.1

[[2]]
alpha == 0.05

[[3]]
alpha == 0.01

[[4]]
alpha == 0.005

[[5]]
alpha == 0.001

它产生一个调用列表。

第二步是将这些组合成一个表达式,我用do.call()

> do.call(expression, labs)
expression(alpha == 0.1, alpha == 0.05, alpha == 0.01, alpha == 
    0.005, alpha == 0.001)

你当然可以结合这些:

labs <- do.call(expression, lapply(alpha, function(x) bquote(alpha == .(x))))
axis(4, at = seq(1, by = 2, length = 5),
     labels = labs, las = 1)
于 2012-10-25T12:46:15.470 回答