Daniel Vila merve HF staff commited on
Commit
a4f1003
·
0 Parent(s):

Duplicate from deprem-ml/ner-active-learning

Browse files

Co-authored-by: Merve Noyan <[email protected]>

Files changed (4) hide show
  1. .gitattributes +34 -0
  2. README.md +14 -0
  3. app.py +85 -0
  4. requirements.txt +3 -0
.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,14 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ title: NER Active Learning
3
+ emoji: 📖
4
+ colorFrom: yellow
5
+ colorTo: green
6
+ sdk: gradio
7
+ sdk_version: 3.18.0
8
+ app_file: app.py
9
+ pinned: false
10
+ license: apache-2.0
11
+ duplicated_from: deprem-ml/ner-active-learning
12
+ ---
13
+
14
+ Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
app.py ADDED
@@ -0,0 +1,85 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import os
2
+ import gradio as gr
3
+ from gradio import FlaggingCallback
4
+ from gradio.components import IOComponent
5
+
6
+ from transformers import pipeline
7
+
8
+ from typing import List, Optional, Any
9
+
10
+ import argilla as rg
11
+
12
+ import os
13
+
14
+
15
+
16
+ nlp = pipeline("ner", model="deprem-ml/deprem-ner")
17
+
18
+ examples = [
19
+ ["Lütfen yardım Akevler mahallesi Rüzgar sokak Tuncay apartmanı zemin kat Antakya akrabalarım göçük altında #hatay #Afad"]
20
+ ]
21
+
22
+ def create_record(input_text, feedback):
23
+ # define the record status based on feedback
24
+ # default means it needs to be reviewed --> "Incorrect" or "Ambiguous"
25
+ # validated means it's correct and has been checked --> "Correct"
26
+ status = "Validated" if feedback == "Doğru" else "Default"
27
+
28
+ # Making the prediction
29
+ predictions = nlp(input_text, aggregation_strategy="first")
30
+
31
+ # Creating the predicted entities as a list of tuples (entity, start_char, end_char, score)
32
+ prediction = [(pred["entity_group"], pred["start"], pred["end"], pred["score"]) for pred in predictions]
33
+
34
+ # Create word tokens
35
+ batch_encoding = nlp.tokenizer(input_text)
36
+ word_ids = sorted(set(batch_encoding.word_ids()) - {None})
37
+ words = []
38
+ for word_id in word_ids:
39
+ char_span = batch_encoding.word_to_chars(word_id)
40
+ words.append(input_text[char_span.start:char_span.end])
41
+
42
+ # Building a TokenClassificationRecord
43
+ record = rg.TokenClassificationRecord(
44
+ text=input_text,
45
+ tokens=words,
46
+ prediction=prediction,
47
+ prediction_agent="deprem-ml/deprem-ner",
48
+ status=status,
49
+ metadata={"feedback": feedback}
50
+ )
51
+ print(record)
52
+ return record
53
+
54
+ class ArgillaLogger(FlaggingCallback):
55
+ def __init__(self, api_url, api_key, dataset_name):
56
+ rg.init(api_url=api_url, api_key=api_key)
57
+ self.dataset_name = dataset_name
58
+ def setup(self, components: List[IOComponent], flagging_dir: str):
59
+ pass
60
+ def flag(
61
+ self,
62
+ flag_data: List[Any],
63
+ flag_option: Optional[str] = None,
64
+ flag_index: Optional[int] = None,
65
+ username: Optional[str] = None,
66
+ ) -> int:
67
+ text = flag_data[0]
68
+ inference = flag_data[1]
69
+ rg.log(name=self.dataset_name, records=create_record(text, flag_option))
70
+
71
+
72
+
73
+ gr.Interface.load(
74
+ "models/deprem-ml/deprem-ner",
75
+ examples=examples,
76
+ title = "NER Adres Aktif Öğrenme Arayüzü",
77
+ description = "Aşağıda veri girişi yapıp modelin çıktısına göre Doğru/Yanlış/Belirsiz olarak işaretleyerek modelimizi değerlendirmemize yardımcı olabilirsiniz. Not: flag'lere bir kez tıklamanız yeterlidir. Şu an arayüzü flag alındığında size feedback verecek şekilde düzeltiyoruz. ",
78
+ allow_flagging="manual",
79
+ flagging_callback=ArgillaLogger(
80
+ api_url="https://sandbox.argilla.io",
81
+ api_key=os.getenv("TEAM_API_KEY"),
82
+ dataset_name="ner-flags"
83
+ ),
84
+ flagging_options=["Doğru", "Yanlış", "Belirsiz"]
85
+ ).launch()
requirements.txt ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ transformers
2
+ torch
3
+ argilla