使用 R 处理图像

在 R 中进行图像处理,使用像 imager 这样的包,可以实现强大的数字图像分析和处理。本博客将基于"图像数据分析"文档的概念,演示使用 imager 包进行的关键技术------图像增强、去噪和直方图均衡化,并通过可视化结果展示这些效果。

理解数字图像

数字图像是一个二维函数 f ( x , y ) : R 2 → R f(x, y): \mathbb{R}^2 \rightarrow \mathbb{R} f(x,y):R2→R,其中 ( x , y ) (x, y) (x,y) 是空间坐标, f ( x , y ) f(x, y) f(x,y) 表示像素强度。在数字图像中,像素具有离散的位置和值。对于8位灰度图像,强度范围从0(黑色)到255(白色)。图像可分为以下类别:

  • 二值图像:像素值为0(黑色)或1(白色)
  • 灰度图像 :像素值在 { 0 , ... , 255 } \{0, \ldots, 255\} {0,...,255} 范围内
  • 彩色图像 :三个通道(RGB),每个通道的值在 { 0 , ... , 255 } \{0, \ldots, 255\} {0,...,255} 范围内

使用 imager 处理图像

imager 包基于CImg构建,支持图像的加载、处理和可视化。下面,我们将使用内置的"parrots.png"图像,通过代码和可视化输出来演示关键操作。

1. 图像获取

加载并显示图像:

r 复制代码
library(imager)
file <- system.file('extdata/parrots.png', package='imager')
img <- load.image(file)
plot(img, main="原始鹦鹉图像")

结果

2. 图像增强(模糊)

模糊处理可以增强特定应用中的图像,例如平滑细节:

r 复制代码
img_blurry <- isoblur(img, sigma=10)
plot(img_blurry, main="模糊图像 (sigma=10)")

结果

注意:模糊后的图像更加平滑,减少了羽毛纹理等细节。

3. 图像去噪

去噪可以在保持结构的同时去除噪声。添加噪声并应用各向异性模糊:

r 复制代码
img_noisy <- img + 0.5 * rnorm(prod(dim(img)))
img_denoised <- blur_anisotropic(img_noisy, ampl=1e3, sharp=0.3)
layout(t(1:2))
plot(img_noisy, main="含噪图像")
plot(img_denoised, main="去噪后图像(各向异性)")

结果

注意:含噪图像显示随机斑点,而去噪后的图像恢复了清晰度,同时保持了边缘特征。

4. 直方图均衡化

直方图均衡化通过重新分配像素强度来增强对比度:

r 复制代码
img_gray <- grayscale(img)
f <- ecdf(img_gray)
img_equalized <- f(img_gray) %>% as.cimg(dim=dim(img_gray))
layout(t(1:2))
plot(img_gray, main="灰度图像")
plot(img_equalized, main="直方图均衡化后图像")

结果

注意:均衡化后的图像对比度得到改善,使得颜色变化等细节更加明显。

5. 形态学处理

通过强度进行阈值分割对象:

r 复制代码
img_gray <- grayscale(img)
threshold(img_gray, "20%") %>% plot(main="阈值处理后图像 (20%)")

结果

注意:阈值处理创建了一个二值图像,突出显示了较亮区域(如白色羽毛)与较暗区域的对比。

6. 完整代码

r 复制代码
library(imager)

# 设置保存图像的目录(可选:如果不存在则创建)
output_dir <- "plots"
if (!dir.exists(output_dir)) {
  dir.create(output_dir)
}

# 图像获取
file <- system.file('extdata/parrots.png', package='imager')
img <- load.image(file)
plot(img, main="原始鹦鹉图像")
dev.copy(png, file.path(output_dir, "original_parrots.png"))
dev.off()

# 图像增强(模糊)
img_blurry <- isoblur(img, sigma=10)
plot(img_blurry, main="模糊图像 (sigma=10)")
dev.copy(png, file.path(output_dir, "blurred_parrots.png"))
dev.off()

# 图像去噪
img_noisy <- img + 0.5 * rnorm(prod(dim(img)))
img_denoised <- blur_anisotropic(img_noisy, ampl=1e3, sharp=0.3)
layout(t(1:2))
plot(img_noisy, main="含噪图像")
plot(img_denoised, main="去噪后图像(各向异性)")
dev.copy(png, file.path(output_dir, "noisy_vs_denoised_parrots.png"))
dev.off()

# 直方图均衡化
img_gray <- grayscale(img)
f <- ecdf(img_gray)
img_equalized <- f(img_gray) %>% as.cimg(dim=dim(img_gray))
layout(t(1:2))
plot(img_gray, main="灰度图像")
plot(img_equalized, main="直方图均衡化后图像")
dev.copy(png, file.path(output_dir, "grayscale_vs_equalized_parrots.png"))
dev.off()

# 形态学处理
img_gray <- grayscale(img)
threshold(img_gray, "20%") %>% plot(main="阈值处理后图像 (20%)")
dev.copy(png, file.path(output_dir, "thresholded_parrots.png"))
dev.off()

应用场景

R中的图像处理应用于以下领域:

  • 汽车工业:车道检测、障碍物警告
  • 医疗:诊断成像、手术辅助
  • 安防:人脸识别、监控
  • 媒体:特效、图像编辑

结论

R中的 imager 包简化了图像处理任务,如增强、去噪和直方图均衡化。可视化结果展示了这些技术如何转换图像,改善质量或提取特征。探索 imagerimagerExtra 以进行更高级的应用。

资源

相关推荐
想要成为祖国的花朵5 分钟前
Java_Springboot技术框架讲解部分(二)
java·开发语言·spring boot·spring
Q_Q51100828511 分钟前
python的小学课外综合管理系统
开发语言·spring boot·python·django·flask·node.js
勤奋的知更鸟22 分钟前
JavaScript 性能优化实战:深入性能瓶颈,精炼优化技巧与最佳实践
开发语言·javascript·性能优化
hqxstudying39 分钟前
Java行为型模式---模板方法模式
java·开发语言·设计模式·代码规范·模板方法模式
weixin_4432906942 分钟前
【脚本系列】如何使用 Python 脚本对同一文件夹中表头相同的 Excel 文件进行合并
开发语言·python·excel
路溪非溪1 小时前
认识下计算机视觉中的人脸识别
人工智能·计算机视觉
荷蒲2 小时前
【小白量化智能体】应用5:编写通达信股票交易指标及生成QMT自动交易Python策略程序
开发语言·python
ljh5746491192 小时前
PHP password_verify() 函数
开发语言·php
lovix122 小时前
java进阶(三):单例、工厂、模版方法与代理模式详解
java·开发语言
医工交叉实验工坊2 小时前
R 语言绘制 10 种精美火山图:转录组差异基因可视化
python·信息可视化·r语言