本文整理匯總了Python中rcnn.processing.nms.py_nms_wrapper方法的典型用法代碼示例。如果您正苦於以下問題:Python nms.py_nms_wrapper方法的具體用法?Python nms.py_nms_wrapper怎麽用?Python nms.py_nms_wrapper使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類rcnn.processing.nms
的用法示例。
在下文中一共展示了nms.py_nms_wrapper方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: pred_demo_mask
# 需要導入模塊: from rcnn.processing import nms [as 別名]
# 或者: from rcnn.processing.nms import py_nms_wrapper [as 別名]
def pred_demo_mask(predictor, test_data, imdb, roidb, result_path, vis=False, thresh=1e-1):
"""
wrapper for calculating offline validation for faster data analysis
in this example, all threshold are set by hand
:param predictor: Predictor
:param test_data: data iterator, must be non-shuffle
:param imdb: image database
:param vis: controls visualization
:param thresh: valid detection threshold
:return:
"""
assert vis or not test_data.shuffle
data_names = [k[0] for k in test_data.provide_data]
nms = py_nms_wrapper(config.TEST.NMS)
# limit detections to max_per_image over all classes
max_per_image = -1
num_images = imdb.num_images
# all detections are collected into:
# all_boxes[cls][image] = N x 5 array of detections in
# (x1, y1, x2, y2, score)
i = 0
for im_info, data_batch in test_data:
roi_rec = roidb[i]
scale = im_info[0, 2]
scores, boxes, data_dict, mask_output = im_detect_mask(predictor, data_batch, data_names)
CLASSES = imdb.classes
all_boxes = [[[] for _ in xrange(num_images)]
for _ in xrange(imdb.num_classes)]
all_masks = [[[] for _ in xrange(num_images)]
for _ in xrange(imdb.num_classes)]
label = np.argmax(scores, axis=1)
label = label[:, np.newaxis]
for cls in CLASSES:
cls_ind = CLASSES.index(cls)
cls_boxes = boxes[:, 4 * cls_ind:4 * (cls_ind + 1)]
cls_masks = mask_output[:, cls_ind, :, :]
cls_scores = scores[:, cls_ind, np.newaxis]
#print cls_scores.shape, label.shape
keep = np.where((cls_scores >= thresh) & (label == cls_ind))[0]
cls_masks = cls_masks[keep, :, :]
dets = np.hstack((cls_boxes, cls_scores)).astype(np.float32)[keep, :]
keep = nms(dets)
#print dets.shape, cls_masks.shape
all_boxes[cls_ind] = dets[keep, :]
all_masks[cls_ind] = cls_masks[keep, :, :]
boxes_this_image = [[]] + [all_boxes[j] for j in range(1, len(CLASSES))]
masks_this_image = [[]] + [all_masks[j] for j in range(1, len(CLASSES))]
filename = roi_rec['image'].split("/")[-1]
filename = result_path + '/' + filename.replace('.png', '') + '.jpg'
data_dict = dict(zip(data_names, data_batch.data))
draw_detection_mask(data_dict['data'], boxes_this_image, masks_this_image, scale, filename)
i += 1