pytorch生成图片脉冲噪声并保存到原文件夹下的代码
时间: 2023-08-06 07:04:12 浏览: 98
以下是使用PyTorch生成图片脉冲噪声并将其保存到原文件夹下的示例代码:
```python
import os
import torch
import torchvision.transforms as transforms
from PIL import Image
# 定义脉冲噪声函数
def pulse_noise(image_size, prob):
noise = torch.rand(image_size)
mask = noise < prob
noise[mask] = 1
noise[~mask] = 0
return noise
# 设置文件路径和名称
file_path = "path/to/file.png"
file_name = os.path.basename(file_path)
# 读取原始图片文件
img = Image.open(file_path)
# 转换图片为张量
transform = transforms.ToTensor()
img_tensor = transform(img)
# 生成脉冲噪声并添加到图片张量上
image_size = img_tensor.shape[-2:]
prob = 0.1
noise = pulse_noise(image_size, prob)
noisy_img_tensor = img_tensor.clone()
for i in range(img_tensor.shape[0]):
noisy_img_tensor[i] = img_tensor[i] + noise
# 将有噪声的图片张量转换为PIL图片并保存
noisy_img = transforms.ToPILImage()(noisy_img_tensor)
noisy_file_path = os.path.join(os.path.dirname(file_path), "noisy_" + file_name)
noisy_img.save(noisy_file_path)
```
在这个示例中,我们首先使用`os.path`模块获取原始图片文件的路径和名称,并使用Pillow库中的`Image.open`函数加载原始图片文件。然后,我们使用`torchvision.transforms`模块中的`ToTensor`函数将图片转换为张量,并使用之前定义的`pulse_noise`函数生成脉冲噪声。接着,我们将脉冲噪声添加到图片张量上,生成有噪声的图片张量。
最后,我们将有噪声的图片张量转换为PIL图片,并使用`save`函数将其保存到与原始文件相同的目录下,并在文件名前加上前缀"noisy_"。
你可以根据需要修改脉冲出现概率或保存文件的前缀。注意,这个示例仅适用于PNG格式的图片文件,如果你要处理其他格式的图片文件,需要使用相应的库进行加载和保存。
阅读全文