news-reporter-3b / README.md
ksingla025's picture
Update README.md
ce405a5 verified
metadata
license: apache-2.0
datasets:
  - RedHenLabs/qa-news-2016
language:
  - en
library_name: transformers
pipeline_tag: text-generation

News reporter 3B LLM

Image

Model Description

News Reporter 3B LLM is based on Phi-3 Mini-4K Instruct a dense decoder-only Transformer model designed to generate high-quality text based on user prompts. With 3.8 billion parameters, the model is fine-tuned using Supervised Fine-Tuning (SFT) to align with human preferences and question answer pairs.

Base Model

We evaluated multiple off-the-shelf models, including Gemma-7B, Gemma-2B, Llama-3-8B, and Phi-3-mini-4K, and found that the Phi-3-mini-4K model performed best overall for our evaluation set. This model excels in multilingual query understanding and response generation, thanks to its 3.8 billion parameters and a 4096 context window length. Trained with over 3.3 trillion tokens, Phi-3-mini-4K stands out for its ability to be quantized to 4 bits, reducing its memory footprint to around 1.8 GB. It processes 8 to 12 tokens per second on a single T4 GPU, requiring just 3-4 GB of VRAM for inference.

Key Features:

  • Parameter Count: 3.8 billion.
  • Architecture: Dense decoder-only Transformer.
  • Context Length: Supports up to 4,000 tokens.
  • Training Data: 43.5K+ question and answer pairs curated from different News channel.

Inference

import torch
from transformers import AutoTokenizer, AutoModelForCausalLM, pipeline,set_seed

model_name = "RedHenLabs/news-reporter-3b"

tokenizer = AutoTokenizer.from_pretrained(model_name,trust_remote_code=True)
model = AutoModelForCausalLM.from_pretrained(model_name, trust_remote_code=True, torch_dtype="auto", device_map="cuda")

pipe = pipeline("text-generation", model=model, tokenizer=tokenizer)

def test_inference(prompt):
    prefix = "Generate a concise and accurate news summary based on the following question.\n Input:"
    prompt = pipe.tokenizer.apply_chat_template([{"role": "user", "content": prefix+prompt}], tokenize=False, add_generation_prompt=True)
    outputs = pipe(prompt, max_new_tokens=512, do_sample=True, num_beams=1, temperature=0.1, top_k=50, top_p=0.95,
                   max_time= 180)
    return outputs[0]['generated_text'][len(prompt):].strip()

res = test_inference(" What is the status of the evacuations and the condition of those injured?")
print(res)

Model Benchmark

(0 Shot) News-reporter-3b Phi-3-mini-4k Gemma-7b-it Llama-2-7B Mistral-7B-Instruct-v0.2
MMLU 69.49 69.90 64.3 45.3 59.02
ARC_C 56.40 56.14 53.2 45.9 55.89
Winogrande 74.19 73.24 68.03 69.5 73.72
Truthfulqa 50.43 66.46 44.18 57.4 53.00

Citation

@misc {lucifertrj,
   author       = { {Tarun Jain} },
   title        = { News Reporter 3B by Red Hen Lab part of Google Summer of Code 2024},
   year         = 2024,
   url          = { https://huggingface.co/RedHenLabs/news-reporter-3b },
   publisher    = { Hugging Face }
}

arxiv.org/abs/2410.07520