mirror of
https://github.com/pytorch/pytorch.git
synced 2025-10-20 21:14:14 +08:00
This PR is part of the work to deprecate torch::deploy in OSS. Effectively it does 3 things to get started. 1. Remove test_deploy_interaction as we no longer need to worry about this 2. Remove all torch._running_with_deploy checks and use the False path always (surfaced 1) 3. Remove `USE_DEPLOY` and switch to the default path always Note: MyPy does fail on a bunch of things here as a bunch of older files are touched. It may be better to fix these things on a separate PR Pull Request resolved: https://github.com/pytorch/pytorch/pull/158288 Approved by: https://github.com/albanD
29 lines
824 B
Python
29 lines
824 B
Python
from typing import Any
|
|
|
|
import torch.library
|
|
from torch import Tensor
|
|
from torch.autograd import Function
|
|
|
|
|
|
_test_lib_def = torch.library.Library("_inductor_test", "DEF")
|
|
_test_lib_def.define("realize(Tensor self) -> Tensor", tags=torch.Tag.pt2_compliant_tag)
|
|
|
|
_test_lib_impl = torch.library.Library("_inductor_test", "IMPL")
|
|
for dispatch_key in ("CPU", "CUDA", "MPS", "Meta"):
|
|
_test_lib_impl.impl("realize", lambda x: x.clone(), dispatch_key)
|
|
|
|
|
|
class Realize(Function):
|
|
@staticmethod
|
|
def forward(ctx: object, x: Tensor) -> Tensor:
|
|
return torch.ops._inductor_test.realize(x)
|
|
|
|
@staticmethod
|
|
# types need to stay consistent with _SingleLevelFunction
|
|
def backward(ctx: Any, *grad_output: Any) -> Any:
|
|
return grad_output[0]
|
|
|
|
|
|
def realize(x: Tensor) -> Tensor:
|
|
return Realize.apply(x)
|