4

我使用包mosaic中的函数创建了一个马赛克图vcd。现在我希望使用labeling_cells. 不幸的是,我得到一个错误。问题可能是它不是标准Titanic示例......

library("grid"); library("vcd")
dataset <- read.table("http://bit.ly/1aJTI1C")

# prepare data for plot as a "Structured Contingency Table"
data1 <- structable(dauer ~ groesse + ort, dataset) 

# basic plot
mosaic(data1,
       # separate the two elements of the plot  
       split_vertical = c(T, T, F),

       # put the names in the right places and adds boxes 
       labeling_args = list(tl_labels = TRUE,
                            tl_varnames = FALSE,
                            boxes = TRUE),
       # grip remains open 
       pop=FALSE 
       )

在此处输入图像描述

# structure that matches plot, but it does not help
#match<-t(data1)

# try to add labels 
labeling_cells(text = data1, clip = FALSE)(data1)

这导致:

# Error in ifelse(abbreviate_varnames, sapply(seq_along(dn), function(i) abbreviate(dn[i],  : 
#   replacement has length zero
# In addition: Warning message:
# In rep(no, length.out = length(ans)) :
#  'x' is NULL so the result will be NULL

我遇到的另一个问题是盒子不适合标签。如果您对此有任何提示,也请告诉我!

这是我在这里的第一个问题,所以请原谅潜在的错误!

非常感谢!

4

2 回答 2

4

在 vcd 1.4-4 中修复了上游,但请注意,您可以简单地使用

mosaic(data1, labeling = labeling_values)
于 2017-06-14T22:32:45.270 回答
2

是的,这很令人困惑,应该在labeling_cells(). 由于某种原因,标签中的数据应该是常规的table,而不是structable. 我将与包的主要作者mosaic()和包维护者大卫一起提出这个问题。

但是,如果您知道它很容易解决它:

labeling_cells(text = as.table(data1), clip = FALSE)(as.table(data1))

马赛克标签

于 2017-06-13T21:14:24.813 回答