1

我正在尝试为浮点数绘制一条数线(稍微简化,带有一个符号位,一位用于系数(当不为零时),两位用于指数)。我有这个:

library(ggplot2)
library(tibble)
library(ggrepel)

d <- tribble(
  ~repr,             ~number,
 "1.1[2] %*% 2^-11", 2**-3 + 2**-4,
 "1.0[2] %*% 2^-11", 2**-3,
 "1.1[2] %*% 2^-10", 2**-2 + 2**-3,
 "1.0[2] %*% 2^-10", 2**-2,
 "1.1[2] %*% 2^-01", 2**-1 + 2**-2,
 "1.0[2] %*% 2^-01", 2**-1,
 "1.0[2] %*% 2^0",   1,
 "1.1[2] %*% 2^0",   1 + 2**-1,
 "0.0[2] %*% 2^0",   0,
 "1.1[2] %*% 2^01",   2 + 1,
 "1.0[2] %*% 2^01",   2,
 "1.1[2] %*% 2^10",   2**2 + 2**1,
 "1.0[2] %*% 2^10",   2**2,
 "1.1[2] %*% 2^11",   2**3 + 2**2,
 "1.0[2] %*% 2^11",   2**3,

 "-1.1[2] %*% 2^-11", -(2**-3 + 2**-4),
 "-1.0[2] %*% 2^-11", -(2**-3),
 "-1.1[2] %*% 2^-10", -(2**-2 + 2**-3),
 "-1.0[2] %*% 2^-10", -(2**-2),
 "-1.1[2] %*% 2^-01", -(2**-1 + 2**-2),
 "-1.0[2] %*% 2^-01", -(2**-1),
 "-1.0[2] %*% 2^0",   -1,
 "-1.1[2] %*% 2^0",   -(1 + 2**-1),
 "-1.1[2] %*% 2^01",  -(2 + 1),
 "-1.0[2] %*% 2^01",  -2,
 "-1.1[2] %*% 2^10",  -(2**2 + 2**1),
 "-1.0[2] %*% 2^10",  -2**2,
 "-1.1[2] %*% 2^11",  -(2**3 + 2**2),
 "-1.0[2] %*% 2^11",  -2**3
)

ggplot(d) +
  geom_text_repel(aes(x = number, y = -0.1, label = number),
                  parse = TRUE,
                  angle = 0,
                  ylim = c(NA, -0.1)) +
  geom_text_repel(aes(x = number, y = 0.1, label = repr),
                  angle = 0,
                  parse = TRUE, direction = "both", #angle = 90,
                  ylim = c(0.1, NA)) +
  geom_hline(yintercept = 0) +
  coord_cartesian(ylim = c(-2, 2)) +
  labs(x = NULL, y = NULL) +
  theme_classic() +
  theme(axis.line.y = element_blank(),
        axis.ticks = element_blank(),
        axis.text = element_blank())

结果如下所示:

数线图

这几乎是我想要的,但我希望标签从左到右按与数字相同的顺序排列(并且我想避免跨越任何线)。

有没有办法避免与 越界geom_text_repel?我不介意在零附近有更大的标签分布,其中有很多值,我只是认为很难按原样阅读情节,因为标签按照它们的顺序被打乱了。

4

1 回答 1

3

让我们添加另一列来定位文本标签:

d <- d[order(d$number),]
d$i <- seq(min(d$number), max(d$number), length.out = nrow(d))
head(d)

这里是:

            repr  number          i
-1.1[2] %*% 2^11     -12  -12.00000
-1.0[2] %*% 2^11      -8  -11.14285
-1.1[2] %*% 2^10      -6  -10.28571
-1.0[2] %*% 2^10      -4  -9.428571
-1.1[2] %*% 2^01      -3  -8.571429
-1.0[2] %*% 2^01      -2  -7.714286

我们不需要ggrepel:

ggplot() +
geom_point(
  data = d,
  mapping = aes(x = 0, y = number),
  size = 0.1
) +
geom_text(
  data = d,
  mapping = aes(x = 0.05, y = i, label = repr),
  parse = TRUE, hjust = 0
) +
geom_segment(
  data = d,
  mapping = aes(x = 0, xend = 0.05, y = number, yend = i),
  size = 0.1
) +
scale_y_continuous(
  breaks = c(-12, -8, -6, -4, -3, -2, -1, 0, 1, 2, 3, 4, 6, 8, 12)
) +
coord_cartesian(xlim = c(-0.01, 0.12)) +
theme_classic(base_size = 14) +
labs(x = NULL, y = NULL) +
theme(
  axis.line.y = element_line(size = 0.2),
  axis.ticks.y = element_line(size = 0.2),
  axis.line.x = element_blank(),
  axis.ticks.x = element_blank(),
  axis.text.x = element_blank()
)

在此处输入图像描述

于 2018-06-26T15:22:26.400 回答