Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
2
22_23-J 18
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
22_23-J 18
22_23-J 18
Commits
91b0cd14
Commit
91b0cd14
authored
Apr 19, 2023
by
Lelkada L L P S M
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'it19001708_p' into 'master'
It19001708 p See merge request
!17
parents
45aea284
526b7bdc
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
175 additions
and
110 deletions
+175
-110
App/Backend/__pycache__/word_card_game.cpython-311.pyc
App/Backend/__pycache__/word_card_game.cpython-311.pyc
+0
-0
App/Backend/__pycache__/word_generation.cpython-311.pyc
App/Backend/__pycache__/word_generation.cpython-311.pyc
+0
-0
App/Backend/requirements.txt
App/Backend/requirements.txt
+2
-0
App/Backend/server.py
App/Backend/server.py
+27
-2
App/Backend/word_generation.py
App/Backend/word_generation.py
+38
-0
App/Frontend/screens/WordGenerationScreen.js
App/Frontend/screens/WordGenerationScreen.js
+108
-108
No files found.
App/Backend/__pycache__/word_card_game.cpython-311.pyc
0 → 100644
View file @
91b0cd14
File added
App/Backend/__pycache__/word_generation.cpython-311.pyc
0 → 100644
View file @
91b0cd14
File added
App/Backend/requirements.txt
View file @
91b0cd14
Flask==2.2.3
numpy==1.24.2
transformers
torch
\ No newline at end of file
App/Backend/server.py
View file @
91b0cd14
import
numpy
as
np
from
flask
import
Flask
,
request
,
jsonify
,
request
import
pickle
#
import pickle
from
word_card_game
import
wordGameData
from
word_generation
import
get_similar_words
from
flask_cors
import
CORS
app
=
Flask
(
__name__
)
...
...
@@ -12,6 +14,7 @@ app = Flask(__name__)
# send a json {'exp':1.8,} as a post request to make a prediction
'''
@app.route('/api/predict',methods=['POST'])
def predict():
data = request.get_json(force=True)
...
...
@@ -24,7 +27,29 @@ def predict():
def default_get():
return "<p>HereMe Backend !</p>"
'''
@
app
.
route
(
'/api/word-game'
,
methods
=
[
'GET'
])
def
word_game_api
():
w1
=
request
.
args
.
get
(
'w1'
)
w2
=
request
.
args
.
get
(
'w2'
)
w3
=
request
.
args
.
get
(
'w3'
)
if
not
all
([
w1
,
w2
,
w3
]):
return
jsonify
({
'error'
:
'All three words must be provided'
}),
400
data
=
wordGameData
(
w1
,
w2
,
w3
)
return
jsonify
(
data
)
@
app
.
route
(
'/api/similar-words'
,
methods
=
[
'GET'
])
def
similar_words_api
():
word
=
request
.
args
.
get
(
'word'
)
if
not
word
:
return
jsonify
({
'error'
:
'A word must be provided'
}),
400
similar_words
=
get_similar_words
(
word
)
return
jsonify
({
'similar_words'
:
similar_words
})
if
__name__
==
'__main__'
:
app
.
run
(
port
=
5000
,
debug
=
True
)
\ No newline at end of file
CORS
(
app
.
run
(
host
=
'0.0.0.0'
,
port
=
5000
,
debug
=
True
))
#app.run(host='0.0.0.0', port=5000, debug=True)
\ No newline at end of file
App/Backend/word_generation.py
0 → 100644
View file @
91b0cd14
import
torch
from
transformers
import
RobertaTokenizer
,
RobertaForMaskedLM
# Load the pretrained RoBERTa model and tokenizer
tokenizer
=
RobertaTokenizer
.
from_pretrained
(
'roberta-base'
)
model
=
RobertaForMaskedLM
.
from_pretrained
(
'roberta-base'
)
def
get_similar_words
(
input_word
,
top_k
=
3
):
# Create a masked sentence with the input word
masked_sentence
=
f
"The {input_word} is related to the {tokenizer.mask_token}."
# Tokenize the masked sentence
inputs
=
tokenizer
(
masked_sentence
,
return_tensors
=
'pt'
)
# Get the index of the mask token
mask_token_index
=
torch
.
where
(
inputs
[
'input_ids'
][
0
]
==
tokenizer
.
mask_token_id
)[
0
]
.
item
()
# Predict words for the mask token
with
torch
.
no_grad
():
output
=
model
(
**
inputs
)
predictions
=
output
.
logits
[
0
,
mask_token_index
]
# Get the top k predicted words
top_k_indices
=
torch
.
topk
(
predictions
,
top_k
)
.
indices
.
tolist
()
related_words
=
[
tokenizer
.
decode
(
idx
)
.
strip
()
for
idx
in
top_k_indices
]
# Create the result array
result
=
[]
for
word
in
related_words
:
image_url
=
f
'https://fyp-word-images.s3.us-east-2.amazonaws.com/{word}.png'
audio_url
=
f
'https://fyp-word-audio.s3.us-east-2.amazonaws.com/{word}.m4a'
result
.
append
({
'word'
:
word
,
'image'
:
image_url
,
'audio'
:
audio_url
})
return
result
App/Frontend/screens/WordGenerationScreen.js
View file @
91b0cd14
...
...
@@ -12,32 +12,37 @@ import {
import
{
Audio
}
from
"
expo-av
"
;
import
{
MaterialIcons
}
from
'
@expo/vector-icons
'
;
import
{
Ionicons
}
from
'
@expo/vector-icons
'
;
const
cards
=
[
{
word
:
"
kitchen
"
,
image
:
require
(
"
./assets/CG/content/kitchen.png
"
),
audio
:
require
(
"
./assets/CG/content/kitchen.m4a
"
),
},
{
word
:
"
pot
"
,
image
:
require
(
"
./assets/CG/content/pot.png
"
),
audio
:
require
(
"
./assets/CG/content/pot.m4a
"
),
},
{
word
:
"
vegetable
"
,
image
:
require
(
"
./assets/CG/content/vegetable.png
"
),
audio
:
require
(
"
./assets/CG/content/vegetable.m4a
"
),
},
];
const
screenWidth
=
Dimensions
.
get
(
"
window
"
).
width
;
const
screenHeight
=
Dimensions
.
get
(
"
window
"
).
height
;
const
fetchCards
=
async
()
=>
{
try
{
console
.
log
(
"
fetch cards 1
"
)
const
response
=
await
fetch
(
'
http://192.168.216.111:5000/api/similar-words?word=school
'
);
const
data
=
await
response
.
json
();
console
.
log
(
data
)
return
data
.
similar_words
;
}
catch
(
error
)
{
console
.
error
(
'
Error fetching cards:
'
,
error
);
}
};
export
default
function
ContentGenerationScreen
({
navigation
})
{
const
[
activeIndex
,
setActiveIndex
]
=
useState
(
0
);
const
[
cards
,
setCards
]
=
useState
([]);
const
scrollViewRef
=
useRef
(
null
);
const
soundRef
=
useRef
(
new
Audio
.
Sound
());
useEffect
(()
=>
{
const
loadCards
=
async
()
=>
{
const
fetchedCards
=
await
fetchCards
();
setCards
(
fetchedCards
);
};
loadCards
();
},
[]);
useEffect
(()
=>
{
const
unloadAudio
=
async
()
=>
{
await
soundRef
.
current
.
unloadAsync
();
...
...
@@ -50,7 +55,6 @@ export default function ContentGenerationScreen({ navigation }) {
};
},
[]);
const
handleScroll
=
async
(
event
)
=>
{
const
newIndex
=
Math
.
round
(
event
.
nativeEvent
.
contentOffset
.
x
/
screenWidth
...
...
@@ -58,66 +62,64 @@ export default function ContentGenerationScreen({ navigation }) {
if
(
newIndex
!==
activeIndex
)
{
setActiveIndex
(
newIndex
);
await
soundRef
.
current
.
unloadAsync
();
await
soundRef
.
current
.
loadAsync
(
cards
[
newIndex
].
audio
);
await
soundRef
.
current
.
loadAsync
(
{
uri
:
cards
[
newIndex
].
audio
}
);
await
soundRef
.
current
.
playAsync
();
}
};
const
handleAudioPress
=
async
()
=>
{
await
soundRef
.
current
.
unloadAsync
();
await
soundRef
.
current
.
loadAsync
(
cards
[
activeIndex
].
audio
);
await
soundRef
.
current
.
loadAsync
(
{
uri
:
cards
[
activeIndex
].
audio
}
);
await
soundRef
.
current
.
playAsync
();
};
return
(
<
ImageBackground
source
=
{
require
(
'
./assets/home/home_bg.png
'
)}
style
=
{
styles
.
backgroundImage
}
>
<
Image
<
Image
source
=
{
require
(
"
./assets/CG/monkey.png
"
)}
style
=
{
styles
.
monkeyImage
}
/
>
<
ScrollView
horizontal
pagingEnabled
showsHorizontalScrollIndicator
=
{
false
}
onScroll
=
{
handleScroll
}
ref
=
{
scrollViewRef
}
>
{
cards
.
map
((
card
,
index
)
=>
(
<
View
key
=
{
index
}
style
=
{[
styles
.
card
,
{
width
:
screenWidth
*
1
,
height
:
screenHeight
*
0.8
,
marginTop
:
screenHeight
*
0.15
},
]}
>
<
Image
source
=
{
require
(
"
./assets/CG/card_bg_2.png
"
)}
style
=
{
styles
.
cardBackground
}
/
>
<
Image
source
=
{
card
.
image
}
style
=
{
styles
.
cardImage
}
/
>
<
Text
style
=
{
styles
.
cardText
}
>
{
card
.
word
}
<
/Text
>
<
ScrollView
horizontal
pagingEnabled
showsHorizontalScrollIndicator
=
{
false
}
onScroll
=
{
handleScroll
}
ref
=
{
scrollViewRef
}
>
{
cards
.
map
((
card
,
index
)
=>
(
<
View
key
=
{
index
}
style
=
{[
styles
.
card
,
{
width
:
screenWidth
*
1
,
height
:
screenHeight
*
0.8
,
marginTop
:
screenHeight
*
0.15
},
]}
>
<
Image
source
=
{
require
(
"
./assets/CG/card_bg_2.png
"
)}
style
=
{
styles
.
cardBackground
}
/
>
<
Image
source
=
{{
uri
:
card
.
image
}}
style
=
{
styles
.
cardImage
}
/
>
<
Text
style
=
{
styles
.
cardText
}
>
{
card
.
word
}
<
/Text
>
<
TouchableOpacity
onPress
=
{
handleAudioPress
}
style
=
{
styles
.
audioButton
}
>
<
Ionicons
name
=
"
volume-high-outline
"
size
=
{
50
}
color
=
"
#FFCE6D
"
/>
<
/TouchableOpacity
>
<
TouchableOpacity
onPress
=
{
handleAudioPress
}
style
=
{
styles
.
audioButton
}
>
<
Ionicons
name
=
"
volume-high-outline
"
size
=
{
50
}
color
=
"
#FFCE6D
"
/>
<
/TouchableOpacity
>
{
index
===
cards
.
length
-
1
&&
(
<
TouchableOpacity
onPress
=
{()
=>
navigation
.
navigate
(
'
FlipCardGame
'
)
}
style
=
{
styles
.
nextButton
}
>
<
MaterialIcons
name
=
"
keyboard-arrow-right
"
size
=
{
65
}
color
=
"
#FFCE6D
"
/
>
<
/TouchableOpacity
>
)}
<
/View
>
))}
<
/ScrollView
>
<
/ImageBackground
>
);
{
index
===
cards
.
length
-
1
&&
(
<
TouchableOpacity
onPress
=
{()
=>
navigation
.
navigate
(
'
FlipCardGame
'
)}
style
=
{
styles
.
nextButton
}
>
<
MaterialIcons
name
=
"
keyboard-arrow-right
"
size
=
{
65
}
color
=
"
#FFCE6D
"
/
>
<
/TouchableOpacity
>
)}
<
/View
>
))}
<
/ScrollView
>
<
/ImageBackground
>
);
}
const
styles
=
StyleSheet
.
create
({
...
...
@@ -134,55 +136,53 @@ const styles = StyleSheet.create({
width
:
screenWidth
*
0.6
,
zIndex
:
1
,
},
card
:
{
justifyContent
:
"
center
"
,
alignItems
:
"
center
"
,
},
cardBackground
:
{
position
:
"
absolute
"
,
width
:
"
100%
"
,
height
:
"
100%
"
,
resizeMode
:
"
cover
"
,
},
cardImage
:
{
width
:
"
70%
"
,
height
:
"
50%
"
,
resizeMode
:
"
contain
"
,
},
cardText
:
{
fontSize
:
55
,
fontWeight
:
"
bold
"
,
marginTop
:
20
,
color
:
'
#FFCE6D
'
,
textShadowColor
:
'
rgba(0, 0, 0, 1)
'
,
textShadowOffset
:
{
width
:
-
1
,
height
:
1
},
textShadowRadius
:
10
,
},
audioButton
:
{
paddingHorizontal
:
20
,
paddingVertical
:
10
,
borderRadius
:
5
,
marginTop
:
20
,
backgroundColor
:
'
transparent
'
},
audioButtonText
:
{
color
:
"
#FFFFFF
"
,
fontSize
:
18
,
},
nextButton
:
{
backgroundColor
:
"
transparent
"
,
position
:
'
absolute
'
,
card
:
{
justifyContent
:
"
center
"
,
alignItems
:
"
center
"
,
},
cardBackground
:
{
position
:
"
absolute
"
,
width
:
"
100%
"
,
height
:
"
100%
"
,
resizeMode
:
"
cover
"
,
},
cardImage
:
{
width
:
"
70%
"
,
height
:
"
50%
"
,
resizeMode
:
"
contain
"
,
},
cardText
:
{
fontSize
:
55
,
fontWeight
:
"
bold
"
,
marginTop
:
20
,
color
:
'
#FFCE6D
'
,
textShadowColor
:
'
rgba(0, 0, 0, 1)
'
,
textShadowOffset
:
{
width
:
-
1
,
height
:
1
},
textShadowRadius
:
10
,
},
audioButton
:
{
paddingHorizontal
:
20
,
paddingVertical
:
10
,
borderRadius
:
5
,
marginTop
:
20
,
backgroundColor
:
'
transparent
'
},
audioButtonText
:
{
color
:
"
#FFFFFF
"
,
fontSize
:
18
,
},
nextButton
:
{
backgroundColor
:
"
transparent
"
,
position
:
'
absolute
'
,
bottom
:
20
,
right
:
45
,
justifyContent
:
'
center
'
,
alignItems
:
'
center
'
,
},
nextButtonText
:
{
color
:
"
#000000
"
,
fontSize
:
18
,
bottom
:
10
,
right
:
10
,
},
},
nextButtonText
:
{
color
:
"
#000000
"
,
fontSize
:
18
,
bottom
:
10
,
right
:
10
,
},
});
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