Spaces:
Sleeping
Sleeping
File size: 2,595 Bytes
2c1ff7f |
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 |
GRADIO_TITLE = "Langues Guesser based on Name"
GRADIO_DESCRIPTION = '''
This is a self-learning project which replicates the [pytorch tutorial](https://pytorch.org/tutorials/intermediate/char_rnn_classification_tutorial.html) with modifications.
Kindly see [my GitHub: you may speak](https://github.com/LunaticMaestro/-NLP-_you_may_speak) readme to checkout the modifications.
Model Trained for names on following languages: ['Korean ๐ฐ๐ท', 'Portuguese ๐ต๐น', 'Dutch ๐ณ๐ฑ', 'Italian ๐ฎ๐น', 'German ๐ฉ๐ช', 'Scottish ๐ด\U000e0067\U000e0062\U000e0073\U000e0063\U000e0074\U000e007f', 'Vietnamese ๐ป๐ณ', 'French ๐ซ๐ท', 'English ๐ฌ๐ง', 'Arabic ๐ฒ๐ฆ', 'Irish ๐ฎ๐ช', 'Chinese ๐จ๐ณ', 'Japanese ๐ฏ๐ต', 'Russian ๐ท๐บ', 'Polish ๐ต๐ฑ', 'Czech ๐จ๐ฟ', 'Spanish ๐ช๐ธ', 'Greek ๐ฌ๐ท']
'''
import gradio as gr
from z_modelops import NameToLanguages
from z_inference import setup_inference, infer_lang
model, labels = setup_inference()
def get_langauge(name):
langugages = infer_lang(name, model, labels)
language_flags = {
"Korean": "\U0001F1F0\U0001F1F7", # South Korea
"Portuguese": "\U0001F1F5\U0001F1F9", # Portugal
"Dutch": "\U0001F1F3\U0001F1F1", # Netherlands
"Italian": "\U0001F1EE\U0001F1F9", # Italy
"German": "\U0001F1E9\U0001F1EA", # Germany
"Scottish": "\U0001F3F4\U000E0067\U000E0062\U000E0073\U000E0063\U000E0074\U000E007F", # Scotland (flag sequence)
"Vietnamese": "\U0001F1FB\U0001F1F3", # Vietnam
"French": "\U0001F1EB\U0001F1F7", # France
"English": "\U0001F1EC\U0001F1E7", # England (flag sequence)
"Arabic": "\U0001F1F2\U0001F1E6", # UAE (commonly associated with Arabic)
"Irish": "\U0001F1EE\U0001F1EA", # Ireland
"Chinese": "\U0001F1E8\U0001F1F3", # China
"Japanese": "\U0001F1EF\U0001F1F5", # Japan
"Russian": "\U0001F1F7\U0001F1FA", # Russia
"Polish": "\U0001F1F5\U0001F1F1", # Poland
"Czech": "\U0001F1E8\U0001F1FF", # Czech Republic
"Spanish": "\U0001F1EA\U0001F1F8", # Spain
"Greek": "\U0001F1EC\U0001F1F7" # Greece
}
return '\n'.join([lang + " " + language_flags[lang] for lang in langugages])
input_textbox = gr.Textbox(label="Your Name", placeholder="Naifeh", max_lines=1)
demo = gr.Interface(
fn=get_langauge,
inputs=input_textbox ,
outputs=gr.Label(label="You may speak"),
title=GRADIO_TITLE,
description=GRADIO_DESCRIPTION
)
demo.launch(debug=True) |