【问题标题】:Simple discriminant analysis in R using the lda function fails使用 lda 函数在 R 中进行简单判别分析失败
【发布时间】:2012-02-29 23:27:16
【问题描述】:

我正在尝试进行判别分析并不断遇到以下错误:

Error in sqrt((n * prior) * fac) * scale(group.means, center = xbar, scale = FALSE) %*%  : 
  non-conformable arrays
Calls: lda -> lda.formula -> lda.default

这是我的代码分解为几行:

categories <- c(1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 2, 3, 1, 1, 3, 3, 2, 1, 1, 3, 1, 1, 3, 2, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 1, 3, 1, 1, 1, 1, 1, 1, 2, 2, 3, 3, 3, 3)
values <- c(1, 2, 3, 2, 0, 2, 2, 3, 3, 1, 3, 5, 5, 4, 3, 3, 4, 4, 2, 4, 7, 6, 7, 5, 7, 7, 7, 7, 7, 5, 3, 6, 7, 7, 7, 2, 5, 0, 3, 7, 6, 3, 2, 2, 4, 2, 2, 5, 5, 6, 2, 2, 4, 1, 3, 0, 3, 1, 4, 1, 1, 2, 4, 2, 4, 3, 3, 4, 7, 6, 4, 7, 6, 7, 7, 3, 6, 7, 4, 7, 3, 1, 2, 0, 2, 2, 5, 2, 7, 6, 6, 7)

data <- data.frame(categories=categories, values=values)
counts <- table(data[["categories"]])
prior <- counts / sum(counts)

z <- lda(categories ~ values, data, prior=prior)
predict(z, data)$class

这可能是一件微不足道的事情......

【问题讨论】:

    标签: r classification


    【解决方案1】:

    问题是您的对象prior 属于table 类,但lda 需要您的先验是vector

    一个简单的解决方法是在表的结果上使用as.vector

    prior <- as.vector(counts / sum(counts))
    
    z <- lda(categories ~ values, dat, prior=prior)
    predict(z, data)$class
    
     [1] 1 1 2 1 1 1 1 2 2 1 2 3 3 2 2 2 2 2 1 2 3 3 3 3 3 3 3 3 3 3 2 3 3 3 3 1 3 1
    [39] 2 3 3 2 1 1 2 1 1 3 3 3 1 1 2 1 2 1 2 1 2 1 1 1 2 1 2 2 2 2 3 3 2 3 3 3 3 2
    [77] 3 3 2 3 2 1 1 1 1 1 3 1 3 3 3 3
    Levels: 1 2 3
    

    【讨论】:

    • 感谢您的帮助!节省了我很多时间-.-
    猜你喜欢
    • 1970-01-01
    • 2021-09-19
    • 2014-08-19
    • 2011-08-03
    • 2017-05-22
    • 1970-01-01
    • 1970-01-01
    • 2015-09-15
    • 1970-01-01
    相关资源
    最近更新 更多