mirror of
https://github.com/pytorch/pytorch.git
synced 2025-10-20 21:14:14 +08:00
Fixes #64532 As state in issue, replace `clone.detach` by `detach.clone` Pull Request resolved: https://github.com/pytorch/pytorch/pull/140264 Approved by: https://github.com/soulitzer
76 lines
2.1 KiB
Python
76 lines
2.1 KiB
Python
# Owner(s): ["module: dynamo"]
|
|
import torch
|
|
import torch._dynamo
|
|
import torch._dynamo.test_case
|
|
|
|
|
|
class PreDispatchTests(torch._dynamo.test_case.TestCase):
|
|
def test_no_grad_simple(self):
|
|
def f(a):
|
|
b = a.sin()
|
|
with torch.no_grad():
|
|
c = b.cos()
|
|
return b * c.sin()
|
|
|
|
f_compiled = torch.compile(f, backend="pre_dispatch_eager")
|
|
|
|
a_ref = torch.randn(4, requires_grad=True)
|
|
a_test = a_ref.detach().clone().requires_grad_(True)
|
|
|
|
out_ref = f(a_ref)
|
|
out_test = f_compiled(a_test)
|
|
self.assertEqual(out_ref, out_test)
|
|
|
|
out_ref.sum().backward()
|
|
out_test.sum().backward()
|
|
self.assertEqual(a_ref.grad, a_test.grad)
|
|
|
|
def test_enable_grad_and_no_grad(self):
|
|
def f(a):
|
|
b = a * 2
|
|
with torch.no_grad():
|
|
c = b * 3
|
|
with torch.enable_grad():
|
|
d = c * 4
|
|
e = d * 5
|
|
return b + c + d + e
|
|
|
|
f_compiled = torch.compile(f, backend="pre_dispatch_eager")
|
|
|
|
a_ref = torch.randn(4, requires_grad=True)
|
|
a_test = a_ref.detach().clone().requires_grad_(True)
|
|
|
|
out_ref = f(a_ref)
|
|
out_test = f_compiled(a_test)
|
|
self.assertEqual(out_ref, out_test)
|
|
|
|
out_ref.sum().backward()
|
|
out_test.sum().backward()
|
|
self.assertEqual(a_ref.grad, a_test.grad)
|
|
|
|
def test_autocast_simple(self):
|
|
def f(a):
|
|
b = a * 2
|
|
with torch.amp.autocast(device_type="cpu"):
|
|
c = torch.matmul(b, b)
|
|
return b + c
|
|
|
|
f_compiled = torch.compile(f, backend="pre_dispatch_eager")
|
|
|
|
a_ref = torch.randn(4, device="cpu", requires_grad=True)
|
|
a_test = a_ref.detach().clone().requires_grad_(True)
|
|
|
|
out_ref = f(a_ref)
|
|
out_test = f_compiled(a_test)
|
|
self.assertEqual(out_ref, out_test)
|
|
|
|
out_ref.sum().backward()
|
|
out_test.sum().backward()
|
|
self.assertEqual(a_ref.grad, a_test.grad)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
from torch._dynamo.test_case import run_tests
|
|
|
|
run_tests()
|