Irpan commited on
Commit
734a7ea
·
1 Parent(s): deb8ef3
Files changed (2) hide show
  1. app.py +5 -33
  2. util.py +30 -0
app.py CHANGED
@@ -1,37 +1,7 @@
1
  import gradio as gr
2
- import random
3
- from umsc import UgMultiScriptConverter
4
-
5
-
6
- # Lists of Uyghur short and long texts
7
- short_texts = [
8
- "سالام", "رەھمەت", "ياخشىمۇسىز"
9
- ]
10
- long_texts = [
11
- "مەكتەپكە بارغاندا تېخىمۇ بىلىملىك بولۇپ قېلىمەن.",
12
- "يېزا مەنزىرىسى ھەقىقەتەن گۈزەل.",
13
- "پېقىرلارغا ياردەم قىلىش مەنەم پەرزەندە."
14
- ]
15
 
16
  # Functions
17
- def generate_short_text(script_choice):
18
- """Generate a random Uyghur short text based on the type."""
19
- ug_arab_to_latn = UgMultiScriptConverter('UAS', 'ULS')
20
-
21
- text = random.choice(short_texts)
22
- if script_choice == "Uyghur Latin":
23
- return ug_arab_to_latn(text)
24
- return text
25
-
26
- def generate_long_text(script_choice):
27
- """Generate a random Uyghur long text based on the type."""
28
- ug_arab_to_latn = UgMultiScriptConverter('UAS', 'ULS')
29
-
30
- text = random.choice(long_texts)
31
- if script_choice == "Uyghur Latin":
32
- return ug_arab_to_latn(text)
33
- return text
34
-
35
  def generate_example_pronunciation(input_text, script):
36
  # Placeholder for generating example pronunciation
37
  example_audio = None # Replace with actual example audio generation logic
@@ -47,6 +17,7 @@ def check_pronunciation(input_text, script, user_audio):
47
  pronunciation_score = 85.7 # Replace with actual score calculation
48
  return transcript_ugArab_box, transcript_ugLatn_box, correct_pronunciation, user_pronunciation, pronunciation_match, pronunciation_score
49
 
 
50
  with gr.Blocks() as app:
51
  with gr.Row():
52
  # Input Column
@@ -122,13 +93,13 @@ with gr.Blocks() as app:
122
 
123
  # Bind functions to buttons
124
  generate_short_btn.click(
125
- generate_short_text,
126
  inputs=[script_choice],
127
  outputs=[input_text]
128
  )
129
 
130
  generate_long_btn.click(
131
- generate_long_text,
132
  inputs=[script_choice],
133
  outputs=[input_text]
134
  )
@@ -145,5 +116,6 @@ with gr.Blocks() as app:
145
  outputs=[transcript_ugArab_box, transcript_ugLatn_box, correct_pronunciation_box, user_pronunciation_box, match_box, score_box]
146
  )
147
 
 
148
  if __name__ == "__main__":
149
  app.launch()
 
1
  import gradio as gr
2
+ import util
 
 
 
 
 
 
 
 
 
 
 
 
3
 
4
  # Functions
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5
  def generate_example_pronunciation(input_text, script):
6
  # Placeholder for generating example pronunciation
7
  example_audio = None # Replace with actual example audio generation logic
 
17
  pronunciation_score = 85.7 # Replace with actual score calculation
18
  return transcript_ugArab_box, transcript_ugLatn_box, correct_pronunciation, user_pronunciation, pronunciation_match, pronunciation_score
19
 
20
+ # Front-End
21
  with gr.Blocks() as app:
22
  with gr.Row():
23
  # Input Column
 
93
 
94
  # Bind functions to buttons
95
  generate_short_btn.click(
96
+ util.generate_short_text,
97
  inputs=[script_choice],
98
  outputs=[input_text]
99
  )
100
 
101
  generate_long_btn.click(
102
+ util.generate_long_text,
103
  inputs=[script_choice],
104
  outputs=[input_text]
105
  )
 
116
  outputs=[transcript_ugArab_box, transcript_ugLatn_box, correct_pronunciation_box, user_pronunciation_box, match_box, score_box]
117
  )
118
 
119
+ # Main
120
  if __name__ == "__main__":
121
  app.launch()
util.py CHANGED
@@ -0,0 +1,30 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import random
2
+ from umsc import UgMultiScriptConverter
3
+
4
+ # Lists of Uyghur short and long texts
5
+ short_texts = [
6
+ "سالام", "رەھمەت", "ياخشىمۇسىز"
7
+ ]
8
+ long_texts = [
9
+ "مەكتەپكە بارغاندا تېخىمۇ بىلىملىك بولۇپ قېلىمەن.",
10
+ "يېزا مەنزىرىسى ھەقىقەتەن گۈزەل.",
11
+ "پېقىرلارغا ياردەم قىلىش مەنەم پەرزەندە."
12
+ ]
13
+
14
+ def generate_short_text(script_choice):
15
+ """Generate a random Uyghur short text based on the type."""
16
+ ug_arab_to_latn = UgMultiScriptConverter('UAS', 'ULS')
17
+
18
+ text = random.choice(short_texts)
19
+ if script_choice == "Uyghur Latin":
20
+ return ug_arab_to_latn(text)
21
+ return text
22
+
23
+ def generate_long_text(script_choice):
24
+ """Generate a random Uyghur long text based on the type."""
25
+ ug_arab_to_latn = UgMultiScriptConverter('UAS', 'ULS')
26
+
27
+ text = random.choice(long_texts)
28
+ if script_choice == "Uyghur Latin":
29
+ return ug_arab_to_latn(text)
30
+ return text