Image analysis for speckle pattern
22 次查看(过去 30 天)
显示 更早的评论
I have a NxN real (double) matrix which contains the information of a speckle pattern like the one shown in figure 1 (see the attachement).
The main goal here is to have a size distribution of the "speckle grains", so we can divide the problem in two different parts:
- given the image (or the matrix, whatever is the best for the algorithm), try to find the grains of the image;
- for each grain, apply some sort of analysis (contour? regionprops? edge?) in order to extrapolate the information of its size (i.e.: is it possible to fit a circunference and then extrapolate the diameter/radius?)
The idea is to apply a sort of "pattern recognition" in order to extrapolate both the number of grains and their size information, is it possible?
2 个评论
DGM
2023-2-1
In order to isolate the grains and get information about their properties, you need to first decide what defines a "grain" and how each grain is distinct from the background and its neighbors.
I see a lot of features that are large entangled blobs. If you expect those features to be divided into smaller parts, @Benjamin Thompson's suggestion might be a good place to start.
回答(3 个)
Benjamin Thompson
2023-1-31
It is possible, try looking over this example:
3 个评论
Benjamin Thompson
2023-2-1
We cannot help you define what is a grain in your problem, but once you have done that, these methods will calcalate the grain area and other properties. If you are having problems with this, sometimes changing how the image is captured can help. Try different lighting, a different type of camera, etc.
Image Analyst
2023-2-1
It's not obvious what a single grain is. What instrument created this? Was it an AFM? Can you zoom in so that the "grains" are bigger than a few pixels? What material is this?
Otherwise I think you'll need to look to other metrics to describe what you are trying to correlate your image analysis measurement to. Like for example you want some image metric to correlate with strength of the material. Well maybe you can measure some bulk metric like the standard deviation of the gray levels and that might be just as good as if you were able to find the grain area distribution.
Bjorn Gustavsson
2023-2-3
A couple of things I'd try would be to determine the size-distribution of the speckles at different intensity-levels. This I'd do by determining the grain-boundaries at some intensity-levels using contour and either of contour-matrix-to-coordinates or getcontourlinecoordinates to get the speckle-boundaries, then find all contours that are closed and calculate their areas using
For each speckle j.
It should be reasonably straightforward to determine which contours are closed - same start and end-point, at least to within double-precision.
Once you have the contour-coordinates and loop over all speckles you might as well calculate the total intensity inside a speckle, for that you should have good use of inpolygon to determine which pixels belong to a speckle (this might not be very efficient, but this should not be a too time-consuming task anyway). You might just as well calculate the centroids (both the area-centroid and the center-of-intensity) of the speckles and look at the distribution of those over the image (nearest-neighbor-distance and whatnot.)
HTH
0 个评论
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!