| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| """Tests for tensorflow_models.object_detection.core.post_processing.""" |
| import numpy as np |
| import tensorflow as tf |
| from object_detection.core import post_processing |
| from object_detection.core import standard_fields as fields |
| from object_detection.utils import test_case |
|
|
|
|
| class MulticlassNonMaxSuppressionTest(test_case.TestCase): |
|
|
| def test_multiclass_nms_select_with_shared_boxes(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 1000, 1, 1002], |
| [0, 100, 1, 101]] |
| exp_nms_scores = [.95, .9, .85, .3] |
| exp_nms_classes = [0, 0, 1, 0] |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, max_output_size) |
| with self.test_session() as sess: |
| nms_corners_output, nms_scores_output, nms_classes_output = sess.run( |
| [nms.get(), nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes)]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
|
|
| def test_multiclass_nms_select_with_shared_boxes_pad_to_max_output_size(self): |
| boxes = np.array([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], np.float32) |
| scores = np.array([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]], np.float32) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_size_per_class = 4 |
| max_output_size = 5 |
|
|
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 1000, 1, 1002], |
| [0, 100, 1, 101]] |
| exp_nms_scores = [.95, .9, .85, .3] |
| exp_nms_classes = [0, 0, 1, 0] |
|
|
| def graph_fn(boxes, scores): |
| nms, num_valid_nms_boxes = post_processing.multiclass_non_max_suppression( |
| boxes, |
| scores, |
| score_thresh, |
| iou_thresh, |
| max_size_per_class, |
| max_total_size=max_output_size, |
| pad_to_max_output_size=True) |
| return [nms.get(), nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes), num_valid_nms_boxes] |
|
|
| [nms_corners_output, nms_scores_output, nms_classes_output, |
| num_valid_nms_boxes] = self.execute(graph_fn, [boxes, scores]) |
|
|
| self.assertEqual(num_valid_nms_boxes, 4) |
| self.assertAllClose(nms_corners_output[0:num_valid_nms_boxes], |
| exp_nms_corners) |
| self.assertAllClose(nms_scores_output[0:num_valid_nms_boxes], |
| exp_nms_scores) |
| self.assertAllClose(nms_classes_output[0:num_valid_nms_boxes], |
| exp_nms_classes) |
|
|
| def test_multiclass_nms_select_with_shared_boxes_given_keypoints(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
| num_keypoints = 6 |
| keypoints = tf.tile( |
| tf.reshape(tf.range(8), [8, 1, 1]), |
| [1, num_keypoints, 2]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 1000, 1, 1002], |
| [0, 100, 1, 101]] |
| exp_nms_scores = [.95, .9, .85, .3] |
| exp_nms_classes = [0, 0, 1, 0] |
| exp_nms_keypoints_tensor = tf.tile( |
| tf.reshape(tf.constant([3, 0, 6, 5], dtype=tf.float32), [4, 1, 1]), |
| [1, num_keypoints, 2]) |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, |
| scores, |
| score_thresh, |
| iou_thresh, |
| max_output_size, |
| additional_fields={fields.BoxListFields.keypoints: keypoints}) |
|
|
| with self.test_session() as sess: |
| (nms_corners_output, |
| nms_scores_output, |
| nms_classes_output, |
| nms_keypoints, |
| exp_nms_keypoints) = sess.run([ |
| nms.get(), |
| nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes), |
| nms.get_field(fields.BoxListFields.keypoints), |
| exp_nms_keypoints_tensor |
| ]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
| self.assertAllEqual(nms_keypoints, exp_nms_keypoints) |
|
|
| def test_multiclass_nms_with_shared_boxes_given_keypoint_heatmaps(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
|
|
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
|
|
| num_boxes = tf.shape(boxes)[0] |
| heatmap_height = 5 |
| heatmap_width = 5 |
| num_keypoints = 17 |
| keypoint_heatmaps = tf.ones( |
| [num_boxes, heatmap_height, heatmap_width, num_keypoints], |
| dtype=tf.float32) |
|
|
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 1000, 1, 1002], |
| [0, 100, 1, 101]] |
|
|
| exp_nms_scores = [.95, .9, .85, .3] |
| exp_nms_classes = [0, 0, 1, 0] |
| exp_nms_keypoint_heatmaps = np.ones( |
| (4, heatmap_height, heatmap_width, num_keypoints), dtype=np.float32) |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, |
| scores, |
| score_thresh, |
| iou_thresh, |
| max_output_size, |
| additional_fields={ |
| fields.BoxListFields.keypoint_heatmaps: keypoint_heatmaps |
| }) |
|
|
| with self.test_session() as sess: |
| (nms_corners_output, |
| nms_scores_output, |
| nms_classes_output, |
| nms_keypoint_heatmaps) = sess.run( |
| [nms.get(), |
| nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes), |
| nms.get_field(fields.BoxListFields.keypoint_heatmaps)]) |
|
|
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
| self.assertAllEqual(nms_keypoint_heatmaps, exp_nms_keypoint_heatmaps) |
|
|
| def test_multiclass_nms_with_additional_fields(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
|
|
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
|
|
| coarse_boxes_key = 'coarse_boxes' |
| coarse_boxes = tf.constant([[0.1, 0.1, 1.1, 1.1], |
| [0.1, 0.2, 1.1, 1.2], |
| [0.1, -0.2, 1.1, 1.0], |
| [0.1, 10.1, 1.1, 11.1], |
| [0.1, 10.2, 1.1, 11.2], |
| [0.1, 100.1, 1.1, 101.1], |
| [0.1, 1000.1, 1.1, 1002.1], |
| [0.1, 1000.1, 1.1, 1002.2]], tf.float32) |
|
|
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = np.array([[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 1000, 1, 1002], |
| [0, 100, 1, 101]], dtype=np.float32) |
|
|
| exp_nms_coarse_corners = np.array([[0.1, 10.1, 1.1, 11.1], |
| [0.1, 0.1, 1.1, 1.1], |
| [0.1, 1000.1, 1.1, 1002.1], |
| [0.1, 100.1, 1.1, 101.1]], |
| dtype=np.float32) |
|
|
| exp_nms_scores = [.95, .9, .85, .3] |
| exp_nms_classes = [0, 0, 1, 0] |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, |
| scores, |
| score_thresh, |
| iou_thresh, |
| max_output_size, |
| additional_fields={coarse_boxes_key: coarse_boxes}) |
|
|
| with self.test_session() as sess: |
| (nms_corners_output, |
| nms_scores_output, |
| nms_classes_output, |
| nms_coarse_corners) = sess.run( |
| [nms.get(), |
| nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes), |
| nms.get_field(coarse_boxes_key)]) |
|
|
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
| self.assertAllEqual(nms_coarse_corners, exp_nms_coarse_corners) |
|
|
| def test_multiclass_nms_select_with_shared_boxes_given_masks(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
| num_classes = 2 |
| mask_height = 3 |
| mask_width = 3 |
| masks = tf.tile( |
| tf.reshape(tf.range(8), [8, 1, 1, 1]), |
| [1, num_classes, mask_height, mask_width]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 1000, 1, 1002], |
| [0, 100, 1, 101]] |
| exp_nms_scores = [.95, .9, .85, .3] |
| exp_nms_classes = [0, 0, 1, 0] |
| exp_nms_masks_tensor = tf.tile( |
| tf.reshape(tf.constant([3, 0, 6, 5], dtype=tf.float32), [4, 1, 1]), |
| [1, mask_height, mask_width]) |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, max_output_size, masks=masks) |
| with self.test_session() as sess: |
| (nms_corners_output, |
| nms_scores_output, |
| nms_classes_output, |
| nms_masks, |
| exp_nms_masks) = sess.run([nms.get(), |
| nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes), |
| nms.get_field(fields.BoxListFields.masks), |
| exp_nms_masks_tensor]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
| self.assertAllEqual(nms_masks, exp_nms_masks) |
|
|
| def test_multiclass_nms_select_with_clip_window(self): |
| boxes = tf.constant([[[0, 0, 10, 10]], |
| [[1, 1, 11, 11]]], tf.float32) |
| scores = tf.constant([[.9], [.75]]) |
| clip_window = tf.constant([5, 4, 8, 7], tf.float32) |
| score_thresh = 0.0 |
| iou_thresh = 0.5 |
| max_output_size = 100 |
|
|
| exp_nms_corners = [[5, 4, 8, 7]] |
| exp_nms_scores = [.9] |
| exp_nms_classes = [0] |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, |
| scores, |
| score_thresh, |
| iou_thresh, |
| max_output_size, |
| clip_window=clip_window) |
| with self.test_session() as sess: |
| nms_corners_output, nms_scores_output, nms_classes_output = sess.run( |
| [nms.get(), nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes)]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
|
|
| def test_multiclass_nms_select_with_clip_window_change_coordinate_frame(self): |
| boxes = tf.constant([[[0, 0, 10, 10]], |
| [[1, 1, 11, 11]]], tf.float32) |
| scores = tf.constant([[.9], [.75]]) |
| clip_window = tf.constant([5, 4, 8, 7], tf.float32) |
| score_thresh = 0.0 |
| iou_thresh = 0.5 |
| max_output_size = 100 |
|
|
| exp_nms_corners = [[0, 0, 1, 1]] |
| exp_nms_scores = [.9] |
| exp_nms_classes = [0] |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, |
| scores, |
| score_thresh, |
| iou_thresh, |
| max_output_size, |
| clip_window=clip_window, |
| change_coordinate_frame=True) |
| with self.test_session() as sess: |
| nms_corners_output, nms_scores_output, nms_classes_output = sess.run( |
| [nms.get(), nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes)]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
|
|
| def test_multiclass_nms_select_with_per_class_cap(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_size_per_class = 2 |
|
|
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 1000, 1, 1002]] |
| exp_nms_scores = [.95, .9, .85] |
| exp_nms_classes = [0, 0, 1] |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, max_size_per_class) |
| with self.test_session() as sess: |
| nms_corners_output, nms_scores_output, nms_classes_output = sess.run( |
| [nms.get(), nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes)]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
|
|
| def test_multiclass_nms_select_with_total_cap(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_size_per_class = 4 |
| max_total_size = 2 |
|
|
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1]] |
| exp_nms_scores = [.95, .9] |
| exp_nms_classes = [0, 0] |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, max_size_per_class, |
| max_total_size) |
| with self.test_session() as sess: |
| nms_corners_output, nms_scores_output, nms_classes_output = sess.run( |
| [nms.get(), nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes)]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
|
|
| def test_multiclass_nms_threshold_then_select_with_shared_boxes(self): |
| boxes = tf.constant([[[0, 0, 1, 1]], |
| [[0, 0.1, 1, 1.1]], |
| [[0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101]], |
| [[0, 1000, 1, 1002]], |
| [[0, 1000, 1, 1002.1]]], tf.float32) |
| scores = tf.constant([[.9], [.75], [.6], [.95], [.5], [.3], [.01], [.01]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 3 |
|
|
| exp_nms = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 100, 1, 101]] |
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, max_output_size) |
| with self.test_session() as sess: |
| nms_output = sess.run(nms.get()) |
| self.assertAllClose(nms_output, exp_nms) |
|
|
| def test_multiclass_nms_select_with_separate_boxes(self): |
| boxes = tf.constant([[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]], |
| tf.float32) |
| scores = tf.constant([[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = [[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 999, 2, 1004], |
| [0, 100, 1, 101]] |
| exp_nms_scores = [.95, .9, .85, .3] |
| exp_nms_classes = [0, 0, 1, 0] |
|
|
| nms, _ = post_processing.multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, max_output_size) |
| with self.test_session() as sess: |
| nms_corners_output, nms_scores_output, nms_classes_output = sess.run( |
| [nms.get(), nms.get_field(fields.BoxListFields.scores), |
| nms.get_field(fields.BoxListFields.classes)]) |
| self.assertAllClose(nms_corners_output, exp_nms_corners) |
| self.assertAllClose(nms_scores_output, exp_nms_scores) |
| self.assertAllClose(nms_classes_output, exp_nms_classes) |
|
|
| def test_batch_multiclass_nms_with_batch_size_1(self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]], |
| [[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0], |
| [.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = [[[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 999, 2, 1004], |
| [0, 100, 1, 101]]] |
| exp_nms_scores = [[.95, .9, .85, .3]] |
| exp_nms_classes = [[0, 0, 1, 0]] |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size) |
|
|
| self.assertIsNone(nmsed_masks) |
| self.assertIsNone(nmsed_additional_fields) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections]) |
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| self.assertEqual(num_detections, [4]) |
|
|
| def test_batch_multiclass_nms_with_batch_size_2(self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = np.array([[[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 999, 2, 1004], |
| [0, 10.1, 1, 11.1], |
| [0, 100, 1, 101], |
| [0, 0, 0, 0]]]) |
| exp_nms_scores = np.array([[.95, .9, 0, 0], |
| [.85, .5, .3, 0]]) |
| exp_nms_classes = np.array([[0, 0, 0, 0], |
| [1, 0, 0, 0]]) |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size) |
|
|
| self.assertIsNone(nmsed_masks) |
| self.assertIsNone(nmsed_additional_fields) |
| |
| self.assertAllEqual(nmsed_boxes.shape.as_list(), |
| exp_nms_corners.shape) |
| self.assertAllEqual(nmsed_scores.shape.as_list(), |
| exp_nms_scores.shape) |
| self.assertAllEqual(nmsed_classes.shape.as_list(), |
| exp_nms_classes.shape) |
| self.assertEqual(num_detections.shape.as_list(), [2]) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections]) |
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| self.assertAllClose(num_detections, [2, 3]) |
|
|
| def test_batch_multiclass_nms_with_per_batch_clip_window(self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| clip_window = tf.constant([0., 0., 200., 200.]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = np.array([[[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 10.1, 1, 11.1], |
| [0, 100, 1, 101], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]]]) |
| exp_nms_scores = np.array([[.95, .9, 0, 0], |
| [.5, .3, 0, 0]]) |
| exp_nms_classes = np.array([[0, 0, 0, 0], |
| [0, 0, 0, 0]]) |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size, |
| clip_window=clip_window) |
|
|
| self.assertIsNone(nmsed_masks) |
| self.assertIsNone(nmsed_additional_fields) |
| |
| self.assertAllEqual(nmsed_boxes.shape.as_list(), |
| exp_nms_corners.shape) |
| self.assertAllEqual(nmsed_scores.shape.as_list(), |
| exp_nms_scores.shape) |
| self.assertAllEqual(nmsed_classes.shape.as_list(), |
| exp_nms_classes.shape) |
| self.assertEqual(num_detections.shape.as_list(), [2]) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections]) |
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| self.assertAllClose(num_detections, [2, 2]) |
|
|
| def test_batch_multiclass_nms_with_per_image_clip_window(self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| clip_window = tf.constant([[0., 0., 5., 5.], |
| [0., 0., 200., 200.]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = np.array([[[0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 10.1, 1, 11.1], |
| [0, 100, 1, 101], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]]]) |
| exp_nms_scores = np.array([[.9, 0., 0., 0.], |
| [.5, .3, 0, 0]]) |
| exp_nms_classes = np.array([[0, 0, 0, 0], |
| [0, 0, 0, 0]]) |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size, |
| clip_window=clip_window) |
|
|
| self.assertIsNone(nmsed_masks) |
| self.assertIsNone(nmsed_additional_fields) |
| |
| self.assertAllEqual(nmsed_boxes.shape.as_list(), |
| exp_nms_corners.shape) |
| self.assertAllEqual(nmsed_scores.shape.as_list(), |
| exp_nms_scores.shape) |
| self.assertAllEqual(nmsed_classes.shape.as_list(), |
| exp_nms_classes.shape) |
| self.assertEqual(num_detections.shape.as_list(), [2]) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| num_detections]) |
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| self.assertAllClose(num_detections, [1, 2]) |
|
|
| def test_batch_multiclass_nms_with_masks(self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| masks = tf.constant([[[[[0, 1], [2, 3]], [[1, 2], [3, 4]]], |
| [[[2, 3], [4, 5]], [[3, 4], [5, 6]]], |
| [[[4, 5], [6, 7]], [[5, 6], [7, 8]]], |
| [[[6, 7], [8, 9]], [[7, 8], [9, 10]]]], |
| [[[[8, 9], [10, 11]], [[9, 10], [11, 12]]], |
| [[[10, 11], [12, 13]], [[11, 12], [13, 14]]], |
| [[[12, 13], [14, 15]], [[13, 14], [15, 16]]], |
| [[[14, 15], [16, 17]], [[15, 16], [17, 18]]]]], |
| tf.float32) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = np.array([[[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 999, 2, 1004], |
| [0, 10.1, 1, 11.1], |
| [0, 100, 1, 101], |
| [0, 0, 0, 0]]]) |
| exp_nms_scores = np.array([[.95, .9, 0, 0], |
| [.85, .5, .3, 0]]) |
| exp_nms_classes = np.array([[0, 0, 0, 0], |
| [1, 0, 0, 0]]) |
| exp_nms_masks = np.array([[[[6, 7], [8, 9]], |
| [[0, 1], [2, 3]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]], |
| [[[13, 14], [15, 16]], |
| [[8, 9], [10, 11]], |
| [[10, 11], [12, 13]], |
| [[0, 0], [0, 0]]]]) |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size, |
| masks=masks) |
|
|
| self.assertIsNone(nmsed_additional_fields) |
| |
| self.assertAllEqual(nmsed_boxes.shape.as_list(), exp_nms_corners.shape) |
| self.assertAllEqual(nmsed_scores.shape.as_list(), exp_nms_scores.shape) |
| self.assertAllEqual(nmsed_classes.shape.as_list(), exp_nms_classes.shape) |
| self.assertAllEqual(nmsed_masks.shape.as_list(), exp_nms_masks.shape) |
| self.assertEqual(num_detections.shape.as_list(), [2]) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| nmsed_masks, num_detections]) |
|
|
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| self.assertAllClose(num_detections, [2, 3]) |
| self.assertAllClose(nmsed_masks, exp_nms_masks) |
|
|
| def test_batch_multiclass_nms_with_additional_fields(self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| additional_fields = { |
| 'keypoints': tf.constant( |
| [[[[6, 7], [8, 9]], |
| [[0, 1], [2, 3]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]], |
| [[[13, 14], [15, 16]], |
| [[8, 9], [10, 11]], |
| [[10, 11], [12, 13]], |
| [[0, 0], [0, 0]]]], |
| tf.float32) |
| } |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = np.array([[[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 999, 2, 1004], |
| [0, 10.1, 1, 11.1], |
| [0, 100, 1, 101], |
| [0, 0, 0, 0]]]) |
| exp_nms_scores = np.array([[.95, .9, 0, 0], |
| [.85, .5, .3, 0]]) |
| exp_nms_classes = np.array([[0, 0, 0, 0], |
| [1, 0, 0, 0]]) |
| exp_nms_additional_fields = { |
| 'keypoints': np.array([[[[0, 0], [0, 0]], |
| [[6, 7], [8, 9]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]], |
| [[[10, 11], [12, 13]], |
| [[13, 14], [15, 16]], |
| [[8, 9], [10, 11]], |
| [[0, 0], [0, 0]]]]) |
| } |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size, |
| additional_fields=additional_fields) |
|
|
| self.assertIsNone(nmsed_masks) |
| |
| self.assertAllEqual(nmsed_boxes.shape.as_list(), exp_nms_corners.shape) |
| self.assertAllEqual(nmsed_scores.shape.as_list(), exp_nms_scores.shape) |
| self.assertAllEqual(nmsed_classes.shape.as_list(), exp_nms_classes.shape) |
| self.assertEqual(len(nmsed_additional_fields), |
| len(exp_nms_additional_fields)) |
| for key in exp_nms_additional_fields: |
| self.assertAllEqual(nmsed_additional_fields[key].shape.as_list(), |
| exp_nms_additional_fields[key].shape) |
| self.assertEqual(num_detections.shape.as_list(), [2]) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_additional_fields, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| nmsed_additional_fields, num_detections]) |
|
|
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| for key in exp_nms_additional_fields: |
| self.assertAllClose(nmsed_additional_fields[key], |
| exp_nms_additional_fields[key]) |
| self.assertAllClose(num_detections, [2, 3]) |
|
|
| def test_batch_multiclass_nms_with_dynamic_batch_size(self): |
| boxes_placeholder = tf.placeholder(tf.float32, shape=(None, None, 2, 4)) |
| scores_placeholder = tf.placeholder(tf.float32, shape=(None, None, 2)) |
| masks_placeholder = tf.placeholder(tf.float32, shape=(None, None, 2, 2, 2)) |
|
|
| boxes = np.array([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]]) |
| scores = np.array([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| masks = np.array([[[[[0, 1], [2, 3]], [[1, 2], [3, 4]]], |
| [[[2, 3], [4, 5]], [[3, 4], [5, 6]]], |
| [[[4, 5], [6, 7]], [[5, 6], [7, 8]]], |
| [[[6, 7], [8, 9]], [[7, 8], [9, 10]]]], |
| [[[[8, 9], [10, 11]], [[9, 10], [11, 12]]], |
| [[[10, 11], [12, 13]], [[11, 12], [13, 14]]], |
| [[[12, 13], [14, 15]], [[13, 14], [15, 16]]], |
| [[[14, 15], [16, 17]], [[15, 16], [17, 18]]]]]) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = np.array([[[0, 10, 1, 11], |
| [0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 999, 2, 1004], |
| [0, 10.1, 1, 11.1], |
| [0, 100, 1, 101], |
| [0, 0, 0, 0]]]) |
| exp_nms_scores = np.array([[.95, .9, 0, 0], |
| [.85, .5, .3, 0]]) |
| exp_nms_classes = np.array([[0, 0, 0, 0], |
| [1, 0, 0, 0]]) |
| exp_nms_masks = np.array([[[[6, 7], [8, 9]], |
| [[0, 1], [2, 3]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]], |
| [[[13, 14], [15, 16]], |
| [[8, 9], [10, 11]], |
| [[10, 11], [12, 13]], |
| [[0, 0], [0, 0]]]]) |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes_placeholder, scores_placeholder, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size, |
| masks=masks_placeholder) |
|
|
| self.assertIsNone(nmsed_additional_fields) |
| |
| self.assertAllEqual(nmsed_boxes.shape.as_list(), [None, 4, 4]) |
| self.assertAllEqual(nmsed_scores.shape.as_list(), [None, 4]) |
| self.assertAllEqual(nmsed_classes.shape.as_list(), [None, 4]) |
| self.assertAllEqual(nmsed_masks.shape.as_list(), [None, 4, 2, 2]) |
| self.assertEqual(num_detections.shape.as_list(), [None]) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| nmsed_masks, num_detections], |
| feed_dict={boxes_placeholder: boxes, |
| scores_placeholder: scores, |
| masks_placeholder: masks}) |
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| self.assertAllClose(num_detections, [2, 3]) |
| self.assertAllClose(nmsed_masks, exp_nms_masks) |
|
|
| def test_batch_multiclass_nms_with_masks_and_num_valid_boxes(self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| masks = tf.constant([[[[[0, 1], [2, 3]], [[1, 2], [3, 4]]], |
| [[[2, 3], [4, 5]], [[3, 4], [5, 6]]], |
| [[[4, 5], [6, 7]], [[5, 6], [7, 8]]], |
| [[[6, 7], [8, 9]], [[7, 8], [9, 10]]]], |
| [[[[8, 9], [10, 11]], [[9, 10], [11, 12]]], |
| [[[10, 11], [12, 13]], [[11, 12], [13, 14]]], |
| [[[12, 13], [14, 15]], [[13, 14], [15, 16]]], |
| [[[14, 15], [16, 17]], [[15, 16], [17, 18]]]]], |
| tf.float32) |
| num_valid_boxes = tf.constant([1, 1], tf.int32) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = [[[0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 10.1, 1, 11.1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]]] |
| exp_nms_scores = [[.9, 0, 0, 0], |
| [.5, 0, 0, 0]] |
| exp_nms_classes = [[0, 0, 0, 0], |
| [0, 0, 0, 0]] |
| exp_nms_masks = [[[[0, 1], [2, 3]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]], |
| [[[8, 9], [10, 11]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]]] |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size, |
| num_valid_boxes=num_valid_boxes, masks=masks) |
|
|
| self.assertIsNone(nmsed_additional_fields) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| nmsed_masks, num_detections]) |
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| self.assertAllClose(num_detections, [1, 1]) |
| self.assertAllClose(nmsed_masks, exp_nms_masks) |
|
|
| def test_batch_multiclass_nms_with_additional_fields_and_num_valid_boxes( |
| self): |
| boxes = tf.constant([[[[0, 0, 1, 1], [0, 0, 4, 5]], |
| [[0, 0.1, 1, 1.1], [0, 0.1, 2, 1.1]], |
| [[0, -0.1, 1, 0.9], [0, -0.1, 1, 0.9]], |
| [[0, 10, 1, 11], [0, 10, 1, 11]]], |
| [[[0, 10.1, 1, 11.1], [0, 10.1, 1, 11.1]], |
| [[0, 100, 1, 101], [0, 100, 1, 101]], |
| [[0, 1000, 1, 1002], [0, 999, 2, 1004]], |
| [[0, 1000, 1, 1002.1], [0, 999, 2, 1002.7]]]], |
| tf.float32) |
| scores = tf.constant([[[.9, 0.01], [.75, 0.05], |
| [.6, 0.01], [.95, 0]], |
| [[.5, 0.01], [.3, 0.01], |
| [.01, .85], [.01, .5]]]) |
| additional_fields = { |
| 'keypoints': tf.constant( |
| [[[[6, 7], [8, 9]], |
| [[0, 1], [2, 3]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]], |
| [[[13, 14], [15, 16]], |
| [[8, 9], [10, 11]], |
| [[10, 11], [12, 13]], |
| [[0, 0], [0, 0]]]], |
| tf.float32) |
| } |
| num_valid_boxes = tf.constant([1, 1], tf.int32) |
| score_thresh = 0.1 |
| iou_thresh = .5 |
| max_output_size = 4 |
|
|
| exp_nms_corners = [[[0, 0, 1, 1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]], |
| [[0, 10.1, 1, 11.1], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0], |
| [0, 0, 0, 0]]] |
| exp_nms_scores = [[.9, 0, 0, 0], |
| [.5, 0, 0, 0]] |
| exp_nms_classes = [[0, 0, 0, 0], |
| [0, 0, 0, 0]] |
| exp_nms_additional_fields = { |
| 'keypoints': np.array([[[[6, 7], [8, 9]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]], |
| [[[13, 14], [15, 16]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]], |
| [[0, 0], [0, 0]]]]) |
| } |
|
|
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_masks, |
| nmsed_additional_fields, num_detections |
| ) = post_processing.batch_multiclass_non_max_suppression( |
| boxes, scores, score_thresh, iou_thresh, |
| max_size_per_class=max_output_size, max_total_size=max_output_size, |
| num_valid_boxes=num_valid_boxes, |
| additional_fields=additional_fields) |
|
|
| self.assertIsNone(nmsed_masks) |
|
|
| with self.test_session() as sess: |
| (nmsed_boxes, nmsed_scores, nmsed_classes, nmsed_additional_fields, |
| num_detections) = sess.run([nmsed_boxes, nmsed_scores, nmsed_classes, |
| nmsed_additional_fields, num_detections]) |
|
|
| self.assertAllClose(nmsed_boxes, exp_nms_corners) |
| self.assertAllClose(nmsed_scores, exp_nms_scores) |
| self.assertAllClose(nmsed_classes, exp_nms_classes) |
| for key in exp_nms_additional_fields: |
| self.assertAllClose(nmsed_additional_fields[key], |
| exp_nms_additional_fields[key]) |
| self.assertAllClose(num_detections, [1, 1]) |
|
|
| |
|
|
| if __name__ == '__main__': |
| tf.test.main() |
|
|