使用乘数转换ggplot2的轴标签

11

之前在ggplot2中,我使用了一个格式化函数将Y轴上的值乘以100:

formatter100 <- function(x){ 
x*100 }

使用新版ggplot2(v0.9.1)时,我在尝试使用一个新的转换函数来转换坐标轴标签时遇到了问题:

mult_trans <- function() {
        trans_new("mult", function(x) 100*x, function(x) x/100) }

以下是示例的绘图函数

library(scales)

test<-data.frame(ecdf=c(0.02040816,0.04081633,0.06122449,0.08163265,0.10204082,0.14285714,0.14285714,0.16326531,0.24489796,0.24489796,0.24489796,0.24489796,0.26530612,0.28571429,0.30612245,0.32653061,0.36734694,0.36734694,0.38775510,0.40816327,0.42857143,0.46938776,0.46938776,0.48979592,0.53061224,0.53061224,0.59183673,0.59183673,0.59183673,0.61224490,0.63265306,0.65306122,0.67346939,0.69387755,0.71428571,0.73469388,0.75510204,0.77551020,0.79591837,0.81632653,0.83673469,0.85714286,0.87755102,0.89795918,0.91836735,0.93877551,0.95918367,0.97959184,0.99900000),lat=c(50.7812,66.4062,70.3125,97.6562,101.5620,105.4690,105.4690,109.3750,113.2810,113.2810,113.2810,113.2810,125.0000,136.7190,148.4380,164.0620,167.9690,167.9690,171.8750,175.7810,183.5940,187.5000,187.5000,191.4060,195.3120,195.3120,234.3750,234.3750,234.3750,238.2810,261.7190,312.5000,316.4060,324.2190,417.9690,507.8120,511.7190,562.5000,664.0620,683.5940,957.0310,1023.4400,1050.7800,1070.3100,1109.3800,1484.3800,1574.2200,1593.7500,1750.0000))


xbreaks<-c(50,100,150,200,300,500,1000,2000)
ybreaks<-c(1,2,5,10,20,30,40,50,60,70,80,90,95,98,99,99.5,99.9)/100

p <- ggplot( test, aes(lat, ecdf) ) 

p<-p + 
  geom_point()+
  scale_x_log10(breaks=xbreaks, labels = comma(xbreaks))+
  scale_y_continuous(trans='probit', 
                     labels = trans_format(mult_trans()), 
                     "cumulative probability %",
                     breaks=ybreaks)+
  xlab("latency ms")
p

出现了以下错误: Error in scale$labels(breaks) : could not find function "trans"

看起来我误解了如何正确使用转换函数。


1
标签 = 函数(x) x * 100 是足够的。 - kohske
2个回答

14

转换实际上是转换比例尺本身。在您的y轴的情况下,您只是格式化刻度。因此,您不需要使用trans_new,只需使用常规格式化函数即可。同样,您需要使用comma_format而不是comma,因为前者会根据需要返回一个函数:

mult_format <- function() {
     function(x) format(100*x,digits = 2) 
}
p <- ggplot( test, aes(lat, ecdf) ) 
p<-p + 
  geom_point()+
  scale_x_log10(breaks = xbreaks,labels = comma_format()) +
  scale_y_continuous(trans='probit', 
                     labels = mult_format(), 
                     breaks=ybreaks) + 
  xlab("latency ms")
p

输入图像描述


0

我将y轴的值乘以6,但是我想要显示未被乘的值作为标签,因此最终我添加了这个:

scale_y_continuous(breaks=seq(-100,100,2)*6,labels=seq(-100,100,2))

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接