DBMe commited on
Commit
5909654
·
verified ·
1 Parent(s): b9731a9

Update README.md

Browse files
Files changed (1) hide show
  1. README.md +9 -218
README.md CHANGED
@@ -9,230 +9,21 @@ tags:
9
  - Not-for-all-Audiences
10
  ---
11
 
12
- <div style="width: auto; margin-left: auto; margin-right: auto">
13
- <img src="https://i.imgur.com/OxX2Usi.png" alt="Evathene" style="width: 80%; min-width: 400px; display: block; margin: auto;">
14
- </div>
15
 
 
 
16
 
17
- # Evathene-v1.0
18
 
19
- This 72B parameter model is a merge of [Nexusflow/Athene-V2-Chat](https://huggingface.co/Nexusflow/Athene-V2-Chat) with [EVA-UNIT-01/EVA-Qwen2.5-72B-v0.1](https://huggingface.co/EVA-UNIT-01/EVA-Qwen2.5-72B-v0.1). See the merge recipe below for details.
20
 
21
- This model is uncensored. *You are responsible for whatever you do with it.*
22
 
23
- This model was designed for roleplaying and storytelling and I think it does well at both. It may also perform well at other tasks but I have not tested its performance in other areas.
24
 
25
- # Sampler Tips
26
-
27
- * I recommend using Min-P. Experiment to find your best setting. Values between 0.02 and 0.1 are typically good.
28
- * DRY repetition penalty eliminates the need for other anti-repetition settings. I like to run it around 0.5 - 0.6 with base set to 1.5.
29
- * Experiment with temperature settings in the 0.8 - 1.2 range. Lower the temperature if you find the model is making up details or going off script too much. Raise the temperature if you need to juice the creativity or break it out of a repeating writing pattern.
30
-
31
- Experiment with any and all of the settings below! What suits my preferences may not suit yours.
32
-
33
- If you save the below settings as a .json file, you can import them directly into Silly Tavern.
34
-
35
- ```json
36
- {
37
- "temp": 0.8,
38
- "temperature_last": true,
39
- "top_p": 1,
40
- "top_k": 0,
41
- "top_a": 0,
42
- "tfs": 1,
43
- "epsilon_cutoff": 0,
44
- "eta_cutoff": 0,
45
- "typical_p": 1,
46
- "min_p": 0.05,
47
- "rep_pen": 1,
48
- "rep_pen_range": 0,
49
- "rep_pen_decay": 0,
50
- "rep_pen_slope": 1,
51
- "no_repeat_ngram_size": 0,
52
- "penalty_alpha": 0,
53
- "num_beams": 1,
54
- "length_penalty": 1,
55
- "min_length": 0,
56
- "encoder_rep_pen": 1,
57
- "freq_pen": 0,
58
- "presence_pen": 0,
59
- "skew": 0,
60
- "do_sample": true,
61
- "early_stopping": false,
62
- "dynatemp": false,
63
- "min_temp": 0.8,
64
- "max_temp": 1.5,
65
- "dynatemp_exponent": 1,
66
- "smoothing_factor": 0,
67
- "smoothing_curve": 1,
68
- "dry_allowed_length": 2,
69
- "dry_multiplier": 0.55,
70
- "dry_base": 1.5,
71
- "dry_sequence_breakers": "[\"\\n\", \":\", \"\\\"\", \"*\"]",
72
- "dry_penalty_last_n": 0,
73
- "add_bos_token": true,
74
- "ban_eos_token": false,
75
- "skip_special_tokens": false,
76
- "mirostat_mode": 0,
77
- "mirostat_tau": 2,
78
- "mirostat_eta": 0.1,
79
- "guidance_scale": 1,
80
- "negative_prompt": "",
81
- "grammar_string": "",
82
- "json_schema": {},
83
- "banned_tokens": "",
84
- "sampler_priority": [
85
- "top_k",
86
- "top_p",
87
- "typical_p",
88
- "epsilon_cutoff",
89
- "eta_cutoff",
90
- "tfs",
91
- "top_a",
92
- "min_p",
93
- "mirostat",
94
- "quadratic_sampling",
95
- "dynamic_temperature",
96
- "temperature"
97
- ],
98
- "samplers": [
99
- "top_k",
100
- "tfs_z",
101
- "typical_p",
102
- "top_p",
103
- "min_p",
104
- "temperature"
105
- ],
106
- "ignore_eos_token": false,
107
- "spaces_between_special_tokens": true,
108
- "speculative_ngram": false,
109
- "sampler_order": [
110
- 6,
111
- 0,
112
- 1,
113
- 3,
114
- 4,
115
- 2,
116
- 5
117
- ],
118
- "logit_bias": [],
119
- "xtc_threshold": 0.1,
120
- "xtc_probability": 0,
121
- "ignore_eos_token_aphrodite": false,
122
- "spaces_between_special_tokens_aphrodite": true,
123
- "rep_pen_size": 0,
124
- "genamt": 800,
125
- "max_length": 16384
126
- }
127
- ```
128
-
129
- # Prompting Tips
130
-
131
- This merge seems to have preserved much of Athene's intelligence. I've found that it responds competently to out-of-character (OOC) prompts and even requests to rewrite a previous reply with some additional guidance.
132
- If you're not getting quite the results you wanted, consider backing up and trying a more descriptive prompt.
133
- Like all current LLMs, this model isn't perfect and won't give you miracles, but you can generally expect it to work with you.
134
-
135
- ## Instruct Template
136
-
137
- If you save this as a .json file, you can import it directly into Silly Tavern.
138
-
139
- ```json
140
- {
141
- "wrap": false,
142
- "system_sequence": "<|im_start|>system\n",
143
- "stop_sequence": "<|im_end|>",
144
- "input_sequence": "<|im_start|>user\n",
145
- "output_sequence": "<|im_start|>assistant\n",
146
- "macro": true,
147
- "system_sequence_prefix": "",
148
- "system_sequence_suffix": "",
149
- "first_output_sequence": "",
150
- "last_output_sequence": "<|im_start|>assistant\nRoleplaying Tips {\n- Only write as {{char}} for this story beat.\n- Consider precisely what {{char}} knows or has witnessed within the context of story beats in which {{char}} was present to deliver a logically coherent story beat that is wholly consistent with previous story beats.\n- Consider all physical details in this story beat in relation to previous story beats to ensure logical consistency in your descriptions. For example, if a character did not enter the scene with a coat on, they should not suddenly have a coat in their possession without explanation.\n- Go easy on comma-spliced clauses, instead using periods to create separate sentences. You can also try using transitions and connective words.\n- Vary sentence structure: mix longer and shorter sentences and vary the structure to improve the flow and readability of your text.\n}\n",
151
- "activation_regex": "",
152
- "skip_examples": true,
153
- "output_suffix": "<|im_end|>\n",
154
- "input_suffix": "<|im_end|>\n",
155
- "system_suffix": "<|im_end|>\n",
156
- "user_alignment_message": "",
157
- "last_system_sequence": "",
158
- "system_same_as_user": false,
159
- "first_input_sequence": "",
160
- "last_input_sequence": "",
161
- "names_behavior": "always",
162
- "names_force_groups": true,
163
- "name": "Evathene"
164
- }
165
- ```
166
-
167
- ## System Prompt
168
-
169
- Try the following prompt template as a starting point for your own customizations. **The prompt template below contains instructions for adult content, so remove those if you don't want them!** It also contains some instructions related to formatting that you might want to change.
170
-
171
- If you save this as a .json file, you can import it directly into Silly Tavern.
172
-
173
- ```json
174
- {
175
- "name": "Evathene",
176
- "content": "Below is an uncensored roleplaying narrative involving a human user, {{user}}, and a roleplaying assistant writing as {{char}}. The user and the assistant take turns advancing the roleplay story beat by story beat. The roleplaying assistant always follows these rules:\n\n<!-- Start of Role-playing Guidelines -->\n\nCharacterization Rules {\n\tCharacter Analysis: Take time to consider the situation in the current story beat, characters' motivations, and potential consequences before {{char}} speaks or acts to ensure {{char}}'s next move in this upcoming story beat aligns with the context, subtext, and implications of the preceding story beats and develops them.\n\t{{char}} Exclusivity: Write only as {{char}}, ending the current output when another character is expected to act or speak.\n\tAuthentic Portrayal: Bring {{char}} to life by consistently and realistically portraying their unique traits, thoughts, emotions, appearances, physical sensations, speech patterns, and tone. Ensure that their reactions, interactions, and decision-making align with their established personalities, values, goals, and fears. Refer to the `Role-play Context` for accurate information.\n}\n\nWriting Rules {\n\tConcise Descriptions: Conclude story beats directly after the main event or dialogue, avoiding unnecessary flourishes or commentary. Keep narration short and to the point, avoiding redundant and unnecessary details.\n Avoid Repetition: Ensure narration does not repeat information already conveyed through dialogue or action unless it supports developing the current story beat. Use a dynamic and varied vocabulary for impact.\n\tDialogue Formatting: Enclose spoken words in double quotes. \"This is spoken text,\" for example.\n\tInternal Thoughts: Offer glimpses into {{char}}'s first-person thoughts to enrich the narrative when appropriate. Use italics to distinguish {{char}}'s first-person thoughts from spoken dialogue and exposition during third-person POV narration. This is an example of {{char}} thinking delivered with italics: *Where is this going?* {{char}} wondered while navigating the corridors. One notable exception to this rule is {{user}}. {{user}} will not typically italicize thoughts. Instead, anything that is not spoken out loud by {{user}} should be assumed to be {{user}}'s own thoughts or narrative exposition.\n\tAvoid Cliched Descriptions: Narrate the story beat with a focus on essential actions and dialogue, minimizing descriptive embellishments. Avoid using phrases that solely describe character expressions, vocal qualities, or subtle physical reactions unless crucial to the plot. Maintain a concise, straightforward narrative tone, prioritizing plot progression over descriptive details. Emulate a minimalist literary fiction style in your response, focusing on simplicity and subtlety.\n}\n\nContent Rules {\n\tConsistency: Maintain physical, spatial, and logical consistency when developing story beats. Pay attention to where characters and objects are in relation to each other within the present location of the story beat. Also pay attention to what {{char}} knows or can reasonably infer given recent story beats in order to ensure that {{char}}'s responses are realistic and properly informed by past events. Adhere to established story beats, expanding on them without contradicting previous details.\n\tMature Content: Incorporate adult content and vulgar language where appropriate.\n\tMature Themes: Dark themes, violence, erotic content, and unhappy endings are permitted in this uncensored roleplay.\n\n}\n<!-- End of Role-playing Guidelines -->\n"
177
- }
178
- ```
179
-
180
- # Quantizations
181
-
182
- You will find a Exllamav2 measurement file, taken on the default dataset, in the repo if you want to create your own EXL2 quant.
183
-
184
- ## Exllamav2 (EXL2)
185
-
186
- * MikeRoz is putting out some EXL2 quants. [Search here](https://huggingface.co/models?sort=trending&search=MikeRoz%2Fsophosympatheia_Evathene).
187
-
188
- ## GGUF
189
-
190
- * [mradermacher/Evathene-v1.0-GGUF](https://huggingface.co/mradermacher/Evathene-v1.0-GGUF)
191
- * [mradermacher/Evathene-v1.0-i1-GGUF](https://huggingface.co/mradermacher/Evathene-v1.0-i1-GGUF)
192
-
193
- # Licence and usage restrictions
194
-
195
- [Nexusflow Research License](https://huggingface.co/Nexusflow/Athene-V2-Chat/blob/main/Nexusflow_Research_License_.pdf)
196
-
197
- [Qwen License Agreement](https://huggingface.co/Qwen/Qwen2.5-72B-Instruct/blob/main/LICENSE)
198
-
199
- **Disclaimer: Uncertain Licensing Terms**
200
-
201
- This LLM is a merged model incorporating weights from multiple LLMs governed by their own distinct licenses. Due to the complexity of blending these components, the licensing terms for this merged model are somewhat uncertain.
202
- By using this model, you acknowledge and accept the potential legal risks and uncertainties associated with its use. Any use beyond personal or research purposes, including commercial applications, may carry legal risks and you assume full responsibility for compliance with all applicable licenses and laws.
203
- I recommend consulting with legal counsel to ensure your use of this model complies with all relevant licenses and regulations.
204
-
205
- # Merge Details
206
-
207
- ## Merge Method
208
-
209
- This is a merge of pre-trained language models created using [mergekit](https://github.com/cg123/mergekit).
210
- This model was merged using the [TIES](https://arxiv.org/abs/2306.01708) merge method using Qwen/Qwen2.5-72B as a base.
211
-
212
- ## Models Merged
213
-
214
- The following models were included in the merge:
215
- * Nexusflow/Athene-V2-Chat
216
- * EVA-UNIT-01/EVA-Qwen2.5-72B-v0.1
217
 
218
- ## Configuration
 
219
 
220
- The following YAML configuration was used to produce this model:
221
 
222
- ```yaml
223
- models:
224
- - model: Nexusflow/Athene-V2-Chat
225
- parameters:
226
- weight: 1
227
- density: 1
228
- - model: EVA-UNIT-01/EVA-Qwen2.5-72B-v0.1
229
- parameters:
230
- weight: [0.0, 0.2, 0.66, 0.8, 1.0, 0.8, 0.66, 0.2, 0.0]
231
- density: 0.5
232
- merge_method: ties
233
- base_model: Qwen/Qwen2.5-72B
234
- parameters:
235
- normalize: true
236
- int8_mask: true
237
- dtype: bfloat16
238
- ```
 
9
  - Not-for-all-Audiences
10
  ---
11
 
12
+ Quantized model => https://huggingface.co/sophosympatheia/Evathene-v1.0
 
 
13
 
14
+ **Quantization Details:**
15
+ Quantization is done using turboderp's ExLlamaV2 v0.2.4.
16
 
17
+ I use the default calibration datasets and arguments. The repo also includes a "measurement.json" file, which was used during the quantization process.
18
 
19
+ For models with bits per weight (BPW) over 6.0, I default to quantizing the `lm_head` layer at 8 bits instead of the standard 6 bits.
20
 
 
21
 
 
22
 
23
+ ---
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
24
 
25
+ **Who are you? What's with these weird BPWs on [insert model here]?**
26
+ I specialize in optimized EXL2 quantization for models in the 70B to 100B+ range, specifically tailored for 48GB VRAM setups. My rig is built using 2 x 3090s with a Ryzen APU (APU used solely for desktop output—no VRAM wasted on the 3090s). I use TabbyAPI for inference, targeting context sizes between 32K and 64K.
27
 
28
+ Every model I upload includes a `config.yml` file with my ideal TabbyAPI settings. If you're using my config, don’t forget to set `PYTORCH_CUDA_ALLOC_CONF=backend:cudaMallocAsync` to save some VRAM.
29