Re: "stepwise" integrating a 2D array
- To: mathgroup at smc.vnet.net
- Subject: [mg91205] Re: "stepwise" integrating a 2D array
- From: Jens-Peer Kuska <kuska at informatik.uni-leipzig.de>
- Date: Sat, 9 Aug 2008 07:46:44 -0400 (EDT)
- References: <g7h9mc$b73$1@smc.vnet.net>
Hi,
try
hvAccumulate[m_] :=
Reverse[Rest[FoldList[#1 + #2 & , 0, #]] & /@
Transpose[
Rest[FoldList[#1 + #2 & , 0, #]] & /@ Transpose[Reverse[m]]]]
and
hvAccumulate[{{a1, a2}, {b1, b2}}]
gives
{{a1 + b1, a1 + a2 + b1 + b2},
{b1, b1 + b2}}
Regards
Jens
Claus wrote:
> Hi,
> I have an array, consisting of n tuples (x,y,z).
> The first entry is the point at the bottom left (thinking in a
> coordinate system, smallest (x,y) pair).
> Now I want to do something like an "stepwise"/empirical integral over (x,y).
>
> Schematically, if I had a 2x2 array (only the z-values),like
>
> a1 a2
> b1 b2
>
> I would want an array like this:
>
> a1+b1 b1+b2+a1+a2
> b1 b1+b2
>
> In the code below, "xyzVals" is the array that I want to integrate,
> containing the (x,y,z) tuples.
>
> I could do a bunch of for loops, but I am trying to not use do loops in
> mathematica whenever possible.
> Is it possible to do it without?
> I tried some of the examples from
> http://www.verbeia.com/mathematica/tips/HTMLLinks/Tricks_A-K_3.html
> and I also thought about an array with sub-arrays,
> but couldn't get it for me to work.
>
> Thanks for any pointers!
> Claus
>
>
> In[13]:= X = RandomReal[{0, 1}, 500];
> Y = RandomReal[{0, 1}, 500];
> BinWidth = 0.2;
> DensVals =
> Flatten[BinCounts[
> Transpose[{X, Y}], {0, 1, BinWidth}, {0, 1, BinWidth}]]
>
> Out[16]= {16, 16, 17, 26, 23, 23, 16, 18, 25, 17, 13, 26, 26, 21, 19, \
> 15, 32, 20, 21, 15, 11, 26, 16, 19, 23}
>
> In[17]:= xyzVals = Table[{i/(1/BinWidth) + (BinWidth/2),
> j/(1/BinWidth) + (BinWidth/2),
> DensVals[[(1/BinWidth) i + j + 1]]}
> , {i, 0, (1/BinWidth) - 1}
> , {j, 0, (1/BinWidth) - 1}]
>
> Out[17]= {{{0.1, 0.1, 16}, {0.1, 0.3, 16}, {0.1, 0.5, 17}, {0.1, 0.7,
> 26}, {0.1, 0.9, 23}}, {{0.3, 0.1, 23}, {0.3, 0.3, 16}, {0.3, 0.5,
> 18}, {0.3, 0.7, 25}, {0.3, 0.9, 17}}, {{0.5, 0.1, 13}, {0.5, 0.3,
> 26}, {0.5, 0.5, 26}, {0.5, 0.7, 21}, {0.5, 0.9, 19}}, {{0.7, 0.1,
> 15}, {0.7, 0.3, 32}, {0.7, 0.5, 20}, {0.7, 0.7, 21}, {0.7, 0.9,
> 15}}, {{0.9, 0.1, 11}, {0.9, 0.3, 26}, {0.9, 0.5, 16}, {0.9, 0.7,
> 19}, {0.9, 0.9, 23}}}
>