g(x, y) = T[f(x, y)]
(x, y)处的g值仅有f在该点的灰度决定,T也变为亮度或灰度函数。在处理单色图像时,这两个术语可以相互换用。在处理彩色图像时,亮度用于表示某些色彩空间中的一个彩色图像分量。
g = imadjust(f, [low_in high_in], [low_out high_out], gamma)
>> g1 = imadjust(f, [0 1], [1 0]);
>> imshow(g1);
>> g = imcomplement(f);
>> imshow(g);
imadjust(f, [0 1], [1 0])
imcomplement(f)
两个函数都能表示图片的负片
>> g3 = imadjust(f, [], [], 0.5);
>> imshow(g3);
也可以直接改变gamma值
>> g3 = imadjust(f, stretchlim(f), []);
>> imshow(g3);
g3图片,stretchlim(f)函数实现了对比度拉伸,默认情况下提升了对比度。
在MATLAB中函数对浮点图像实现的方法就是借助公式*g = 1 ./ (1 + (m./f) .^ E)*gs = im2uint8(mat2gray(g));
>> g = im2uint8(mat2gray(z));
>> gs = im2uint8(mat2gray(log(1 + double(z))));
>> imshow(gs);
>> figure, imshow(g);
T为列向量,z是长度与T相同的列向量,使用下面方法实现g = interp1(z, T, f)
==使用取值范围为[0 1]的浮点数来表示输入和输出图像会大大简化程序==z = linspace(0, 1, numel(T));
n = nargin
function [m, n] = testhv3(varargin)
function [varargout] = testhv4(m, n)
%可以有一个固定的输入参数,后面跟随可变数量的输入参数
function [m, n] = testhv3(x, varargin)
>> g = intrans(f, 'stretch', mean2(im2double(f)), 0.9);
>> figure, imshow(g);
实现灰度变换
- 灰度标定的函数
function g = gscale(f, varargin)
if length(varargin) == 0
method = 'full8';
else
method = varargin{1};
end
if strcmp(class(f), 'double') && (max(f(:))>1 || min(f(:))<0)
f = mat2gray(f);
end
switch method
case 'full8'
g = im2uint8(mat2gray(double(f)));
case 'full16'
g = im2uint16(mat2gray(double(f)));
case 'minmax'
low = varargin{2};high = varargin{3};
if low>1 | low<0 | high>1 | high<0
error('Parameters low and high must be in the range [0,1]')
end
if strcmp(class(f), 'double')
low_in = min(f(:));
high_in = max(f(:));
elseif strcmp(class(f), 'uint8')
low_in = double(min(f(:)))./255;
high_in = double(max(f(:)))./255;
elseif strcmp(class(f), 'uint16')
low_in = double(min(f(:)))./65535;
high_in = double(max(f(:)))./65535;
end
g = imadjust(f,[low_in high_in],[low high]);
otherwise
error('Unknown method')
end
调用以下语句
g = gscale(f, method, low, high)
method可以的有效值是‘full8’(默认)、‘full16’和‘minmax’。
h(rk) = nk
rk是区间[0,G]内第k级灰度
nk是出现rk的像素数
p(rk) = h(rk) / n = nk / n
p(rk)是灰度级rk出现的概率估计
处理直方图有一个核心函数
h = imhist(f, b);
b是用来形成直方图“容器”的数目(若b未包含在此参量中,其默认值为256)。
>> imhist(f);
==一个容器只是灰度范围的小部分,b就是将256个级别分为b个部分==
归一化直方图的方法:
p = imhist(f, b) / numel(f)
- bar方法
>> h = imhist(ff, 25);
>> horz = linspace(0, 155, 25);
>> bar(horz, h)
>> axis([0 255 0 60000])
>> set(gca, 'xtick', 0:50:255)
>> set(gca, 'ytick', 0:20000:60000)
>> figure, imshow(h);
>> figure, imshow(ff);
==linspace(x1,x2,N)==
功能:linspace是Matlab中的均分计算指令,用于产生x1,x2之间的N点行线性的矢量。其中x1、x2、N分别为起始值、终止值、元素个数。若默认N,默认点数为100。
==axis([horzmin horzmax vertmin vertmax])==
功能:设定水平和垂直轴的范围
set(gca, ‘xtick’, 0:50:255)
意思是将x轴设定为从0开始每次增加50,直到增加到255,设定也y轴同理。
>> h = imhist(f, 25);
>> horz = linspace(0, 255, 25);
>> stem(horz, h, 'fill')
>> hc = imhist(ff);
>> plot(hc)
>> axis([0 255 0 15000])
>> set(gca, 'xtick', [0:50:255])
>> set(gca, 'ytick', [0:2000:15000])
==set中的gca是用来返回当前axes (坐标图)对象的句柄,也就是返回了一个坐标图像。==
ylim(‘auto’)
xlim(‘auto’)
自动设定符合条件的x, y的范围。也可以手工设定,同下。
ylim([ymin ymax])
xlim([xmin xmax])
fplot(fhandle, limits, ‘LineSpec’)
>> fandle = @sin
fandle =
function_handle with value:
@sin
>> fplot(fandlw, [0 6], ':')
在0到6之间绘制了一个正弦函数图像。
也可以通过其他函数来美化图像
>> fandle.LineStyle = ':';
>> fandle.Color = 'r';
>> fandle.Marker = 'x';
>> fandle.MarkerEdgeColor = 'b';
g = histeq(f, nlev)
>> f = Fig0208;
>> imshow(f);
>> figure, imhist(f);
>> ylim('auto')
进行直方图均衡后
>> g = histeq(f, 256);
>> figure, imshow(g);
>> figure, imhist(g);
>> ylim('auto')
直方图累加求和列出了灰度变化的整个过程
(cumsum函数是表示累加求和,比如
A = 1:5;
B = cumsum(A)
B = 1 3 6 10 15)
>> hnorm = imhist(f) ./ numel(f);
>> cdf = cumsum(hnorm);
>> x = linspace(0, 1, 256);
>> plot(x, cdf)
>> axis([0 1 0 1])
>> set(gca, 'xtick', 0:.2:1)
>> set(gca, 'ytick', 0:.2:1)
>> xlabel('Input intensity values', 'fontsize', 9)
>> ylabel('Output intensity values', 'fontsize', 9)
==可以使用窗口中的Insert来修改插入图形==
g = histeq(f, hspec)
>> imshow(f);
>> figure, imhist(f);
>> g = histeq(f, 256);
>> figure, imshow(g);
>> figure, imhist(g);
在给定工具箱函数中灰度级移到较高端,但是还是给出了一幅低对比度且有褪色的图像。从原始图中看出灰度级在0及其附近过于集中。有直方图得到的累计变换函数很陡,因此把低端过于集中的像素点映射到了灰度级的高端。
利用直方图匹配能够补救这一现象。
- 直方图匹配增强
>> g = histeq(f, p);
>> imshow(g);
>> figure, plot(p);
>> ylim('auto')
>> figure, imhist(g);
这一函数执行所谓的对比度受限的自适应直方图均衡,也就是用直方图匹配的方法来逐个处理图像中的小区域(小片),再将相邻小片结合起来,从而==消除人工引入的边界==。
g = adapthisteq(f, param1, val1, param2, val2…)
param / val是表中内容
>> g1 = adapthisteq(f);
>> g2 = adapthisteq(f, 'NumTiles', [25 25]);
>> g3 = adapthisteq(f, 'NumTiles', [25 25], 'ClipLimit', 0.05);
由图中可以看出,局部增强方法好于全局增强,但是额外的代价是函数的复杂性增加。
相关:按照上面理解的方式处理图像数组。
卷积:模板旋转180度后再以相同的方式处理图像数组。
- full和same
‘full’:填充图像,进行相关计算。
‘same’:产生一个大小与f相同的相关。这种计算同样用0填充,但是开始的位置位于f的原点与模板的中心的对准的位置。
- 实现线性空间滤波
g = imfilter(f, w, filtering_mode, boundary_options, size_option)
w为滤波模板,filtering_mode相关完成滤波为‘corr’,对卷积规定为‘conv’;boundary_options处理边界填充问题,边界大小有滤波器尺寸确定;size_option不是‘same’就是‘full’。
>> f = im2double(f);
>> subplot(231), imshow(f), title('f');
>> w = ones(31);
>> gd = imfilter(f, w);
>> subplot(232), imshow(gd, []), title('gd');
>> gr = imfilter(f, w, 'replicate');
>> subplot(233), imshow(gr, []), title('gr');
>> gs = imfilter(f, w, 'symmetric');
>> subplot(234), imshow(gs, []), title('gs');
>> gc = imfilter(f, w, 'circular');
>> subplot(235), imshow(gc, []), title('gc');
>> f8 = im2uint8(f);
>> g8r = imfilter(f, w, 'replicate');
>> subplot(236), imshow(g8r, []), title('g8r');
线性滤波是基于计算乘积和,而非线性滤波则基于涉及滤波器包围的邻域内像素的非线性操作。
- 非线性滤波器处理函数
g = colifilt(f, [m n], ‘sliding’, fun)
‘sliding’表明处理过程中m x n区域在输入图像f中逐像素滑动,fun是函数句柄。
>> f = Fig0216;
>> subplot(121), imshow(f);
>> gmean = @(A)prod(A, 1) .^ 1/size(A, 1);
>> g = colfilt(f, [5 5], 'sliding', gmean);
>> subplot(122), inshow(g);
fp = padarry(f, [r c], method, direction)
w = fspecial(‘type’, parameters)
>> f = Fig0217;
>> w = [0 1 0; 1 -4 1; 0 1 0];
>> g1 = imfilter(f, w, 'replicate');
>> f2 = im2double(f);
>> g2 = imfilter(f2, w, 'replicate');
>> g = f2 - g2;
>> subplot(141), imshow(f)
>> subplot(142), imshow(g1, [ ])
>> subplot(143), imshow(g2, [ ])
>> subplot(144), imshow(g)
用原图减去拉普拉斯图像就是增强后的图像。
>> f = Fig0217;
>> w4 = fspecial('laplacian', 0);
>> w8 = [1 1 1; 1 -8 1; 1 1 1];
>> f = im2double(f);
>> g4 = f - imfilter(f, w4, 'replicate');
>> g8 = f - imfilter(f, w8, 'replicate');
>> subplot(131), imshow(f);
>> subplot(132), imshow(g4);
>> subplot(133), imshow(g8);
图片清晰度逐渐增加,使用中心系数为-8的拉普拉斯滤波器为三张图片中最清晰的一个。
这些非线性空间滤波器的响应基于对图像邻域中所包含像素的排序,然后使排序结果确定的值替换邻域中的中心像素。
g = ordfilt2(f, order, domain)
使用order个元素去替代f中的每个元素,domain是一个由0和1组成的大小为m x n的矩阵。
g = ordfilt2(f, (m * n + 1) / 2, ones(m, n))
g = medfilt2(f, [m n], padopt)
[m n]定义一个大小为m x n的邻域,padopt指定三个可能的边界填充选项:‘zeros’(默认值),‘symmetric’指出f按照镜像反射方式对称地沿边界扩展,‘indexed’表示若f是double类则用1填充,否则用0填充。
>> f = Fig0219;
>> fn = imnoise(f, 'salt & pepper', 0.2);
>> subplot(141), imshow(f);
>> subplot(142), imshow(fn);
>> gm = medfilt2(fn);
>> subplot(143), imshow(gm);
>> gms = medfilt2(fn, 'symmetric');
>> subplot(144), imshow(gms);