maddes8cht commited on
Commit
06dc748
·
1 Parent(s): 5d0ff46

"Update README.md"

Browse files
Files changed (1) hide show
  1. README.md +199 -0
README.md ADDED
@@ -0,0 +1,199 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ license: cc-by-sa-3.0
3
+ datasets:
4
+ - VMware/open-instruct
5
+ language:
6
+ - en
7
+ library_name: transformers
8
+ pipeline_tag: text-generation
9
+ ---
10
+ [![banner](https://maddes8cht.github.io/assets/buttons/Huggingface-banner.jpg)]()
11
+
12
+ I'm constantly enhancing these model descriptions to provide you with the most relevant and comprehensive information
13
+
14
+ # open-llama-7b-v2-open-instruct - GGUF
15
+ - Model creator: [VMware](https://huggingface.co/VMware)
16
+ - Original model: [open-llama-7b-v2-open-instruct](https://huggingface.co/VMware/open-llama-7b-v2-open-instruct)
17
+
18
+ OpenLlama is a free reimplementation of the original Llama Model which is licensed under Apache 2 license.
19
+
20
+
21
+
22
+ # About GGUF format
23
+
24
+ `gguf` is the current file format used by the [`ggml`](https://github.com/ggerganov/ggml) library.
25
+ A growing list of Software is using it and can therefore use this model.
26
+ The core project making use of the ggml library is the [llama.cpp](https://github.com/ggerganov/llama.cpp) project by Georgi Gerganov
27
+
28
+ # Quantization variants
29
+
30
+ There is a bunch of quantized files available to cater to your specific needs. Here's how to choose the best option for you:
31
+
32
+ # Legacy quants
33
+
34
+ Q4_0, Q4_1, Q5_0, Q5_1 and Q8 are `legacy` quantization types.
35
+ Nevertheless, they are fully supported, as there are several circumstances that cause certain model not to be compatible with the modern K-quants.
36
+ ## Note:
37
+ Now there's a new option to use K-quants even for previously 'incompatible' models, although this involves some fallback solution that makes them not *real* K-quants. More details can be found in affected model descriptions.
38
+ (This mainly refers to Falcon 7b and Starcoder models)
39
+
40
+ # K-quants
41
+
42
+ K-quants are designed with the idea that different levels of quantization in specific parts of the model can optimize performance, file size, and memory load.
43
+ So, if possible, use K-quants.
44
+ With a Q6_K, you'll likely find it challenging to discern a quality difference from the original model - ask your model two times the same question and you may encounter bigger quality differences.
45
+
46
+
47
+
48
+
49
+ ---
50
+
51
+ # Original Model Card:
52
+ # VMware/open-llama-7B-v2-open-instruct
53
+ Instruction-tuned version of the fully trained Open LLama 7B v2 model. The model is open for <b>COMMERCIAL USE</b>. <br>
54
+
55
+ - This model performs better on code compared to v1 due to the improvements made on the base model by the openlm-research team.
56
+ - The instruction model is trained on an improved instruction tuning dataset compared to v1
57
+
58
+ **NOTE**: The model was trained using the Alpaca prompt template <br>
59
+ **NOTE**: Fast tokenizer results in incorrect encoding, set the ```use_fast = False``` parameter, when instantiating the tokenizer
60
+
61
+
62
+ ## License
63
+ - CC BY-SA-3.0 **(Commercially Viable!)**
64
+ - Base Language Model ([openlm-research/open_llama_v2_7b](https://huggingface.co/openlm-research/open_llama_v2_7b)) is under apache-2.0
65
+ - Fine-Tuning Dataset ([VMware/open-instruct](https://huggingface.co/datasets/VMware/open-instruct)) is under cc-by-sa-3.0
66
+
67
+ ## Datasets used for Fine-Tuning
68
+
69
+ ### Open-instruct
70
+
71
+ **Open-instruct-v1**
72
+ - Mosaic/Dolly-HHRLHF + filtered OASST1 - cc by 3.0
73
+
74
+ **Subset of COT SUBMIX (FROM FLAN V2) Zeroshot examples**
75
+ - ESNLI - MIT
76
+ - ECQA - CDLA 1.0 - Sharing
77
+ - Strategy - MIT
78
+ - CREAK - MIT
79
+ - gsmk8 - MIT
80
+ - aqua - MIT
81
+ - qasc - Apache 2.0
82
+
83
+
84
+ ## Nomenclature
85
+
86
+ - Model : Open-llama-v2
87
+ - Model Size: 7B parameters
88
+ - Dataset: Open-instruct
89
+
90
+
91
+ ## Use in Transformers
92
+
93
+ ```
94
+ import os
95
+ import torch
96
+ from transformers import AutoModelForCausalLM, AutoTokenizer
97
+
98
+ model_name = 'VMware/open-llama-7b-v2-open-instruct'
99
+
100
+
101
+ tokenizer = AutoTokenizer.from_pretrained(model_name, use_fast=False)
102
+
103
+ model = AutoModelForCausalLM.from_pretrained(model_name, torch_dtype=torch.float16, device_map='sequential')
104
+
105
+ prompt_template = "Below is an instruction that describes a task. Write a response that appropriately completes the request.\n\n### Instruction:\n{instruction}\n\n### Response:"
106
+
107
+ prompt = """What is attention mechanism of a transformer model?
108
+ Write a python code to illustrate how attention works within a transformer model using numpy library. Donot use pytorch or tensorflow."""
109
+
110
+
111
+ inputt = prompt_template.format(instruction= prompt)
112
+ input_ids = tokenizer(inputt, return_tensors="pt").input_ids.to("cuda")
113
+
114
+ output1 = model.generate(input_ids, max_length=512)
115
+ input_length = input_ids.shape[1]
116
+ output1 = output1[:, input_length:]
117
+ output = tokenizer.decode(output1[0])
118
+
119
+ print(output)
120
+
121
+ ```
122
+
123
+
124
+ ### Output
125
+
126
+ Sure, I can help you with that!
127
+
128
+ Attention mechanisms in transformer models are typically implemented using the attention mechanism in the self-attention layer. Self-attention allows the model to focus on different parts of the input sequence when processing it. This is achieved by computing a set of attention weights, which are used to weigh the contribution of each input element to the output.
129
+
130
+ Here's an example code using NumPy to illustrate how attention works in a transformer model:
131
+
132
+ ```python
133
+ import numpy as np
134
+
135
+ def attention_weights(query, key, value, mask):
136
+ # Query, key, and value are input tensors. Mask is a tensor of zeros and ones that represents the attention mask.
137
+ # It is used to prevent the model from attending to certain positions in the input sequence if they are not relevant.
138
+ # The attention weights are the element-wise product of the query, key, and mask tensors.
139
+ # The result is a tensor of the same shape as the query tensor.
140
+
141
+ # Compute the dot product between the query tensor and the key tensor
142
+ dot = np.matmul(query, key)
143
+
144
+ # Compute the element-wise softmax of the dot product tensor
145
+ exp_dot = np.exp(dot)
146
+
147
+ # Multiply the dot product and the softmax of the dot product tensors
148
+ weights = dot * exp_dot
149
+
150
+ # Return the attention weights as a NumPy tensor
151
+ return weights
152
+
153
+ # Define the input sequence
154
+ query = np.array([[0.1, 0.2, 0.3], [0.4, 0.5, 0.6]])
155
+ key = np.array([[0.1, 0.2], [0.3, 0.4]])
156
+ value = np.array([[0.1, 0.2, 0.3], [0.4, 0.5, 0.6]])
157
+ mask = np.array([[False, True, True], [False, True, True]])
158
+
159
+ # Compute the attention weights
160
+ weights = attention_weights(query, key, value, mask)
161
+
162
+ # Print the attention weights
163
+ print(weights)
164
+ ```
165
+
166
+ In this example, the `attention_weights` function takes as input the query tensor, key tensor, value tensor, and mask tensor. It computes the dot product between the query and key tensors using the `np.matmul` function, and then applies a softmax function using the `np.exp` function to the element-wise dot product tensor. It then multiplies the dot product and softmax tensors using the `np.matmul` function, and returns the result as a NumPy tensor.
167
+
168
+ The `query`, `key`, and `value` tensors represent the input sequence to the transformer model. The `mask` tensor represents the attention mask, which is used to prevent the model from attending to certain positions in the input sequence if they are not relevant.
169
+
170
+ The output of the `attention_weights` function is a NumPy tensor that represents the attention weights for the input sequence. These weights are used by the transformer model to weigh the contribution of each input element to the output.
171
+
172
+ I hope this helps!</s>
173
+ <hr>
174
+
175
+
176
+ ## Finetuning details
177
+ The finetuning scripts will be available in our [RAIL Github Repository](https://github.com/vmware-labs/research-and-development-artificial-intelligence-lab/tree/main/instruction-tuning)
178
+
179
+
180
+ ## Evaluation
181
+
182
+ **TODO**
183
+
184
+ ***End of original Model File***
185
+ ---
186
+
187
+
188
+ ## Please consider to support my work
189
+ **Coming Soon:** I'm in the process of launching a sponsorship/crowdfunding campaign for my work. I'm evaluating Kickstarter, Patreon, or the new GitHub Sponsors platform, and I am hoping for some support and contribution to the continued availability of these kind of models. Your support will enable me to provide even more valuable resources and maintain the models you rely on. Your patience and ongoing support are greatly appreciated as I work to make this page an even more valuable resource for the community.
190
+
191
+ <center>
192
+
193
+ [![GitHub](https://maddes8cht.github.io/assets/buttons/github-io-button.png)](https://maddes8cht.github.io)
194
+ [![Stack Exchange](https://stackexchange.com/users/flair/26485911.png)](https://stackexchange.com/users/26485911)
195
+ [![GitHub](https://maddes8cht.github.io/assets/buttons/github-button.png)](https://github.com/maddes8cht)
196
+ [![HuggingFace](https://maddes8cht.github.io/assets/buttons/huggingface-button.png)](https://huggingface.co/maddes8cht)
197
+ [![Twitter](https://maddes8cht.github.io/assets/buttons/twitter-button.png)](https://twitter.com/maddes1966)
198
+
199
+ </center>