私はおおよそこの機能を持っています:
plot_pca_models <- function(models, id) {
library(lattice)
splom(models, groups=id)
}
そして、私はそれを次のように呼んでいます:
plot_pca_models(data.pca, log$id)
このエラーが発生します。
Error in eval(expr, envir, enclos) : object 'id' not found
ラッピング関数なしで呼び出すと:
splom(data.pca, groups=log$id)
次のエラーが発生します。
Error in log$id : object of type 'special' is not subsettable
しかし、私がこれを行うと:
id <- log$id
splom(models, groups=id)
期待どおりに動作します。
なぜこのように動作するのか、それを修正する方法を誰かが説明できますか? ありがとう。
ところで:私はここで同様の質問を知っています。
しかし、それらのどれも私を助けませんでした。
編集: 要求に応じて、完全な "plot_pca_models" 関数があります。
plot_pca_models <- function(data, id, sel=c(1:4), comp=1) {
# 'data' ... princomp objects
# 'id' ... list of samples id (classes)
# 'sel' ... list of models to compare
# 'comp' ... which pca component to compare
library(lattice)
models <- c()
models.size <- 1:length(data)
for(model in models.size) {
models <- c(models, list(data[[model]]$scores[,comp]))
}
names(models) <- 1:length(data)
models <- do.call(cbind, models[sel])
splom(models, groups=id)
}
edit2 : 問題を再現可能にすることができました。
require(lattice)
my.data <- data.frame(pca1 = rnorm(100), pca2 = rnorm(100), pca3 = rnorm(100))
my.id <- data.frame(id = sample(letters[1:4], 100, replace = TRUE))
plot_pca_models2 <- function(x, ajdi) {
splom(x, group = ajdi)
}
plot_pca_models2(x = my.data, ajdi = my.id$id)
上記と同じエラーが発生します。