Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

IOU with segm masks and MAP for instance segment. #822

Merged
merged 166 commits into from
May 24, 2022
Merged
Show file tree
Hide file tree
Changes from 164 commits
Commits
Show all changes
166 commits
Select commit Hold shift + click to select a range
471bb0e
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
6ec2c5c
rebase; ddp test still failing
gianscarpe Feb 5, 2022
f0ab083
checking pr
gianscarpe Mar 17, 2022
8564c4a
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
2eef666
fixing import
gianscarpe Apr 6, 2022
0ede5e8
map test
gianscarpe Apr 21, 2022
65453f0
fixes
gianscarpe Apr 21, 2022
b4ce676
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
cf0c775
rebased and fixed GPU device
gianscarpe Apr 21, 2022
5fb5b6e
docstring and smooth fix
gianscarpe Apr 21, 2022
b56688c
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
0b1104e
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
83ed880
pycocotools test req
gianscarpe Apr 22, 2022
7f7469a
Merge branch 'master' into instance_segmentation_metric
SkafteNicki Apr 26, 2022
a4d60a8
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
d4b0c67
rebase; ddp test still failing
gianscarpe Feb 5, 2022
ff74a0f
checking pr
gianscarpe Mar 17, 2022
0691965
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
faa709d
fixing import
gianscarpe Apr 6, 2022
4c63b2b
map test
gianscarpe Apr 21, 2022
2ceaaa7
fixes
gianscarpe Apr 21, 2022
93dbf7e
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
41681bc
rebased and fixed GPU device
gianscarpe Apr 21, 2022
9e41b80
docstring and smooth fix
gianscarpe Apr 21, 2022
0270285
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
c1c122c
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
0d5da9c
pycocotools test req
gianscarpe Apr 22, 2022
792e97e
moved test inputs to json file
gianscarpe Apr 26, 2022
142f98e
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe Apr 26, 2022
8de2489
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
c04efa6
rebase; ddp test still failing
gianscarpe Feb 5, 2022
1450335
checking pr
gianscarpe Mar 17, 2022
54c9674
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
9e24e44
fixing import
gianscarpe Apr 6, 2022
73036c8
map test
gianscarpe Apr 21, 2022
251e8b4
fixes
gianscarpe Apr 21, 2022
51b3b72
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
79ccda7
rebased and fixed GPU device
gianscarpe Apr 21, 2022
6793715
docstring and smooth fix
gianscarpe Apr 21, 2022
a5f2c37
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
79b9e68
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
0d3e99d
pycocotools test req
gianscarpe Apr 22, 2022
27e682a
moved test inputs to json file
gianscarpe Apr 26, 2022
7072ff6
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 26, 2022
00923d6
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
0871426
checking pr
gianscarpe Mar 17, 2022
d740426
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
d3b6d55
map test
gianscarpe Apr 21, 2022
29e74aa
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
04be648
rebased and fixed GPU device
gianscarpe Apr 21, 2022
0334dd1
docstring and smooth fix
gianscarpe Apr 21, 2022
f9ce2ed
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
4d49943
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
86897fc
pycocotools test req
gianscarpe Apr 22, 2022
063f286
Rebased and fixes
gianscarpe Apr 26, 2022
b542ed9
Update tests/detection/test_map.py
gianscarpe Apr 26, 2022
3c7b404
Update tests/detection/test_map.py
gianscarpe Apr 26, 2022
71f836d
Update tests/detection/test_map.py
gianscarpe Apr 26, 2022
a5438c3
Update tests/detection/test_map.py
gianscarpe Apr 26, 2022
1ce261d
Update torchmetrics/metric.py
SkafteNicki Apr 28, 2022
51a2cd8
Merge branch 'master' into instance_segmentation_metric
SkafteNicki Apr 28, 2022
bd4d322
Merge branch 'master' into instance_segmentation_metric
SkafteNicki May 2, 2022
255f443
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 2, 2022
f53257d
missing torch
SkafteNicki May 2, 2022
eb22266
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 2, 2022
225f546
flake8
SkafteNicki May 2, 2022
e493330
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 2, 2022
3245488
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
67e50dc
rebase; ddp test still failing
gianscarpe Feb 5, 2022
b1b6c92
checking pr
gianscarpe Mar 17, 2022
4850616
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
c2811ab
fixing import
gianscarpe Apr 6, 2022
ebed3b6
map test
gianscarpe Apr 21, 2022
c6ebd43
fixes
gianscarpe Apr 21, 2022
ac770c4
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
c33e571
rebased and fixed GPU device
gianscarpe Apr 21, 2022
ec6f5c8
docstring and smooth fix
gianscarpe Apr 21, 2022
7e5db62
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
70ae107
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
44c975e
pycocotools test req
gianscarpe Apr 22, 2022
0a0aad3
moved test inputs to json file
gianscarpe Apr 26, 2022
2469cda
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
f22c15d
checking pr
gianscarpe Mar 17, 2022
f604370
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
8225364
map test
gianscarpe Apr 21, 2022
7e2a47e
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
9a314b5
rebased and fixed GPU device
gianscarpe Apr 21, 2022
acccbfe
docstring and smooth fix
gianscarpe Apr 21, 2022
e570a8d
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
73e3503
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
efe43ab
pycocotools test req
gianscarpe Apr 22, 2022
782b756
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
cb2afe3
checking pr
gianscarpe Mar 17, 2022
b3f5c73
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
4565eed
map test
gianscarpe Apr 21, 2022
2ca734b
fixes
gianscarpe Apr 21, 2022
976f3b5
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
a897ce3
rebased and fixed GPU device
gianscarpe Apr 21, 2022
a789f3a
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
babac03
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
104948a
pycocotools test req
gianscarpe Apr 22, 2022
768a4ca
moved test inputs to json file
gianscarpe Apr 26, 2022
3836267
implementaed IOU with segmentation masks and MAP for instance segment…
gianscarpe Jan 31, 2022
72aec73
checking pr
gianscarpe Mar 17, 2022
fab0e20
clean API interface; working on tests for iou_type SEGM
gianscarpe Mar 17, 2022
6591e09
map test
gianscarpe Apr 21, 2022
17b0a81
test added (required native RLE encoding from COCO); fixed IOU
gianscarpe Apr 21, 2022
1f2bf82
rebased and fixed GPU device
gianscarpe Apr 21, 2022
e2878a6
docstring and smooth fix
gianscarpe Apr 21, 2022
378795e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Apr 21, 2022
9087fa5
Added pycocotools as detection requirements for test
gianscarpe Apr 22, 2022
c4eac30
pycocotools test req
gianscarpe Apr 22, 2022
76a5aa8
Update tests/detection/test_map.py
gianscarpe Apr 26, 2022
34004ad
Update tests/detection/test_map.py
gianscarpe Apr 26, 2022
ce58d52
Update tests/detection/test_map.py
gianscarpe Apr 26, 2022
08ebc41
IOU for segm and bbox working! Need to introduce fixes for handle RLE…
gianscarpe May 5, 2022
0884712
fixes for tensor
gianscarpe May 5, 2022
43dd37d
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe May 5, 2022
ff6f315
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 5, 2022
d41435a
fixed docstring
gianscarpe May 5, 2022
0662861
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe May 5, 2022
c2bef39
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 5, 2022
c0dc242
minor fixesz
gianscarpe May 5, 2022
3cc6111
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe May 5, 2022
fbc358b
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 5, 2022
3179615
Merge branch 'master' into instance_segmentation_metric
Borda May 5, 2022
15187d6
flake8
Borda May 5, 2022
f5033b9
fixing docstring
gianscarpe May 10, 2022
2e7bd83
doctest for pycocotools
gianscarpe May 10, 2022
cb588a8
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe May 10, 2022
3acda53
Merge branch 'master' into instance_segmentation_metric
gianscarpe May 10, 2022
f1d1750
Merge branch 'master' into instance_segmentation_metric
Borda May 12, 2022
995111c
Merge branch 'master' into instance_segmentation_metric
SkafteNicki May 12, 2022
3c4c436
Merge branch 'master' into instance_segmentation_metric
SkafteNicki May 13, 2022
2cd7080
small fix for myppy
gianscarpe May 13, 2022
8aff62f
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe May 13, 2022
02d1c1e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 13, 2022
ac8f73b
Merge branch 'master' into instance_segmentation_metric
Borda May 16, 2022
56cf440
simple
Borda May 16, 2022
bd13c23
req
Borda May 16, 2022
688bb94
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 16, 2022
d3d5b76
idx
Borda May 16, 2022
9101511
Merge branch 'instance_segmentation_metric' of https://github.com/gia…
Borda May 16, 2022
abee271
Merge branch 'master' into instance_segmentation_metric
Borda May 16, 2022
4bfc128
Update torchmetrics/detection/mean_ap.py
gianscarpe May 17, 2022
d55d476
Merge branch 'master' into instance_segmentation_metric
gianscarpe May 17, 2022
f294285
pycocotools requirements
gianscarpe May 17, 2022
7f641f8
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 17, 2022
5b7a611
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe May 17, 2022
5185ba1
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 17, 2022
07e728a
pycocotools both in test_detection and detection requirements?
gianscarpe May 17, 2022
8f14108
Merge branch 'instance_segmentation_metric' of github.com:gianscarpe/…
gianscarpe May 17, 2022
03a0e2c
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 17, 2022
ac2b9e2
fix test for logical_or tensor overflown (windows only)
gianscarpe May 17, 2022
9eff906
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 17, 2022
9d3e5c5
Update torchmetrics/detection/mean_ap.py
SkafteNicki May 19, 2022
7c3d2b7
update docs
SkafteNicki May 19, 2022
e1b7184
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] May 19, 2022
e013ff1
sample
Borda May 19, 2022
83a9809
Apply suggestions from code review
Borda May 19, 2022
833839a
Merge branch 'master' into instance_segmentation_metric
Borda May 23, 2022
c2f4330
Merge branch 'master' into instance_segmentation_metric
Borda May 23, 2022
8cffaee
Merge branch 'master' into instance_segmentation_metric
SkafteNicki May 24, 2022
fc8b220
Update detection_test.txt
SkafteNicki May 24, 2022
2a991a7
fix path
Borda May 24, 2022
7006e01
Merge branch 'master' into instance_segmentation_metric
mergify[bot] May 24, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

- Added `Dice` to classification package ([#1021](https://github.com/PyTorchLightning/metrics/pull/1021))

- Added support to segmentation type `segm` as IOU for mean average precision ([#822](https://github.com/PyTorchLightning/metrics/pull/822))

### Changed

Expand Down
1 change: 1 addition & 0 deletions requirements/detection.txt
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
torchvision>=0.8
pycocotools
1 change: 1 addition & 0 deletions requirements/detection_test.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
pycocotools
1 change: 1 addition & 0 deletions requirements/devel.txt
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,4 @@
-r image_test.txt
-r text_test.txt
-r audio_test.txt
-r detection_test.txt
5 changes: 5 additions & 0 deletions tests/detection/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import os

from tests import _PATH_TESTS

_SAMPLE_DETECTION_SEGMENTATION = os.path.join(_PATH_TESTS, "_data", "detection", "instance_segmentation_inputs.json")
115 changes: 110 additions & 5 deletions tests/detection/test_map.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,18 +12,51 @@
# See the License for the specific language governing permissions and
# limitations under the License.

import json
from collections import namedtuple

import numpy as np
import pytest
import torch
from pycocotools import mask
from torch import IntTensor, Tensor

from tests.detection import _SAMPLE_DETECTION_SEGMENTATION
from tests.helpers.testers import MetricTester
from torchmetrics.detection.mean_ap import MeanAveragePrecision
from torchmetrics.utilities.imports import _TORCHVISION_AVAILABLE, _TORCHVISION_GREATER_EQUAL_0_8

Input = namedtuple("Input", ["preds", "target"])

with open(_SAMPLE_DETECTION_SEGMENTATION) as fp:
inputs_json = json.load(fp)

_mask_unsqueeze_bool = lambda m: Tensor(mask.decode(m)).unsqueeze(0).bool()
_masks_stack_bool = lambda ms: Tensor(np.stack([mask.decode(m) for m in ms])).bool()

_inputs_masks = Input(
preds=[
[
dict(masks=_mask_unsqueeze_bool(inputs_json["preds"][0]), scores=Tensor([0.236]), labels=IntTensor([4])),
dict(
masks=_masks_stack_bool([inputs_json["preds"][1], inputs_json["preds"][2]]),
scores=Tensor([0.318, 0.726]),
labels=IntTensor([3, 2]),
), # 73
],
],
target=[
[
dict(masks=_mask_unsqueeze_bool(inputs_json["targets"][0]), labels=IntTensor([4])), # 42
dict(
masks=_masks_stack_bool([inputs_json["targets"][1], inputs_json["targets"][2]]),
labels=IntTensor([2, 2]),
), # 73
],
],
)


_inputs = Input(
preds=[
[
Expand Down Expand Up @@ -139,15 +172,15 @@
_inputs3 = Input(
preds=[
[
dict(boxes=torch.tensor([]), scores=torch.tensor([]), labels=torch.tensor([])),
dict(boxes=Tensor([]), scores=Tensor([]), labels=Tensor([])),
],
],
target=[
[
dict(
boxes=torch.tensor([[1.0, 2.0, 3.0, 4.0]]),
scores=torch.tensor([0.8]),
labels=torch.tensor([1]),
boxes=Tensor([[1.0, 2.0, 3.0, 4.0]]),
scores=Tensor([0.8]),
labels=Tensor([1]),
),
],
],
Expand Down Expand Up @@ -214,6 +247,41 @@ def _compare_fn(preds, target) -> dict:
}


def _compare_fn_segm(preds, target) -> dict:
"""Comparison function for map implementation for instance segmentation.

Official pycocotools results calculated from a subset of https://github.com/cocodataset/cocoapi/tree/master/results
Average Precision (AP) @[ IoU=0.50:0.95 | area= all | maxDets=100 ] = 0.352
Average Precision (AP) @[ IoU=0.50 | area= all | maxDets=100 ] = 0.752
Average Precision (AP) @[ IoU=0.75 | area= all | maxDets=100 ] = 0.252
Average Precision (AP) @[ IoU=0.50:0.95 | area= small | maxDets=100 ] = -1.000
Average Precision (AP) @[ IoU=0.50:0.95 | area=medium | maxDets=100 ] = -1.000
Average Precision (AP) @[ IoU=0.50:0.95 | area= large | maxDets=100 ] = 0.352
Average Recall (AR) @[ IoU=0.50:0.95 | area= all | maxDets= 1 ] = 0.350
Average Recall (AR) @[ IoU=0.50:0.95 | area= all | maxDets= 10 ] = 0.350
Average Recall (AR) @[ IoU=0.50:0.95 | area= all | maxDets=100 ] = 0.350
Average Recall (AR) @[ IoU=0.50:0.95 | area= small | maxDets=100 ] = -1.000
Average Recall (AR) @[ IoU=0.50:0.95 | area=medium | maxDets=100 ] = -1.000
Average Recall (AR) @[ IoU=0.50:0.95 | area= large | maxDets=100 ] = 0.350
"""
return {
"map": Tensor([0.352]),
"map_50": Tensor([0.742]),
"map_75": Tensor([0.252]),
"map_small": Tensor([-1]),
"map_medium": Tensor([-1]),
"map_large": Tensor([0.352]),
"mar_1": Tensor([0.35]),
"mar_10": Tensor([0.35]),
"mar_100": Tensor([0.35]),
"mar_small": Tensor([-1]),
"mar_medium": Tensor([-1]),
"mar_large": Tensor([0.35]),
"map_per_class": Tensor([0.4039604, -1.0, 0.3]),
"mar_100_per_class": Tensor([0.4, -1.0, 0.3]),
}


_pytest_condition = not (_TORCHVISION_AVAILABLE and _TORCHVISION_GREATER_EQUAL_0_8)


Expand All @@ -230,7 +298,8 @@ class TestMAP(MetricTester):
atol = 1e-1

@pytest.mark.parametrize("ddp", [False, True])
def test_map(self, compute_on_cpu, ddp):
def test_map_bbox(self, compute_on_cpu, ddp):

"""Test modular implementation for correctness."""
self.run_class_metric_test(
ddp=ddp,
Expand All @@ -243,6 +312,21 @@ def test_map(self, compute_on_cpu, ddp):
metric_args={"class_metrics": True, "compute_on_cpu": compute_on_cpu},
)

@pytest.mark.parametrize("ddp", [False])
gianscarpe marked this conversation as resolved.
Show resolved Hide resolved
def test_map_segm(self, compute_on_cpu, ddp):
"""Test modular implementation for correctness."""

self.run_class_metric_test(
ddp=ddp,
preds=_inputs_masks.preds,
target=_inputs_masks.target,
metric_class=MeanAveragePrecision,
sk_metric=_compare_fn_segm,
dist_sync_on_step=False,
check_batch=False,
metric_args={"class_metrics": True, "compute_on_cpu": compute_on_cpu, "iou_type": "segm"},
)


# noinspection PyTypeChecker
@pytest.mark.skipif(_pytest_condition, reason="test requires that torchvision=>0.8.0 is installed")
Expand Down Expand Up @@ -377,6 +461,27 @@ def test_missing_gt():
assert result["map"] < 1, "MAP cannot be 1, as there is an image with no ground truth, but some predictions."


@pytest.mark.skipif(_pytest_condition, reason="test requires that torchvision=>0.8.0 is installed")
def test_segm_iou_empty_mask():
"""Test empty ground truths."""
metric = MeanAveragePrecision(iou_type="segm")

metric.update(
[
dict(
masks=torch.randint(0, 1, (1, 10, 10)).bool(),
scores=Tensor([0.5]),
labels=IntTensor([4]),
),
],
[
dict(masks=Tensor([]), labels=IntTensor([])),
],
)

metric.compute()


@pytest.mark.skipif(_pytest_condition, reason="test requires that torchvision=>0.8.0 is installed")
def test_error_on_wrong_input():
"""Test class input validation."""
Expand Down
1 change: 1 addition & 0 deletions tests/helpers/testers.py
Original file line number Diff line number Diff line change
Expand Up @@ -212,6 +212,7 @@ def _class_test(
_assert_allclose(batch_result, sk_batch_result, atol=atol)

# check that metrics are hashable

assert hash(metric)

# assert that state dict is empty
Expand Down
Loading