-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathRANSAC-sample-collection.py
73 lines (64 loc) · 2.64 KB
/
RANSAC-sample-collection.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
72
73
#!/usr/bin/env python
from cv2 import imwrite
import freenect
import numpy as np
def RawDepthToMeters(depthValue):
# http://pille.iwr.uni-heidelberg.de/~kinect01/doc/classdescription.html#kinectcloud-section
return 1/(depthValue * (-0.0030711016) + 3.3309495161)
def DepthToWorld(x, y, depthValue):
fx_d = 5.9421434211923247e+02
fy_d = 5.9104053696870778e+02
cx_d = 3.3930780975300314e+02
cy_d = 2.4273913761751615e+02
depth = RawDepthToMeters(depthValue)
# http://pille.iwr.uni-heidelberg.de/~kinect01/doc/classdescription.html#kinectcloud-section
resultZ = float(depth)
resultX = float((x - cx_d) * resultZ)/fx_d
resultY = float((y - cy_d) * resultZ)/fy_d
result = [resultX, resultY, resultZ]
return result
def GenerateCloud():
(depth,_) = freenect.sync_get_depth()
(image,_) = freenect.sync_get_video()
# Collects 4800 points/frame
worldCoordinates = np.arange(14400, dtype = np.float64).reshape(60, 80, 3)
for i in range(0, 480, 8):
for j in range(0, 640, 8):
depthValue = depth[i,j]
if depthValue < 2047:
# if the depth value is small enough, convert it
# to depth in meters
values = DepthToWorld(i, j, depthValue)
worldCoordinates[i/8, j/8, 0] = values[0]
worldCoordinates[i/8, j/8, 1] = values[1]
worldCoordinates[i/8, j/8, 2] = values[2]
else:
# otherwise, assign the value to zero
worldCoordinates[i/8, j/8, 0] = 0
worldCoordinates[i/8, j/8, 1] = 0
worldCoordinates[i/8, j/8, 2] = 0
cloud = []
for row in worldCoordinates:
for point in row:
if str(point) != "[ 0. 0. 0.]":
cloud.append([point[0],point[1],point[2]])
return (image, cloud)
print "\n" + "KINECT ONLINE"
(image, pointCloud) = GenerateCloud()
rowCount = len(pointCloud)
columnCount = 3
filename = raw_input("Cloud generated. Enter filename for point cloud (e.g., RANSAC.mat): \t")
print "Saving to output/" + filename + "... \t",
with open("output/"+filename, "w") as f:
f.write("# Created by Nick Magerko and Jon Reynolds\n")
f.write("# name: cloud\n")
f.write("# type: matrix\n")
f.write("# rows: " + str(rowCount) + "\n")
f.write("# columns: " + str(columnCount) + "\n")
for point in pointCloud:
f.write(" " + str(point[0]) + " " + str(point[1]) + " " + str(point[2]) + "\n")
print "DONE"
filename = raw_input("Enter filename for RGB image (image.png): \t")
print "Saving to output/" + filename + "... \t"
imwrite("output/"+filename, image)
print "DONE \n"