This repository has been archived by the owner on Sep 21, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathThread_Server.py
100 lines (96 loc) · 3.05 KB
/
Thread_Server.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
''' usage :
python3 Server.py
'''
import numpy as np
import cv2
# Import the socket library
import socket
import pickle
import struct
from Recognize import *
import threading
def handle_client(client_socket):
skin_detect = Skin_Detect()
size1 = (30,30)
size2 = (80,110)
scale_factor = 3
Face_Detect = Face_Detector(skin_detect)
face_cascade = './Haar_Cascades/haarcascade_frontalface_default.xml'
file_name = 'train.yaml'
if not (os.path.isfile(file_name)):
raise RuntimeError("%s: not found" % file_name)
if not (os.path.isfile(face_cascade)):
raise RuntimeError("%s: not found" % face_cascade)
# variables for LBPH algorithm
radius = 1
neighbour = 8
grid_x = 8
grid_y = 8
var = list([radius,neighbour,grid_x,grid_y])
model = Recognizer(face_cascade,file_name,var)
while True:
data = b""
# struct_size is 8 bytes
struct_size = struct.calcsize("l")
#print("\n[*] Struct Size: ",struct_size)
img_size= client_socket.recv(struct_size)
# struct.unpack retrun a tuple
if len(img_size) == 0:
break
img_size = struct.unpack("l", img_size)[0]
#print("\n[*] Message Size : {}".format(img_size))
while len(data) < img_size:
data += client_socket.recv(CHUNK_SIZE)
#print("\n[*] Receiving ",len(data))
if len(data) == 0 :
break
frame_data = data[:img_size]
#print(len(data))
data = data[img_size:]
frame=pickle.loads(frame_data)
frame = cv2.imdecode(frame, cv2.IMREAD_COLOR)
predicted = model.predict(frame,Face_Detect,size1,size2)
result, frame = cv2.imencode('.jpeg', predicted, encode_param)
# Returns the bytes object of the serialized object.
data = pickle.dumps(frame, 0)
size = len(data)
#print("\n[*] Sending a packet size of: ",size)
client_socket.sendall(struct.pack("l",size) + data)
#print("\n[*] Image is sent successfully ")
# wainting for recognized images
#print('\n[*] Waiting for Server...')
#time.sleep(2)
client_socket.close()
print('\n[*] Socket closed...')
if __name__ == "__main__":
try:
# Create a socket object
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
print("\n[*] Socket successfully created")
except socket.error as err:
print("\n[*] Socket creation failed with error : ",err)
HOST = "localhost"
# Port for socket
PORT = 4444 # Arbitrary non-privileged port
# Bind to the port
try:
server_socket.bind((HOST, PORT))
except socket.error as err:
print('Bind failed. Error Message : ',err)
sys.exit()
print('Socket bind successfully')
print("\n[*] Socket binded to : ",PORT)
# Listen for connections : allow only 5 connection
server_socket.listen(5)
print("\n[*] Socket is now listening")
CHUNK_SIZE = 4 * 1024
encode_param = [int(cv2.IMWRITE_JPEG_QUALITY), 90]
while True:
print('\n[*] Waiting for client...')
# Wait to accept a connection - blocking call
client_socket, addr = server_socket.accept()
# print the socket object : ip addr and port nb : client info
print('\n[*] Connected from ip: {} and port : {} '.format(addr[0],addr[1]))
t = threading.Thread(target=handle_client, args=(client_socket,))
#t.daemon = True
t.start()