palmyra-base / README.md
wassemgtk's picture
Update README.md
e73aa55
|
raw
history blame
4.13 kB
metadata
language:
  - en
datasets:
  - English
tags:
  - text generation
  - pytorch
  - causal-lm
  - Writer-data
  - gpt
  - NeMo
pipeline_tag: text-generation
library_name: transformers

license: cc-by-4.0

Palmyra-base

|Model architecture|Model size|Language

Model Description

Palmyra was primarily pretrained with English text, there is still a trace amount of non-English data present within the training corpus that was accessed through CommonCrawl. A causal language modeling (CLM) objective was utilized during the process of the model's pretraining. Similar to GPT-3, Palmyra is a member of the same family of models that only contain a decoder. As a result, it was pretrained utilizing the objective of self-supervised causal language modeling. Palmyra uses the prompts and general experimental setup from GPT-3 in order to conduct its evaluation in accordance with GPT-3. Read the official paper if you want more information about this.

Training data

Palmyra-base 5b was trained on Writer custom dataset

Intended Use and Limitations

Palmyra-base learns an inner representation of the English language that can be used to extract features useful for downstream tasks. The model is best at what it was pretrained for however, which is generating text from a prompt.

How to use

This model can be easily loaded using the AutoModelForCausalLM functionality:


from transformers import AutoModelForCausalLM, AutoTokenizer
import torch

model = AutoModelForCausalLM.from_pretrained("Writer/palmyra-base", torch_dtype=torch.float16).cuda()

# the fast tokenizer currently does not work correctly
tokenizer = AutoTokenizer.from_pretrained("Writer/palmyra-base", use_fast=False)

prompt = "What is the color of a carrot?\nA:"

input_ids = tokenizer(prompt, return_tensors="pt").input_ids.cuda()

generated_ids = model.generate(input_ids)

tokenizer.batch_decode(generated_ids, skip_special_tokens=True)

Limitations and Biases

Palmyra's core functionality is to take a string of text and predict the next token. While language models are widely used for other tasks, there are many unknowns in this work. When prompting Palmyra, keep in mind that the statistically most likely next token is not always the token that produces the most "accurate" text. Never rely on Palmyra to produce factually correct results.

Palmyra was trained on Writer custom data. As with all language models, it is difficult to predict how Palmyra will respond to specific prompts, and offensive content may appear unexpectedly. We recommend that the outputs be curated or filtered by humans before they are released, both to censor undesirable content and to improve the quality of the results.

Use case

Palmyra-based is extremely powerful while also being extremely fast. While Palmyra-large is better at analyzing complex text, Palmyra-base is capable of many nuanced tasks such as sentiment classification and summarization. Curie is also effective as a general service chatbot, answering questions and performing Q&A.

Competent in: complex classification, text sentiment, and summarization

Evaluation results

Evaluation of Palmyra-base model on the SuperGLUE benchmark

Task Metric Value
boolq acc 64.43
cb acc 10.71
f1 08.32
copa acc 76.00
multirc acc 01.26
record f1 84.02
em 83.29
wic acc 50.00
wsc acc 36.54

Citation and Related Information

To cite this model:

@misc{Palmyra,
  author = {Writer Engineering team},
  title = {{Palmyra-base Parameter Autoregressive Language Model}},
  howpublished = {\url{https://dev.writer.com}},
  year = 2023,
  month = January 
}