Netta1994 commited on
Commit
f810a51
1 Parent(s): 3ceb443

Add SetFit model

Browse files
1_Pooling/config.json ADDED
@@ -0,0 +1,10 @@
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "word_embedding_dimension": 768,
3
+ "pooling_mode_cls_token": true,
4
+ "pooling_mode_mean_tokens": false,
5
+ "pooling_mode_max_tokens": false,
6
+ "pooling_mode_mean_sqrt_len_tokens": false,
7
+ "pooling_mode_weightedmean_tokens": false,
8
+ "pooling_mode_lasttoken": false,
9
+ "include_prompt": true
10
+ }
README.md ADDED
@@ -0,0 +1,241 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ base_model: BAAI/bge-base-en-v1.5
3
+ library_name: setfit
4
+ metrics:
5
+ - accuracy
6
+ pipeline_tag: text-classification
7
+ tags:
8
+ - setfit
9
+ - sentence-transformers
10
+ - text-classification
11
+ - generated_from_setfit_trainer
12
+ widget:
13
+ - text: 'Reasoning:
14
+
15
+ The answer is grounded well in the document and stays relevant to the question.
16
+ Importantly, every point mentioned is specifically found in the provided document
17
+ with no unnecessary deviation.
18
+
19
+
20
+ Evaluation:'
21
+ - text: 'Reasoning:
22
+
23
+ correct- The provided answer accurately portrays the process of writing a paper
24
+ in MLA format and is supported by the details provided in the given document.
25
+
26
+ Evaluation:'
27
+ - text: 'Reasoning:
28
+
29
+ Context Grounding: The answer is closely aligned with the information in the document,
30
+ which provides an extensive guide on the prerequisites, GPA importance, clinical
31
+ experience, and MCAT preparation.
32
+
33
+ Relevance: The answer addresses the question directly by discussing key steps
34
+ such as focusing on core courses, gaining clinical experience, and preparing for
35
+ the MCAT.
36
+
37
+ Conciseness: The answer is concise yet comprehensive, covering the main steps
38
+ without introducing extraneous information.
39
+
40
+
41
+ Final Result:'
42
+ - text: 'Reasoning:
43
+
44
+ The answer is reasonably well-grounded in the provided document, and it remains
45
+ relevant to the question. However, it introduces the notion of camouflaging in
46
+ multi-colored areas, which is implied but not explicitly stated with that specificity
47
+ in the document.
48
+
49
+
50
+ Evaluation:'
51
+ - text: 'Reasoning:
52
+
53
+ contradiction - The answer contains information that contradicts what appears
54
+ in the document.
55
+
56
+ Evaluation:'
57
+ inference: true
58
+ model-index:
59
+ - name: SetFit with BAAI/bge-base-en-v1.5
60
+ results:
61
+ - task:
62
+ type: text-classification
63
+ name: Text Classification
64
+ dataset:
65
+ name: Unknown
66
+ type: unknown
67
+ split: test
68
+ metrics:
69
+ - type: accuracy
70
+ value: 0.84
71
+ name: Accuracy
72
+ ---
73
+
74
+ # SetFit with BAAI/bge-base-en-v1.5
75
+
76
+ This is a [SetFit](https://github.com/huggingface/setfit) model that can be used for Text Classification. This SetFit model uses [BAAI/bge-base-en-v1.5](https://huggingface.co/BAAI/bge-base-en-v1.5) as the Sentence Transformer embedding model. A [LogisticRegression](https://scikit-learn.org/stable/modules/generated/sklearn.linear_model.LogisticRegression.html) instance is used for classification.
77
+
78
+ The model has been trained using an efficient few-shot learning technique that involves:
79
+
80
+ 1. Fine-tuning a [Sentence Transformer](https://www.sbert.net) with contrastive learning.
81
+ 2. Training a classification head with features from the fine-tuned Sentence Transformer.
82
+
83
+ ## Model Details
84
+
85
+ ### Model Description
86
+ - **Model Type:** SetFit
87
+ - **Sentence Transformer body:** [BAAI/bge-base-en-v1.5](https://huggingface.co/BAAI/bge-base-en-v1.5)
88
+ - **Classification head:** a [LogisticRegression](https://scikit-learn.org/stable/modules/generated/sklearn.linear_model.LogisticRegression.html) instance
89
+ - **Maximum Sequence Length:** 512 tokens
90
+ - **Number of Classes:** 2 classes
91
+ <!-- - **Training Dataset:** [Unknown](https://huggingface.co/datasets/unknown) -->
92
+ <!-- - **Language:** Unknown -->
93
+ <!-- - **License:** Unknown -->
94
+
95
+ ### Model Sources
96
+
97
+ - **Repository:** [SetFit on GitHub](https://github.com/huggingface/setfit)
98
+ - **Paper:** [Efficient Few-Shot Learning Without Prompts](https://arxiv.org/abs/2209.11055)
99
+ - **Blogpost:** [SetFit: Efficient Few-Shot Learning Without Prompts](https://huggingface.co/blog/setfit)
100
+
101
+ ### Model Labels
102
+ | Label | Examples |
103
+ |:------|:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
104
+ | 0 | <ul><li>'Reasoning:\ncontradiction - The answer contains information that contradicts what appears in the document.\nEvaluation:'</li><li>'Reasoning:\nhallucination - The answer contains information not found in the document, which indicates that it is hallucinating.\nEvaluation:'</li><li>"Reasoning:\nirrelevant - The answer does not address the question asked, and instead discusses a football player's transfer.\nEvaluation:"</li></ul> |
105
+ | 1 | <ul><li>"Reasoning:\nhallucination - The answer is incorrect, and it's contradicted.\nEvaluation:"</li><li>'Reasoning:\nThe answer aligns well with the content provided in the document, covering techniques and methods to reduce feelings of emptiness such as journaling, trying new activities, and making new friends. These suggestions closely mirror the strategies outlined in the document, ensuring context grounding, relevance, and conciseness.\n\nFinal Result:'</li><li>'Reasoning:\nThe answer is well-supported by the document, sticking closely to the recommended steps for drying curly hair. It grounds its advice directly within the given procedures, such as squeezing out excess water with hands, using a leave-in conditioner, and detangling with a wide-tooth comb. It only includes necessary details that are directly related to air drying curly hair and does not resort to unrelated information or unnecessary elaboration.\n\nEvaluation:'</li></ul> |
106
+
107
+ ## Evaluation
108
+
109
+ ### Metrics
110
+ | Label | Accuracy |
111
+ |:--------|:---------|
112
+ | **all** | 0.84 |
113
+
114
+ ## Uses
115
+
116
+ ### Direct Use for Inference
117
+
118
+ First install the SetFit library:
119
+
120
+ ```bash
121
+ pip install setfit
122
+ ```
123
+
124
+ Then you can load this model and run inference.
125
+
126
+ ```python
127
+ from setfit import SetFitModel
128
+
129
+ # Download from the 🤗 Hub
130
+ model = SetFitModel.from_pretrained("Netta1994/setfit_baai_wikisum_gpt-4o_improved-cot-instructions_chat_few_shot_remove_final_evalu")
131
+ # Run inference
132
+ preds = model("Reasoning:
133
+ contradiction - The answer contains information that contradicts what appears in the document.
134
+ Evaluation:")
135
+ ```
136
+
137
+ <!--
138
+ ### Downstream Use
139
+
140
+ *List how someone could finetune this model on their own dataset.*
141
+ -->
142
+
143
+ <!--
144
+ ### Out-of-Scope Use
145
+
146
+ *List how the model may foreseeably be misused and address what users ought not to do with the model.*
147
+ -->
148
+
149
+ <!--
150
+ ## Bias, Risks and Limitations
151
+
152
+ *What are the known or foreseeable issues stemming from this model? You could also flag here known failure cases or weaknesses of the model.*
153
+ -->
154
+
155
+ <!--
156
+ ### Recommendations
157
+
158
+ *What are recommendations with respect to the foreseeable issues? For example, filtering explicit content.*
159
+ -->
160
+
161
+ ## Training Details
162
+
163
+ ### Training Set Metrics
164
+ | Training set | Min | Median | Max |
165
+ |:-------------|:----|:--------|:----|
166
+ | Word count | 3 | 32.0704 | 125 |
167
+
168
+ | Label | Training Sample Count |
169
+ |:------|:----------------------|
170
+ | 0 | 34 |
171
+ | 1 | 37 |
172
+
173
+ ### Training Hyperparameters
174
+ - batch_size: (16, 16)
175
+ - num_epochs: (1, 1)
176
+ - max_steps: -1
177
+ - sampling_strategy: oversampling
178
+ - num_iterations: 20
179
+ - body_learning_rate: (2e-05, 2e-05)
180
+ - head_learning_rate: 2e-05
181
+ - loss: CosineSimilarityLoss
182
+ - distance_metric: cosine_distance
183
+ - margin: 0.25
184
+ - end_to_end: False
185
+ - use_amp: False
186
+ - warmup_proportion: 0.1
187
+ - l2_weight: 0.01
188
+ - seed: 42
189
+ - eval_max_steps: -1
190
+ - load_best_model_at_end: False
191
+
192
+ ### Training Results
193
+ | Epoch | Step | Training Loss | Validation Loss |
194
+ |:------:|:----:|:-------------:|:---------------:|
195
+ | 0.0056 | 1 | 0.1876 | - |
196
+ | 0.2809 | 50 | 0.2134 | - |
197
+ | 0.5618 | 100 | 0.1484 | - |
198
+ | 0.8427 | 150 | 0.1032 | - |
199
+
200
+ ### Framework Versions
201
+ - Python: 3.10.14
202
+ - SetFit: 1.1.0
203
+ - Sentence Transformers: 3.1.0
204
+ - Transformers: 4.44.0
205
+ - PyTorch: 2.4.1+cu121
206
+ - Datasets: 2.19.2
207
+ - Tokenizers: 0.19.1
208
+
209
+ ## Citation
210
+
211
+ ### BibTeX
212
+ ```bibtex
213
+ @article{https://doi.org/10.48550/arxiv.2209.11055,
214
+ doi = {10.48550/ARXIV.2209.11055},
215
+ url = {https://arxiv.org/abs/2209.11055},
216
+ author = {Tunstall, Lewis and Reimers, Nils and Jo, Unso Eun Seo and Bates, Luke and Korat, Daniel and Wasserblat, Moshe and Pereg, Oren},
217
+ keywords = {Computation and Language (cs.CL), FOS: Computer and information sciences, FOS: Computer and information sciences},
218
+ title = {Efficient Few-Shot Learning Without Prompts},
219
+ publisher = {arXiv},
220
+ year = {2022},
221
+ copyright = {Creative Commons Attribution 4.0 International}
222
+ }
223
+ ```
224
+
225
+ <!--
226
+ ## Glossary
227
+
228
+ *Clearly define terms in order to be accessible across audiences.*
229
+ -->
230
+
231
+ <!--
232
+ ## Model Card Authors
233
+
234
+ *Lists the people who create the model card, providing recognition and accountability for the detailed work that goes into its construction.*
235
+ -->
236
+
237
+ <!--
238
+ ## Model Card Contact
239
+
240
+ *Provides a way for people who have updates to the Model Card, suggestions, or questions, to contact the Model Card authors.*
241
+ -->
config.json ADDED
@@ -0,0 +1,32 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "_name_or_path": "BAAI/bge-base-en-v1.5",
3
+ "architectures": [
4
+ "BertModel"
5
+ ],
6
+ "attention_probs_dropout_prob": 0.1,
7
+ "classifier_dropout": null,
8
+ "gradient_checkpointing": false,
9
+ "hidden_act": "gelu",
10
+ "hidden_dropout_prob": 0.1,
11
+ "hidden_size": 768,
12
+ "id2label": {
13
+ "0": "LABEL_0"
14
+ },
15
+ "initializer_range": 0.02,
16
+ "intermediate_size": 3072,
17
+ "label2id": {
18
+ "LABEL_0": 0
19
+ },
20
+ "layer_norm_eps": 1e-12,
21
+ "max_position_embeddings": 512,
22
+ "model_type": "bert",
23
+ "num_attention_heads": 12,
24
+ "num_hidden_layers": 12,
25
+ "pad_token_id": 0,
26
+ "position_embedding_type": "absolute",
27
+ "torch_dtype": "float32",
28
+ "transformers_version": "4.44.0",
29
+ "type_vocab_size": 2,
30
+ "use_cache": true,
31
+ "vocab_size": 30522
32
+ }
config_sentence_transformers.json ADDED
@@ -0,0 +1,10 @@
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "__version__": {
3
+ "sentence_transformers": "3.1.0",
4
+ "transformers": "4.44.0",
5
+ "pytorch": "2.4.1+cu121"
6
+ },
7
+ "prompts": {},
8
+ "default_prompt_name": null,
9
+ "similarity_fn_name": null
10
+ }
config_setfit.json ADDED
@@ -0,0 +1,4 @@
 
 
 
 
 
1
+ {
2
+ "normalize_embeddings": false,
3
+ "labels": null
4
+ }
model.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:a294ca64eab591ac658c5bda58498920690a59b87647003186b89027114af86d
3
+ size 437951328
model_head.pkl ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:d621158c7299e23d4dc4a1fb808facc679364ebeb1d340d493325f0ecbdfc122
3
+ size 7007
modules.json ADDED
@@ -0,0 +1,20 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ [
2
+ {
3
+ "idx": 0,
4
+ "name": "0",
5
+ "path": "",
6
+ "type": "sentence_transformers.models.Transformer"
7
+ },
8
+ {
9
+ "idx": 1,
10
+ "name": "1",
11
+ "path": "1_Pooling",
12
+ "type": "sentence_transformers.models.Pooling"
13
+ },
14
+ {
15
+ "idx": 2,
16
+ "name": "2",
17
+ "path": "2_Normalize",
18
+ "type": "sentence_transformers.models.Normalize"
19
+ }
20
+ ]
sentence_bert_config.json ADDED
@@ -0,0 +1,4 @@
 
 
 
 
 
1
+ {
2
+ "max_seq_length": 512,
3
+ "do_lower_case": true
4
+ }
special_tokens_map.json ADDED
@@ -0,0 +1,37 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "cls_token": {
3
+ "content": "[CLS]",
4
+ "lstrip": false,
5
+ "normalized": false,
6
+ "rstrip": false,
7
+ "single_word": false
8
+ },
9
+ "mask_token": {
10
+ "content": "[MASK]",
11
+ "lstrip": false,
12
+ "normalized": false,
13
+ "rstrip": false,
14
+ "single_word": false
15
+ },
16
+ "pad_token": {
17
+ "content": "[PAD]",
18
+ "lstrip": false,
19
+ "normalized": false,
20
+ "rstrip": false,
21
+ "single_word": false
22
+ },
23
+ "sep_token": {
24
+ "content": "[SEP]",
25
+ "lstrip": false,
26
+ "normalized": false,
27
+ "rstrip": false,
28
+ "single_word": false
29
+ },
30
+ "unk_token": {
31
+ "content": "[UNK]",
32
+ "lstrip": false,
33
+ "normalized": false,
34
+ "rstrip": false,
35
+ "single_word": false
36
+ }
37
+ }
tokenizer.json ADDED
The diff for this file is too large to render. See raw diff
 
tokenizer_config.json ADDED
@@ -0,0 +1,57 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "added_tokens_decoder": {
3
+ "0": {
4
+ "content": "[PAD]",
5
+ "lstrip": false,
6
+ "normalized": false,
7
+ "rstrip": false,
8
+ "single_word": false,
9
+ "special": true
10
+ },
11
+ "100": {
12
+ "content": "[UNK]",
13
+ "lstrip": false,
14
+ "normalized": false,
15
+ "rstrip": false,
16
+ "single_word": false,
17
+ "special": true
18
+ },
19
+ "101": {
20
+ "content": "[CLS]",
21
+ "lstrip": false,
22
+ "normalized": false,
23
+ "rstrip": false,
24
+ "single_word": false,
25
+ "special": true
26
+ },
27
+ "102": {
28
+ "content": "[SEP]",
29
+ "lstrip": false,
30
+ "normalized": false,
31
+ "rstrip": false,
32
+ "single_word": false,
33
+ "special": true
34
+ },
35
+ "103": {
36
+ "content": "[MASK]",
37
+ "lstrip": false,
38
+ "normalized": false,
39
+ "rstrip": false,
40
+ "single_word": false,
41
+ "special": true
42
+ }
43
+ },
44
+ "clean_up_tokenization_spaces": true,
45
+ "cls_token": "[CLS]",
46
+ "do_basic_tokenize": true,
47
+ "do_lower_case": true,
48
+ "mask_token": "[MASK]",
49
+ "model_max_length": 512,
50
+ "never_split": null,
51
+ "pad_token": "[PAD]",
52
+ "sep_token": "[SEP]",
53
+ "strip_accents": null,
54
+ "tokenize_chinese_chars": true,
55
+ "tokenizer_class": "BertTokenizer",
56
+ "unk_token": "[UNK]"
57
+ }
vocab.txt ADDED
The diff for this file is too large to render. See raw diff