中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python怎么實現對圖像添加高斯噪聲或椒鹽噪聲

發布時間:2021-11-24 11:10:05 來源:億速云 閱讀:926 作者:小新 欄目:開發技術

這篇文章主要為大家展示了“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

在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)

以上是“Python怎么實現對圖像添加高斯噪聲或椒鹽噪聲”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

承德县| 武清区| 南昌市| 虎林市| 和硕县| 乌恰县| 荥经县| 托克逊县| 无极县| 北碚区| 平度市| 壶关县| 项城市| 临漳县| 枣庄市| 桓台县| 玉环县| 安康市| 澜沧| 海林市| 龙岩市| 京山县| 南部县| 天镇县| 临城县| 剑河县| 绵竹市| 南丰县| 庄河市| 波密县| 通许县| 乌拉特后旗| 玛沁县| 邓州市| 鞍山市| 惠水县| 任丘市| 姜堰市| 乾安县| 开封市| 惠东县|