您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:Python实现对图像加噪(高斯噪声 椒盐噪声)

51自学网 2022-02-21 10:47:28
  python
这篇教程Python实现对图像加噪(高斯噪声 椒盐噪声)写得很实用,希望能帮到您。

内容简介

展示如何给图像叠加不同等级的椒盐噪声和高斯噪声的代码,相应的叠加噪声的已编为对应的类,可实例化使用。以下主要展示自己编写的:

加噪声的代码(高斯噪声,椒盐噪声)

add_noise.py

#代码中的noisef为信号等级,例如我需要0.7的噪声,传入参数我传入的是1-0.7from PIL import Imageimport numpy as npimport randomimport torchvision.transforms as transformsnorm_mean = (0.5, 0.5, 0.5)norm_std = (0.5, 0.5, 0.5)class AddPepperNoise(object):    """增加椒盐噪声    Args:        snr (float): Signal Noise Rate        p (float): 概率值,依概率执行该操作    """    def __init__(self, snr, p=0.9):        assert isinstance(snr, float) and (isinstance(p, float))    # 2020 07 26 or --> and        self.snr = snr        self.p = p    def __call__(self, img):        """        Args:            img (PIL Image): PIL Image        Returns:            PIL Image: PIL image.        """        if random.uniform(0, 1) < self.p:            img_ = np.array(img).copy()            h, w, c = img_.shape            signal_pct = self.snr            noise_pct = (1 - self.snr)            mask = np.random.choice((0, 1, 2), size=(h, w, 1), p=[signal_pct, noise_pct/2., noise_pct/2.])            mask = np.repeat(mask, c, axis=2)            img_[mask == 1] = 255   # 盐噪声            img_[mask == 2] = 0     # 椒噪声            return Image.fromarray(img_.astype('uint8')).convert('RGB')        else:            return imgclass Gaussian_noise(object):    """增加高斯噪声    此函数用将产生的高斯噪声加到图片上    传入:        img   :  原图        mean  :  均值        sigma :  标准差    返回:        gaussian_out : 噪声处理后的图片    """    def __init__(self, mean, sigma):        self.mean = mean        self.sigma = sigma    def __call__(self, img):        """        Args:            img (PIL Image): PIL Image        Returns:            PIL Image: PIL image.        """        # 将图片灰度标准化        img_ = np.array(img).copy()        img_ = img_ / 255.0        # 产生高斯 noise        noise = np.random.normal(self.mean, self.sigma, img_.shape)        # 将噪声和图片叠加        gaussian_out = img_ + noise        # 将超过 1 的置 1,低于 0 的置 0        gaussian_out = np.clip(gaussian_out, 0, 1)        # 将图片灰度范围的恢复为 0-255        gaussian_out = np.uint8(gaussian_out*255)        # 将噪声范围搞为 0-255        # noise = np.uint8(noise*255)        return Image.fromarray(gaussian_out).convert('RGB')def image_transform(noisef):    """对训练集和测试集的图片作预处理转换        train_transform:加噪图        _train_transform:原图(不加噪)        test_transform:测试图(不加噪)    """    train_transform = transforms.Compose([        transforms.Resize((256, 256)),  # 重设大小        #transforms.RandomCrop(32,padding=4),        AddPepperNoise(noisef, p=0.9),                 #加椒盐噪声        #Gaussian_noise(0, noisef),  # 加高斯噪声        transforms.ToTensor(),  # 转换为张量        # transforms.Normalize(norm_mean,norm_std),    ])    _train_transform = transforms.Compose([        transforms.Resize((256, 256)),        #transforms.RandomCrop(32,padding=4),        transforms.ToTensor(),        # transforms.Normalize(norm_mean,norm_std),    ])    test_transform = transforms.Compose([        transforms.Resize((256, 256)),        #transforms.RandomCrop(32,padding=4),        transforms.ToTensor(),        # transforms.Normalize(norm_mean,norm_std),    ])    return train_transform, _train_transform, test_transform

在pytorch中如何使用

# 图像变换和加噪声train_transform为加噪图,_train_transform为原图,test_transform为测试图   noisef为传入的噪声等级train_transform,_train_transform,test_transform = image_transform(noisef)training_data=FabricDataset_file(data_dir=train_dir,transform=train_transform)_training_data=FabricDataset_file(data_dir=_train_dir,transform=_train_transform)testing_data=FabricDataset_file(data_dir=test_dir,transform=test_transform) 

补充

图像添加随机噪声

随机噪声就是通过随机函数在图像上随机地添加噪声点

def random_noise(image,noise_num):    '''    添加随机噪点(实际上就是随机在图像上将像素点的灰度值变为255即白色)    :param image: 需要加噪的图片    :param noise_num: 添加的噪音点数目,一般是上千级别的    :return: img_noise    '''    #    # 参数image:,noise_num:    img = cv2.imread(image)    img_noise = img    # cv2.imshow("src", img)    rows, cols, chn = img_noise.shape    # 加噪声    for i in range(noise_num):        x = np.random.randint(0, rows)#随机生成指定范围的整数        y = np.random.randint(0, cols)        img_noise[x, y, :] = 255    return img_noise
img_noise = random_noise("colorful_lena.jpg",3000)cv2.imshow('random_noise',img_noise)cv2.waitKey(0)

以上就是Python实现对图像添加高斯噪声或椒盐噪声的详细内容,更多关于Python的资料请关注51zixue.net其它相关文章!


Python自动化之批量生成含指定数据的word文档
Python
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。