Tee*_*Kea 2 r facet ggplot2 boxplot
我有代表两种方法的结果的箱线图,每种方法都有两种验证方法和三种场景,使用 ggplot2 绘制。一切正常,但我想更改 x 轴刻度标签以区分每个组中使用的技术类型。
我使用了以下代码:
data <- read.csv("results.csv", header = TRUE, sep=',')
ggplot() +
geom_boxplot(data = data, aes(x = Validation, y = Accuracy, fill = Scenario)) +
facet_wrap(~ Method) +
labs(fill = "")
Run Code Online (Sandbox Code Playgroud)
其中我的数据结构如下:
Method Validation Scenario Accuracy
-------------------------------------------------------
Method 1 Iterations Scenario 1 0.90
Method 1 Iterations Scenario 2 0.80
Method 1 Iterations Scenario 3 0.86
Method 1 Recursive Scenario 2 0.82
Method 2 Iterations Scenario 1 0.69
Method 2 Recursive Scenario 3 0.75
Run Code Online (Sandbox Code Playgroud)
并得到以下情节:
我只想将方法 1 和方法 2 中的第一个 x-tick 标签(Iterations)分别更改为100-iterations和10-iterations。
我尝试添加此代码,但这更改了两个组的标签。
+ scale_x_discrete(name = "Validation",
labels = c("100-iterations", "Recursive",
"10-iterations", "Recursive")) +
Run Code Online (Sandbox Code Playgroud)
提前致谢。
ggplot 包的 facet 选项不是为跨方面的不同轴标签/比例而设计的(有关详细说明,请参见此处),但在这种情况下的一种解决方法是改变不同方面的基础 x 轴变量的值,并设置scales = "free_x"为facet_wrap()以便在每个方面的 x 轴中仅显示相关值:
library(ggplot2)
library(dplyr)
ggplot(data %>%
mutate(Validation = case_when(Validation == "Recursive" ~ "Recursive",
Method == "Method 1" ~ "100-iterations",
TRUE ~ "10-iterations")),
aes(x = Validation, y = Accuracy, fill = Scenario)) +
geom_boxplot() +
facet_wrap(~ Method, scales = "free_x")
Run Code Online (Sandbox Code Playgroud)
数据:
set.seed(1)
data <- data.frame(
Method = rep(c("Method 1", "Method 2"), each = 100),
Validation = rep(c("Iterations", "Recursive"), times = 100),
Scenario = sample(c("Scenario 1", "Scenario 2", "Scenario 3"), 200, replace = TRUE),
Accuracy = runif(200)
)
Run Code Online (Sandbox Code Playgroud)