Skip to content

Commit

Permalink
Fix ONNX export for panotpic model (facebookresearch#180)
Browse files Browse the repository at this point in the history
* Fix ONNX export for panotpic model

The operation `.view_as(an_other_tensor)` is not supported by ONNX, `view(an_other_tensor.size())` is identical and supported. This fix allow to export panoptic models.

* Update test_all.py

Add onnx export test for panoptic model

* fix lint

* fix lint

* Skip test on OOM CI error
  • Loading branch information
m3at authored Aug 19, 2020
1 parent d45a12c commit 5e66b4c
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 1 deletion.
2 changes: 1 addition & 1 deletion models/segmentation.py
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ def forward(self, q, k, mask: Optional[Tensor] = None):

if mask is not None:
weights.masked_fill_(mask.unsqueeze(1).unsqueeze(1), float("-inf"))
weights = F.softmax(weights.flatten(2), dim=-1).view_as(weights)
weights = F.softmax(weights.flatten(2), dim=-1).view(weights.size())
weights = self.dropout(weights)
return weights

Expand Down
15 changes: 15 additions & 0 deletions test_all.py
Original file line number Diff line number Diff line change
Expand Up @@ -167,6 +167,21 @@ def test_model_onnx_detection(self):
tolerate_small_mismatch=True,
)

@unittest.skip("CI doesn't have enough memory")
def test_model_onnx_detection_panoptic(self):
model = detr_resnet50_panoptic(pretrained=False).eval()
dummy_image = torch.ones(1, 3, 800, 800) * 0.3
model(dummy_image)

# Test exported model on images of different size, or dummy input
self.run_model(
model,
[(torch.rand(1, 3, 750, 800),)],
input_names=["inputs"],
output_names=["pred_logits", "pred_boxes", "pred_masks"],
tolerate_small_mismatch=True,
)


if __name__ == '__main__':
unittest.main()

0 comments on commit 5e66b4c

Please sign in to comment.