一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Python實(shí)現(xiàn)對(duì)圖像加噪(高斯噪聲 椒鹽噪聲)

Python實(shí)現(xiàn)對(duì)圖像加噪(高斯噪聲 椒鹽噪聲)

2022-03-07 00:15驪山道童 Python

這篇文章主要介紹了展示通過(guò)Python給圖像疊加不同等級(jí)的椒鹽噪聲和高斯噪聲的代碼,相應(yīng)的疊加噪聲的已編為對(duì)應(yīng)的類,可實(shí)例化使用。感興趣的同學(xué)可以看看

內(nèi)容簡(jiǎn)介

展示如何給圖像疊加不同等級(jí)的椒鹽噪聲和高斯噪聲的代碼,相應(yīng)的疊加噪聲的已編為對(duì)應(yīng)的類,可實(shí)例化使用。以下主要展示自己編寫(xiě)的:

加噪聲的代碼(高斯噪聲,椒鹽噪聲)

add_noise.py

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#代碼中的noisef為信號(hào)等級(jí),例如我需要0.7的噪聲,傳入?yún)?shù)我傳入的是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): 概率值,依概率執(zhí)行該操作
    """
 
    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):
    """增加高斯噪聲
    此函數(shù)用將產(chǎn)生的高斯噪聲加到圖片上
    傳入:
        img   :  原圖
        mean  :  均值
        sigma :  標(biāo)準(zhǔn)差
    返回:
        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.
        """
        # 將圖片灰度標(biāo)準(zhǔn)化
        img_ = np.array(img).copy()
        img_ = img_ / 255.0
        # 產(chǎn)生高斯 noise
        noise = np.random.normal(self.mean, self.sigma, img_.shape)
        # 將噪聲和圖片疊加
        gaussian_out = img_ + noise
        # 將超過(guò) 1 的置 1,低于 0 的置 0
        gaussian_out = np.clip(gaussian_out, 0, 1)
        # 將圖片灰度范圍的恢復(fù)為 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):
    """對(duì)訓(xùn)練集和測(cè)試集的圖片作預(yù)處理轉(zhuǎn)換
        train_transform:加噪圖
        _train_transform:原圖(不加噪)
        test_transform:測(cè)試圖(不加噪)
    """
    train_transform = transforms.Compose([
        transforms.Resize((256, 256)),  # 重設(shè)大小
        #transforms.RandomCrop(32,padding=4),
        AddPepperNoise(noisef, p=0.9),                 #加椒鹽噪聲
 
        #Gaussian_noise(0, noisef),  # 加高斯噪聲
 
        transforms.ToTensor(),  # 轉(zhuǎn)換為張量
        # 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中如何使用

?
1
2
3
4
5
6
# 圖像變換和加噪聲train_transform為加噪圖,_train_transform為原圖,test_transform為測(cè)試圖   noisef為傳入的噪聲等級(jí)
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)<font face="Arial, Verdana, sans-serif"><span style="white-space: normal;"> </span></font>

補(bǔ)充

圖像添加隨機(jī)噪聲

隨機(jī)噪聲就是通過(guò)隨機(jī)函數(shù)在圖像上隨機(jī)地添加噪聲點(diǎn)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
def random_noise(image,noise_num):
    '''
    添加隨機(jī)噪點(diǎn)(實(shí)際上就是隨機(jī)在圖像上將像素點(diǎn)的灰度值變?yōu)?55即白色)
    :param image: 需要加噪的圖片
    :param noise_num: 添加的噪音點(diǎn)數(shù)目,一般是上千級(jí)別的
    :return: img_noise
    '''
    #
    # 參數(shù)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)#隨機(jī)生成指定范圍的整數(shù)
        y = np.random.randint(0, cols)
        img_noise[x, y, :] = 255
    return img_noise
?
1
2
3
img_noise = random_noise("colorful_lena.jpg",3000)
cv2.imshow('random_noise',img_noise)
cv2.waitKey(0)

以上就是Python實(shí)現(xiàn)對(duì)圖像添加高斯噪聲或椒鹽噪聲的詳細(xì)內(nèi)容,更多關(guān)于Python的資料請(qǐng)關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://blog.csdn.net/qq_41858510/article/details/121485126

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品国产91久久久久 | 秋葵污视频 | 欧洲第一区第二区第三区 | 欧美人妖大啪啪 | 国产真实偷乱视频在线观看 | 福利片免费一区二区三区 | 12345国产精品高清在线 | 日韩经典在线 | 草草在线免费视频 | 羞羞漫画免费漫画页面在线看漫画秋蝉 | 2021小妲己永久回家地址 | 99精品视频一区在线观看miya | 亚洲国产成人久久精品hezyo | 射玉足| 精品无码一区二区三区中文字幕 | 色综合亚洲天天综合网站 | 美女用手扒开粉嫩的屁股 | 门卫老张和女警花小说 | 亚洲欧美日韩天堂 | pregnantxxx孕交| 千金奴隶在线 | 性欧美sexvideo另类 | 色老汉 | 色噜噜 男人的天堂在线观看 | 波多野给衣一区二区三区 | 全日本爽视频在线 | 5g影院天天爽爽 | 亚洲黄色网页 | 久久伊人中文字幕有码 | 日韩欧美国产免费看清风阁 | 日本黄色录像视频 | 性欧美video| 母爱成瘾在线观看 | 精品久久亚洲 | 国外欧美一区另类中文字幕 | 高跟翘臀老师后进式视频 | 四虎影院久久 | 日本妇人成熟免费不卡片 | 高清一区高清二区视频 | 成人性生交大片免费看软件 | 欧美另类videos另类粗暴 |