From 6e4fa22dfe70264582f435e7b219a303e1c8a087 Mon Sep 17 00:00:00 2001 From: Vivek Miglani Date: Mon, 21 Oct 2024 20:29:57 -0700 Subject: [PATCH] Fix pyre errors in GuidedGradCAM (#1396) Summary: Initial work on fixing Pyre errors in Guided GradCAM Reviewed By: craymichael Differential Revision: D64677347 --- captum/attr/_core/guided_grad_cam.py | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/captum/attr/_core/guided_grad_cam.py b/captum/attr/_core/guided_grad_cam.py index bb9beb6a0..b1aa0145e 100644 --- a/captum/attr/_core/guided_grad_cam.py +++ b/captum/attr/_core/guided_grad_cam.py @@ -72,8 +72,7 @@ def attribute( self, inputs: TensorOrTupleOfTensorsGeneric, target: TargetType = None, - # pyre-fixme[2]: Parameter annotation cannot be `Any`. - additional_forward_args: Any = None, + additional_forward_args: object = None, interpolate_mode: str = "nearest", attribute_to_layer_input: bool = False, ) -> TensorOrTupleOfTensorsGeneric: @@ -181,15 +180,11 @@ def attribute( >>> # attribution size matches input size, Nx3x32x32 >>> attribution = guided_gc.attribute(input, 3) """ - # pyre-fixme[6]: For 1st argument expected `Tensor` but got - # `TensorOrTupleOfTensorsGeneric`. is_inputs_tuple = _is_tuple(inputs) - # pyre-fixme[9]: inputs has type `TensorOrTupleOfTensorsGeneric`; used as - # `Tuple[Tensor, ...]`. - inputs = _format_tensor_into_tuples(inputs) + inputs_tuple = _format_tensor_into_tuples(inputs) grad_cam_attr = self.grad_cam.attribute.__wrapped__( self.grad_cam, # self - inputs=inputs, + inputs=inputs_tuple, target=target, additional_forward_args=additional_forward_args, attribute_to_layer_input=attribute_to_layer_input, @@ -204,20 +199,18 @@ def attribute( guided_backprop_attr = self.guided_backprop.attribute.__wrapped__( self.guided_backprop, # self - inputs=inputs, + inputs=inputs_tuple, target=target, additional_forward_args=additional_forward_args, ) output_attr: List[Tensor] = [] - for i in range(len(inputs)): + for i in range(len(inputs_tuple)): try: output_attr.append( guided_backprop_attr[i] * LayerAttribution.interpolate( grad_cam_attr, - # pyre-fixme[6]: For 2nd argument expected `Union[int, - # typing.Tuple[int, ...]]` but got `Size`. - inputs[i].shape[2:], + tuple(inputs_tuple[i].shape[2:]), interpolate_mode=interpolate_mode, ) )