[R] R lappy, sapply or mapply question
Adams, Jean
jvadams at usgs.gov
Fri Oct 9 23:56:15 CEST 2015
You were very close. Try this.
df <- data.frame(x5=dailyrecord$a, x6 = dailyrecord$e, x7 = dailyrecord$f)
apply(df, 1, function(row) fun3(list1, list2, as.list(row)))
Jean
On Fri, Oct 9, 2015 at 3:15 PM, liqunhan--- via R-help <r-help at r-project.org
> wrote:
>
>
> Hello, R-experts,
> In R-program, I have a question about the apply-family.
> I want to use apply-family to replace a for-loop in my R-code,But, lapply
> returns a list of 3 (each component is the same), sapply returns a matrix,
> and mapply with error message.
> how to use apply-family function so that it returns a vector, as it does
> when using for-loop in my R-codes below?
> Hope to hear back soon!
> Thank you very much!
>
>
>
> #-------------------------------------------------------------------------
> # Below is my R-codes:
> #----------- begin of R code --------------------------------------
> # suppose list1 returned by fun1()
> # fun1() is a R-script with about 200 lines
> list1 <- list(u=3.8, v=53.42)# suppose list2 returned by fun2()
> # fun2() is a R-script with about 5000 lines
> list2 <- list(x=3.8, y=-9,3)# demo fun3(), the actual function is much
> more complicated
> fun3 <- function(xlist1, xlist2, xlist3) {
>
> x1 <- xlist1$u
> x2 <- xlist1$v
>
> x3 <- xlist2$x
> x4 <- xlist2$y
>
> x5 <- xlist3$x5
> x6 <- xlist3$x6
> x7 <- xlist3$x7
>
> w <- x1^2 + sqrt(x2+x3) - 0.75*x4 + exp(x5)
> z <- sin(x2)/x7 + x6/(x3+x4)
> return(w+z)
> }dailyrecord <- data.frame(a = rnorm(50000), b = rnorm(50000), c =
> rnorm(50000),
> d = rnorm(50000), e = rnorm(50000), f =
> rnorm(50000),
> g = rnorm(50000))
> result_forloop <- rep(0, 50000)
> # use for - loop ## how to avoid the for-loop ??for (k in 1 : 50000) {
> xlist <- list(x5 = dailyrecord$a[k], x6 = dailyrecord$e[k], x7 =
> dailyrecord$f[k])
> result_forloop[k] <- fun3(list1, list2, xlist)
> }# use lapply #--- return a list of 3 ------------
> xlst <- list(x5=dailyrecord$a, x6 = dailyrecord$e, x7 = dailyrecord$f)
> result_lapply <- lapply(xlst, function(s) fun3(list1, list2, xlst))
>
> # use sapply #--- return a matrix -------
> result_sapply <- sapply(xlst, function(s) fun3(list1, list2, xlst))
>
> # use mapply #--- error -------
> result_mapply <- mapply(fun3, xlist1 = list1, xlist2 = list2, xlist3 =
> xlst)
>
> #----------- end of R code --------------------------------------
>
>
> [[alternative HTML version deleted]]
>
> ______________________________________________
> R-help at r-project.org mailing list -- To UNSUBSCRIBE and more, see
> 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.
[[alternative HTML version deleted]]
More information about the R-help
mailing list