| 123456789101112131415161718192021222324252627282930313233343536 |
- # mypy: allow-untyped-defs
- from torch.fx.proxy import Proxy
- from ._compatibility import compatibility
- @compatibility(is_backward_compatible=False)
- def annotate(val, type):
- """
- Annotates a Proxy object with a given type.
- This function annotates a val with a given type if a type of the val is a torch.fx.Proxy object
- Args:
- val (object): An object to be annotated if its type is torch.fx.Proxy.
- type (object): A type to be assigned to a given proxy object as val.
- Returns:
- The given val.
- Raises:
- RuntimeError: If a val already has a type in its node.
- """
- if isinstance(val, Proxy):
- if val.node.type:
- raise RuntimeError(
- f"Tried to annotate a value that already had a type on it!"
- f" Existing type is {val.node.type} "
- f"and new type is {type}. "
- f"This could happen if you tried to annotate a function parameter "
- f"value (in which case you should use the type slot "
- f"on the function signature) or you called "
- f"annotate on the same value twice"
- )
- else:
- val.node.type = type
- return val
- else:
- return val
|