index out of bounds
37 views (last 30 days)
Show older comments
I have passed a matrix "p" to some function. In that function, I want to check the four neighbourhoods of some pixel.
For that, I got the following error:
Attempted to access p(1,51); index out of bounds because size(p)=[50,50].
How can I workaround this issue?
Thanks.
0 Comments
Answers (3)
Mischa Kim
on 27 Feb 2014
Edited: Mischa Kim
on 27 Feb 2014
As the message implies you are trying to access an element that does not exist. Pixel (1,50) only has 3 neighbours.
... (1,48) (1,49) (1,50)
... (2,48) (2,49) (2,50)
... (3,48) (3,49) (3,50)
The solution would be to define the neighbourhood of a pixel depending on its location. If that approach allows you to even consistently do the comparision, that is.
2 Comments
Mischa Kim
on 27 Feb 2014
Sure, you could. Again, I believe the question is, whether or not your analysis is still valid, since you do analysis on pixels with different number of neighbours. You'd be the only one that can make that call.
As an alternative you could limit your analysis to pixels excluding the outermost ones.
the cyclist
on 27 Feb 2014
What do you mean be work around?
When you are at the edge of your array (index=50), you have to put something in your code to define the "neighborhood" differently, because you cannot access an element at index=51. (That element does not exist in a 50x50 array.)
Andy
on 27 Feb 2014
I assume you have two variables which you are indexing to loop through the image i.e.
for x = 1:50
for y = 1:50
% Code to check condition of neighbouring pixel above
% Code to check condition of neighbouring pixel below
% Code to check condition of neighbouring pixel left
% Code to check condition of neighbouring pixel right
end
end
The first part of the code in each section should be to check if the value of X±1 and Y±1 is still valid. i.e For the first check
if (((x+1)<51)&&((y+1)<51))
% code to check pixel x+1,y+1
else
% return dummy value or ignore
end
0 Comments
See Also
Categories
Find more on Matrix Indexing 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!