Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
2
2022-169
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
2022-169
2022-169
Commits
a1f57042
Commit
a1f57042
authored
Oct 10, 2022
by
Heshani H.U
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Upload New File
parent
9c2ddc23
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
347 additions
and
0 deletions
+347
-0
app.py
app.py
+347
-0
No files found.
app.py
0 → 100644
View file @
a1f57042
from
PIL
import
Image
,
ImageTk
import
tkinter
as
tk
import
cv2
import
os
import
numpy
as
np
from
keras.models
import
model_from_json
import
operator
import
time
import
sys
,
os
import
matplotlib.pyplot
as
plt
import
hunspell
from
string
import
ascii_uppercase
class
Application
:
def
__init__
(
self
):
self
.
directory
=
'model'
self
.
hs
=
hunspell
.
HunSpell
(
'/usr/share/hunspell/en_US.dic'
,
'/usr/share/hunspell/en_US.aff'
)
self
.
vs
=
cv2
.
VideoCapture
(
0
)
self
.
current_image
=
None
self
.
current_image2
=
None
self
.
json_file
=
open
(
self
.
directory
+
"model-bw.json"
,
"r"
)
self
.
model_json
=
self
.
json_file
.
read
()
self
.
json_file
.
close
()
self
.
loaded_model
=
model_from_json
(
self
.
model_json
)
self
.
loaded_model
.
load_weights
(
self
.
directory
+
"model-bw.h5"
)
self
.
json_file_dru
=
open
(
self
.
directory
+
"model-bw_dru.json"
,
"r"
)
self
.
model_json_dru
=
self
.
json_file_dru
.
read
()
self
.
json_file_dru
.
close
()
self
.
loaded_model_dru
=
model_from_json
(
self
.
model_json_dru
)
self
.
loaded_model_dru
.
load_weights
(
"model-bw_dru.h5"
)
self
.
json_file_tkdi
=
open
(
self
.
directory
+
"model-bw_tkdi.json"
,
"r"
)
self
.
model_json_tkdi
=
self
.
json_file_tkdi
.
read
()
self
.
json_file_tkdi
.
close
()
self
.
loaded_model_tkdi
=
model_from_json
(
self
.
model_json_tkdi
)
self
.
loaded_model_tkdi
.
load_weights
(
self
.
directory
+
"model-bw_tkdi.h5"
)
self
.
json_file_smn
=
open
(
self
.
directory
+
"model-bw_smn.json"
,
"r"
)
self
.
model_json_smn
=
self
.
json_file_smn
.
read
()
self
.
json_file_smn
.
close
()
self
.
loaded_model_smn
=
model_from_json
(
self
.
model_json_smn
)
self
.
loaded_model_smn
.
load_weights
(
self
.
directory
+
"model-bw_smn.h5"
)
self
.
ct
=
{}
self
.
ct
[
'blank'
]
=
0
self
.
blank_flag
=
0
for
i
in
ascii_uppercase
:
self
.
ct
[
i
]
=
0
print
(
"Loaded model from disk"
)
self
.
root
=
tk
.
Tk
()
self
.
root
.
title
(
"Sign language to Text Converter"
)
self
.
root
.
protocol
(
'WM_DELETE_WINDOW'
,
self
.
destructor
)
self
.
root
.
geometry
(
"900x1100"
)
self
.
panel
=
tk
.
Label
(
self
.
root
)
self
.
panel
.
place
(
x
=
135
,
y
=
10
,
width
=
640
,
height
=
640
)
self
.
panel2
=
tk
.
Label
(
self
.
root
)
# initialize image panel
self
.
panel2
.
place
(
x
=
460
,
y
=
95
,
width
=
310
,
height
=
310
)
self
.
T
=
tk
.
Label
(
self
.
root
)
self
.
T
.
place
(
x
=
31
,
y
=
17
)
self
.
T
.
config
(
text
=
"Sign Language to Text"
,
font
=
(
"courier"
,
40
,
"bold"
))
self
.
panel3
=
tk
.
Label
(
self
.
root
)
# Current SYmbol
self
.
panel3
.
place
(
x
=
500
,
y
=
640
)
self
.
T1
=
tk
.
Label
(
self
.
root
)
self
.
T1
.
place
(
x
=
10
,
y
=
640
)
self
.
T1
.
config
(
text
=
"Character :"
,
font
=
(
"Courier"
,
40
,
"bold"
))
self
.
panel4
=
tk
.
Label
(
self
.
root
)
# Word
self
.
panel4
.
place
(
x
=
220
,
y
=
700
)
self
.
T2
=
tk
.
Label
(
self
.
root
)
self
.
T2
.
place
(
x
=
10
,
y
=
700
)
self
.
T2
.
config
(
text
=
"Word :"
,
font
=
(
"Courier"
,
40
,
"bold"
))
self
.
panel5
=
tk
.
Label
(
self
.
root
)
# Sentence
self
.
panel5
.
place
(
x
=
350
,
y
=
760
)
self
.
T3
=
tk
.
Label
(
self
.
root
)
self
.
T3
.
place
(
x
=
10
,
y
=
760
)
self
.
T3
.
config
(
text
=
"Sentence :"
,
font
=
(
"Courier"
,
40
,
"bold"
))
self
.
T4
=
tk
.
Label
(
self
.
root
)
self
.
T4
.
place
(
x
=
250
,
y
=
820
)
self
.
T4
.
config
(
text
=
"Suggestions"
,
fg
=
"red"
,
font
=
(
"Courier"
,
40
,
"bold"
))
self
.
btcall
=
tk
.
Button
(
self
.
root
,
command
=
self
.
action_call
,
height
=
0
,
width
=
0
)
self
.
btcall
.
config
(
text
=
"About"
,
font
=
(
"Courier"
,
14
))
self
.
btcall
.
place
(
x
=
825
,
y
=
0
)
self
.
bt1
=
tk
.
Button
(
self
.
root
,
command
=
self
.
action1
,
height
=
0
,
width
=
0
)
self
.
bt1
.
place
(
x
=
26
,
y
=
890
)
# self.bt1.grid(padx = 10, pady = 10)
self
.
bt2
=
tk
.
Button
(
self
.
root
,
command
=
self
.
action2
,
height
=
0
,
width
=
0
)
self
.
bt2
.
place
(
x
=
325
,
y
=
890
)
# self.panel3.place(x = 10,y=660)
# self.bt2.grid(row = 4, column = 1, columnspan = 1, padx = 10, pady = 10, sticky = tk.NW)
self
.
bt3
=
tk
.
Button
(
self
.
root
,
command
=
self
.
action3
,
height
=
0
,
width
=
0
)
self
.
bt3
.
place
(
x
=
625
,
y
=
890
)
# self.bt3.grid(row = 4, column = 2, columnspan = 1, padx = 10, pady = 10, sticky = tk.NW)
self
.
bt4
=
tk
.
Button
(
self
.
root
,
command
=
self
.
action4
,
height
=
0
,
width
=
0
)
self
.
bt4
.
place
(
x
=
125
,
y
=
950
)
# self.bt4.grid(row = bt1, column = 0, columnspan = 1, padx = 10, pady = 10, sticky = tk.N)
self
.
bt5
=
tk
.
Button
(
self
.
root
,
command
=
self
.
action5
,
height
=
0
,
width
=
0
)
self
.
bt5
.
place
(
x
=
425
,
y
=
950
)
# self.bt5.grid(row = 5, column = 1, columnspan = 1, padx = 10, pady = 10, sticky = tk.N)
self
.
str
=
""
self
.
word
=
""
self
.
current_symbol
=
"Empty"
self
.
photo
=
"Empty"
self
.
video_loop
()
def
video_loop
(
self
):
ok
,
frame
=
self
.
vs
.
read
()
if
ok
:
cv2image
=
cv2
.
flip
(
frame
,
1
)
x1
=
int
(
0.5
*
frame
.
shape
[
1
])
y1
=
10
x2
=
frame
.
shape
[
1
]
-
10
y2
=
int
(
0.5
*
frame
.
shape
[
1
])
cv2
.
rectangle
(
frame
,
(
x1
-
1
,
y1
-
1
),
(
x2
+
1
,
y2
+
1
),
(
255
,
0
,
0
),
1
)
cv2image
=
cv2
.
cvtColor
(
cv2image
,
cv2
.
COLOR_BGR2RGBA
)
self
.
current_image
=
Image
.
fromarray
(
cv2image
)
imgtk
=
ImageTk
.
PhotoImage
(
image
=
self
.
current_image
)
self
.
panel
.
imgtk
=
imgtk
self
.
panel
.
config
(
image
=
imgtk
)
cv2image
=
cv2image
[
y1
:
y2
,
x1
:
x2
]
gray
=
cv2
.
cvtColor
(
cv2image
,
cv2
.
COLOR_BGR2GRAY
)
blur
=
cv2
.
GaussianBlur
(
gray
,
(
5
,
5
),
2
)
th3
=
cv2
.
adaptiveThreshold
(
blur
,
255
,
cv2
.
ADAPTIVE_THRESH_GAUSSIAN_C
,
cv2
.
THRESH_BINARY_INV
,
11
,
2
)
ret
,
res
=
cv2
.
threshold
(
th3
,
70
,
255
,
cv2
.
THRESH_BINARY_INV
+
cv2
.
THRESH_OTSU
)
self
.
predict
(
res
)
self
.
current_image2
=
Image
.
fromarray
(
res
)
imgtk
=
ImageTk
.
PhotoImage
(
image
=
self
.
current_image2
)
self
.
panel2
.
imgtk
=
imgtk
self
.
panel2
.
config
(
image
=
imgtk
)
self
.
panel3
.
config
(
text
=
self
.
current_symbol
,
font
=
(
"Courier"
,
50
))
self
.
panel4
.
config
(
text
=
self
.
word
,
font
=
(
"Courier"
,
40
))
self
.
panel5
.
config
(
text
=
self
.
str
,
font
=
(
"Courier"
,
40
))
predicts
=
self
.
hs
.
suggest
(
self
.
word
)
if
(
len
(
predicts
)
>
0
):
self
.
bt1
.
config
(
text
=
predicts
[
0
],
font
=
(
"Courier"
,
20
))
else
:
self
.
bt1
.
config
(
text
=
""
)
if
(
len
(
predicts
)
>
1
):
self
.
bt2
.
config
(
text
=
predicts
[
1
],
font
=
(
"Courier"
,
20
))
else
:
self
.
bt2
.
config
(
text
=
""
)
if
(
len
(
predicts
)
>
2
):
self
.
bt3
.
config
(
text
=
predicts
[
2
],
font
=
(
"Courier"
,
20
))
else
:
self
.
bt3
.
config
(
text
=
""
)
if
(
len
(
predicts
)
>
3
):
self
.
bt4
.
config
(
text
=
predicts
[
3
],
font
=
(
"Courier"
,
20
))
else
:
self
.
bt4
.
config
(
text
=
""
)
if
(
len
(
predicts
)
>
4
):
self
.
bt4
.
config
(
text
=
predicts
[
4
],
font
=
(
"Courier"
,
20
))
else
:
self
.
bt4
.
config
(
text
=
""
)
self
.
root
.
after
(
30
,
self
.
video_loop
)
def
predict
(
self
,
test_image
):
test_image
=
cv2
.
resize
(
test_image
,
(
128
,
128
))
result
=
self
.
loaded_model
.
predict
(
test_image
.
reshape
(
1
,
128
,
128
,
1
))
result_dru
=
self
.
loaded_model_dru
.
predict
(
test_image
.
reshape
(
1
,
128
,
128
,
1
))
result_tkdi
=
self
.
loaded_model_tkdi
.
predict
(
test_image
.
reshape
(
1
,
128
,
128
,
1
))
result_smn
=
self
.
loaded_model_smn
.
predict
(
test_image
.
reshape
(
1
,
128
,
128
,
1
))
prediction
=
{}
prediction
[
'blank'
]
=
result
[
0
][
0
]
inde
=
1
for
i
in
ascii_uppercase
:
prediction
[
i
]
=
result
[
0
][
inde
]
inde
+=
1
# LAYER 1
prediction
=
sorted
(
prediction
.
items
(),
key
=
operator
.
itemgetter
(
1
),
reverse
=
True
)
self
.
current_symbol
=
prediction
[
0
][
0
]
# LAYER 2
if
(
self
.
current_symbol
==
'D'
or
self
.
current_symbol
==
'R'
or
self
.
current_symbol
==
'U'
):
prediction
=
{}
prediction
[
'D'
]
=
result_dru
[
0
][
0
]
prediction
[
'R'
]
=
result_dru
[
0
][
1
]
prediction
[
'U'
]
=
result_dru
[
0
][
2
]
prediction
=
sorted
(
prediction
.
items
(),
key
=
operator
.
itemgetter
(
1
),
reverse
=
True
)
self
.
current_symbol
=
prediction
[
0
][
0
]
if
(
self
.
current_symbol
==
'D'
or
self
.
current_symbol
==
'I'
or
self
.
current_symbol
==
'K'
or
self
.
current_symbol
==
'T'
):
prediction
=
{}
prediction
[
'D'
]
=
result_tkdi
[
0
][
0
]
prediction
[
'I'
]
=
result_tkdi
[
0
][
1
]
prediction
[
'K'
]
=
result_tkdi
[
0
][
2
]
prediction
[
'T'
]
=
result_tkdi
[
0
][
3
]
prediction
=
sorted
(
prediction
.
items
(),
key
=
operator
.
itemgetter
(
1
),
reverse
=
True
)
self
.
current_symbol
=
prediction
[
0
][
0
]
if
(
self
.
current_symbol
==
'M'
or
self
.
current_symbol
==
'N'
or
self
.
current_symbol
==
'S'
):
prediction1
=
{}
prediction1
[
'M'
]
=
result_smn
[
0
][
0
]
prediction1
[
'N'
]
=
result_smn
[
0
][
1
]
prediction1
[
'S'
]
=
result_smn
[
0
][
2
]
prediction1
=
sorted
(
prediction1
.
items
(),
key
=
operator
.
itemgetter
(
1
),
reverse
=
True
)
if
(
prediction1
[
0
][
0
]
==
'S'
):
self
.
current_symbol
=
prediction1
[
0
][
0
]
else
:
self
.
current_symbol
=
prediction
[
0
][
0
]
if
(
self
.
current_symbol
==
'blank'
):
for
i
in
ascii_uppercase
:
self
.
ct
[
i
]
=
0
self
.
ct
[
self
.
current_symbol
]
+=
1
if
(
self
.
ct
[
self
.
current_symbol
]
>
60
):
for
i
in
ascii_uppercase
:
if
i
==
self
.
current_symbol
:
continue
tmp
=
self
.
ct
[
self
.
current_symbol
]
-
self
.
ct
[
i
]
if
tmp
<
0
:
tmp
*=
-
1
if
tmp
<=
20
:
self
.
ct
[
'blank'
]
=
0
for
i
in
ascii_uppercase
:
self
.
ct
[
i
]
=
0
return
self
.
ct
[
'blank'
]
=
0
for
i
in
ascii_uppercase
:
self
.
ct
[
i
]
=
0
if
self
.
current_symbol
==
'blank'
:
if
self
.
blank_flag
==
0
:
self
.
blank_flag
=
1
if
len
(
self
.
str
)
>
0
:
self
.
str
+=
" "
self
.
str
+=
self
.
word
self
.
word
=
""
else
:
if
(
len
(
self
.
str
)
>
16
):
self
.
str
=
""
self
.
blank_flag
=
0
self
.
word
+=
self
.
current_symbol
def
action1
(
self
):
predicts
=
self
.
hs
.
suggest
(
self
.
word
)
if
(
len
(
predicts
)
>
0
):
self
.
word
=
""
self
.
str
+=
" "
self
.
str
+=
predicts
[
0
]
def
action2
(
self
):
predicts
=
self
.
hs
.
suggest
(
self
.
word
)
if
(
len
(
predicts
)
>
1
):
self
.
word
=
""
self
.
str
+=
" "
self
.
str
+=
predicts
[
1
]
def
action3
(
self
):
predicts
=
self
.
hs
.
suggest
(
self
.
word
)
if
(
len
(
predicts
)
>
2
):
self
.
word
=
""
self
.
str
+=
" "
self
.
str
+=
predicts
[
2
]
def
action4
(
self
):
predicts
=
self
.
hs
.
suggest
(
self
.
word
)
if
(
len
(
predicts
)
>
3
):
self
.
word
=
""
self
.
str
+=
" "
self
.
str
+=
predicts
[
3
]
def
action5
(
self
):
predicts
=
self
.
hs
.
suggest
(
self
.
word
)
if
(
len
(
predicts
)
>
4
):
self
.
word
=
""
self
.
str
+=
" "
self
.
str
+=
predicts
[
4
]
def
destructor
(
self
):
print
(
"Closing Application..."
)
self
.
root
.
destroy
()
self
.
vs
.
release
()
cv2
.
destroyAllWindows
()
def
destructor1
(
self
):
print
(
"Closing Application..."
)
self
.
root1
.
destroy
()
def
action_call
(
self
):
self
.
root1
=
tk
.
Toplevel
(
self
.
root
)
self
.
root1
.
title
(
"About"
)
self
.
root1
.
protocol
(
'WM_DELETE_WINDOW'
,
self
.
destructor1
)
self
.
root1
.
geometry
(
"900x900"
)
# img = cv2.imread("Pictures/sir.jpg", 1)
# # img = cv2.resize(img, (300, 300))
# cv2.imwrite("Pictures/sir.png", img)
# return
self
.
tx
=
tk
.
Label
(
self
.
root1
)
self
.
tx
.
place
(
x
=
330
,
y
=
20
)
self
.
tx
.
config
(
text
=
"Efforts By"
,
fg
=
"red"
,
font
=
(
"Courier"
,
30
,
"bold"
))
self
.
photo1
=
tk
.
PhotoImage
(
file
=
'Pictures/ravi.png'
)
self
.
w1
=
tk
.
Label
(
self
.
root1
,
image
=
self
.
photo1
)
self
.
w1
.
place
(
x
=
20
,
y
=
105
)
self
.
tx6
=
tk
.
Label
(
self
.
root1
)
self
.
tx6
.
place
(
x
=
20
,
y
=
250
)
self
.
tx6
.
config
(
text
=
"RC
\n
IIT2016141"
,
font
=
(
"Courier"
,
15
,
"bold"
))
self
.
photo2
=
tk
.
PhotoImage
(
file
=
'Pictures/nitin.png'
)
self
.
w2
=
tk
.
Label
(
self
.
root1
,
image
=
self
.
photo2
)
self
.
w2
.
place
(
x
=
200
,
y
=
105
)
self
.
tx2
=
tk
.
Label
(
self
.
root1
)
self
.
tx2
.
place
(
x
=
200
,
y
=
250
)
self
.
tx2
.
config
(
text
=
"Nitin
\n
IIT2016132"
,
font
=
(
"Courier"
,
15
,
"bold"
))
self
.
photo3
=
tk
.
PhotoImage
(
file
=
'Pictures/luv.png'
)
self
.
w3
=
tk
.
Label
(
self
.
root1
,
image
=
self
.
photo3
)
self
.
w3
.
place
(
x
=
380
,
y
=
105
)
self
.
tx3
=
tk
.
Label
(
self
.
root1
)
self
.
tx3
.
place
(
x
=
380
,
y
=
250
)
self
.
tx3
.
config
(
text
=
"Luv
\n
IIT2016085"
,
font
=
(
"Courier"
,
15
,
"bold"
))
self
.
photo4
=
tk
.
PhotoImage
(
file
=
'Pictures/sheldon.png'
)
self
.
w4
=
tk
.
Label
(
self
.
root1
,
image
=
self
.
photo4
)
self
.
w4
.
place
(
x
=
560
,
y
=
105
)
self
.
tx4
=
tk
.
Label
(
self
.
root1
)
self
.
tx4
.
place
(
x
=
560
,
y
=
250
)
self
.
tx4
.
config
(
text
=
"Sheldon
\n
IIT2016137"
,
font
=
(
"Courier"
,
15
,
"bold"
))
self
.
photo5
=
tk
.
PhotoImage
(
file
=
'Pictures/sid.png'
)
self
.
w5
=
tk
.
Label
(
self
.
root1
,
image
=
self
.
photo5
)
self
.
w5
.
place
(
x
=
740
,
y
=
105
)
self
.
tx5
=
tk
.
Label
(
self
.
root1
)
self
.
tx5
.
place
(
x
=
740
,
y
=
250
)
self
.
tx5
.
config
(
text
=
"Siddhant
\n
IIT2016069"
,
font
=
(
"Courier"
,
15
,
"bold"
))
self
.
tx7
=
tk
.
Label
(
self
.
root1
)
self
.
tx7
.
place
(
x
=
170
,
y
=
360
)
self
.
tx7
.
config
(
text
=
"Under the supervision of"
,
fg
=
"red"
,
font
=
(
"Courier"
,
30
,
"bold"
))
self
.
photo6
=
tk
.
PhotoImage
(
file
=
'Pictures/sir.png'
)
self
.
w6
=
tk
.
Label
(
self
.
root1
,
image
=
self
.
photo6
)
self
.
w6
.
place
(
x
=
350
,
y
=
420
)
self
.
tx6
=
tk
.
Label
(
self
.
root1
)
self
.
tx6
.
place
(
x
=
230
,
y
=
670
)
self
.
tx6
.
config
(
text
=
"Dr. Vrijendra Singh"
,
font
=
(
"Courier"
,
30
,
"bold"
))
print
(
"Starting Application..."
)
pba
=
Application
()
pba
.
root
.
mainloop
()
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment