@torch.jit.ignore
是 TorchScript 提供的一个装饰器,用于标记某些 Python 方法或函数在 TorchScript 转换过程中被忽略。这在以下场景中非常有用:
- 某些方法或函数无法转换为 TorchScript(例如,它们依赖于 Python 的动态特性)。
- 需要在 TorchScript 模型中保留 Python 的原始实现,仅在纯 Python 环境下执行。
主要功能
-
忽略无法脚本化的代码: 如果某个方法包含 TorchScript 不支持的特性(如动态控制流、复杂的 Python 数据结构等),可以用
@torch.jit.ignore
标记,使其在 TorchScript 转换过程中被跳过。 -
兼容 Python 和 TorchScript: 在纯 Python 环境中,使用原始方法;在 TorchScript 环境中,方法被忽略,调用时会引发错误。
使用场景和示例
1. 标记无法脚本化的辅助方法
import torch
import torch.nn as nn
class MyModel(nn.Module):
def __init__(self):
super(MyModel, self).__init__()
self.linear = nn.Linear(10, 5)
d