* 046746 *Data Types *Image Representation *Image/Video I/O *Matrix access *Image Manipulation *MEX - MATLAB Executable *Data Visualization *General Tips *Tricks * *Relevant data types * double – default in most cases * single * uint8 – [0 255] * uint16 – [0 65,535] * Logical – [0 1] *Simple casting: double(), uint8(). *Useful when displaying images with a dynamic range not corresponding to its actual type. *Conversion: im2double(),im2uint8(),lab2double(),lab2uint8() * I = imread('world.jpg'); I2 = I-1.4; diffI = I-I2; fprintf('Max difference between images: %d\n',max(diffI(:))); figure(1); subplot(1,2,1); imshow(I); title('I'); subplot(1,2,2); imshow(I2); title('I2'); Max difference between images: 1 I * I2 I = double(imread('world.jpg')); I2 = I-1.4; diffI = I-I2; fprintf('Max difference between images: %2.1f\n',max(diffI(:))); figure(1); subplot(1,2,1); imshow(I); title('I'); subplot(1,2,2); imshow(I2); title('I2'); Max difference between images: 1.4 I * I2 2D Matrix * Intensity: Each pixel value in the dynamic range [minP, maxP]. * Can represent a grayscale image, results of a 2d function, fuzzy ground truth, etc. * Useful commands: imagesc(), axis, colormap(). * Binary: a.k.a masks. * Can represent absolute ground truth, etc. * Useful commands: bwlabel(),bwmorph(),bwdist(),im2bw(),bwperim(). * 2D Matrix * Indexed: Each pixel value in the range [minP, maxP]. * Can represent segmentation. * Useful commands: regionprops(),label2rgb() * 3D Matrix * True Color: Three 2D matrices stacked. Each represents a color component. (e.g. RGB) * Can represent an RGB color image,LAB image, etc. * Useful commands: imshow(),rgb2gray(),rgb2ind(). * Useful Commands * imread() – read image * imwrite() – write image * im2fram() – convert image to movie frame * movie2avi() – write avi file * aviread() – read avi file * mmreader()/VideoReader() – read video (better) * movie() – show movie * Useful Commands: * sub2ind()– convert subscript (e.g. (r,c,clr)) to index (n). * Ind2sub() – convert index (n) to subscipt (e.g. (r,c,clr)). * meshgrid() – generate X,Y grids. * Useful Commands: * * imcrop()– Useful for interactive cropping. * imrotate()– Rotate image. * imfilter() – Use kernal to convolve/correlation. * nlfilter() – Sliding neighborhood operation. * blkproc() – Perform function on (semi-)destinct blocks. * fspecial() – Create common image filter kernals. * imresize() – Resize image using defined interpolation. * kron() – Kronecker tensor product * padarray() – Pad image. * colfilt() – Colum-stack filtering (faster) * imfreehand()- Select region with mouse * Dynamically linked subroutines produced from C, C++ or Fortran source code. * Useful when dealing with non efficient-Matlab algorithms (e.g. iterative algorithm implemented as loops). * mex –setup : Setup mex compiling configurations. * Useful Commands: * scatter() – Useful to plot points on image. * Imagesc() – Useful for 2D data. * print() – Save figure as image on disk (careful with lossy compressions) * * Avoid loops * Manage memory (Clear unused variables) * Useful command: clearvars() * Avoid memory duplication – use nested functions function myfun A = magic(500); function setrowval(row, value) A(row,:) = value; end setrowval(400, 0); disp('The new value of A(399:401,1:10) is') A(399:401,1:10) end * Long-Term Usage (Windows Systems Only) On 32-bit Microsoft Windows, the workspace of MATLAB can fragment over time due to the fact that the Windows memory manager does not return blocks of certain types and sizes to the operating system. Clearing the MATLAB workspace does not fix this problem. You can minimize the problem by allocating the largest variables first. This cannot address, however, the eventual fragmentation of the workspace that occurs from continual use of MATLAB over many days and weeks, for example. The only solution to this is to save your work and restart MATLAB. The pack command, which saves all variables to disk and loads them back, does not help with this situation. * Stenography (Wikipedia) The art of hiding a message within another larger message Original * Result Stenography (Wikipedia) The art of hiding a message within another larger message I= imread('StenographyOriginal.png'); I4=85*mod(I,4); figure; subplot(1,2,1) imshow(I); title('Original'); subplot(1,2,2) imshow(I4);title('Result'); * Almost Connected (Steve Eddins’ Blog) * Almost Connected (Steve Eddins’ Blog) url = 'http://blogs.mathworks.com/images/steve/2010/blobs_in_clumps.png'; bw = imread(url); lbl = bwlabel(bw); figure; imagesc(lbl); axis image; 50 100 150 200 250 300 * 50 100 150 200 250 300 Almost Connected (Steve Eddins’ Blog) bw2 = bwdist(bw) <= 12.5; lbl2 = bwlabel(bw2); figure; imshow(bw2); figure; imagesc(lbl2); axis image; 50 100 150 200 250 300 * 50 100 150 200 250 300 Almost Connected (Steve Eddins’ Blog) lbl3 = lbl2.*bw; figure; imagesc(lbl3); axis image; 50 100 150 200 250 300 * 50 100 150 200 250 300 Feature AND (Steve Eddins’ Blog) bw = imread('text.png'); dots = rand(size(bw))>0.99; * Feature AND (Steve Eddins’ Blog) touching_pixels = bw & dots; Overlapping * Feature AND (Steve Eddins’ Blog) out = imreconstruct(touching_pixels, bw); Reconstructed *