Histogram within Minimum Bounding Box
3 views (last 30 days)
Show older comments
How do I calculate the histogram within a minimum bounding box, along the orientation of the rectangle? Let say I have the coordinates of the four corners.
0 Comments
Accepted Answer
Image Analyst
on 11 Jul 2015
Ignore my last answer since it doesn't look like you want "the histogram within a minimum bounding box" like you said first. The second part of your question looks like you really want the radon transform. To get the radon transform, look it up in the help. The radon transform is the sum of your image (the profile) as it's summed along a particular angle, which is what it sounds like you want.
I'm attaching a demo where I use the radon transform to rotate an image to align it with the raster lines.
3 Comments
Image Analyst
on 13 Jul 2015
It you have the coordinates of the box, like you said you did, then the angle is just atan2(deltaY/deltaX). With that angle, you can put it into the radon() function to get the sum of the shape along that direction.
More Answers (1)
Image Analyst
on 11 Jul 2015
If you've gotten the vertices of the ROI, say using John D'Errico's excellent bounding object app, then you can simply use poly2mask to create a binary image and then call imhist():
[rows, columns, numberOfColorChannels] = size(grayImage);
rectMask = poly2mask(xVertices, yVertices, rows, columns);
[pixelCounts, grayLevels] = imhist(grayImage(rectMask));
grayImage(rectMask) gives a 1D list of only those pixels inside your ROI (the tilted rectangle). Of course you'll have some pixels in the black part of your binary image included along with the pixels inside the irregularly-shaped white blob because it's everything inside the rectangle, not just stuff inside the white blob.
0 Comments
See Also
Categories
Find more on Histograms in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!