[R] exercise in frustration: applying a function to subsamples
Erik Iverson
eriki at ccbr.umn.edu
Mon Jul 12 21:20:21 CEST 2010
Your code is not reproducible. Can you come up with a small example
showing the crux of your data structures/problem, that we can all run in
our R sessions? You're likely get much higher quality responses this way.
Ted Byers wrote:
>>From the documentation I have found, it seems that one of the functions from
> package plyr, or a combination of functions like split and lapply would
> allow me to have a really short R script to analyze all my data (I have
> reduced it to a couple hundred thousand records with about half a dozen
> records.
>
> I get the same result from ddply and split/lapply:
>
>> ddply(moreinfo,c("m_id","sale_year","sale_week"),
>> + function(df) data.frame(res = fitdist(df$elapsed_time,"exp"),est =
>> res$estimate,sd = res$sd))
>> Error in fitdist(df$elapsed_time, "exp") :
>> data must be a numeric vector of length greater than 1
>>
>
> and
>
>> lapply(split(moreinfo,list(moreinfo$m_id,moreinfo$sale_year,moreinfo$sale_week)),
>> + function(df) fitdist(df$elapsed_time,"exp"))
>> Error in fitdist(df$elapsed_time, "exp") :
>> data must be a numeric vector of length greater than 1
>>
>
> Now, in retrospect, unless I misunderstood the properties of a data.frame, I
> suppose a data.frame might not have been entirely appropriate as the m_id
> samples start and end on very different dates, but I would have thought a
> list data structure should have been able to handle that. It would seem
> that split is making groups that have the same start and end dates (or that
> if, for example, I have sale data for precisely the last year, split would
> insist on both 2009 and 2010 having weeks from 0 through 52 instead of just
> the weeks in each year that actually have data: 26 through 52 for last year
> and 1 through 25 for this year). I don't see how else the data passed to
> fitdist could have a sample size of 0.
>
> I'd appreciate understanding how to resolve this. However, it isn't s show
> stopper as it now seems trivial to just break it out into a loop (followed
> by a lapply/split combo using only sale year and sale month).
>
> While I am asking, is there a better way to split such temporally ordered
> data into weekly samples that respective the year in which the sample is
> taken as well as the week in which it is taken?
>
> Thanks
>
> Ted
>
> [[alternative HTML version deleted]]
>
> ______________________________________________
> R-help at 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.
More information about the R-help
mailing list