np.unique sorting correction
This commit is contained in:
parent
a284fc921d
commit
6116acb8c2
|
@ -175,14 +175,21 @@ def build_targets(pred_boxes, pred_conf, pred_cls, target, anchor_wh, nA, nC, nG
|
||||||
# Select best iou_pred and anchor
|
# Select best iou_pred and anchor
|
||||||
iou_anch_best, a = iou_anch.max(0) # best anchor [0-2] for each target
|
iou_anch_best, a = iou_anch.max(0) # best anchor [0-2] for each target
|
||||||
|
|
||||||
# Two targets can not claim the same anchor
|
# Select best IOU target-anchor combo in case multiple targets want same anchor
|
||||||
if nTb > 1:
|
if nTb > 1:
|
||||||
iou_order = np.argsort(-iou_anch_best) # best to worst
|
iou_order = np.argsort(-iou_anch_best) # best to worst
|
||||||
# u = torch.cat((gi, gj, a), 0).view(3, -1).numpy()
|
|
||||||
# _, first_unique = np.unique(u[:, iou_order], axis=1, return_index=True) # first unique indices
|
# Unique anchor selection (slow but retains original order)
|
||||||
u = gi.float() * 0.4361538773074043 + gj.float() * 0.28012496588736746 + a.float() * 0.6627147212460307
|
u = torch.cat((gi, gj, a), 0).view(3, -1).numpy()
|
||||||
_, first_unique = np.unique(u[iou_order], return_index=True) # first unique indices
|
_, first_unique = np.unique(u[:, iou_order], axis=1, return_index=True) # first unique indices
|
||||||
# print(((np.sort(first_unique) - np.sort(first_unique2)) ** 2).sum())
|
|
||||||
|
# Unique anchor selection (fast but does not retain order) TODO: update to retain original order
|
||||||
|
# u = gi.float() * 0.4361538773074043 + gj.float() * 0.28012496588736746 + a.float() * 0.6627147212460307
|
||||||
|
# _, first_unique_sorted = np.unique(u[iou_order], return_index=True) # first unique indices
|
||||||
|
|
||||||
|
# Slow - fast difference comparison
|
||||||
|
# print(((first_unique - first_unique_sorted) ** 2).sum())
|
||||||
|
|
||||||
i = iou_order[first_unique]
|
i = iou_order[first_unique]
|
||||||
# best anchor must share significant commonality (iou) with target
|
# best anchor must share significant commonality (iou) with target
|
||||||
i = i[iou_anch_best[i] > 0.10]
|
i = i[iou_anch_best[i] > 0.10]
|
||||||
|
|
Loading…
Reference in New Issue