Hi,

First, some toy data would have helped a lot, and that can explain why 
you got so few answers...

Second, I have maybe some thoughts about it, not sure if this can help.

The error tells you that the data passed to aov is not a matrix. In your 
function, you don't specify explicitly the data object to be used, that 
might be a problem. And that object has to be a matrix, it might not be.
Maybe something like:

form<- as.formula(paste("pcs", "~", paste(fac, collapse = "*")),
...
if (length(pcs) == 1) out<- aov(formula = form, data=score.matrix)

That would work if I understood what you're doing (hum...) and if both "pcs" 
and "fac" are parts of "score.matrix". But I've always done aov from a 
dataframe, which makes sense if you have both numerical variables and factors. 
How can you do it from a matrix? Maybe my understanding is limited.

As I said, just some thoughts...
HTH,
Ivan


Le 8/26/2010 14:47, Bryan Hanson a écrit :
> Hello Again Gurus and Lurkers:
>
> I¹m trying to build a very user-friendly function which does aov without
> having the user type in a formula (which would be tedious in this case).
> The idea is to take the response from a PCA score matrix, and the factors
> from a list.  A simple example is the function given below, along with test
> data and a sample call to the function.
>
> I'm certainly having trouble understanding the proper ways to work with
> formulas and related items, but I think what I do in the function should
> work (it's built on ideas dug out of the archives).  However, when the data
> is passed to aov (directly or via manova), something in the bowels of aov
> complains with the following error:
>
> Error in model.frame.default(formula = form, drop.unused.levels = TRUE) :
>    object is not a matrix
>
> To me, the formula looks legitimate, and the variables in the formula are
> all in the environment (I think: The way I am doing this is basically that
> described in ?summary.manova where only a formula is passed, no data
> argument).  Based upon reading the archives, the problem might arise with
> one of the deparse statements in aov, but I can't resolve it.  It might also
> be one of scoping/environment, but again, this is only an idea.
>
> TIA for any assistance.  Bryan
> *************
> Bryan Hanson
> Professor of Chemistry&  Biochemistry
> DePauw University, Greencastle IN USA
>
>
> hypTestScores<-
>      function(mylist, score.matrix, pcs = 1:3, fac = NULL, ...) {
>
>      scores<- score.matrix[,pcs]
> #    str(scores)    # looks correct to me
>      form<- as.formula(paste("scores", "~", paste(fac, collapse = "*")),
>          env = parent.frame())
> #    str(form)       # looks correct to me
>      attach(mylist)
>      if (length(pcs)>  1) out<- manova(formula = form, ...)
>      if (length(pcs) == 1) out<- aov(formula = form, ...)
>      print(summary(out))
>      detach(mylist)
>      invisible(out)
>      }
>
> # test data
> td1<- matrix(rnorm(50), ncol = 5) # like PCA scores
> td2<- list(
>      f1 = as.factor(sample(c("A", "B"), 10, replace = TRUE)),
>      f2 = as.factor(sample(c("C", "D"), 10, replace = TRUE)))
>
> # test call
> hypTestScores(mylist = td2, score.matrix = td1,
>      fac = c("f1", "f2"))
> detach("mylist") # needed if there is an error
>
>> sessionInfo()
> R version 2.11.0 (2010-04-22)
> x86_64-apple-darwin9.8.0
>
> locale:
> [1] en_US.UTF-8/en_US.UTF-8/C/C/en_US.UTF-8/en_US.UTF-8
>
> attached base packages:
> [1] datasets  tools     grid      graphics  grDevices utils     stats
> [8] methods   base
>
> other attached packages:
>   [1] faraway_1.0.4      GGally_0.2         xtable_1.5-6
>   [4] mvbutils_2.5.1     ggplot2_0.8.8      proto_0.3-8
>   [7] reshape_0.8.3      ChemoSpec_1.45     R.utils_1.4.0
> [10] R.oo_1.7.2         R.methodsS3_1.2.0  rgl_0.91
> [13] lattice_0.18-5     mvoutlier_1.4      plyr_1.0.3
> [16] RColorBrewer_1.0-2 chemometrics_0.8   som_0.3-5
> [19] robustbase_0.5-0-1 rpart_3.1-46       pls_2.1-0
> [22] pcaPP_1.8-1        mvtnorm_0.9-9      nnet_7.3-1
> [25] mclust_3.4.4       MASS_7.3-5         lars_0.9-7
> [28] e1071_1.5-23       class_7.3-2
>
> ______________________________________________
> R-help@r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
> and provide commented, minimal, self-contained, reproducible code.
>

-- 
Ivan CALANDRA
PhD Student
University of Hamburg
Biozentrum Grindel und Zoologisches Museum
Abt. Säugetiere
Martin-Luther-King-Platz 3
D-20146 Hamburg, GERMANY
+49(0)40 42838 6231
ivan.calan...@uni-hamburg.de

**********
http://www.for771.uni-bonn.de
http://webapp5.rrz.uni-hamburg.de/mammals/eng/mitarbeiter.php


        [[alternative HTML version deleted]]

______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

Reply via email to