GRAG Logo

GRAG-NEMO-12B-ORPO-HESSIAN-AI

GRAG (German Retrieval Augmented Generation) models are designed for the German-speaking market, enabling innovation and AI solutions to drive German research collaboration in business-focused Generative AI by 2025

Our GRAG-NEMP-ORPO model are trained on this GRAG-ORPO dataset.

Model Details

The core models released in this batch are the following:

Size Training Tokens
GRAG-NEMO-CPT 507.47 million
GRAG-NEMO-SFT 2.03 billion
GRAG-NEMO-ORPO 2.0577 billion

Model Description

  • Developed by: Avemio AI Team
  • Supported by: Hessian AI
  • Model type: a Transformer style autoregressive language model.
  • Language(s) (NLP): German, English
  • License: The code and model are released under Apache 2.0.
  • Contact: grag@avemio.digital

Model Sources

Uses

Inference

Quickly get inference running with the following required installation: Now, proceed as usual with HuggingFace:

from transformers import AutoModelForCausalLM, AutoTokenizer
 
model_name = "avemio/GRAG-NEMO-12B-ORPO-HESSIAN-AI"
 
model = AutoModelForCausalLM.from_pretrained(
    model_name,
    torch_dtype="auto",
    device_map="auto"
)
tokenizer = AutoTokenizer.from_pretrained(model_name)
im_end_token_id = tokenizer.convert_tokens_to_ids('<|im_end|>')
im_start_token_id = tokenizer.convert_tokens_to_ids('<|im_start|>')
 
messages = [
    {"role": "system", "content": "Folge den Anweisungen des Benutzers. Bevor du deine finale Antwort gibst, schildere deine Überlegungen zur Lösung des Problems."},
    {"role": "user", "content": "Ferdinand steht vor der Herausforderung, eine faire Besuchsregelung für seine drei Kinder zu finden, die den Bedürfnissen jedes einzelnen Kindes gerecht wird. Jedes Kind hat unterschiedliche Vorlieben und Bedürfnisse, die in den Besuchsplan integriert werden müssen. Er muss sicherstellen, dass die Regelung sowohl den Interessen der Kinder als auch den rechtlichen Vorgaben entspricht. Ferdinand hat eine Woche Zeit, um einen Vorschlag zu erarbeiten, den er mit seinem Anwalt besprechen kann."}
]
text = tokenizer.apply_chat_template(
    messages,
    tokenize=False,
    add_generation_prompt=False
)
model_inputs = tokenizer([text], return_tensors="pt").to(model.device)
 
generated_ids = model.generate(
    **model_inputs,
    max_length=2024,
    temperature=0.01,
    do_sample=False,
    #bos_token_id=im_start_token_id,
    eos_token_id=im_end_token_id,
    pad_token_id=tokenizer.eos_token_id,
    repetition_penalty=1.1,
    num_return_sequences=1,
    top_k=40,
    top_p=0.95,
)
generated_ids = [
    output_ids[len(input_ids):] for input_ids, output_ids in zip(model_inputs.input_ids, generated_ids)
]
 
response = tokenizer.batch_decode(generated_ids, skip_special_tokens=True)[0]
 

Fine-tuning

We are providing a comprehensive Google Colab notebook to guide users through the process of fine-tuning our model, complete with detailed instructions, essential dependencies, and configurable settings. Colab-Notebook.

GRAG-LLM-EASY-BENCHMARK EVAL

The evaluation was performed using seven subsets, focusing on extraction recall, question answering (QA) with multiple references, and time difference reasoning. Relevant context and summarization were treated as distinct subsets, each playing a crucial role in the evaluation process. For relevant context, the model's ability to identify and extract pertinent information from the source material was assessed. In contrast, the summarization subset evaluated the model's capability to generate concise and accurate summaries based on the relevant context.

Four evaluation metrics were employed across all subsets: language quality, overall correctness, instruction following, and an overall score.

  • Language quality: This metric focused on the overall linguistic quality of the outputs, considering factors such as grammar, fluency, and clarity.
  • Overall correctness: The accuracy and correctness of the content were evaluated under this metric.
  • Instruction following: This metric assessed the model's ability to follow specific instructions provided for each task.
  • Overall score: This metric combined the results from the previous three metrics, offering a comprehensive evaluation of the model's capabilities across all subsets.
Metric Vanila-Mistral-Nemo-Instruct-2407 GRAG-NEMO-SFT GRAG-NEMO-ORPO GPT-3.5-TURBO
Average Language Quality 85.88 89.61 89.1 91.86
OVERALL SCORES (weighted):
extraction_recall 35.2 52.3 48.8 87.2
qa_multiple_references 65.3 71.0 74.0 77.2
qa_without_time_difference 71.5 85.6 85.6 83.1
qa_with_time_difference 65.3 87.9 85.4 83.2
relevant_context 71.3 69.1 65.5 89.5
summarizations 73.8 81.6 80.3 86.9

GRAG-LLM-HARD-BENCHMARK EVAL

GRAG Logo
Metric Vanila-Mistral-Nemo-Instruct-2407 GRAG-NEMO-ORPO GPT-3.5-TURBO GPT-4o GPT-4o-mini
OVERALL SCORES (weighted):
hard_reasoning_de 43.6 49.7 37.9 62.9 58.4
hard_reasoning_en 54.2 55.6 48.3 61.7 62.9

Model Details

Data

For training data details, please see the GRAG-ORPO-Dataset documentation.

The ORPO Tasks Dataset represents a specialized collection for fine-tuning language models with a focus on RAG-specific capabilities.

The subsets can be for this training step are derived from 3 different sources:

  • SauerkrautLM Preference Datasets:
    • SauerkrautLM-Fermented-GER-DPO: is a specialized dataset designed for training language models in function calling irrelevance detection using Preference Optimization. The dataset consists of 2,000 carefully evaluated instruction-response pairs, specifically curated to help models recognize situations where function calls are unnecessary and direct responses are more appropriate.
    • SauerkrautLM-Fermented-Irrelevance-GER-DPO: is a high-quality German instruction-response dataset specifically designed for Preference Optimization training. The dataset consists of 3,305 instruction-response pairs. Rather than being merged from existing German datasets, it was carefully created through a sophisticated augmentation process, transforming curated English instructions and responses into culturally adapted German content. Each pair includes comprehensive quality metrics and rejected responses for Preference training.
  • Hard Reasoning DE & EN: Synthetic generation inspired by Tencent's (“Scaling Synthetic Data Creation with 1,000,000,000 Personas”).
  • Multi-Turn-QA: Developed by Avemio AG, this dataset builds upon and enhances the German Wikipedia dump provided by Cohere (wikipedia-22-12-de-embeddings), expanding it with synthetic examples and structured tasks to create a robust training resource.

Data Subsets

Subset Examples per Task
SauerkrautLM-Fermented-GER-DPO 3.31k
SauerkrautLM-Fermented-Irrelevance-GER-DPO 2k
hard-reasoning-de 3.19k
hard-reasoning-en 1.97k
multi-turn-qa 3.2k

Source Data: SauerkrautLM

SauerkrautLM-Fermented-GER-DPO

SauerkrautLM-Fermented-Irrelevance-GER-DPO

Source Data: Hard-Reasoning DE & EN

  • Base: (proj-Persona/PersonaHub)
  • Enhancement: Synthetic data generation by Avemio AG
  • Quality: Automatic validation and curation of examples by Open Source LLM's

Methodology: Reasoning-DE & Reasoning-EN

  • Providing Persona Descriptions and rewriting in a similar style with a different focus area and name in german/english language
  • Generating Simple Logical Problems out of Persona-specific Views & Language.
  • Generating Approaches, Thinking-Steps & Solutions separately verified by Llama-3.1-405B-Instruct
  • Quality assurance and validation

Source Data: Multi-Turn-QA

Methodology: Multi-Turn-QA

  1. Extraction of base content from German Wikipedia
  2. Enhancement through synthetic example generation
  3. Structure addition for specific task types
  4. Quality assurance and validation

Architecture

Parameter GRAG-NEMO-ORPO
d_model 5120
num heads 32
num layers 40
MLP ratio 2.8
LayerNorm type RMSNorm
pos embeddings RoPE
attention variant Standard Multi-Head Self Attention
biases none
block type sequential
activation SiLU
sequence length 1024000
weight typing bfloat16

Hyperparameters

Parameter GRAG-NEMO-ORPO
warmup steps 50
peak LR 5.0E-07
weight decay 0.1
LR schedule linear
gradient reduce dtype FP32
optimizer state dtype FP32

Environmental Impact

GRAG-NEMO-ORPO, running on NVIDIA A100 with 80 GPUs for 4 days, has an approximate power consumption as follows:

It's important to note that the actual power consumption may vary depending on the specific workload and operational conditions. For accurate power consumption measurements, using dedicated power monitoring tools is recommended.

Model GPU Type Power Consumption From GPUs
GRAG-NEMO-ORPO A100 (Hessian AI supercomputer) 0.01843 MWh

Bias, Risks, and Limitations

Like any base language model or fine-tuned model without safety filtering, it is relatively easy for a user to prompt these models to generate harmful and generally sensitive content. Such content can also be produced unintentionally, especially in the case of bias, so we recommend users consider the risks of applications of this technology.

Otherwise, many facts from GRAG-NEMO-ORPO or any LLM will often not be true, so they should be checked.

Model Card Contact

For errors in this model card, please contact (grag@avemio.digital).

The GRAG AI Team

Marcel Rosiak Soumya Paul Siavash Mollaebrahim Zain ul Haq

Downloads last month
43
Safetensors
Model size
12.2B params
Tensor type
BF16
·
Inference Examples
Unable to determine this model's library. Check the docs .

Model tree for avemio/GRAG-NEMO-12B-ORPO-HESSIAN-AI

Datasets used to train avemio/GRAG-NEMO-12B-ORPO-HESSIAN-AI

Collection including avemio/GRAG-NEMO-12B-ORPO-HESSIAN-AI