-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathDataloader.py
71 lines (55 loc) · 2.19 KB
/
Dataloader.py
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#Dataloader class
import numpy as np
import scipy.io as sio
from os.path import dirname, join as pjoin
import cv2
class Dataloader:
def __init__(self, directory, dataset_name = "/bear_front"):
self.directory = directory
self.mat_content = sio.loadmat(pjoin(self.directory, "frames.mat"))
self.frames = self.mat_content["frames"]
self.K = self.frames[0,0]['K']
self.getIntrinsics()
self.getNumOfFrames()
self.getTimeandFrameIDs()
self.bboxes = np.loadtxt(self.directory+dataset_name+".txt", delimiter = ",")
self.init_bbox = np.loadtxt(pjoin(directory, "init.txt"), delimiter = ",")
def getIntrinsics(self):
self.cx = self.K[0,2]
self.cy = self.K[1,2]
self.fx = self.K[0,0]
self.fy = self.K[1,1]
def getNumOfFrames(self):
self.numOfFrames = self.frames[0,0]['length'][0][0]
def getTimeandFrameIDs(self):
self.imageTimeStamps = self.frames[0,0]['imageTimestamp'][0]
self.imageFrameIDs = self.frames[0,0]['imageFrameID'][0]
self.depthTimeStamps = self.frames[0,0]['depthTimestamp'][0]
self.depthFrameIDs = self.frames[0,0]['depthFrameID'][0]
def getRGB(self, frameId):
imageName = pjoin(self.directory, "rgb/r-%d-%d.png" %(self.imageTimeStamps[frameId], self.imageFrameIDs[frameId]))
img = cv2.imread(imageName)
return img
def getDepth(self, frameId):
depthName = pjoin(self.directory, "depth/d-%d-%d.png" %(self.depthTimeStamps[frameId], self.depthFrameIDs[frameId]))
depth = cv2.imread(depthName,-1)
depth = (depth >> 3) | (depth << (16 - 3))
depth_div = depth/1000
return depth_div
def getXYZ(self, frameId):
depth_div = self.getDepth(frameId)
[x,y] = np.meshgrid(np.arange(0, 640), np.arange(0, 480))
Xworld = ((x-self.cx)*depth_div)*1/self.fx
Yworld = ((y-self.cy)*depth_div)*1/self.fy
Zworld = depth_div
XYZarray = np.dstack((Xworld, Yworld, Zworld))
return XYZarray
def getBbox(self, frameId):
bbox_coords = self.bboxes[frameId]
bbox = np.zeros(4)
bbox[0] = bbox_coords[0]
bbox[1] = bbox_coords[1]
bbox[2] = bbox_coords[0]+bbox_coords[2]
bbox[3] = bbox_coords[1]+bbox_coords[3]
bbox = bbox.astype('int')
return [bbox], [bbox_coords]