P20.神经网络-非线性激活
Pytorch官网 -> Docs -> Pytorch -> torch.nn -> ReLU
class
torch.nn.
ReLU
(inplace=False)
Parameters
inplace – can optionally do the operation in-place. Default:
False
import torch
from torch import nn
from torch.nn import ReLU
input = torch.tensor(([[1, -0.5],
[-1, 3]]))
input = torch.reshape(input, (-1, 1, 2, 2))
print(input.shape)
class Tudui(nn.Module):
def __init__(self):
super(Tudui, self).__init__()
self.relu1 = ReLU() # inplace = False, save the original value, put the new value to another variable
def forward(self, input):
output = self.relu1(input)
return output
tudui = Tudui()
output = tudui(input)
print(output)
torch.Size([1, 1, 2, 2])
tensor([[[[1., 0.],
[0., 3.]]]])
class
torch.nn.
Sigmoid
import torch
import torchvision
from torch import nn
from torch.nn import ReLU, Sigmoid
from torch.utils.data import DataLoader
from torch.utils.tensorboard import SummaryWriter
input = torch.tensor(([[1, -0.5],
[-1, 3]]))
input = torch.reshape(input, (-1, 1, 2, 2))
print(input.shape)
dataset = torchvision.datasets.CIFAR10(root="dataset", train=False, download=True,
transform=torchvision.transforms.ToTensor())
dataloader = DataLoader(dataset, batch_size=64)
class Tudui(nn.Module):
def __init__(self):
super(Tudui, self).__init__()
self.relu1 = ReLU() # inplace = False, save the original value, put the new value to another variable
self.sigmoid1 = Sigmoid()
def forward(self, input):
output = self.sigmoid1(input)
return output
tudui = Tudui()
writer = SummaryWriter("P20")
step = 0
for data in dataloader:
imgs, targets = data
writer.add_images("input", imgs, global_step=step)
output = tudui(input)
writer.add_images("output", output, step)
step += 1
writer.close()
tensorboard --logdir=P20