Department of Computer Science and Engineering Government Polytechnic For Women, Ramanagara 562159

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 72

DEPARTMENT OF COMPUTER SCIENCE AND ENGINEERING

GOVERNMENT POLYTECHNIC FOR WOMEN, RAMANAGARA 562159

MINI PROJECT REPORT ON

“AGE - GENDEER DETECTION”

Submitted in partial fulfillment of fifth semester Artificial Inteligence And Machine


Learning .in Computer Science and Engineering

Submitted By

142CS20018 PUNYA.B.B

142CS20019 RAFIYA NISBA

142CS20020 RAKSHITHA .K

142CS20022 SAHANA.K

Under the guidance of,

Guide Program Co-ordinate Principal

SUJATHA RATHNAKAR KANTHARAJU H M USHA D

Lecture
DEPARTMENT OF COMPUTER SCIENCE AND ENGINEERING

GOVERNMENT POLYTECHNIC FOR WOMEN

RAMANAGARA 562159

2022-23

CERTIFICATE

This is to certify that miss PUNYA.B.B : 142CS20018 and RAFIYA NISBA :


142CS20019 and RAKSHITHA .K : 142CS20020 : SAHANA.K has satisfactorily
implemented the mini project titled “AGE - GENDEER DETECTION” in fifth
semester Artificial Intelligence and Machine Learing with mini-project(20CS5511)

Mrs.Usha Mr.KANTHARAJU Mrs.SUJATHARATHNAKAR

Dept.of CS&E Dept.of CS&E Dept.of CS&E

Principle Hod Guid

External viva

Name &Signature of Examiner with Date

1.

2.

4
DECLARATION

We, PUNYA B B , RAFIYA NISBA , RAKSHITHA K, & SAHANA K Students of 5 th


Semester Government Women Polytechnic Of Ramanagra , bearing REGISTER
NUMBER: 142CS20018,142CS20019,142CS20020,& 142CS20022 Respectively,
Hereby Declared That The Project Entiled “AGE_GENDER_DETECTION” Has Been
Carried Out By Us Under the Supervision Of Our Guide ,Miss ,SUJATHA
RATNAKAR, Lecture Of Department Of COMPUTER SCIENCE & ENNG
RAMANAGARA Have Submitted In Partial Fulfillment Of The Requirements

DATE:

PLACE: Project Associates:

PUNYA B B

RAFIYA NISBA

RAKSHITHA K

SAHANA K
ACKNOWLEDGEMENT

The completion of any project Involves the efforts of many people. We have been
lucky to have received a lot of helps and support from all directions during the
making of this project, so with gratitude we take this opportunity to acknowledge
all those whose guidance & encouragement helped us to emerge successful.

We express our heartiest gratitude to our principle MISS USHA D

We are deeply indebted to professor and head of the Department, MR


KANTHRAJU H M & all the staff Department of CS&E for their constant guidance
& encouragement

We would like to express our profound sense of gratitude to our guide MISS
SUJATHA RATNAKAR , Department of CS&E for his kind guidance.

We Thank all the Teaching, non_teaching and technical supporting staff of


Department of computer science & engineering and Government polytechnic for
women Ramanagara

Project Associates:

PUNYA B B

RAFIYA NISBA

RAKSHITHA K

SAHANA K

CONTENTS:
Acknowledgement

Table of Contents

Abstract

1.INTRODUCTION
1.1 ABOUT GENDER & AGE DETECTION PROJECT
1.2 APPLICATIONS

1.3 TECHNOLOGIES USED

2.REQUIREMENTS SPECIFICATION
2.1 USER REQUIREMENTS
2.2 FUNCTIONAL REQUIREMENTS
2.3 HARDWARE SPECIFICATION DETAILS
2.4 SOFTWARE SPECIFICATION DETAILS

3.DESIGN

3.1 BASIC DESIGN


3.2 THE SOURCE CODE FOLDER FOR GENDER AND AGE DETECTION PROJECT CONSISTS OF THE FILES:
3.3 flow chart

4.IMPLEMENTATION

4.1code

5.SNAPSHOTS CONCLUSION REFERENCE


ABSTRACT

Abstract
Automatic prediction of age and
gender from face images has
drawn a lot of attention
recently,
due it is wide applications in
various facial analysis
problems. However, due to the
large intra-
class variation of face images
(such as variation in lighting,
pose, scale, occlusion), the
existing
models are still behind the
desired accuracy level, which is
necessary for th
Age and Gender
Detection System
Abstract
Automatic prediction of age and
gender from face images has
drawn a lot of attention
recently,
due it is wide applications in
various facial analysis
problems. However, due to the
large intra-
class variation of face images
(such as variation in lighting,
pose, scale, occlusion), the
existing
models are still behind the
desired accuracy level, which is
necessary for the use of these
models in real-world
applications. In this work, we
propose a deep learning
framework, based
on the ensemble of attentional
and residual convolutional
networks, to predict gender and
age
group of facial images with
high accuracy rate. Using
attention mechanism enables
our model to
focus on the important and
informative parts of the face,
which can help it to make a
more
accurate prediction. We train
our model in a multi-task
learning fashion, and augment
the
feature embedding of the age
classifier, with the predicted
gender, and show that doing so
can
further increase the accuracy of
age prediction. Our model is
trained on a popular face age
and
gender dataset, and achieved
promising results. Through
visualization of the attention
maps of
the train model, we show that
our model has learned to
become sensitive to the right
regions of
the fac
Automatic prediction of age and gender from face images has drawn a lot of
attention recently,

due it is wide applications in various facial analysis problems. However, due to the
large intra-class variation of face images(such as variation in lighting, pose, scale,
occlusion), the existing models are still behind the desired accuracy level, which is
necessary for the use of these models in real-world applications. In this work, we
propose a deep learning framework , based on the ensemble of attentional and
residual convolutional networks, to predict gender and age group of facial images
with high accuracy rate. Using attention mechanism enables our model to focus
on the important and informative parts of the face, which can help it to make a
more accurate prediction. We train our model in a multi-task learning fashion,
and augment the feature embedding of the age classifier, with the predicted
gender, and show that doing so can further increase the accuracy of age
prediction. Our model is trained on a popular face age and gender dataset, and
achived promising results. Through visualization of the attention maps of the train
model, we show that our model has learned to become sensitive to the right
regions of the face.
INTRODUCTION

About Gender and Age Detection Project:

Due to the rise of social platforms and social media nowadays, there is also an increase in the
number of applications that want automatic age and gender classification. As we know, age and
Gender are two key facial attributes that play a very important role in social interactions.
So, in this deep learning project. we will be creating real-time gender and age detection using
Deep Learning, and also in this, we will be using pre-trained models that classify the gender and
age of the person. So the model will predict the gender as ‘Male’ and ‘Female’, and the
predicted age will be in one of the following ranges- (0-2),(4-6),(8-12),(15-20),(25-32),(38-43),
(48-53),(60-100) ( so there are 8 nodes in the final output layer or say softmax layer).
It is very difficult to predict the exact age of the person due to many reasons like (makeup, light,
facial expressions, etc.) so that’s why we have considered this as a classification problem
instead of a regression problem.

To identify the age and gender of several faces’ procedures, are followedby several

methods. From the neural network, features are taken by the convolution network. In

light of the prepared models, the image is processed into one of the age classes. The

highlights are handled further and shipped off the preparation frameworks.

Artificial intelligence-based face analyzed technologies have gained serious importance. The
most important factor underlying the popularity of these technologies is that they can be used
very effectively in business life. Thanks to these technologies, such as customer segmentation,
product development, and business diary have all become improvable. The most widely used
artificial intelligence technologies based on face analysis are age detection and face
gender detection technologies. These technologies provide highly effective
APPLICATIONS

Quividi which is an AI software application which is used to detect age and


gender of user who passes by based on online face analyses and automatically
starts playing advertisement based on the target audience.

Human gender and age recognition is an emerging application foe intelligent


viedo analysis

 In the forensic field, where often only the description of suspect is available,
usually the data that is always gender and an age range, which would be very
useful in reducing the list of candidates to be compared with the sketch to get
answers to be more precise.

TECHNOLOGIES USED

1.OpenCv
openCV is Open Source Computer vision. This libray is capable of processing real-
time frame and viedo while also boasting analytical capabilities.

Features of OpenCV Library:


1. Read and write frames
2. Capture and save videos
3. Process frame

2.CONVOLUTIONAL NEURAL NETWORKS (CNN)

CNN is deep neural network widely used for the purpose of frame recognition
and processing and NLP.

3.TENSORFLOW

Tensor Flow is an end-to end open source platform for machine learning.
TensorFlow is a rich system for managing all aspects of a machine learning system
Abstract
Automatic prediction of age and
gender from face images has
drawn a lot of attention
recently,
due it is wide applications in
various facial analysis
problems. However, due to the
large intra-
class variation of face images
(such as variation in lighting,
pose, scale, occlusion), the
existing
models are still behind the
desired accuracy level, which is
necessary for th
Age and Gender
Detection System
Abstract
Automatic prediction of age and
gender from face images has
drawn a lot of attention
recently,
due it is wide applications in
various facial analysis
problems. However, due to the
large intra-
class variation of face images
(such as variation in lighting,
pose, scale, occlusion), the
existing
models are still behind the
desired accuracy level, which is
necessary for the use of these
models in real-world
applications. In this work, we
propose a deep learning
framework, based
on the ensemble of attentional
and residual convolutional
networks, to predict gender and
age
group of facial images with
high accuracy rate. Using
attention mechanism enables
our model to
focus on the important and
informative parts of the face,
which can help it to make a
more
accurate prediction. We train
our model in a multi-task
learning fashion, and augment
the
feature embedding of the age
classifier, with the predicted
gender, and show that doing so
can
further increase the accuracy of
age prediction. Our model is
trained on a popular face age
and
gender dataset, and achieved
promising results. Through
visualization of the attention
maps of
the train model, we show that
our model has learned to
become sensitive to the right
regions of
the fac
Age and Gender
Detection System
Abstract
Automatic prediction of age and
gender from face images has
drawn a lot of attention
recently,
due it is wide applications in
various facial analysis
problems. However, due to the
large intra-
class variation of face images
(such as variation in lighting,
pose, scale, occlusion), the
existing
models are still behind the
desired accuracy level, which is
necessary for the use of these
models in real-world
applications. In this work, we
propose a deep learning
framework, based
on the ensemble of attentional
and residual convolutional
networks, to predict gender and
age
group of facial images with
high accuracy rate. Using
attention mechanism enables
our model to
focus on the important and
informative parts of the face,
which can help it to make a
more
accurate prediction. We train
our model in a multi-task
learning fashion, and augment
the
feature embedding of the age
classifier, with the predicted
gender, and show that doing so
can
further increase the accuracy of
age prediction. Our model is
trained on a popular face age
and
gender dataset, and achieved
promising results. Through
visualization of the attention
maps of
the train model, we show that
our model has learned to
become sensitive to the right
regions of
the fac
REQUIREMENTS SPECIFICATION
System requirements are expressed in software requirement document.It is the official
statement of what is required of the system developers.Requirements document includes the
requirement definitions and requirement specification . The software requirement document is
not a designed document. It should set out what the system should do without specifying how
it should be done.

USER REQUIREMENT:

The package provides good user interface.

The system design should be based on functions

Age and gender detection is essential for authentication,human-computer interaction

FUNCTIONAL REQUIRMENTS

 First we detect faces,

Predict their Gender (Classify them into Male/Female)

Predict their Age ( Classify them into 8 age ranges that is mentioned above)

And at last put the results on the person’s face and display it.

HARDWARE REQUIREMENT
Processor :Intel 386 onwards Compatible Hardware
RAM:4GB RAM

Key board: Normal keyboard

Web camera

Computer

SOFTWARE REQUIRMENT
Operating system:windows 10

Libraries:cv2
DESIGN

So the Source Code folder for gender and age detection project consists of the following files:

age_deploy.prototxt: This is the file that will be required to run the age classification model.

age_net.caffemodle: This is the model file that contains the trained model which classifies the age in the
specified range.

gender_deploy.prototxt: This is the file which will be required to run the gender classification model.

gender_net.caffemodel: This file contains the trained model which predicts the gender of a person
present in an image or frame.

opencv_face_detector.pbtxt: This file will be required to detect faces in a particular image.

opencv_face_detector_unit8.pb : With the help of this file we will be able to detect faces.

Real_time_gender_age_detection.py: This is our main python file which contains whole code in which
we have used all the models and classify persons gender and age in real-time.

The full form of OpenCV is Open Source Computer Vision. It is widely used in machine learning as it is
capable of processing real-time image and video.

So to install OpenCV please open your command prompt and type:

1. Download this zip. Unzip it and put its contents in a directory you’ll call gad.

The contents of this zip are:

opencv_face_detector.pbtxt

opencv_face_detector_uint8.pb

age_deploy.prototxt

age_net.caffemodel

gender_deploy.prototxt

gender_net.caffemodel

a few pictures to try the project on


For face detection, we have a .pb file- this is a protobuf file (protocol buffer); it holds
the graph definition and the trained weights of the model. We can use this to run the
trained model. And while a .pb file holds the protobuf in binary format, one with
the .pbtxt extension holds it in text format. These are TensorFlow files. For age and
gender, the .prototxt files describe the network configuration and the .caffemodel file
defines the internal states of the parameters of the layers.

2. We use the argparse library to create an argument parser so we can get the image
argument from the command prompt. We make it parse the argument holding the path
to the image to classify gender and age for.

For face, age, and gender, initialize protocol buffer and model.

Initialize the mean values for the model and the lists of age ranges and genders to
classify from.

Now, use the readNet() method to load the networks. The first parameter holds trained
weights and the second carries network configuration.

Let’s capture video stream in case you’d like to classify on a webcam’s stream. Set
padding to 20.

Now until any key is pressed, we read the stream and store the content into the names
hasFrame and frame. If it isn’t a video, it must wait, and so we call up waitKey() from cv2,
then break.

Let’s make a call to the highlightFace() function with the faceNet and frame parameters,
and what this returns, we will store in the names resultImg and faceBoxes. And if we got
0 faceBoxes, it means there was no face to detect. Here, net is faceNet- this model is the
DNN Face Detector and holds only about 2.7MB on disk.

Create a shallow copy of frame and get its height and width.

Create a blob from the shallow copy.

Set the input and make a forward pass to the network.

faceBoxes is an empty list now. for each value in 0 to 127, define the confidence

(between 0 and 1). Wherever we find the confidence greater than the confidence
threshold, which is 0.7, we get the x1, y1, x2, and y2 coordinates and append a list of
those to faceBoxes.

Then, we put up rectangles on the image for each such list of coordinates and return
two things: the shallow copy and the list of faceBoxes.

But if there are indeed faceBoxes, for each of those, we define the face, create a 4-
dimensional blob from the image. In doing this, we scale it, resize it, and pass in the
mean values.

We feed the input and give the network a forward pass to get the confidence of the two
class. Whichever is higher, that is the gender of the person in the picture.

Then, we do the same thing for age.

We’ll add the gender and age texts to the resulting image and display it with imshow().
IMPLEMENTATION

Source code

Input code:

import cv2

def getFaceBox(faceNet, frame):


frameHeight = frame.shape[0]
frameWidth = frame.shape[1]
blob = cv2.dnn.blobFromImage(frame, 1.0, (227, 227), [104, 117, 123], swapRB=False)
faceNet.setInput(blob)
detection = faceNet.forward()
faceBoxes = []
for i in range(detection.shape[2]):
confidence = detection[0, 0, i, 2]
if confidence > 0.7:
x1 = int(detection[0, 0, i, 3] * frameWidth)
y1 = int(detection[0, 0, i, 4] * frameHeight)
x2 = int(detection[0, 0, i, 5] * frameWidth)
y2 = int(detection[0, 0, i, 6] * frameHeight)
faceBoxes.append([x1, y1, x2, y2])
cv2.rectangle(frame, (x1, y1), (x2, y2), (0, 255, 0), 1)
return frame, faceBoxes

faceProto = "opencv_face_detector.pbtxt"
faceModel = "opencv_face_detector_uint8.pb"

ageProto = "age_deploy.prototxt"
ageModel = "age_net.caffemodel"

genderProto = "gender_deploy.prototxt"
genderModel = "gender_net.caffemodel"

faceNet = cv2.dnn.readNet(faceModel, faceProto)


ageNet = cv2.dnn.readNet(ageModel, ageProto)
genderNet = cv2.dnn.readNet(genderModel, genderProto)
MODEL_MEAN_VALUES = (78.4263377603, 87.7689143744, 114.895847746)
ageList = ['(0-2)', '(4-6)', '(8-12)', '(15-20)', '(25-32)', '(38-43)', '(48-53)', '(60-100)']
genderList = ['Male', 'Female']

video = cv2.VideoCapture(0)

padding = 20

while True:
hasFrame, vidFrame = video.read()

if not hasFrame:
cv2.waitKey()
break

frame, faceBoxes = getFaceBox(faceNet, vidFrame)

if not faceBoxes:
print("No face detected")

for faceBox in faceBoxes:


face = frame[max(0, faceBox[1] - padding):min(faceBox[3] + padding, frame.shape[0] - 1),
max(0, faceBox[0] - padding):min(faceBox[2] + padding, frame.shape[1] - 1)]

blob = cv2.dnn.blobFromImage(face, 1.0, (227, 227), MODEL_MEAN_VALUES, swapRB=False)

genderNet.setInput(blob)
genderPred = genderNet.forward()
gender = genderList[genderPred[0].argmax()]

ageNet.setInput(blob)
agePred = ageNet.forward()
age = ageList[agePred[0].argmax()]

labelGender = "{}".format("Gender : " + gender)


labelAge = "{}".format("Age : " + age + "Years")
cv2.putText(frame, labelGender, (faceBox[0], faceBox[1] - 40), cv2.FONT_HERSHEY_SIMPLEX, 0.8,
(0, 255, 255), 2, cv2.LINE_AA)
cv2.putText(frame, labelAge, (faceBox[0], faceBox[1] - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.8,
(0, 255, 255), 2, cv2.LINE_AA)
cv2.imshow("Age-Gender Detector", frame)
if cv2.waitKey(1) == ord('q'):
break

video.release()
cv2.destroyAllWindows()
output
CONCLUSION

Though many prevision methods have addressed the


problems of age and gender classification , until recently,
much of this work has focused on constrained images
taken in lab settings. Such settings do not adequately
reflect appearance varitations common to the real-world
images in social website and online repositiories.

You might also like