File size: 1,512 Bytes
404d2af |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
import torch
import torch.distributed as dist
import numpy as np
import cv2
def parse_pair_seq(pair_num_list):
#generate pair_seq_list: [#pair_num]:seq
# accu_pair_num: dict{seq_name:accumulated_pair}
pair_num=int(pair_num_list[0,1])
pair_num_list=pair_num_list[1:]
pair_seq_list=[]
cursor=0
accu_pair_num={}
for line in pair_num_list:
seq,seq_pair_num=line[0],int(line[1])
for _ in range(seq_pair_num):
pair_seq_list.append(seq)
accu_pair_num[seq]=cursor
cursor+=seq_pair_num
assert pair_num==cursor
return pair_seq_list,accu_pair_num
def tocuda(data):
# convert tensor data in dictionary to cuda when it is a tensor
for key in data.keys():
if type(data[key]) == torch.Tensor:
data[key] = data[key].cuda()
return data
def reduce_tensor(tensor,op='mean'):
rt = tensor.detach()
dist.all_reduce(rt, op=dist.ReduceOp.SUM)
if op=='mean':
rt /= dist.get_world_size()
return rt
def get_rnd_homography(batch_size, pert_ratio=0.25):
corners = np.array([[-1, 1], [1, 1], [-1, -1], [1, -1]], dtype=np.float32)
homo_tower = []
for _ in range(batch_size):
rnd_pert = np.random.uniform(-2 * pert_ratio, 2 * pert_ratio, (4, 2)).astype(np.float32)
pert_corners = corners + rnd_pert
M = cv2.getPerspectiveTransform(corners, pert_corners)
homo_tower.append(M)
homo_tower = np.stack(homo_tower, axis=0)
return homo_tower
|