快捷方式

ModuleDict

class torch.nn.ModuleDict(modules=None)[source]

在一个字典中保存子模块。

ModuleDict 可以像普通的 Python 字典一样索引,但它包含的模块将被正确注册,并且所有 Module 方法都可以看到。

ModuleDict 是一个有序字典,它尊重

  • 插入顺序,以及

  • update() 中,合并的 OrderedDictdict(从 Python 3.6 开始)或另一个 ModuleDictupdate() 的参数)的顺序。

请注意,使用其他无序映射类型(例如,在 Python 3.6 版本之前的 Python 的普通 dict)的 update() 不会保留合并映射的顺序。

参数

modules (iterable, optional) – (字符串: 模块) 的映射(字典)或类型为 (字符串, 模块) 的键值对的迭代器

示例

class MyModule(nn.Module):
    def __init__(self) -> None:
        super().__init__()
        self.choices = nn.ModuleDict({
                'conv': nn.Conv2d(10, 10, 3),
                'pool': nn.MaxPool2d(3)
        })
        self.activations = nn.ModuleDict([
                ['lrelu', nn.LeakyReLU()],
                ['prelu', nn.PReLU()]
        ])

    def forward(self, x, choice, act):
        x = self.choices[choice](x)
        x = self.activations[act](x)
        return x
clear()[source]

从 ModuleDict 中删除所有项目。

items()[source]

返回 ModuleDict 键/值对的迭代器。

返回类型

Iterable[Tuple[str, Module]]

keys()[source]

返回 ModuleDict 键的迭代器。

返回类型

Iterable[str]

pop(key)[source]

从 ModuleDict 中删除键并返回其模块。

参数

key (str) – 要从 ModuleDict 中弹出 的键

返回类型

模块

update(modules)[source]

使用映射中的键值对更新 ModuleDict,覆盖现有键。

注意

如果 modules 是一个 OrderedDict、一个 ModuleDict 或一个键值对的可迭代对象,则其中新元素的顺序将被保留。

参数

modules (iterable) – 一个从字符串到 Module 的映射(字典),或一个类型为 (string, Module) 的键值对的可迭代对象

values()[source]

返回 ModuleDict 值的可迭代对象。

返回类型

Iterable[Module]

文档

访问 PyTorch 的全面开发者文档

查看文档

教程

获取面向初学者和高级开发者的深入教程

查看教程

资源

查找开发资源并获得问题的解答

查看资源