rafmacalaba commited on
Commit
b817b87
·
verified ·
1 Parent(s): 27793a1

Upload README.md with huggingface_hub

Browse files
Files changed (1) hide show
  1. README.md +116 -189
README.md CHANGED
@@ -5,202 +5,129 @@ tags:
5
  - base_model:adapter:fastino/gliner2-large-v1
6
  - lora
7
  - transformers
 
 
 
8
  ---
9
 
10
- # Model Card for Model ID
11
 
12
- <!-- Provide a quick summary of what the model is/does. -->
13
 
 
 
 
14
 
 
15
 
16
- ## Model Details
17
-
18
- ### Model Description
19
-
20
- <!-- Provide a longer summary of what this model is. -->
21
-
22
-
23
-
24
- - **Developed by:** [More Information Needed]
25
- - **Funded by [optional]:** [More Information Needed]
26
- - **Shared by [optional]:** [More Information Needed]
27
- - **Model type:** [More Information Needed]
28
- - **Language(s) (NLP):** [More Information Needed]
29
- - **License:** [More Information Needed]
30
- - **Finetuned from model [optional]:** [More Information Needed]
31
-
32
- ### Model Sources [optional]
33
-
34
- <!-- Provide the basic links for the model. -->
35
-
36
- - **Repository:** [More Information Needed]
37
- - **Paper [optional]:** [More Information Needed]
38
- - **Demo [optional]:** [More Information Needed]
39
-
40
- ## Uses
41
-
42
- <!-- Address questions around how the model is intended to be used, including the foreseeable users of the model and those affected by the model. -->
43
-
44
- ### Direct Use
45
-
46
- <!-- This section is for the model use without fine-tuning or plugging into a larger ecosystem/app. -->
47
-
48
- [More Information Needed]
49
-
50
- ### Downstream Use [optional]
51
-
52
- <!-- This section is for the model use when fine-tuned for a task, or when plugged into a larger ecosystem/app -->
53
-
54
- [More Information Needed]
55
-
56
- ### Out-of-Scope Use
57
-
58
- <!-- This section addresses misuse, malicious use, and uses that the model will not work well for. -->
59
-
60
- [More Information Needed]
61
-
62
- ## Bias, Risks, and Limitations
63
-
64
- <!-- This section is meant to convey both technical and sociotechnical limitations. -->
65
-
66
- [More Information Needed]
67
-
68
- ### Recommendations
69
-
70
- <!-- This section is meant to convey recommendations with respect to the bias, risk, and technical limitations. -->
71
 
72
- Users (both direct and downstream) should be made aware of the risks, biases and limitations of the model. More information needed for further recommendations.
73
 
74
  ## How to Get Started with the Model
75
 
76
- Use the code below to get started with the model.
77
-
78
- [More Information Needed]
79
-
80
- ## Training Details
81
-
82
- ### Training Data
83
-
84
- <!-- This should link to a Dataset Card, perhaps with a short stub of information on what the training data is all about as well as documentation related to data pre-processing or additional filtering. -->
85
-
86
- [More Information Needed]
87
-
88
- ### Training Procedure
89
-
90
- <!-- This relates heavily to the Technical Specifications. Content here should link to that section when it is relevant to the training procedure. -->
91
-
92
- #### Preprocessing [optional]
93
-
94
- [More Information Needed]
95
-
96
-
97
- #### Training Hyperparameters
98
-
99
- - **Training regime:** [More Information Needed] <!--fp32, fp16 mixed precision, bf16 mixed precision, bf16 non-mixed precision, fp16 non-mixed precision, fp8 mixed precision -->
100
-
101
- #### Speeds, Sizes, Times [optional]
102
-
103
- <!-- This section provides information about throughput, start/end time, checkpoint size if relevant, etc. -->
104
-
105
- [More Information Needed]
106
-
107
- ## Evaluation
108
-
109
- <!-- This section describes the evaluation protocols and provides the results. -->
110
-
111
- ### Testing Data, Factors & Metrics
112
-
113
- #### Testing Data
114
-
115
- <!-- This should link to a Dataset Card if possible. -->
116
-
117
- [More Information Needed]
118
-
119
- #### Factors
120
-
121
- <!-- These are the things the evaluation is disaggregating by, e.g., subpopulations or domains. -->
122
-
123
- [More Information Needed]
124
-
125
- #### Metrics
126
-
127
- <!-- These are the evaluation metrics being used, ideally with a description of why. -->
128
-
129
- [More Information Needed]
130
-
131
- ### Results
132
-
133
- [More Information Needed]
134
-
135
- #### Summary
136
-
137
-
138
-
139
- ## Model Examination [optional]
140
-
141
- <!-- Relevant interpretability work for the model goes here -->
142
-
143
- [More Information Needed]
144
-
145
- ## Environmental Impact
146
-
147
- <!-- Total emissions (in grams of CO2eq) and additional considerations, such as electricity usage, go here. Edit the suggested text below accordingly -->
148
-
149
- Carbon emissions can be estimated using the [Machine Learning Impact calculator](https://mlco2.github.io/impact#compute) presented in [Lacoste et al. (2019)](https://arxiv.org/abs/1910.09700).
150
-
151
- - **Hardware Type:** [More Information Needed]
152
- - **Hours used:** [More Information Needed]
153
- - **Cloud Provider:** [More Information Needed]
154
- - **Compute Region:** [More Information Needed]
155
- - **Carbon Emitted:** [More Information Needed]
156
-
157
- ## Technical Specifications [optional]
158
-
159
- ### Model Architecture and Objective
160
-
161
- [More Information Needed]
162
-
163
- ### Compute Infrastructure
164
-
165
- [More Information Needed]
166
-
167
- #### Hardware
168
-
169
- [More Information Needed]
170
-
171
- #### Software
172
-
173
- [More Information Needed]
174
-
175
- ## Citation [optional]
176
-
177
- <!-- If there is a paper or blog post introducing the model, the APA and Bibtex information for that should go in this section. -->
178
-
179
- **BibTeX:**
180
-
181
- [More Information Needed]
182
-
183
- **APA:**
184
-
185
- [More Information Needed]
186
-
187
- ## Glossary [optional]
188
-
189
- <!-- If relevant, include terms and calculations in this section that can help readers understand the model or model card. -->
190
-
191
- [More Information Needed]
192
-
193
- ## More Information [optional]
194
-
195
- [More Information Needed]
196
-
197
- ## Model Card Authors [optional]
198
-
199
- [More Information Needed]
200
-
201
- ## Model Card Contact
202
-
203
- [More Information Needed]
204
- ### Framework versions
205
-
206
- - PEFT 0.19.1
 
5
  - base_model:adapter:fastino/gliner2-large-v1
6
  - lora
7
  - transformers
8
+ - gliner2
9
+ - dataset-extraction
10
+ - data-use
11
  ---
12
 
13
+ # GLiNER2 Data Use Extraction Adapter (v2)
14
 
15
+ This is a fine-tuned LoRA adapter for `fastino/gliner2-large-v1` trained to extract datasets, data mentions, and their relations from academic papers, research, and reports (with a focus on World Bank/UNHCR documents).
16
 
17
+ - **Repository:** [https://github.com/rafmacalaba/monitoring_of_datause](https://github.com/rafmacalaba/monitoring_of_datause)
18
+ - **Base Model:** `fastino/gliner2-large-v1`
19
+ - **Adapter ID:** `ai4data/datause-extraction-v2`
20
 
21
+ ---
22
 
23
+ ## Model Schema & Label Prefix
24
+
25
+ The model is trained on a **7-field all-string schema** to optimize the GLiNER2 count head and prevent collapse.
26
+
27
+ ### Label Prefix
28
+ Every input text **must** be prepended with the following fixed label prefix:
29
+ ```
30
+ specificity: named | descriptive | vague usage: primary | supporting | background |
31
+ ```
32
+
33
+ ### Schema Structure
34
+ ```python
35
+ SCHEMA = {
36
+ "data_mention": [
37
+ "name::str::The exact full name of the data source or dataset",
38
+ "acronym::str::The acronym or abbreviation if any",
39
+ "specificity::str::Whether this mention is named, descriptive, or vague",
40
+ "usage::str::Whether this is primary, supporting, or background data",
41
+ "datatype::str::The type of data verbatim from text such as survey, report, census, program, system, or assessment",
42
+ "producer::str::The organization or entity that produced or published the data",
43
+ "timeframe::str::The year or time period of the data such as 2019 or 2019 to 2020",
44
+ ]
45
+ }
46
+ ```
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
47
 
48
+ ---
49
 
50
  ## How to Get Started with the Model
51
 
52
+ ### 1. Using the `ai4data` Python Library (Recommended)
53
+
54
+ If you are using the repository's native wrapper library, simply import and run:
55
+
56
+ ```python
57
+ from ai4data import extract_from_text, extract_from_document
58
+
59
+ text = """Our analysis uses the 2022 Demographic and Health Survey (DHS) conducted by
60
+ the National Statistics Office. We complement this with administrative systems, but
61
+ only the DHS is used in the empirical models."""
62
+
63
+ # Extract from raw text
64
+ results = extract_from_text(text)
65
+ print(results["datasets"])
66
+
67
+ # Extract from a PDF document
68
+ pdf_results = extract_from_document("report.pdf", pages=[0, 1, 2])
69
+ print(pdf_results)
70
+ ```
71
+
72
+ ### 2. Direct Usage via standard `gliner2` Library
73
+
74
+ If you want to use the raw `gliner2` model and adapter:
75
+
76
+ ```python
77
+ from gliner2 import GLiNER2
78
+ from huggingface_hub import snapshot_download
79
+
80
+ # Load the base model and LoRA adapter
81
+ model = GLiNER2.from_pretrained("fastino/gliner2-large-v1")
82
+ adapter_path = snapshot_download("ai4data/datause-extraction-v2")
83
+ model.load_adapter(adapter_path)
84
+ model.eval()
85
+
86
+ # Configure the entity and relation schemas
87
+ schema = model.create_schema()
88
+ schema.entities({
89
+ "name": "The exact full name of the data source or dataset",
90
+ "acronym": "The acronym or abbreviation if any",
91
+ "producer": "The organization or entity that produced the data",
92
+ "timeframe": "The year or time period such as 2019 or 2019 to 2020",
93
+ "datatype": "The type of data verbatim from text",
94
+ "specificity": "Whether this mention is named, descriptive, or vague",
95
+ "usage": "Whether this is primary, supporting, or background data",
96
+ })
97
+ schema.relations({
98
+ "has_acronym": "The acronym of the dataset",
99
+ "has_producer": "The producer of the dataset",
100
+ "has_timeframe": "The timeframe of the dataset",
101
+ "has_datatype": "The data type of the dataset",
102
+ "has_specificity": "Whether this dataset is named, descriptive, or vague",
103
+ "has_usage": "Whether this dataset is primary, supporting, or background",
104
+ })
105
+
106
+ # format input text with the required label prefix
107
+ text = "We use the Ghana Living Standard Survey (GLSS) 2020 conducted by Ghana Statistical Service."
108
+ prefix = "specificity: named | descriptive | vague usage: primary | supporting | background |"
109
+ prefixed_text = f"{prefix} {text}"
110
+
111
+ # Extract
112
+ result = model.extract(
113
+ prefixed_text,
114
+ schema,
115
+ threshold=0.3,
116
+ include_confidence=True,
117
+ include_spans=True,
118
+ )
119
+
120
+ print(result)
121
+ ```
122
+
123
+ ## Annotation Guidelines & What Counts as a Data Mention
124
+
125
+ ### Specificity Taxonomy
126
+ - **`named`**: A specific, citable dataset (e.g., `"DHS 2020"`, `"World Development Indicators"`, `"Ghana Living Standards Survey (GLSS)"`)
127
+ - **`descriptive`**: A general category of data, not a specific named dataset (e.g., `"household survey data"`, `"administrative records"`, `"panel data on firms"`)
128
+ - **`vague`**: An indirect or ambiguous reference (e.g., `"available data"`, `"our dataset"`, `"the data used in this study"`)
129
+
130
+ ### Usage Context
131
+ - **`primary`**: Core data driving the main analysis in the report.
132
+ - **`supporting`**: Secondary data used to validate, calibrate, or provide robustness checks.
133
+ - **`background`**: Mentioned in passing, in a literature review, or as historical context.