[R] Error in defining function

Megh Dal megh700004 at yahoo.com
Mon Jul 7 09:19:45 CEST 2008


"You will have to translate each character string
to a function separately."

Here I have a modified program :

  library(zoo)
 Z.index <- as.Date(sample(12450:15500, 3000))
  Z.data <- matrix(rnorm(300), ncol = 1)

  data1 <- zoo(Z.data, Z.index)

  fnc = function(data1)
    {
    selection2 = select.list(c("Mean", "SD"), multiple = T)

     Mean = function(dataa) mean(dataa)
     SD = function(dataa) sd(dataa)
     
     my.match.fun <- function(x) match.fun(x) ###
     
     for (i in length(selection2))
        {
         selection2[i] <- my.match.fun(selection2[i]) ###
        }
        
    ag = function(z, by, selection2)
                  {
                         f = function(f) aggregate(z, by, f)
                         do.call(cbind, sapply(selection2, f, simplify = F))
                  }

     return(ag(data1, as.yearqtr, selection2))
    }

    fnc(data1)

Frustrated !! still error. I also have tried downloading from R-forge. But download page is not working. I then tried directly from R using install.packages. Still there is no improvement.

Regards,


--- On Mon, 7/7/08, Gabor Grothendieck <ggrothendieck at gmail.com> wrote:

> From: Gabor Grothendieck <ggrothendieck at gmail.com>
> Subject: Re: [R] Error in defining function
> To: megh700004 at yahoo.com
> Cc: r-help at stat.math.ethz.ch
> Date: Monday, July 7, 2008, 8:44 AM
> Your program works as is if you choose Mean but you have
> introduced two new errors:
> 
> 1. SD is not defined in your program.
> 
> 2. if multiple choices are taken then it will try to pass a
> vector to
> my.match.fun but that calls match.fun which only allows
> functions
> to be passed to it.  You will have to translate each
> character string
> to a function separately.
> 
> Try this:
> 
> funs <- c("Mean", "SD")
> f <- function(fun) aggregate(data1, as.yearqtr,
> get(fun))
> do.call(cbind, sapply(tolower(funs), f, simplify = FALSE))
> 
> 
> On Sun, Jul 6, 2008 at 10:43 PM, Megh Dal
> <megh700004 at yahoo.com> wrote:
> > I made some changes and also incorporated your advice
> :
> >
> >  library(zoo)
> >  Z.index <- as.Date(sample(12450:15500, 3000))
> >  Z.data <- matrix(rnorm(300), ncol = 1)
> >
> >  data1 <- zoo(Z.data, Z.index)
> >
> >  fnc = function(data1)
> >    {
> >    selection2 = select.list(c("Mean",
> "SD"), multiple = T)
> >
> >     Mean = function(dataa) mean(dataa)
> >      my.match.fun <- function(x) match.fun(x) ###
> >    selection2 <- my.match.fun(selection2) ###
> >    ag = function(z, by, selection2)
> >                  {
> >                         f = function(f) aggregate(z,
> by, f)
> >                         do.call(cbind,
> sapply(selection2, f, simplify = F))
> >                  }
> >
> >     return(aggregate(data1, as.yearqtr, selection2))
> >    }
> >
> >    fnc(data1)
> >
> > But still getting same error.
> >
> >
> > --- On Mon, 7/7/08, Gabor Grothendieck
> <ggrothendieck at gmail.com> wrote:
> >
> >> From: Gabor Grothendieck
> <ggrothendieck at gmail.com>
> >> Subject: Re: [R] Error in defining function
> >> To: megh700004 at yahoo.com
> >> Cc: r-help at stat.math.ethz.ch
> >> Date: Monday, July 7, 2008, 1:23 AM
> >> On Sun, Jul 6, 2008 at 3:19 PM, Megh Dal
> >> <megh700004 at yahoo.com> wrote:
> >> > Can anyone please tell me why I am getting
> this error?
> >> >
> >> > library(zoo)
> >> > Z.index <- as.Date(sample(12450:15500,
> 3000))
> >> > Z.data <- matrix(rnorm(300), ncol = 1)
> >> >
> >> > data1 <- zoo(Z.data, Z.index)
> >> >
> >> > fnc = function(data1)
> >> >    {
> >> >    selection2 =
> select.list(c("Mean"),
> >> multiple = F)
> >> >
> >> >     Mean = function(dataa) mean(dataa)
> >> >
> >> >     return(aggregate(data1, as.yearqtr,
> selection2))
> >> >    }
> >> >
> >> >    fnc(data1)
> >> >
> >> > I got following error :
> >> > Error in get(as.character(FUN), mode =
> >> "function", envir = envir) :
> >> >  variable "Mean" of mode
> >> "function" was not found
> >> >
> >>
> >> Its a bug in aggregate.zoo .  Its just been fixed
> in the
> >> zoo devel version
> >> available on R-Forge so you can either grab that
> or use the
> >> workaround
> >> below:
> >>
> >> library(zoo)
> >>
> >> set.seed(1)
> >> Z.data <- matrix(rnorm(300), ncol = 1)
> >> Z.index <- as.Date(sample(12450:15500, 3000))
> >> data1 <- zoo(Z.data, Z.index)
> >>
> >> fnc <- function(data1) {
> >>    selection2 <- select.list("Mean",
> multiple
> >> = FALSE)
> >>     Mean <- function(dataa) mean(dataa)
> >>
> >>     my.match.fun <- function(x) match.fun(x)
> ###
> >>     selection2 <- my.match.fun(selection2) ###
> >>
> >>     return(aggregate(data1, as.yearqtr,
> selection2))
> >> }
> >>
> >> fnc(data1)
> >
> >
> >
> >



More information about the R-help mailing list