Izaan commited on
Commit
41415da
Β·
1 Parent(s): 715a797

first commit

Browse files
dataset2.csv ADDED
@@ -0,0 +1,31 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ problem,solution
2
+ "🍎 + 🍎 + 🍎 = 12 β†’ 🍎 =","4"
3
+ "🍌 + 🍌 = 10 β†’ 🍌 =","5"
4
+ "πŸ’ + πŸ’ + πŸ’ + πŸ’ = 20 β†’ πŸ’ =","5"
5
+ "🍊 + 🍊 + πŸ‡ = 15, 🍊 = 6, πŸ‡ = ? β†’ πŸ‡ =",3"
6
+ "πŸ‰ + πŸ‰ = 18 β†’ πŸ‰ =","9"
7
+ "🍍 + 🍍 + 🍍 = 24 β†’ 🍍 =","8"
8
+ "πŸ₯‘ + πŸ₯‘ + πŸ₯‘ + πŸ₯‘ = 16 β†’ πŸ₯‘ =","4"
9
+ "πŸ“ + πŸ“ = 14 β†’ πŸ“ =","7"
10
+ "πŸ‹ + πŸ‹ + πŸ‹ = 21 β†’ πŸ‹ =","7"
11
+ "πŸ₯• + πŸ₯• = 8 β†’ πŸ₯• =","4"
12
+ "🌽 + 🌽 + 🌽 = 30 β†’ 🌽 =","10"
13
+ "πŸͺ + πŸͺ + πŸͺ = 15 β†’ πŸͺ =","5"
14
+ "πŸ₯œ + πŸ₯œ + πŸ₯œ + πŸ₯œ = 40 β†’ πŸ₯œ =","10"
15
+ "πŸ” + πŸ” = 20 β†’ πŸ” =","10"
16
+ "πŸ• + πŸ• + πŸ• = 27 β†’ πŸ• =","9"
17
+ "πŸ‡ + πŸ‡ = 8 β†’ πŸ‡ =","4"
18
+ "🌰 + 🌰 + 🌰 = 18 β†’ 🌰 =","6"
19
+ "🍞 + 🍞 + 🍞 + 🍞 = 40 β†’ 🍞 =","10"
20
+ "πŸ₯’ + πŸ₯’ + πŸ₯’ = 21 β†’ πŸ₯’ =","7"
21
+ "πŸ₯¦ + πŸ₯¦ + πŸ₯¦ + πŸ₯¦ = 28 β†’ πŸ₯¦ =","7"
22
+ "🍎 + 🍏 = 12, 🍏 = 5 β†’ 🍎 =","7"
23
+ "🍍 + πŸ‰ = 20, πŸ‰ = 8 β†’ 🍍 =","12"
24
+ "πŸ₯₯ + πŸ₯₯ = 30 β†’ πŸ₯₯ =","15"
25
+ "πŸ‰ + πŸ“ = 16, πŸ‰ = 10 β†’ πŸ“ =","6"
26
+ "🍩 + 🍩 + 🍩 + 🍩 = 32 β†’ 🍩 =","8"
27
+ "🍜 + 🍜 + 🍜 = 18 β†’ 🍜 =","6"
28
+ "🍫 + 🍫 = 14 β†’ 🍫 =","7"
29
+ "🍰 + 🍰 + 🍰 = 24 β†’ 🍰 =","8"
30
+ "🍿 + 🍿 + 🍿 + 🍿 = 20 β†’ 🍿 =","5"
31
+ "πŸ” + 🌭 = 18, 🌭 = 8 β†’ πŸ” =","10"
finetuned_deepseek_math/README.md ADDED
@@ -0,0 +1,202 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ base_model: deepseek-ai/deepseek-math-7b-base
3
+ library_name: peft
4
+ ---
5
+
6
+ # Model Card for Model ID
7
+
8
+ <!-- Provide a quick summary of what the model is/does. -->
9
+
10
+
11
+
12
+ ## Model Details
13
+
14
+ ### Model Description
15
+
16
+ <!-- Provide a longer summary of what this model is. -->
17
+
18
+
19
+
20
+ - **Developed by:** [More Information Needed]
21
+ - **Funded by [optional]:** [More Information Needed]
22
+ - **Shared by [optional]:** [More Information Needed]
23
+ - **Model type:** [More Information Needed]
24
+ - **Language(s) (NLP):** [More Information Needed]
25
+ - **License:** [More Information Needed]
26
+ - **Finetuned from model [optional]:** [More Information Needed]
27
+
28
+ ### Model Sources [optional]
29
+
30
+ <!-- Provide the basic links for the model. -->
31
+
32
+ - **Repository:** [More Information Needed]
33
+ - **Paper [optional]:** [More Information Needed]
34
+ - **Demo [optional]:** [More Information Needed]
35
+
36
+ ## Uses
37
+
38
+ <!-- Address questions around how the model is intended to be used, including the foreseeable users of the model and those affected by the model. -->
39
+
40
+ ### Direct Use
41
+
42
+ <!-- This section is for the model use without fine-tuning or plugging into a larger ecosystem/app. -->
43
+
44
+ [More Information Needed]
45
+
46
+ ### Downstream Use [optional]
47
+
48
+ <!-- This section is for the model use when fine-tuned for a task, or when plugged into a larger ecosystem/app -->
49
+
50
+ [More Information Needed]
51
+
52
+ ### Out-of-Scope Use
53
+
54
+ <!-- This section addresses misuse, malicious use, and uses that the model will not work well for. -->
55
+
56
+ [More Information Needed]
57
+
58
+ ## Bias, Risks, and Limitations
59
+
60
+ <!-- This section is meant to convey both technical and sociotechnical limitations. -->
61
+
62
+ [More Information Needed]
63
+
64
+ ### Recommendations
65
+
66
+ <!-- This section is meant to convey recommendations with respect to the bias, risk, and technical limitations. -->
67
+
68
+ Users (both direct and downstream) should be made aware of the risks, biases and limitations of the model. More information needed for further recommendations.
69
+
70
+ ## How to Get Started with the Model
71
+
72
+ Use the code below to get started with the model.
73
+
74
+ [More Information Needed]
75
+
76
+ ## Training Details
77
+
78
+ ### Training Data
79
+
80
+ <!-- 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. -->
81
+
82
+ [More Information Needed]
83
+
84
+ ### Training Procedure
85
+
86
+ <!-- This relates heavily to the Technical Specifications. Content here should link to that section when it is relevant to the training procedure. -->
87
+
88
+ #### Preprocessing [optional]
89
+
90
+ [More Information Needed]
91
+
92
+
93
+ #### Training Hyperparameters
94
+
95
+ - **Training regime:** [More Information Needed] <!--fp32, fp16 mixed precision, bf16 mixed precision, bf16 non-mixed precision, fp16 non-mixed precision, fp8 mixed precision -->
96
+
97
+ #### Speeds, Sizes, Times [optional]
98
+
99
+ <!-- This section provides information about throughput, start/end time, checkpoint size if relevant, etc. -->
100
+
101
+ [More Information Needed]
102
+
103
+ ## Evaluation
104
+
105
+ <!-- This section describes the evaluation protocols and provides the results. -->
106
+
107
+ ### Testing Data, Factors & Metrics
108
+
109
+ #### Testing Data
110
+
111
+ <!-- This should link to a Dataset Card if possible. -->
112
+
113
+ [More Information Needed]
114
+
115
+ #### Factors
116
+
117
+ <!-- These are the things the evaluation is disaggregating by, e.g., subpopulations or domains. -->
118
+
119
+ [More Information Needed]
120
+
121
+ #### Metrics
122
+
123
+ <!-- These are the evaluation metrics being used, ideally with a description of why. -->
124
+
125
+ [More Information Needed]
126
+
127
+ ### Results
128
+
129
+ [More Information Needed]
130
+
131
+ #### Summary
132
+
133
+
134
+
135
+ ## Model Examination [optional]
136
+
137
+ <!-- Relevant interpretability work for the model goes here -->
138
+
139
+ [More Information Needed]
140
+
141
+ ## Environmental Impact
142
+
143
+ <!-- Total emissions (in grams of CO2eq) and additional considerations, such as electricity usage, go here. Edit the suggested text below accordingly -->
144
+
145
+ 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).
146
+
147
+ - **Hardware Type:** [More Information Needed]
148
+ - **Hours used:** [More Information Needed]
149
+ - **Cloud Provider:** [More Information Needed]
150
+ - **Compute Region:** [More Information Needed]
151
+ - **Carbon Emitted:** [More Information Needed]
152
+
153
+ ## Technical Specifications [optional]
154
+
155
+ ### Model Architecture and Objective
156
+
157
+ [More Information Needed]
158
+
159
+ ### Compute Infrastructure
160
+
161
+ [More Information Needed]
162
+
163
+ #### Hardware
164
+
165
+ [More Information Needed]
166
+
167
+ #### Software
168
+
169
+ [More Information Needed]
170
+
171
+ ## Citation [optional]
172
+
173
+ <!-- If there is a paper or blog post introducing the model, the APA and Bibtex information for that should go in this section. -->
174
+
175
+ **BibTeX:**
176
+
177
+ [More Information Needed]
178
+
179
+ **APA:**
180
+
181
+ [More Information Needed]
182
+
183
+ ## Glossary [optional]
184
+
185
+ <!-- If relevant, include terms and calculations in this section that can help readers understand the model or model card. -->
186
+
187
+ [More Information Needed]
188
+
189
+ ## More Information [optional]
190
+
191
+ [More Information Needed]
192
+
193
+ ## Model Card Authors [optional]
194
+
195
+ [More Information Needed]
196
+
197
+ ## Model Card Contact
198
+
199
+ [More Information Needed]
200
+ ### Framework versions
201
+
202
+ - PEFT 0.14.0
finetuned_deepseek_math/adapter_config.json ADDED
@@ -0,0 +1,32 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "alpha_pattern": {},
3
+ "auto_mapping": null,
4
+ "base_model_name_or_path": "deepseek-ai/deepseek-math-7b-base",
5
+ "bias": "none",
6
+ "eva_config": null,
7
+ "exclude_modules": null,
8
+ "fan_in_fan_out": false,
9
+ "inference_mode": true,
10
+ "init_lora_weights": true,
11
+ "layer_replication": null,
12
+ "layers_pattern": null,
13
+ "layers_to_transform": null,
14
+ "loftq_config": {},
15
+ "lora_alpha": 40,
16
+ "lora_bias": false,
17
+ "lora_dropout": 0.05,
18
+ "megatron_config": null,
19
+ "megatron_core": "megatron.core",
20
+ "modules_to_save": null,
21
+ "peft_type": "LORA",
22
+ "r": 20,
23
+ "rank_pattern": {},
24
+ "revision": null,
25
+ "target_modules": [
26
+ "q_proj",
27
+ "v_proj"
28
+ ],
29
+ "task_type": "CAUSAL_LM",
30
+ "use_dora": false,
31
+ "use_rslora": false
32
+ }
finetuned_deepseek_math/adapter_model.safetensors ADDED
@@ -0,0 +1,3 @@
 
 
 
 
1
+ version https://git-lfs.github.com/spec/v1
2
+ oid sha256:44055acddcc26f3f79252f1bd6e7d672e61a003276eaef75b381f22e0af48bda
3
+ size 39337728
requirements.txt ADDED
@@ -0,0 +1,6 @@
 
 
 
 
 
 
 
1
+ streamlit
2
+ torch
3
+ transformers>=4.45.1
4
+ accelerate
5
+ peft
6
+ datasets
streamlit_app.py ADDED
@@ -0,0 +1,73 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import streamlit as st
2
+ import torch
3
+ from transformers import AutoTokenizer, AutoModelForCausalLM, GenerationConfig, BitsAndBytesConfig
4
+ from peft import LoraConfig, get_peft_model, prepare_model_for_kbit_training
5
+
6
+ # Constants
7
+ MODEL_NAME = "deepseek-math"
8
+ SAVE_PATH = "finetuned_deepseek_math"
9
+
10
+ @st.cache_resource(show_spinner=False)
11
+ def load_model():
12
+ # # 4-bit quantization configurationi
13
+ # bnb_config = BitsAndBytesConfig(
14
+ # load_in_4bit=True,
15
+ # bnb_4bit_quant_type="nf4",
16
+ # bnb_4bit_use_double_quant=True,
17
+ # bnb_4bit_compute_dtype=torch.bfloat16
18
+ # )
19
+
20
+ # Load tokenizer and model in 4-bit mode
21
+ tokenizer = AutoTokenizer.from_pretrained(MODEL_NAME)
22
+ tokenizer.pad_token = tokenizer.eos_token
23
+
24
+ model = AutoModelForCausalLM.from_pretrained(
25
+ MODEL_NAME,
26
+ torch_dtype=torch.bfloat16,
27
+ device_map="auto"
28
+ # quantization_config=bnb_config
29
+ )
30
+ model.generation_config = GenerationConfig.from_pretrained(MODEL_NAME)
31
+ model.generation_config.pad_token_id = model.generation_config.eos_token_id
32
+
33
+ # Prepare model for k-bit training and wrap with LoRA via PEFT
34
+ model = prepare_model_for_kbit_training(model)
35
+ lora_config = LoraConfig(
36
+ r=20,
37
+ lora_alpha=40,
38
+ target_modules=["q_proj", "v_proj"],
39
+ lora_dropout=0.05,
40
+ bias="none",
41
+ task_type="CAUSAL_LM"
42
+ )
43
+ model = get_peft_model(model, lora_config)
44
+
45
+ # Load the fine-tuned adapter weights
46
+ model.load_pretrained(SAVE_PATH)
47
+ model.eval()
48
+ return tokenizer, model
49
+
50
+ def generate_output(prompt, tokenizer, model):
51
+ inputs = tokenizer(prompt, return_tensors="pt").to(model.device)
52
+ with torch.inference_mode():
53
+ outputs = model.generate(
54
+ input_ids=inputs.input_ids,
55
+ attention_mask=inputs.attention_mask,
56
+ max_new_tokens=20,
57
+ generation_config=model.generation_config
58
+ )
59
+ result = tokenizer.decode(outputs[0], skip_special_tokens=True)
60
+ return result
61
+
62
+ st.title("Deepseek Math Fine-Tuned Model Inference")
63
+ st.write("Enter your prompt below:")
64
+
65
+ user_input = st.text_input("Prompt", "πŸš— + πŸš— + πŸš— + πŸš— = 20 β†’ πŸš— =")
66
+
67
+ if st.button("Generate Output"):
68
+ with st.spinner("Generating answer..."):
69
+ tokenizer, model = load_model()
70
+ output = generate_output(user_input, tokenizer, model)
71
+ st.success("Output generated!")
72
+ st.write("**Input:**", user_input)
73
+ st.write("**Output:**", output)