An embedded and charset-unspecified text was scrubbed... Name: not available URL: <https://stat.ethz.ch/pipermail/r-help/attachments/20110802/034fc4da/attachment.pl>
Help with aggregate syntax for a multi-column function please.
3 messages · Michael Karol, Jean V Adams, Dennis Murphy
An embedded and charset-unspecified text was scrubbed... Name: not available URL: <https://stat.ethz.ch/pipermail/r-help/attachments/20110802/602e0ee2/attachment.pl>
Hi:
Another way to do this is to use one of the summarization packages.
The following uses the plyr package.
The first step is to create a function that takes a data frame as
input and outputs either a data frame or a scalar. In this case, the
function returns a scalar, but if you want to carry along additional
variables in the output, you can replace it with a data frame that
returns the set of variables you want. You don't need to return the
grouping variables, but no harm is done if you do.
# This assumes the existence of a function AUC with the arguments
# you stated in your post. I presume it returns a scalar value; if not,
# you should modify it to return a data frame instead. It would probably
# be better to modify AUC and call it in ddply() directly, but without the
# function code there's not much one can do...
myAUC <- function(df)
AUC(df, 'TimeBestEstimate', 'Pt','ConcentrationBQLzero')
library('plyr')
ddply(PKdata, .(Cycle, DoseDayNominal, Drug), myAUC)
This is obviously untested, so caveat emptor. Both plyr and data.table
can accept functions with multiple arguments and do the right thing.
The trick in plyr is to write a function that takes a generic input
object (e.g., a (sub)data frame) and then uses (the variables within)
it to do the necessary calculations. Generally, you want the output of
the function to be compatible with the type of output you want from
the **ply() function. In this case, ddply() means data frame input,
data frame output; alply() would mean array input and list output,
etc.
If this doesn't work, please provide a reproducible example.
HTH,
Dennis
On Tue, Aug 2, 2011 at 7:32 AM, Michael Karol <MKarol at syntapharma.com> wrote:
Dear R-experts:
I am using a function called AUC whose arguments are data, time, id, and
dv.
data is the name of the dataframe,
time is the independent variable column name,
id is the subject id and
dv is the dependent variable.
The function computes area under the curve by trapezoidal rule, for each
subject id.
I would like to embed this in aggregate to further subset by each Cycle,
DoseDayNominal and Drug, but I can't seem to get the aggregate syntax
correct. ?All the examples I can find use single column function such as
mean, whereas this AUC function requires four arguments.
Could someone kindly show me the syntax?
This is what I've tried so far:
AUC.DF<- aggregate(PKdata, list(PKdata$Cycle, PKdata$DoseDayNominal,
PKdata$Drug),
? ? ? ? ? ? ? ? ? function(x,tm,pt,conc) {AUC(x)},
tm="TimeBestEstimate", pt="Pt", conc="ConcentrationBQLzero" )
AUC.DF<- aggregate(PKdata, list(PKdata$Cycle, PKdata$DoseDayNominal,
PKdata$Drug),
? ? ? ? ? ? ? ? ? function(x) {AUC(x,"TimeBestEstimate", "Pt",
"ConcentrationBQLzero" )} )
AUC syntax is:
args(AUC)
function (data, time = "TIME", id = "ID", dv = "DV")
thanks
Regards,
Michael
? ? ? ?[[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.