AgaMiko commited on
Commit
bea6893
·
0 Parent(s):

Duplicate from Voicelab/vlT5-keywords-generation

Browse files
.gitattributes ADDED
@@ -0,0 +1,34 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ *.7z filter=lfs diff=lfs merge=lfs -text
2
+ *.arrow filter=lfs diff=lfs merge=lfs -text
3
+ *.bin filter=lfs diff=lfs merge=lfs -text
4
+ *.bz2 filter=lfs diff=lfs merge=lfs -text
5
+ *.ckpt filter=lfs diff=lfs merge=lfs -text
6
+ *.ftz filter=lfs diff=lfs merge=lfs -text
7
+ *.gz filter=lfs diff=lfs merge=lfs -text
8
+ *.h5 filter=lfs diff=lfs merge=lfs -text
9
+ *.joblib filter=lfs diff=lfs merge=lfs -text
10
+ *.lfs.* filter=lfs diff=lfs merge=lfs -text
11
+ *.mlmodel filter=lfs diff=lfs merge=lfs -text
12
+ *.model filter=lfs diff=lfs merge=lfs -text
13
+ *.msgpack filter=lfs diff=lfs merge=lfs -text
14
+ *.npy filter=lfs diff=lfs merge=lfs -text
15
+ *.npz filter=lfs diff=lfs merge=lfs -text
16
+ *.onnx filter=lfs diff=lfs merge=lfs -text
17
+ *.ot filter=lfs diff=lfs merge=lfs -text
18
+ *.parquet filter=lfs diff=lfs merge=lfs -text
19
+ *.pb filter=lfs diff=lfs merge=lfs -text
20
+ *.pickle filter=lfs diff=lfs merge=lfs -text
21
+ *.pkl filter=lfs diff=lfs merge=lfs -text
22
+ *.pt filter=lfs diff=lfs merge=lfs -text
23
+ *.pth filter=lfs diff=lfs merge=lfs -text
24
+ *.rar filter=lfs diff=lfs merge=lfs -text
25
+ *.safetensors filter=lfs diff=lfs merge=lfs -text
26
+ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
27
+ *.tar.* filter=lfs diff=lfs merge=lfs -text
28
+ *.tflite filter=lfs diff=lfs merge=lfs -text
29
+ *.tgz filter=lfs diff=lfs merge=lfs -text
30
+ *.wasm filter=lfs diff=lfs merge=lfs -text
31
+ *.xz filter=lfs diff=lfs merge=lfs -text
32
+ *.zip filter=lfs diff=lfs merge=lfs -text
33
+ *.zst filter=lfs diff=lfs merge=lfs -text
34
+ *tfevents* filter=lfs diff=lfs merge=lfs -text
README.md ADDED
@@ -0,0 +1,13 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ title: VlT5 Keywords Generation
3
+ emoji: 🌍
4
+ colorFrom: pink
5
+ colorTo: pink
6
+ sdk: streamlit
7
+ sdk_version: 1.15.2
8
+ app_file: app.py
9
+ pinned: false
10
+ duplicated_from: Voicelab/vlT5-keywords-generation
11
+ ---
12
+
13
+ Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
app.py ADDED
@@ -0,0 +1,100 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from transformers import T5ForConditionalGeneration, T5Tokenizer
2
+ import streamlit as st
3
+ from PIL import Image
4
+ import os
5
+
6
+ @st.cache(allow_output_mutation=True)
7
+ def load_model_cache():
8
+ auth_token = os.environ.get("TOKEN_FROM_SECRET") or True
9
+ tokenizer_en = T5Tokenizer.from_pretrained(
10
+ "Voicelab/vlt5-base-keywords-v4_3-en", use_auth_token=auth_token
11
+ )
12
+ model_en = T5ForConditionalGeneration.from_pretrained(
13
+ "Voicelab/vlt5-base-keywords-v4_3-en", use_auth_token=auth_token
14
+ )
15
+
16
+ tokenizer_pl = T5Tokenizer.from_pretrained(
17
+ "Voicelab/vlt5-base-keywords-v4_3", use_auth_token=auth_token
18
+ )
19
+ model_pl = T5ForConditionalGeneration.from_pretrained(
20
+ "Voicelab/vlt5-base-keywords-v4_3", use_auth_token=auth_token
21
+ )
22
+
23
+ return tokenizer_en, model_en, tokenizer_pl, model_pl
24
+
25
+
26
+ img_full = Image.open("images/vl-logo-nlp-blue.png")
27
+ img_short = Image.open("images/sVL-NLP-short.png")
28
+ img_favicon = Image.open("images/favicon_vl.png")
29
+ max_length: int = 1000
30
+ cache_size: int = 100
31
+
32
+ st.set_page_config(
33
+ page_title="DEMO - keywords generation",
34
+ page_icon=img_favicon,
35
+ initial_sidebar_state="expanded",
36
+ )
37
+
38
+ tokenizer_en, model_en, tokenizer_pl, model_pl = load_model_cache()
39
+
40
+ def get_predictions(text, language):
41
+ if language == "Polish":
42
+ input_ids = tokenizer_pl(text, return_tensors="pt", truncation=True).input_ids
43
+ output = model_pl.generate(
44
+ input_ids,
45
+ no_repeat_ngram_size=2,
46
+ num_beams=3,
47
+ num_beam_groups=3,
48
+ repetition_penalty=1.5,
49
+ diversity_penalty=2.0,
50
+ length_penalty=2.0,
51
+ )
52
+ predicted_kw = tokenizer_pl.decode(output[0], skip_special_tokens=True)
53
+ elif language == "English":
54
+ input_ids = tokenizer_en(text, return_tensors="pt", truncation=True).input_ids
55
+ output = model_en.generate(
56
+ input_ids,
57
+ no_repeat_ngram_size=2,
58
+ num_beams=3,
59
+ num_beam_groups=3,
60
+ repetition_penalty=1.5,
61
+ diversity_penalty=2.0,
62
+ length_penalty=2.0,
63
+ )
64
+ predicted_kw = tokenizer_en.decode(output[0], skip_special_tokens=True)
65
+ return predicted_kw
66
+
67
+
68
+ def trim_length():
69
+ if len(st.session_state["input"]) > max_length:
70
+ st.session_state["input"] = st.session_state["input"][:max_length]
71
+
72
+
73
+ if __name__ == "__main__":
74
+ st.sidebar.image(img_short)
75
+ st.image(img_full)
76
+ st.title("VLT5 - keywords generation")
77
+
78
+ generated_keywords = ""
79
+ user_input = st.text_area(
80
+ label=f"Input text (max {max_length} characters)",
81
+ value="",
82
+ height=300,
83
+ on_change=trim_length,
84
+ key="input",
85
+ )
86
+
87
+ language = st.sidebar.title("Model settings")
88
+ language = st.sidebar.radio(
89
+ "Select model to test",
90
+ [
91
+ "Polish",
92
+ "English",
93
+ ],
94
+ )
95
+
96
+ result = st.button("Generate keywords")
97
+ if result:
98
+ generated_keywords = get_predictions(text=user_input, language=language)
99
+ st.text_area("Generated keywords", generated_keywords)
100
+ print(f"Input: {user_input}---> Keywords: {generated_keywords}")
images/favicon_vl.png ADDED
images/sVL-NLP-short.png ADDED
images/vl-logo-nlp-blue.png ADDED
requirements.txt ADDED
@@ -0,0 +1,5 @@
 
 
 
 
 
 
1
+ streamlit
2
+ transformers
3
+ torch
4
+ transformers[sentencepiece]
5
+ Pillow