-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtask2_2_step_4.py
66 lines (54 loc) · 2.23 KB
/
task2_2_step_4.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
#step 4
#Apply hard-negative mining. For each image and each possible scale of
#each image in your negative training set, apply the sliding window technique
#and slide your window across the image. At each window compute your HOG descriptors
#and apply your classifier. If your classifier (incorrectly) classifies a given window
#as an object (and it will, there will absolutely be false-positives),
#record the feature vector associated with the false-positive patch along with the
#probability of the classification. This approach is called hard-negative mining.
# USAGE
# python sliding_window.py --image images/adrian_florida.jpg
# import the necessary packages
from imagesearch.helpers import pyramid
from imagesearch.helpers import sliding_window
from task2_2_step_3 import lin_svc
from config import negative_training_1, negative_training_2, negative_training_3, negative_training_4
from config import road9, road10, negative_training_1
from skimage.feature import hog
from PIL import Image
from skimage import color, exposure
from sklearn.svm.libsvm import decision_function
from sklearn import svm
import argparse
import time
import cv2
import numpy as np
# load the image and define the window width and height
image = cv2.imread(road9)
(winW, winH) = (225, 225)
false_positives = []
# loop over the image pyramid
for resized in pyramid(image, scale=1.5):
# loop over the sliding window for each layer of the pyramid
for (x, y, window) in sliding_window(resized, stepSize=32, windowSize=(winW, winH)):
# if the window does not meet our desired window size, ignore it
if window.shape[0] != winH or window.shape[1] != winW:
# print window.shape[0], window.shape[1]
continue
# THIS IS WHERE YOU WOULD PROCESS YOUR WINDOW, SUCH AS APPLYING A
# MACHINE LEARNING CLASSIFIER TO CLASSIFY THE CONTENTS OF THE
# WINDOW
hog = cv2.HOGDescriptor()
h = hog.compute(resized)
print(h)
prediciton = lin_svc.predict(h.reshape(1,-1))
print(prediciton)
# threshold = 0.4
# loc = np.where( h >= threshold)
# print(loc)
# # since we do not have a classifier, we'll just draw the window
clone = resized.copy()
cv2.rectangle(clone, (x,y), (x + 130, y + 130), (0, 255, 0), 2)
cv2.imshow("Window", clone)
cv2.waitKey(1)
time.sleep(10)