This repository has been archived by the owner on Apr 14, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vj3_1.py
109 lines (98 loc) · 5.67 KB
/
vj3_1.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
105
106
107
108
109
from viola_jones.vj2_2 import *
frontDir = '/home/or/Desktop/Programming_Projects/Project_Onion/Onion_Excercises/Or_excercises/dataset_meir/'
cascadeFile = open(frontDir + "finalCascadeRoom.txt", "r")
cascade=[]
for line in cascadeFile:
line=line.strip()
lineData=line.split(" ",2)
cascade.append(weakClassifier([],float(lineData[0]),float(lineData[1])))
lineFeatures=lineData[2].split(" & ")
for stringFeature in lineFeatures:
stringFeature=[float(n) for n in stringFeature.split()]
for i,num in enumerate(stringFeature[0:-1]):
stringFeature[i]=int(num)
cascade[-1].features.append(haarFeature(stringFeature[0],stringFeature[1],stringFeature[2],stringFeature[3],stringFeature[4],stringFeature[5]))
def isFace(img,imgY,imgX,imgScaleFactor=1):
# print "qqqqqqqqqqqqqq"
result = 0
totalAlphaSum = 0
for classifier in cascade:
totalAlphaSum += (classifier.thresh * classifier.alphaSum)
for feature in classifier.features:
# print str(feature.fType)+" "+str(feature.y)+" "+str(feature.x)+" "+str(feature.h)+" "+str(feature.w)
result+=feature.alpha*img.testFeature(feature.fType, imgY+int(feature.y*imgScaleFactor), imgX+int(feature.x*imgScaleFactor),
int(feature.h*imgScaleFactor),int(feature.w*imgScaleFactor))
if result < totalAlphaSum:
print str(result)+" "+str(totalAlphaSum)
return False
print "wwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwww"
# input("asd")
return True
font=cv2.FONT_HERSHEY_SIMPLEX
cap = cv2.VideoCapture(0)
scaleFactor=2
delta=1
# subWindowSize=19.2 #24/1.25=19.2 because loop changes value at start
# currKRows = kRows
# currKCols = kCols
# totalScaleFactor=0.8 #1/1.25=0.8 because loop changes value at start
frameCount=0
while True:
subWindowSize = 19.2 # 24/1.25=19.2 because loop changes value at start
currKRows = kRows*8
currKCols = kCols*8
totalScaleFactor = 4 # 1/1.25=0.8 because loop changes value at start
frameCount+=1
print "rrrr"
# Capture frame-by-frame
ret, frame = cap.read()
frameRows, frameCols,_ = frame.shape
# Our operations on the frame come here
gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
img=imageDB(gray, 0, frameRows, frameCols, 1)
img.img=img.integralImage()
while currKRows<frameRows and currKCols<frameCols:
print "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX " + str(totalScaleFactor) + " " + str(currKRows) + " " + str(currKCols)
# subWindowSize*=((totalScaleFactor+2)/totalScaleFactor)
# currKRows*= ((totalScaleFactor+2.0)/totalScaleFactor)
# currKCols*= ((totalScaleFactor+2.0)/totalScaleFactor)
# totalScaleFactor+=scaleFactor
subWindowSize*=scaleFactor
currKRows*= scaleFactor
currKCols*= scaleFactor
totalScaleFactor*=scaleFactor
print "zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz "+str(totalScaleFactor)+" "+ str(currKRows)+" "+str(currKCols)
# input("123123")
for subWindowY in range(0,int(frameRows-round(currKRows)),int(totalScaleFactor*delta)):
for subWindowX in range(0,int(frameCols-round(currKCols)),int(totalScaleFactor*delta)):
# if int(totalScaleFactor)==12:
# print "@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ " \
# " "+ str(currKRows)+" "+str(currKCols)
# gray2 = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
# cv2.rectangle(gray2,(subWindowX,subWindowY),(subWindowX+24*int(totalScaleFactor),subWindowY+24*int(totalScaleFactor)),(255,0,0),2)
# cv2.imshow("gray",gray2)
# if cv2.waitKey(0) & 0xFF == ord('q'):
# cv2.destroyAllWindows()
# subWindow=imageDB(intImg[subWindowY:subWindowY+int(round(subWindowSize)),subWindowX:subWindowX+int(round(subWindowSize))],0,subWindowSize,
# subWindowSize)
if isFace(img,subWindowY,subWindowX,totalScaleFactor):
print "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa "+str(subWindowY)+" "+str(subWindowX)+" "+str(frameCount)+ " "+ str(
totalScaleFactor)
i=0
for cascadeLevel in cascade:
for feature in cascadeLevel.features:
i+=50
# cv2.rectangle(frame, (subWindowX+int(feature.x*totalScaleFactor),subWindowY+int(feature.y*totalScaleFactor)),
# (subWindowX+int((feature.x+feature.w)*totalScaleFactor),subWindowY+int((feature.y+feature.h)*totalScaleFactor)),
# (i, i,i), 2)
cv2.rectangle(frame, (subWindowX, subWindowY),
(subWindowX+kCols*int(totalScaleFactor),subWindowY+kRows*int(totalScaleFactor)),
(i, i, i), 2)
cv2.putText(frame, 'FACE DETECTED', (100,100), font, 1, (0, 0, 255), 3, 8)
print "&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&"
cv2.imshow('frame',frame)
if cv2.waitKey(100) & 0xFF == ord('q'):
break
# When everything done, release the capture
cap.release()
cv2.destroyAllWindows()