How to normalize GLCMs created for four offsets?
古いコメントを表示
I am using Matlab 2019b to extract texture features of images using gray level co-occurrence matrix (glcm). I have written the following code to extract rotation invariant features with directions 0, 45, 90, 135. The code creates four glcms and every feature has four values; one per direction.
I = imread('test.jpg')
offsets = [0 1; -1 1;-1 0;-1 -1];
glcm = graycomatrix(I, 'GrayLimits', [], 'Offset',offsets);
stats = graycoprops(glcm);
I want to normalize the glcms then extract each feature from the normalized glcms.
Any help is greatly appreciated.
2 件のコメント
Image Analyst
2020 年 3 月 22 日
Not sure what you want. Do you just want this
glcm = glcm / sum(glcm(:));
or
glcm = glcm / max(glcm(:));
or
glcm = rescale(glcm, 0, 1);
Mohammad Farhad Aryan
2020 年 3 月 23 日
編集済み: Mohammad Farhad Aryan
2020 年 3 月 24 日
回答 (2 件)
Image Analyst
2020 年 3 月 24 日
Regarding your last comment above . . .It told you it's not integer and it needs integer. So, cast it to integer:
uint8Image = uint8(rescale(rgb2gray(mskRgbImg), 0, 255));
Then pass that into graycomatrix().
See my attached glcm demo.
3 件のコメント
Mohammad Farhad Aryan
2020 年 3 月 25 日
Image Analyst
2020 年 3 月 25 日
So don't normalize it. Why do you think each should be normalized? If each is normalized independently then how can you compare them?
Mohammad Farhad Aryan
2020 年 3 月 25 日
Hend Abouche
2022 年 4 月 8 日
編集済み: Image Analyst
2022 年 4 月 8 日
0 投票
Hello, I am working on texture features extraction and I want to ask you why you didn't use just the function graycomatrix in a simple way, but you used the offset. Did you do it so you can specify the pixels that you want to calculate their co-occurrence?
5 件のコメント
Image Analyst
2022 年 4 月 8 日
The default says to only consider the pixel to the right of the moving pixel. Doing that, you'll never learn if there is any pattern in the vertical direction. If you specify more directions then it looks at the values all around the moving pixel, like the average texture in all directions. You only need to do 4 of the 8 because you'll pick up the "unused" pairs once the pixel moved to the line below. For example if you're at column 10, row 5, if you looked at all 8 angles, then when you're on row 5 you'll get the pair of pixels at column 10 at rows 5 and 6 (which is below the pixel). But then when you get to the row below, 6, if you looked all around, you'll get the pair of pixels in rows 5 and 6 again (which is above the current pixel). So there is no need to spend the time to consider the same pair of pixels twice, so you just look at 4 directions, instead of all 8.
Hend Abouche
2022 年 4 月 9 日
Thank u so much for this answer, I really got the idea, and plz I have one more question what is the use of graylimits and Numlevels?, cuz we already convert the rgb image to gray before passing it to graycomatrix function
Image Analyst
2022 年 4 月 9 日
I think it's similar to using different numbers of bins in a histogram. Maybe you want fewer, maybe you want more. Personally I just use as many levels as there are gray levels, like 256 if the image is uint8.
Hend Abouche
2022 年 4 月 9 日
So I did, thank you so much for ur time
nissrine Neyy
2022 年 6 月 23 日
Hi @Image Analyst, i have a question in the same context, what's the difference between using symmetric and not (set it to false or true), i know how it works but in term of results which is better and what does it give or add as an information ?
カテゴリ
ヘルプ センター および File Exchange で Texture Analysis についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!
