您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Python怎么實現對圖像添加高斯噪聲或椒鹽噪聲”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Python怎么實現對圖像添加高斯噪聲或椒鹽噪聲”這篇文章吧。
add_noise.py
#代碼中的noisef為信號等級,例如我需要0.7的噪聲,傳入參數我傳入的是1-0.7 from PIL import Image import numpy as np import random import torchvision.transforms as transforms norm_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 img class 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
# 圖像變換和加噪聲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)
以上是“Python怎么實現對圖像添加高斯噪聲或椒鹽噪聲”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。