Index exceeds matrix dimensions
Show older comments
Hi, my tutor is sick of my questions, please help!
for j=2:31
dz(j)=abs(depth(j)-depth(j-1))
end
for i=1:360
for j = 1:180
for k=1:31
intFe68 = Fe68(i,j,k) *dy(360) * dx(j) * dz(j)
end
end
end
nansum(intFe68)
Fe68 has dimensions 360x180x31. It is iron data from a model. I can contour a hydrothermal plume by plotting Fe68 against depth and longitude, below I am trying to get one value for the size of the plume in m^3 but matlab doesn't like the second loop due to the 'index exceeding the matrix dimensions'. Im also not sure if I need the first loop, or what to put in the second loop if I do, dz(j), dz(:), dz(k)..
Any help would be very appreciated!
Alex
2 Comments
Chad Greene
on 11 Feb 2017
Hi Alex,
What exactly do you mean by "integrate up to get one value"? Perhaps describing the context and what you're trying to do will help. This looks like maybe a month's worth of ocean iron content data? What exactly are you trying to calculate?
Alexandra Ridgway
on 11 Feb 2017
Edited: Alexandra Ridgway
on 11 Feb 2017
Answers (1)
Walter Roberson
on 12 Feb 2017
In your loop
for j=2:31
dz(j)=abs(depth(j)-depth(j-1))
end
you initialize dz up to dz(31)
In
for i=1:360
for j = 1:180
for k=1:31
intFe68 = Fe68(i,j,k) *dy(360) * dx(j) * dz(j)
end
end
end
you access dz(j) with j from 1 to 180, so you need up to dz(180) to have been defined.
But notice you have k = 1 : 31 so perhaps you should be accessing dz(k) ?
8 Comments
Alexandra Ridgway
on 12 Feb 2017
Walter Roberson
on 12 Feb 2017
If you only have 31 different depths, then why are you trying to access 180 of them? dz(j) when j = 1:180
Perhaps your code should be
intFe68(i,j,k) = Fe68(i,j,k) *dy(360) * dx(j) * dz(k)
but I have to wonder then whether dy(360) should be dy(i) ?
intFe68(i,j,k) = Fe68(i,j,k) * dy(i) * dx(j) * dz(k)
possibly?
Once you figure out the correct multiplications then we could proceed to optimize the code.
... though with your references to getting one value and your use of "intFe68", I wonder whether you should be using trapz() instead of what you are doing now.
Alexandra Ridgway
on 12 Feb 2017
Edited: Alexandra Ridgway
on 12 Feb 2017
Walter Roberson
on 12 Feb 2017
Are you trying to do numeric integration of the entire Fe68 array under the assumption that the distance between first coordinates is dy, the distance between second coordinates is dx, and the distance between third coordinates is dz ? If you are, then you should be using trapz() which is the numeric integration routine.
dy = gradient(y_coordinates);
dx = gradient(x_coordinates);
dz = gradient(z_coordinates);
numeric_integral = trapz( dy, trapz(dx, trapz(dz, Fe68, 3), 2), 1);
Alexandra Ridgway
on 12 Feb 2017
Edited: Alexandra Ridgway
on 12 Feb 2017
Walter Roberson
on 13 Feb 2017
If Fe68(i,j,k) is the concentration of iron at i, j, k, then you could estimate the total iron by using the gradient and trapz that I showed above, without any explicit looping required.
Alexandra Ridgway
on 13 Feb 2017
Walter Roberson
on 13 Feb 2017
NaN would be returned if any element in Fe68 is NaN, or if any element in the the gradients was NaN, and could be potentially be returned if there are infinities in the data.
Categories
Find more on Numerical Integration and Differentiation in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!