使用matlab对图片灰度值进行简单的运算修改

对图片进行基本运算

上下截断

对低于n的灰度值固定为n,高于m的灰度值固定为m。

matlab代码

scss 复制代码
% 读取图像
originalImage = imread("D:\Project\programmes\数字图像处理\R.jpg"');
% 如果图像是彩色的,则转换为灰度图像
if size(originalImage, 3) == 3
    grayImage = rgb2gray(originalImage);
else
    grayImage = originalImage;
end
% 设置灰度值截断的上限和下限
n = 80;
m = 180;
OriginalGrayImage = grayImage;
% 对低于n的灰度值固定为n
grayImage(grayImage < n) = n;
% 对高于m的灰度值固定为m
grayImage(grayImage > m) = m;
% 在同一窗口内并排显示原始图像和处理后的图像
figure;
subplot(1, 2, 1); % 分割窗口为1行2列,并定位到第1个位置
imshow(OriginalGrayImage), title('Original Image');
subplot(1, 2, 2); % 定位到第2个位置
imshow(grayImage), title('Truncated Image');ayImage), title('Truncated Image');

效果

补偿

对所有像素灰度值提升50,超出255的部分算255。

matlab代码

ini 复制代码
% 读取图像
originalImage = imread("D:\Project\programmes\数字图像处理\R.jpg");
% 如果图像是彩色的,则转换为灰度图像
if size(originalImage, 3) == 3
    grayImage = rgb2gray(originalImage);
else
    grayImage = originalImage;
end
% 提升所有灰度值n,但不超过255
n = 50; % 可以根据需要更改此值
enhancedImage = grayImage + n;
enhancedImage = min(enhancedImage, 255); % 确保灰度值不超过255
% 在同一窗口内并排显示原始图像和增强后的图像
figure;
subplot(1, 2, 1); % 分割窗口为1行2列,并定位到第1个位置
imshow(grayImage), title('Original Image');
subplot(1, 2, 2); % 定位到第2个位置
imshow(enhancedImage), title('Enhanced Image');

效果

平方

对灰度值做平方处理,超出255的部分算255。

matlab代码

ini 复制代码
% 读取图像
originalImage = imread("D:\Project\programmes\数字图像处理\R.jpg");
% 如果图像是彩色的,则转换为灰度图像
if size(originalImage, 3) == 3
    grayImage = rgb2gray(originalImage);
else
    grayImage = originalImage;
end
% 对灰度值进行平方处理
squaredImage = double(grayImage).^2;
% 限制最大值不超过255
squaredImage = min(squaredImage, 255);
% 将处理后的图像转换回uint8类型以便显示
squaredImage = uint8(squaredImage);
% 在同一窗口内并排显示原始图像和处理后的图像
figure;
subplot(1, 2, 1); % 分割窗口为1行2列,并定位到第1个位置
imshow(grayImage), title('Original Image');
subplot(1, 2, 2); % 定位到第2个位置
imshow(squaredImage), title('Squared Image');

效果

方根

对灰度值做方根处理。

matlab代码

ini 复制代码
% 读取图像
originalImage = imread("D:\Project\programmes\数字图像处理\R.jpg");
% 如果图像是彩色的,则转换为灰度图像
if size(originalImage, 3) == 3
    grayImage = rgb2gray(originalImage);
else
    grayImage = originalImage;
end
% 对灰度值进行平方处理
squaredImage = double(grayImage).^2;
% 限制最大值不超过255
squaredImage = min(squaredImage, 255);
% 将处理后的图像转换回uint8类型以便显示
squaredImage = uint8(squaredImage);
% 在同一窗口内并排显示原始图像和处理后的图像
figure;
subplot(1, 2, 1); % 分割窗口为1行2列,并定位到第1个位置
imshow(grayImage), title('Original Image');
subplot(1, 2, 2); % 定位到第2个位置
imshow(squaredImage), title('Squared Image');

效果

求反

将每个像素的灰度值从当前值转换为255减去当前值。

matlab代码

ini 复制代码
% 读取图像
originalImage = imread("D:\Project\programmes\数字图像处理\R.jpg");

% 如果图像是彩色的,则转换为灰度图像
if size(originalImage, 3) == 3
    grayImage = rgb2gray(originalImage);
else
    grayImage = originalImage;
end

% 对灰度值进行求反处理
invertedImage = 255 - grayImage;

% 在同一窗口内并排显示原始图像和求反处理后的图像
figure;
subplot(1, 2, 1); % 分割窗口为1行2列,并定位到第1个位置
imshow(grayImage), title('Original Image');

subplot(1, 2, 2); % 定位到第2个位置
imshow(invertedImage), title('Inverted Image');

效果

放缩

将灰度值乘以n倍,如果超过255则按照255算。

matlab代码

ini 复制代码
% 读取图像
originalImage = imread("D:\Project\programmes\数字图像处理\R.jpg");
% 如果图像是彩色的,则转换为灰度图像
if size(originalImage, 3) == 3
    grayImage = rgb2gray(originalImage);
else
    grayImage = originalImage;
end
% 设置放大倍数n
n = 2; % 例如放大2倍,您可以根据需要调整这个值
% 将灰度值乘以n倍
scaledImage = double(grayImage) * n;
% 限制最大值不超过255
scaledImage = min(scaledImage, 255);
% 将处理后的图像转换回uint8类型以便显示
scaledImage = uint8(scaledImage);
% 在同一窗口内并排显示原始图像和放缩后的图像
figure;
subplot(1, 2, 1); % 分割窗口为1行2列,并定位到第1个位置
imshow(grayImage), title('Original Image');
subplot(1, 2, 2); % 定位到第2个位置
imshow(scaledImage), title('Scaled Image');

效果

Gamma

将灰度值做γ次方运算。

matlab代码

ini 复制代码
% 读取图像
originalImage = imread("D:\Project\programmes\数字图像处理\R.jpg");
% 如果图像是彩色的,则转换为灰度图像
if size(originalImage, 3) == 3
    grayImage = rgb2gray(originalImage);
else
    grayImage = originalImage;
end
% 设置Gamma值
gamma = 1.1; % 举例使用1.1,可以根据需要调整
% 应用Gamma运算
gammaCorrectedImage = double(grayImage).^gamma;
% 将处理后的图像转换回uint8类型以便显示
gammaCorrectedImage = uint8(gammaCorrectedImage);
% 在同一窗口内并排显示原始图像和Gamma处理后的图像
figure;
subplot(1, 2, 1); % 分割窗口为1行2列,并定位到第1个位置
imshow(grayImage), title('Original Image');
subplot(1, 2, 2); % 定位到第2个位置
imshow(gammaCorrectedImage), title(['Gamma Corrected Image, Gamma = ', num2str(gamma)]);

效果

相关推荐
白鹭float.9 天前
【OpenGL/Assimp】渲染模型、半透明材质与封装光源
c++·图形学·opengl·assimp
白鹭float.13 天前
【OpenGL/C++】面向对象扩展——测试环境
c++·图形学·opengl
三翼鸟数字化技术团队1 个月前
模型工作流:自动化的模型内部三角面剔除
计算机图形学·图形学
ttod_qzstudio1 个月前
Unity中Mesh重叠顶点合并参考及其应用
unity·图形学
Ian10252 个月前
《Learn Three.js》学习(3)光源
前端·javascript·学习·webgl·图形学·三维·三维光源
哈市雪花2 个月前
图像处理 之 凸包和最小外围轮廓生成
图像处理·人工智能·图形学·最小外围轮廓·最小外包
zaizai10073 个月前
WebGL编程指南 - 颜色与纹理续
图形学
zaizai10073 个月前
WebGL编程指南 - 绘制和变换三角形
图形学
zaizai10073 个月前
WebGL编程指南 - 入门续
图形学
闲人编程4 个月前
使用Python实现图形学的阴影贴图算法
python·算法·图形学·贴图·阴影贴图