ohwi's picture
Update README.md
9a3bf7d verified
metadata
language:
  - ja
tags:
  - japanese-stablelm
  - causal-lm
pipeline_tag: text-generation
base_model: ohwi/japanese-stablelm-instruct-gamma-7b-repro
datasets:
  - argilla/ultrafeedback-binarized-preferences-cleaned
  - llm-jp/hh-rlhf-12k-ja
license: apache-2.0
extra_gated_fields:
  Name: text
  Email: text
  Country: text
  Organization or Affiliation: text
  I allow Stability AI to contact me about information related to its models and research: checkbox

Japanese Stable LM Instruct Gamma 7B + DPO

Model Description

This is a 7B-parameter decoder-only Japanese language model fine-tuned on preference datasets, built on top of the STF model Japanese Stable LM Instruct Gamma 7B Reproduced, which is the reproduced version of Japanese Stable LM Instruct Gamma 7B.

This model is trained with notus code base.

Training Datasets

The dataset is machine translated version of Ultrafeedback and hh-rlhf-12k-ja. Some samples from Ultrafeedback dataset are missing because of API request failure.

Benchmarks

The result is evaluated by Nejumi-leaderboard Neo.

  • llm-jp-eval:

    AVG EL FA MC MR NLI QA RC chabsa jamp janli jcommonsenseqa jemhopqa jnli jsem jsick jsquad mawps niilc wiki_coreference wiki_dependency wiki_ner wiki_pas wiki_reading
    0.3207 0.0 0.1505 0.81 0.16 0.268 0.1823 0.6744 0.0 0.09 0.56 0.81 0.1546 0.01 0.57 0.11 0.6744 0.16 0.21 0.0 0.0 0.0 0.0 0.7525
  • Japanese Mt-Bench:

    coding extraction humanities math reasoning roleplay stem writing
    2.5 3.7 3.75 1.65 3.45 6.95 5.3 7.15
  • Overall Average: 0.3756625

Credits

The training was carried out by Hwigeon Oh and Fujiki Nakamura.


( Below is the original readme of Japanese Stable LM Instruct Gamma 7B )


Japanese Stable LM Instruct Gamma 7B

Model Description

This is a 7B-parameter decoder-only Japanese language model fine-tuned on instruction-following datasets, built on top of the base model Japanese Stable LM Base Gamma 7B.

If you are in search of a smaller model, please check Japanese StableLM-3B-4E1T Instruct.

Usage

Ensure you are using Transformers 4.34.0 or newer.

import torch
from transformers import AutoTokenizer, AutoModelForCausalLM

tokenizer = AutoTokenizer.from_pretrained("stabilityai/japanese-stablelm-instruct-gamma-7b")
model = AutoModelForCausalLM.from_pretrained(
  "stabilityai/japanese-stablelm-instruct-gamma-7b",
  torch_dtype="auto",
)
model.eval()

if torch.cuda.is_available():
    model = model.to("cuda")

def build_prompt(user_query, inputs="", sep="\n\n### "):
    sys_msg = "ไปฅไธ‹ใฏใ€ใ‚ฟใ‚นใ‚ฏใ‚’่ชฌๆ˜Žใ™ใ‚‹ๆŒ‡็คบใจใ€ๆ–‡่„ˆใฎใ‚ใ‚‹ๅ…ฅๅŠ›ใฎ็ต„ใฟๅˆใ‚ใ›ใงใ™ใ€‚่ฆๆฑ‚ใ‚’้ฉๅˆ‡ใซๆบ€ใŸใ™ๅฟœ็ญ”ใ‚’ๆ›ธใใชใ•ใ„ใ€‚"
    p = sys_msg
    roles = ["ๆŒ‡็คบ", "ๅฟœ็ญ”"]
    msgs = [": \n" + user_query, ": \n"]
    if inputs:
        roles.insert(1, "ๅ…ฅๅŠ›")
        msgs.insert(1, ": \n" + inputs)
    for role, msg in zip(roles, msgs):
        p += sep + role + msg
    return p

# Infer with prompt without any additional input
user_inputs = {
    "user_query": "ไธŽใˆใ‚‰ใ‚ŒใŸใ“ใจใ‚ใ–ใฎๆ„ๅ‘ณใ‚’ๅฐๅญฆ็”Ÿใงใ‚‚ๅˆ†ใ‹ใ‚‹ใ‚ˆใ†ใซๆ•™ใˆใฆใใ ใ•ใ„ใ€‚",
    "inputs": "ๆƒ…ใ‘ใฏไบบใฎใŸใ‚ใชใ‚‰ใš"
}
prompt = build_prompt(**user_inputs)

input_ids = tokenizer.encode(
    prompt, 
    add_special_tokens=True, 
    return_tensors="pt"
)

tokens = model.generate(
    input_ids.to(device=model.device),
    max_new_tokens=256,
    temperature=1,
    top_p=0.95,
    do_sample=True,
)

out = tokenizer.decode(tokens[0][input_ids.shape[1]:], skip_special_tokens=True).strip()
print(out)

Model Details

  • Developed by: Stability AI
  • Model type: Japanese Stable LM Instruct Gamma 7B model is an auto-regressive language model based on the transformer decoder architecture.
  • Language(s): Japanese
  • License: This model is licensed under Apache License, Version 2.0.
  • Contact: For questions and comments about the model, please join Stable Community Japan. For future announcements / information about Stability AI models, research, and events, please follow https://twitter.com/StabilityAI_JP.

Model Architecture

For details, please see Mistral AI's paper and release blog post.

Training Datasets

Use and Limitations

Intended Use

The model is intended to be used by all individuals as a foundational model for application-specific fine-tuning without strict limitations on commercial use.

Limitations and bias

The pre-training dataset may have contained offensive or inappropriate content even after applying data cleansing filters which can be reflected in the model-generated text. We recommend users exercise reasonable caution when using these models in production systems. Do not use the model for any applications that may cause harm or distress to individuals or groups.

Credits

The fine-tuning was carried out by Fujiki Nakamura. Other aspects, including data preparation and evaluation, were handled by the Language Team of Stability AI Japan, notably Meng Lee, Makoto Shing, Paul McCann, Naoki Orii, and Takuya Akiba.

Acknowledgements

This model is based on Mistral-7B-v0.1 released by the Mistral AI team. We are grateful to the Mistral AI team for providing such an excellent base model.

We are grateful for the contributions of the EleutherAI Polyglot-JA team in helping us to collect a large amount of pre-training data in Japanese. Polyglot-JA members includes Hyunwoong Ko (Project Lead), Fujiki Nakamura (originally started this project when he commited to the Polyglot team), Yunho Mo, Minji Jung, KeunSeok Im, and Su-Kyeong Jang.

We are also appreciative of AI Novelist/Sta (Bit192, Inc.) and the numerous contributors from Stable Community Japan for assisting us in gathering a large amount of high-quality Japanese textual data for model training.