python-3.x - 教师力量训练 PyTorch

标签 python-3.x machine-learning deep-learning pytorch

我正在尝试进行 seq2seq 预测。为此,我有一个 LSTM 层,然后是一个完全连接的层。我在培训阶段采用教师培训,并想在测试阶段跳过这个(我在这里可能错了)。我还没有找到直接的方法,所以我采用了如下所示的方法。

def forward(self, inputs, future=0, teacher_force_ratio=0.2, target=None):
    outputs = []
    for idx in range(future):
        rnn_out, _ = self.rnn(inputs)
        output = self.fc1(rnn_out)
        if self.teacher_training:
            new_input = output if np.random.random() >= teacher_force_ratio else target[idx]
        else:
            new_input = output
        inputs = new_input

我使用 bool 变量 teacher_training 来检查是否需要教师培训。这个对吗?如果是,是否有更好的方法来做到这一点?谢谢。

最佳答案

在 PyTorch 中,所有扩展 nn.Module 的类都有一个名为 training 的 kwarg bool 参数。因此,我们应该简单地使用 training 参数而不是 teacher_training。此参数会根据您的模型训练模式(model.train()model.eval())自动设置。

关于python-3.x - 教师力量训练 PyTorch,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64703326/

相关文章:

machine-learning - 如果损失函数乘以一个常数会发生什么?

python - python高效读取数据(仅一行)

python - Gunicorn 不会启动 Flask 应用程序,因为 "Application object must be callable"

image-processing - 只需 2 张图像即可自动进行人脸验证

python - 比较两种产品大数据集

python - 将 Caffe 模型与 OpenCV 结合使用

python - Django:如何翻译模型的字段

python - 用python逐句拆分列表

machine-learning - 让 Scikit-Learn RandomForestClassifier 输出前 N 个结果

python - 如何从特定目录或文件夹导入预下载的 MNIST 数据集?