Hello,

Your way is much better than to mess with the dim attribute, like I did. But,

"If you can create a data.frame or matrix that has the indices"
Actually, it must be a matrix, indices can't be of type list.


A way to avoid loops/apply altogether, and much faster, is the one creating K3
(K is the result from the op.)

n <- 20

t2 <- system.time({
K2 <- array(0,dim=c(n,n,n,n))
mtx <- data.matrix( expand.grid(x1=1:n,x2=1:n,y1=1:n,y2=1:n) )
K2[mtx] <- apply(mtx, 1, function(x) x["x1"]*x["y2"] - sin(x['x2']*x['y1']) )
})

t3 <- system.time({
K3 <- array(0,dim=c(n,n,n,n))
mtx <- data.matrix( expand.grid(x1=1:n,x2=1:n,y1=1:n,y2=1:n) )
K3[mtx] <- with(data.frame(mtx), x1*y2 - sin(x2*y1))
})


It's also woth noting that both use much more memory than the loop version because the index matrix can be large.

Rui Barradas
Em 15-05-2012 11:00, r-help-requ...@r-project.org escreveu:
Date: Mon, 14 May 2012 13:22:11 -0400 From: David Winsemius <dwinsem...@comcast.net> To: math_daddy <math_da...@hotmail.com> Cc: r-help@r-project.org Subject: Re: [R] How to apply a function to a multidimensional array based on its indices Message-ID: <155f48f0-04c2-4033-a7be-fc5109224...@comcast.net> Content-Type: text/plain; charset=US-ASCII; format=flowed; delsp=yes On May 14, 2012, at 10:09 AM, math_daddy wrote:
>  Hello. I have a 4 dimensional array and I want to fill in the slots
>  with
>  values which are a function of the inputs. Through searching the
>  forums here
>  I found that the function "outer" is helpful for 2x2 matrices but
>  cannot be
>  applied to general multidimensional arrays. Is there anything which
>  can
>  achieve, more efficiently than the following code, the job I want?
>
>  K<- array(0,dim=c(2,2,2,2)) #dimensions will be much larger
>  for(x1 in 1:2)
>  {
>    for(y1 in 1:2)
>    {
>      for(x2 in 1:2)
>      {
>        for(y2 in 1:2)
>        {
>          K[x1,y1,x2,y2]<- x1*y2 - sin(x2*y1) #this is just a dummy
>  function.
>        }
>      }
>    }
>  }
>
If you can create a data.frame or matrix that has the indices
x1,x2,y1,y2 and the values you can use the:  K[cbind(index-vectors)]
<- values construction:

mtx<- data.matrix( expand.grid(x1=1:2,x2=1:2,y1=1:2,y2=1:2) )
K[mtx]<- apply(mtx, 1, function(x) x["x1"]*x["y2"] -
sin(x['x2']*x['y1']) )
#----------------
  >  K
, , 1, 1

           [,1]       [,2]
[1,] 0.158529 0.09070257
[2,] 1.158529 1.09070257

, , 2, 1

             [,1]     [,2]
[1,] 0.09070257 1.756802
[2,] 1.09070257 2.756802

, , 1, 2

           [,1]     [,2]
[1,] 1.158529 1.090703
[2,] 3.158529 3.090703

, , 2, 2

           [,1]     [,2]
[1,] 1.090703 2.756802
[2,] 3.090703 4.756802


>  Thank you in advance for any help.
>
>
>  --
>  View this message in 
context:http://r.789695.n4.nabble.com/How-to-apply-a-function-to-a-multidimensional-array-based-on-its-indices-tp4629940.html
>  Sent from the R help mailing list archive at Nabble.com.
>
>  ______________________________________________
>  R-help@r-project.org  mailing list
>  https://stat.ethz.ch/mailman/listinfo/r-help
>  PLEASE do read the posting guidehttp://www.R-project.org/posting-guide.html
>  and provide commented, minimal, self-contained, reproducible code.
David Winsemius, MD
West Hartford, CT


______________________________________________
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