當前位置: 首頁>>代碼示例>>Python>>正文


Python bbox_transform.bbox_transform方法代碼示例

本文整理匯總了Python中bbox.bbox_transform.bbox_transform方法的典型用法代碼示例。如果您正苦於以下問題:Python bbox_transform.bbox_transform方法的具體用法?Python bbox_transform.bbox_transform怎麽用?Python bbox_transform.bbox_transform使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在bbox.bbox_transform的用法示例。


在下文中一共展示了bbox_transform.bbox_transform方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: sample_rois_v2

# 需要導入模塊: from bbox import bbox_transform [as 別名]
# 或者: from bbox.bbox_transform import bbox_transform [as 別名]
def sample_rois_v2(rois, num_classes, cfg,
                   labels=None, overlaps=None, bbox_targets=None, gt_boxes=None):
    """
    generate random sample of ROIs comprising foreground and background examples
    :param rois: all_rois [n, 4]; e2e: [n, 5] with batch_index
    :param fg_rois_per_image: foreground roi number
    :param rois_per_image: total roi number
    :param num_classes: number of classes
    :param labels: maybe precomputed
    :param overlaps: maybe precomputed (max_overlaps)
    :param bbox_targets: maybe precomputed
    :param gt_boxes: optional for e2e [n, 5] (x1, y1, x2, y2, cls)
    :return: (labels, rois, bbox_targets, bbox_weights)
    """
    if labels is None:
        overlaps = bbox_overlaps(rois[:, 1:].astype(np.float), gt_boxes[:, :4].astype(np.float))
        gt_assignment = overlaps.argmax(axis=1)
        overlaps = overlaps.max(axis=1)
        labels = gt_boxes[gt_assignment, 4]

    # set labels of bg_rois to be 0
    bg_ind = np.where(overlaps < cfg.TRAIN.BG_THRESH_HI)[0]
    labels[bg_ind] = 0

    # load or compute bbox_target
    if bbox_targets is not None:
        bbox_target_data = bbox_targets
    else:
        targets = bbox_transform(rois[:, 1:], gt_boxes[gt_assignment, :4])
        if cfg.TRAIN.BBOX_NORMALIZATION_PRECOMPUTED:
            targets = ((targets - np.array(cfg.TRAIN.BBOX_MEANS))
                       / np.array(cfg.TRAIN.BBOX_STDS))
        bbox_target_data = np.hstack((labels[:, np.newaxis], targets))

    bbox_targets, bbox_weights = \
        expand_bbox_regression_targets(bbox_target_data, num_classes, cfg)

    return rois, labels, bbox_targets, bbox_weights 
開發者ID:i-pan,項目名稱:kaggle-rsna18,代碼行數:40,代碼來源:rcnn.py

示例2: get_delta_roi

# 需要導入模塊: from bbox import bbox_transform [as 別名]
# 或者: from bbox.bbox_transform import bbox_transform [as 別名]
def get_delta_roi(filename, roi_rec, im_scale):
    trackid = roi_rec['gt_trackid']
    boxes = roi_rec['boxes']
    boxes = boxes * im_scale
    delta = np.zeros_like(roi_rec['boxes'], dtype=float)
    dic = {}

    tree = ET.parse(filename)
    size = tree.find('size')
    height = float(size.find('height').text)
    width = float(size.find('width').text)
    objs = tree.findall('object')
    for obj in objs:
        bbox = obj.find('bndbox')
        if roi_rec['flipped']==False:
            np.minimum(float(bbox.find('ymax').text), roi_rec['height']-1)
            dic[int(obj.find('trackid').text)] = [np.maximum(float(bbox.find('xmin').text), 0)*im_scale,
                                         np.maximum(float(bbox.find('ymin').text), 0)*im_scale,
                                         np.minimum(float(bbox.find('xmax').text), roi_rec['width']-1)*im_scale,
                                         np.minimum(float(bbox.find('ymax').text), roi_rec['height']-1)*im_scale]
        else:
            xmin = np.maximum(float(bbox.find('xmin').text), 0)
            ymin = np.maximum(float(bbox.find('ymin').text), 0)
            xmax = np.minimum(float(bbox.find('xmax').text), roi_rec['width']-1)
            ymax = np.minimum(float(bbox.find('ymax').text), roi_rec['height']-1)

            xmin_flip = width - 1 - xmax
            xmax_flip = width - 1 - xmin

            assert xmax_flip >= xmin_flip

            dic[int(obj.find('trackid').text)] = [xmin_flip*im_scale, ymin*im_scale, xmax_flip*im_scale, ymax*im_scale]


    for i in range(len(trackid)):
        if trackid[i] in dic:
            delta_trans = bbox_transform(np.array([boxes[i]]), np.array([dic[trackid[i]]]))
            delta[i][:] = delta_trans[0]
    return delta 
開發者ID:wangshy31,項目名稱:MANet_for_Video_Object_Detection,代碼行數:41,代碼來源:image.py


注:本文中的bbox.bbox_transform.bbox_transform方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。