7
from torch.testing._internal.common_utils import run_tests, TestCase, xfailIfTorchDynamo
8
from torch.utils.checkpoint import checkpoint
9
from torch.utils.module_tracker import ModuleTracker
12
class TestModuleTracker(TestCase):
15
def test_module_hierarchy(self):
22
seen_fw.append((copy(tracker.parents), tracker.is_bw))
24
lambda grad: seen_bw.append((copy(tracker.parents), tracker.is_bw))
26
return {"a": torch.mm(x, x)}
29
def __init__(self) -> None:
32
self.b = nn.ModuleDict({"nest": Foo()})
33
self.c = nn.ModuleList([Foo()])
37
return self.b["nest"](self.a(x))
41
with ModuleTracker() as tracker:
42
mod({"a": torch.randn(10, 10, requires_grad=True).clone()})[
45
mod({"a": torch.randn(10, 10, requires_grad=True).clone()})[
52
({"Global", "Mod", "Mod.c.0"}, False),
53
({"Global", "Mod", "Mod.a"}, False),
54
({"Global", "Mod", "Mod.b.nest"}, False),
55
({"Global", "Mod", "Mod.c.0"}, False),
56
({"Global", "Mod", "Mod.a"}, False),
57
({"Global", "Mod", "Mod.b.nest"}, False),
64
({"Global", "Mod", "Mod.b.nest"}, True),
65
({"Global", "Mod", "Mod.a"}, True),
66
({"Global", "Mod", "Mod.c.0"}, True),
67
({"Global", "Mod", "Mod.b.nest"}, True),
68
({"Global", "Mod", "Mod.a"}, True),
69
({"Global", "Mod", "Mod.c.0"}, True),
73
def test_confused_hierarchy(self):
74
class MyMod(nn.Module):
77
self.inner = nn.Linear(2, 2)
80
def forward(self, inp):
86
return self.inner(inp)
89
inp = torch.rand(1, 2, requires_grad=True)
92
with ModuleTracker() as tracker:
97
with ModuleTracker() as tracker:
98
res = checkpoint(lambda inp: mod(inp), inp)
101
def test_bw_detection(self):
102
mod = nn.Linear(2, 2)
104
with ModuleTracker() as tracker:
105
mod(torch.rand(2, requires_grad=True)).sum().backward()
106
self.assertFalse(tracker.is_bw)
107
self.assertEqual(tracker.parents, {"Global"})
110
if __name__ == "__main__":