--- tags: - merge - mergekit - lazymergekit - DiscoResearch/DiscoLM_German_7b_v1 - DRXD1000/Phoenix - VAGOsolutions/SauerkrautLM-7b-v1-mistral - malteos/hermeo-7b base_model: - DiscoResearch/DiscoLM_German_7b_v1 - DRXD1000/Phoenix - VAGOsolutions/SauerkrautLM-7b-v1-mistral - malteos/hermeo-7b --- # Wiedervereinigung-7b-dpo ![image/png](https://huggingface.co/mayflowergmbh/Wiedervereinigung-7b/resolve/main/Wiedervereinigung-7b.png) Some of the best german models with 7b parameters as an dare_ties merge. Since the original models based on mistral - three of them on the brilliant german LeoLM/leo-mistral-hessianai-7b - they are reunited in this merged model. Hence the name. To improve result quality they are dpo-trained with a german translation of oaast-dpo using our german fork of [LLaMA-Factory](https://github.com/mayflower/LLaMA-Factory). Wiedervereinigung-7b itself is a [LazyMergekit](https://colab.research.google.com/drive/1obulZ1ROXHjYLn6PPZJwRR6GzgQogxxb?usp=sharing) merge of: * [DiscoResearch/DiscoLM_German_7b_v1](https://huggingface.co/DiscoResearch/DiscoLM_German_7b_v1) * [DRXD1000/Phoenix](https://huggingface.co/DRXD1000/Phoenix) * [VAGOsolutions/SauerkrautLM-7b-v1-mistral](https://huggingface.co/VAGOsolutions/SauerkrautLM-7b-v1-mistral) * [malteos/hermeo-7b](https://huggingface.co/malteos/hermeo-7b) All the actual heavylifting has been done by the creators of these models. ## 🧩 Configuration ```yaml models: - model: LeoLM/leo-mistral-hessianai-7b # No parameters necessary for base model - model: DiscoResearch/DiscoLM_German_7b_v1 parameters: density: 0.6 weight: 0.25 - model: DRXD1000/Phoenix parameters: density: 0.6 weight: 0.25 - model: VAGOsolutions/SauerkrautLM-7b-v1-mistral parameters: density: 0.6 weight: 0.25 - model: malteos/hermeo-7b parameters: density: 0.6 weight: 0.25 merge_method: dare_ties base_model: LeoLM/leo-mistral-hessianai-7b parameters: int8_mask: true dtype: bfloat16 ``` ## mt-bench-de The results are not bad, but some additional investment into dpo finetuning would probably help a lot. ```json { "first_turn": 6.4625, "second_turn": 5.6375, "categories": { "writing": 7.6, "roleplay": 7.5, "reasoning": 4.25, "math": 3.35, "coding": 3.1, "extraction": 8.15, "stem": 6.55, "humanities": 7.9 }, "average": 6.050000000000001 } ``` ## 💻 Usage ```python !pip install -qU transformers accelerate from transformers import AutoTokenizer import transformers import torch model = "mayflowergmbh/Wiedervereinigung-7b-dpo" messages = [{"role": "user", "content": "Was ist ein large language model?"}] tokenizer = AutoTokenizer.from_pretrained(model) prompt = tokenizer.apply_chat_template(messages, tokenize=False, add_generation_prompt=True) pipeline = transformers.pipeline( "text-generation", model=model, torch_dtype=torch.float16, device_map="auto", ) outputs = pipeline(prompt, max_new_tokens=256, do_sample=True, temperature=0.7, top_k=50, top_p=0.95) print(outputs[0]["generated_text"]) ```