この記事では、ChatGPT(OpenAI API)で同じプロンプトを送っても毎回異なる出力が返ってくる問題について、海外コミュニティでの解決策を要約して解説します。
1. どんな問題(エラー)が発生したか?
- 発生した環境やツール: OpenAI API(GPT-4 / GPT-3.5-turbo)
- エラーメッセージ: エラーは発生しないが、同じ入力に対して出力内容が大きく変動する
- 症状: 自動化スクリプトで一貫した結果が必要な場面で、出力の再現性がない
2. 結論(解決策)
temperatureパラメータを0に設定し、seedパラメータを固定することで出力の一貫性を大幅に向上させることができます。
3. 具体的な手順
- temperatureを0に設定
response = client.chat.completions.create( model="gpt-4", messages=[{"role": "user", "content": "質問内容"}], temperature=0 ) - seedパラメータを固定
response = client.chat.completions.create( model="gpt-4", messages=[{"role": "user", "content": "質問内容"}], temperature=0, seed=42 ) - system_fingerprintで再現性を検証
レスポンスのsystem_fingerprintが同じであれば、同一条件での推論が保証されます。
4. 補足・注意点
temperature=0でも完全に同一の出力が保証されるわけではありません。OpenAIのインフラ側の更新により微妙に結果が変わる可能性があります。完全な再現性が必要な場合は出力をキャッシュする仕組みを併用してください。
5.
👉 【RunPod】1時間数十円から使える高性能クラウドGPU
参考元
本記事は海外コミュニティの複数のディスカッションを要約・再構成したものです。
Source: OpenAI Community Forum
🚀 プロンプト技術をさらに磨くなら
プロンプトエンジニアリングの実践には、高性能なAIモデルへのアクセスが不可欠です。
- ChatGPT Plus — GPT-4o/o1による高度な推論が利用可能
- Claude Pro — 長文コンテキストと精密な指示理解に強い