November 30, 2022

ChatGPT: Optimizing Language Models for Dialogue

ChatGPT: Optimizing Language Models for Dialogue

We’ve trained a model called ChatGPT which interacts in a conversational way. The dialogue format makes it possible for ChatGPT to answer followup questions, admit its mistakes, challenge incorrect premises, and reject inappropriate requests. ChatGPT is a sibling model to InstructGPT, which is trained to follow an instruction in a prompt and provide a detailed response.

Try ChatGPT

We are excited to introduce ChatGPT to get users’ feedback and learn about its strengths and weaknesses. During the research preview, usage of ChatGPT is free. Try it now at chat.openai.com.

Samples

In the following sample, ChatGPT asks the clarifying questions to debug code.
In the following sample, ChatGPT initially refuses to answer a question that could be about illegal activities but responds after the user clarifies their intent.
In the following sample, ChatGPT is able to understand the reference (“it”) to the subject of the previous question (“fermat’s little theorem”).
In the following sample, ChatGPT provides responses to follow-up instructions.
Sample 1234 of 4PreviousNext

Sample 1234 of 4PreviousNext

Try ChatGPT

Methods

We trained this model using Reinforcement Learning from Human Feedback (RLHF), using the same methods as InstructGPT, but with slight differences in the data collection setup. We trained an initial model using supervised fine-tuning: human AI trainers provided conversations in which they played both sides—the user and an AI assistant. We gave the trainers access to model-written suggestions to help them compose their responses. We mixed this new dialogue dataset with the InstructGPT dataset, which we transformed into a dialogue format.

To create a reward model for reinforcement learning, we needed to collect comparison data, which consisted of two or more model responses ranked by quality. To collect this data, we took conversations that AI trainers had with the chatbot. We randomly selected a model-written message, sampled several alternative completions, and had AI trainers rank them. Using these reward models, we can fine-tune the model using Proximal Policy Optimization. We performed several iterations of this process.

ChatGPT: Optimizing Language Models for Dialogue

ChatGPT is fine-tuned from a model in the GPT-3.5 series, which finished training in early 2022. You can learn more about the 3.5 series here. ChatGPT and GPT 3.5 were trained on an Azure AI supercomputing infrastructure.

Limitations

  • ChatGPT sometimes writes plausible-sounding but incorrect or nonsensical answers. Fixing this issue is challenging, as: (1) during RL training, there’s currently no source of truth; (2) training the model to be more cautious causes it to decline questions that it can answer correctly; and (3) supervised training misleads the model because the ideal answer depends on what the model knows, rather than what the human demonstrator knows.
  • ChatGPT is sensitive to tweaks to the input phrasing or attempting the same prompt multiple times. For example, given one phrasing of a question, the model can claim to not know the answer, but given a slight rephrase, can answer correctly.
  • The model is often excessively verbose and overuses certain phrases, such as restating that it’s a language model trained by OpenAI. These issues arise from biases in the training data (trainers prefer longer answers that look more comprehensive) and well-known over-optimization issues.
  • Ideally, the model would ask clarifying questions when the user provided an ambiguous query. Instead, our current models usually guess what the user intended.
  • While we’ve made efforts to make the model refuse inappropriate requests, it will sometimes respond to harmful instructions or exhibit biased behavior. We’re using the Moderation API to warn or block certain types of unsafe content, but we expect it to have some false negatives and positives for now. We’re eager to collect user feedback to aid our ongoing work to improve this system.

Iterative deployment

Today’s research release of ChatGPT is the latest step in OpenAI’s iterative deployment of increasingly safe and useful AI systems. Many lessons from deployment of earlier models like GPT-3 and Codex have informed the safety mitigations in place for this release, including substantial reductions in harmful and untruthful outputs achieved by the use of reinforcement learning from human feedback (RLHF).

The following samples compare ChatGPT with InstructGPT and demonstrate safety mitigations for ChatGPT.
Sample 123 of 3PreviousNext

Sample 123 of 3PreviousNext
Try ChatGPT

We know that many limitations remain as discussed above and we plan to make regular model updates to improve in such areas. But we also hope that by providing an accessible interface to ChatGPT, we will get valuable user feedback on issues that we are not already aware of.

Users are encouraged to provide feedback on problematic model outputs through the UI, as well as on false positives/negatives from the external content filter which is also part of the interface. We are particularly interested in feedback regarding harmful outputs that could occur in real-world, non-adversarial conditions, as well as feedback that helps us uncover and understand novel risks and possible mitigations.You can choose to enter the ChatGPT Feedback Contest for a chance to win up to $500 in API credits.[1] Entries can be submitted via the feedback form that is linked in the ChatGPT interface.

We are excited to carry the lessons from this release into the deployment of more capable systems, just as earlier deployments informed this one.

.samples .sample-line {
padding-top: calc(var(–v) * 1);
}

.samples .user {
background-color: #F5F5F5;
}
.samples .chatgpt,
.samples .chatgpt-inline {
background-color: #DFFFE2;
}
.samples .instructgpt,
.samples .instructgpt-inline {
background-color: #E5F1FF;
}

.samples-note [data-id] {
display: none;
visibility: hidden;
}
.samples-note[data-active=”0″] [data-id=”0″],
.samples-note[data-active=”1″] [data-id=”1″],
.samples-note[data-active=”2″] [data-id=”2″],
.samples-note[data-active=”3″] [data-id=”3″],
.samples-note[data-active=”4″] [data-id=”4″],
.samples-note[data-active=”5″] [data-id=”5″] {
display: unset;
visibility: visible;
}

.js-carousel-previous,
.js-carousel-next {
cursor: pointer;
}

.carousel {
opacity: 0;
transition: opacity 250ms ease-in-out;
}
.carousel.flickity-enabled {
opacity: 1;
}
.carousel-item {
width: 100%;
display: none;
}
.carousel-item.is-selected {
z-index: 1; /* so works with iframe fade */
}
.carousel-item:first-of-type,
.flickity-enabled .carousel-item {
display: block;
}
/* flickity */
.flickity-enabled {
position: relative;
}
.flickity-enabled:focus { outline: none; }
.flickity-viewport {
/*overflow: hidden;*/
position: relative;
height: 100%;
}
.flickity-slider {
position: absolute;
width: 100%;
height: 100%;
}

// Flickity carousel
var initCarousel = function (mainClass, cellClass) {
var el = document.querySelector(mainClass);
if (!el) return;
var flickity = new Flickity(el, {
cellSelector: cellClass,
wrapAround: true,
draggable: false,
pageDots: false,
hash: false,
adaptiveHeight: true,
selectedAttraction: 0.15,
friction: 0.72,
prevNextButtons: false,
arrowShape: ‘M55.18,32.24l2.56,2.54L42.65,50,57.74,65.22l-2.56,2.54L37.59,50Z’,
on: {
ready: function () {
initPrevNextButtons(mainClass, this);
}
},
});
flickity.on(‘change’, function () {
setActiveNote(this, flickity.selectedIndex);
});
return flickity;
};
var setActiveNote = function (f, i) {
var id = f.element.getAttribute(‘data-id’);
var notes = document.querySelectorAll(‘.samples-note[data-carousel-id=”‘ + id + ‘”]’);
if (!notes.length) return;
notes.forEach(function (n) {
n.setAttribute(‘data-active’, i);
});
};
var initPrevNextButtons = function (c, f) {
var id = (c === ‘.js-carousel–samples’) ? ‘samples’ : ‘safety-samples’ ;
var containerEl = document.getElementById(id);
var prevEls = document.querySelectorAll(‘.js-carousel-previous[data-carousel-id=”‘ + id + ‘”]’);
var nextEls = document.querySelectorAll(‘.js-carousel-next[data-carousel-id=”‘ + id + ‘”]’);
prevEls.forEach(function (e) {
e.addEventListener(‘click’, function () {
f.previous();
containerEl.scrollIntoView({behavior: ‘smooth’});
});
});
nextEls.forEach(function (e) {
e.addEventListener(‘click’, function () {
f.next();
containerEl.scrollIntoView({behavior: ‘smooth’});
})
});
};
// call everything
document.addEventListener(‘DOMContentLoaded’, function () {
var samplesCarousel = initCarousel(‘.js-carousel–samples’, ‘.js-carousel-item’);
var safetySamplesCarousel = initCarousel(‘.js-carousel–safety-samples’, ‘.js-carousel-item’);
});


Acknowledgments

Contributors: John Schulman, Barret Zoph, Christina Kim, Jacob Hilton, Jacob Menick, Jiayi Weng, Juan Felipe Ceron Uribe, Liam Fedus, Luke Metz, Michael Pokorny, Rapha Gontijo Lopes, Shengjia Zhao, Arun Vijayvergiya, Eric Sigler, Adam Perelman, Chelsea Voss, Mike Heaton, Joel Parish, Dave Cummings, Rajeev Nayak, Valerie Balcom, David Schnurr, Tomer Kaftan, Chris Hallacy, Nicholas Turley, Noah Deutsch, Vik Goel, Jonathan Ward, Aris Konstantinidis, Wojciech Zaremba, Long Ouyang, Leonard Bogdonoff, Joshua Gross, David Medina, Sarah Yoo, Teddy Lee, Ryan Lowe, Dan Mossing, Joost Huizinga, Roger Jiang, Carroll Wainwright, Diogo Almeida, Steph Lin, Marvin Zhang, Kai Xiao, Katarina Slama, Steven Bills, Alex Gray, Jan Leike, Jakub Pachocki, Phil Tillet, Shantanu Jain, Greg Brockman, Nick Ryder


References
  1. Stiennon, Nisan, et al. “Learning to summarize with human feedback.” Advances in Neural Information Processing Systems 33 (2020): 3008-3021.
  2. Gao, Leo, John Schulman, and Jacob Hilton. “Scaling Laws for Reward Model Overoptimization.” arXiv preprint arXiv:2210.10760 (2022).
  3. The inspiration for this contest comes in part from work by Kenway, Josh, Camille François, Sasha Costanza-Chock, Inioluwa Deborah Raji, and Joy Buolamwini. Bug Bounties For Algorithmic Harms? Lessons from Cybersecurity Vulnerability Disclosure for Algorithmic Harms Discovery, Disclosure, and Redress. Washington, DC: Algorithmic Justice League. January 2022. Available at https://ajl.org/bugs. See also work by Brundage, Miles, Avin, Shahar, Wang, Jasmine, Belfield, Haydn, and Gretchen Krueger et al. “Toward Trustworthy AI Development: Mechanisms for Supporting Verifiable Claims,” April 2020. Available at https://arxiv.org/abs/2004.07213. See an earlier instance of such a competition at HackerOne. 2021b. “Twitter Algorithmic Bias.” HackerOne. https://hackerone.com/twitter-algorithmic-bias?type=team. Finally, see early published work on this topic from Rubinovitz, JB, “Bias Bounty Programs as a Method of Combatting Bias in AI,” August 2018. Available at https://rubinovitz.com/2018/08/01/bias-bounty-programs-as-a-method-of-combatting.


Footnotes

  1. No purchase necessary, void where prohibited. Must be at least 18 to enter. For contest details, see the Official Rules. ↩︎

Share This Post

Leave a Reply

Your email address will not be published. Required fields are marked *


en_USEnglish