-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathExtract M for mid-left.py
104 lines (84 loc) · 3.22 KB
/
Extract M for mid-left.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
# -*- coding: utf-8 -*-
"""
Spyder Editor
This is a temporary script file.
"""
import numpy as np
import cv2
MIN_MATCH_COUNT = 10
img1 = cv2.imread('Soccer-mid.jpg',0) # queryImage
img2 = cv2.imread('Soccer-right.jpg',0) # trainImage
cap = cv2.VideoCapture('football_left.mp4')
cap1 = cv2.VideoCapture('football_mid.mp4')
# Initiate SURF detector
sift=cv2.SIFT()
count=0
while(cap.isOpened() and cap1.isOpened() and count<500):
ret, frame = cap.read()
ret1,frame1=cap1.read()
count+=1
count=0
while(cap.isOpened() and cap1.isOpened()):
ret, frame = cap.read()
ret1,frame1=cap1.read()
image1=frame
image2=frame1
img1 = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
img2 = cv2.cvtColor(frame1, cv2.COLOR_BGR2GRAY)
img1 = cv2.flip(img1,1)
img2 = cv2.flip(img2,1)
image1 = cv2.flip(image1,1)
image2 = cv2.flip(image2,1)
# find the keypoints and descriptors with SURF
kp1, des1 = sift.detectAndCompute(img1,None)
kp2, des2 = sift.detectAndCompute(img2,None)
FLANN_INDEX_KDTREE = 0
index_params = dict(algorithm = FLANN_INDEX_KDTREE, trees = 5)
search_params = dict(checks = 50)
flann = cv2.FlannBasedMatcher(index_params, search_params)
matches = flann.knnMatch(des1,des2,k=2)
# store all the good matches as per Lowe's ratio test.
good = []
for m,n in matches:
if m.distance < 0.7*n.distance:
good.append(m)
if len(good)>MIN_MATCH_COUNT:
src_pts = np.float32([ kp1[m.queryIdx].pt for m in good ]).reshape(-1,1,2)
dst_pts = np.float32([ kp2[m.trainIdx].pt for m in good ]).reshape(-1,1,2)
M, mask = cv2.findHomography(src_pts, dst_pts, cv2.RANSAC,5.0)
matchesMask = mask.ravel().tolist()
h,w = img1.shape
pts = np.float32([ [0,0],[0,h-1],[w-1,h-1],[w-1,0] ]).reshape(-1,1,2)
dst = cv2.perspectiveTransform(pts,M)
img2 = cv2.polylines(img2,[np.int32(dst)],True,255,3, cv2.CV_AA)
out=cv2.warpPerspective(image1,M,(image1.shape[1]+image2.shape[1],image1.shape[0]))
mat=np.zeros([1080,1920,3])
mat=np.concatenate((image2,mat),axis=1)
out=out+mat
#for i in range (0,image2.shape[0]):
# for j in range (0,image2.shape[1]):
# if out[i,j,0]==0 and out[i,j,1]==0 and out[i,j,2]==0:
# out[i,j,0]=image2[i,j,0]
# out[i,j,1]=image2[i,j,1]
# out[i,j,2]=image2[i,j,2]
count+=1
out = cv2.flip(out,1)
cv2.imwrite("29.jpg",out)
print count
else:
print "Not enough matches are found", len(good)," ",MIN_MATCH_COUNT
matchesMask = None
draw_params = dict(matchColor = (0,255,0), # draw matches in green color
singlePointColor = None,
matchesMask = matchesMask, # draw only inliers
flags = 2)
#img3 = cv2.drawMatches(img1,kp1,img2,kp2,good,None,**draw_params)
#cv2.namedWindow('Video', cv2.WINDOW_OPENGL)
#cv2.imshow('Video',img3)
if cv2.waitKey(1) & 0xFF == 27 or count>=6:
break
cap.release()
cap1.release()
cv2.destroyAllWindows()
#plt.imshow(img3, 'gray'),plt.show()
#cv2.imwrite("25.jpg",img3)