[pytorch、学习] - 4.4 自定义层
生活随笔
收集整理的這篇文章主要介紹了
[pytorch、学习] - 4.4 自定义层
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
參考
4.4 自定義層
深度學習的一個魅力在于神經網絡中各式各樣的層,例如全連接層和后面章節將要用介紹的卷積層、池化層與循環層。雖然PyTorch提供了大量常用的層,但有時候我們依然希望自定義層。本節將介紹如何使用Module來自定義層,從而可以被重復調用。
4.4.1 不含模型參數的自定義層
我們先介紹如何定義一個不含模型參數的自定義層。
import torch from torch import nnclass CenteredLayer(nn.Module):def __init__(self, **kwargs):super(CenteredLayer, self).__init__(**kwargs)def forward(self, x):return x - x.mean() layer = CenteredLayer() layer(torch.tensor([1, 2, 3, 4, 5], dtype=torch.float))
我們也可以用它來構造更復雜的模型。
4.4.2 含模型參數的自定義層
我們還可以自定義含模型參數的自定義層。其中的模型參數可以通過訓練學習。
Parameter類其實是Tensor的子類,如果一個Tensor是Parameter,那么它會自動被添加到模型的參數列表里。所以在自定義含模型參數的層時,我們應該將參數定義成Parameter,除了像4.2.1節那樣直接定義成Parameter類外,還可以使用ParameterList和ParameterDict分別定義參數的列表和字典。
ParameterList接收一個Parameter實例的列表作為輸入然后得到一個參數列表,使用的時候可以用索引來訪問某個參數,另外也可以使用append和extend在列表后面新增參數。
class MyDense(nn.Module):def __init__(self):super(MyDense, self).__init__()self.params = nn.ParameterList([nn.Parameter(torch.randn(4, 4)) for i in range(3)])self.params.append(nn.Parameter(torch.randn(4, 1)))def forward(self, x):for i in range(len(self.params)):x = torch.mm(x, self.params[i])return xnet = MyDense() print(net)
而ParameterDict接收一個Parameter實例的字典作為輸入然后得到一個參數字典,然后可以按照字典的規則使用了。
我們也可以使用自定義層構造模型。它和PyTorch的其他層在使用上很類似。
總結
以上是生活随笔為你收集整理的[pytorch、学习] - 4.4 自定义层的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [pytorch、学习] - 4.2 模
- 下一篇: threejs向量夹角和夹角方向