Contents
- this matlab code provides some techniques and methods to view and identify organs of a CT image
- plot histogram of the image
- perform the color map of a CT image
- HSV space
- filtering demo on the CT data
- average filter by hand
- high-pass by hand
- average filter
- gaussian filter
- unsharp mask
- laplacian
- laplacian of gaussian
- threshold
- prewitt edge filter
- sobel edge filter
- standard deviation edge filter
- skew filter
- kurtosis filter
this matlab code provides some techniques and methods to view and identify organs of a CT image
The first method is to use histogram to segment the second method is to use color a CT image third method is filter.
% read a CT image I=imread('./Abdominal wall normal anat (8).png');
plot histogram of the image
subplot(311); % plot to ensure a correct image is loaded.
imhist(I)
subplot(3,1,2:3);
imshow(I);
colorbar
perform the color map of a CT image
colormap(jet); caxis caxis([0,255]);
ans = 0 255
colormap( [repmat([0,0,0],[50,1]); ... % 0-50 repmat([0,1,0],[50,1]);... % 51-100 repmat([1,0,0],[75,1]);... % 100-175 repmat([0,0,1],[50,1]);... % 176-225 repmat([1,1,1],[56-25,1])]); colorbar
HSV space
convert to single-precision floating point
I = single(I); [ny,nx] = size(I); Ihsv = zeros(ny,nx,3); Ihsv(:,:,2) = 0.5; Ihsv(:,:,3) = I/max(I(:)); % add color th1 = 50; th2 = 100; th3 = 170; Ihsv(:,:,1) = Ihsv(:,:,1) + (I<th1) * 0; Ihsv(:,:,1) = Ihsv(:,:,1) + (I>th1 & I<th2) * 0.1; Ihsv(:,:,1) = Ihsv(:,:,1) + (I>th2 & I<th3) * 0.2; Ihsv(:,:,1) = Ihsv(:,:,1) + (I>th3 & I<225) * 0.5; Ihsv(:,:,1) = Ihsv(:,:,1) + (I>225) * 0.8; imshow(hsv2rgb(Ihsv));
filtering demo on the CT data
clf;
imagesc(I);colormap(gray);
title('unfiltered');
average filter by hand
n = 5;
b = ones(n,n)/ (n*n);
I2 = conv2(I,b,'same');
imagesc(I2);
high-pass by hand
b = [-1, -1, -1; -1, 7.9866, -1; -1, -1, -1];
I2 = conv2(I,b,'same');
imagesc(I2);
colorbar
mean(I2(:))
caxis([-200,300])
ans = -0.0026
average filter
I=single(I); b = fspecial('average',[9,9]); I2 = conv2(I,b,'same'); imagesc(I2);
gaussian filter
note: pick filter size appropriately imagausfilt avoids this problem
I=single(I); b = fspecial('gaussian',32,2); I2 = conv2(I,b,'same'); imagesc(I2);
unsharp mask
b = fspecial('unsharp'); subplot(221); imagesc(b); colorbar; subplot(222); imagesc(I); subplot(224); I2 = conv2(I,b,'same'); imagesc(I2);
laplacian
clf b = fspecial('laplacian'); I2 = conv2(I,b,'same'); imagesc(I2);
data:image/s3,"s3://crabby-images/9bfb3/9bfb3e50d82dd34b0939a45837677f9135a23346" alt=""
laplacian of gaussian
b = fspecial('log'); I2 = conv2(I,b,'same'); imagesc(I2); colorbar
data:image/s3,"s3://crabby-images/c913d/c913d13651b74ded0efce87b7d82c80c68b1814e" alt=""
threshold
imagesc(abs(I2)>60);
data:image/s3,"s3://crabby-images/d595a/d595a58376f31a8dd4782590f6f58b54df772314" alt=""
prewitt edge filter
b = fspecial('prewitt'); I2 = conv2(I,b.','same'); imagesc(abs(I2)); colorbar caxis([0,300])
data:image/s3,"s3://crabby-images/1002c/1002caa17b6e9c5b3704c472054d968b6079b50e" alt=""
imagesc(abs(I2)>150)
data:image/s3,"s3://crabby-images/9cf99/9cf999ce830de1d8d6fbf81ccc247b239c1aba6c" alt=""
sobel edge filter
b = fspecial('sobel'); I2 = conv2(I,b,'same'); imagesc(I2); colorbar
data:image/s3,"s3://crabby-images/fbc7b/fbc7b1dc8938ba88863bc205ead9deedf71b05fe" alt=""
imagesc(abs(I2)>200)
data:image/s3,"s3://crabby-images/a02bd/a02bdec91d6c95c76299c7ad4c2585865eba1744" alt=""
standard deviation edge filter
I2 = nlfilter(I, [3,3], 'std2');
imagesc(I2);
colorbar;
data:image/s3,"s3://crabby-images/8c3a1/8c3a153ab3e2533c1d485766baf09bc2953ca570" alt=""
imagesc(I2>10);
data:image/s3,"s3://crabby-images/1a31b/1a31b11f36772e60089f90bff4fcb0ca8d545483" alt=""
skew filter
f = @(X) skewness(X(:)); I2 = nlfilter(I, [3,3], f); imagesc(I2); colorbar;
data:image/s3,"s3://crabby-images/1221e/1221e41f089538539348c31da5bf147afad37be6" alt=""
kurtosis filter
f = @(X) kurtosis(X(:)); I2 = nlfilter(I, [16,16], f); imagesc(I2); colorbar;
data:image/s3,"s3://crabby-images/f5897/f5897136f4aaf0adbc191bcad1f6f768c5ad03ae" alt=""
No comments:
Post a Comment