1.はじめに
OpenAIのChatGPT APIは、ChatGPTのようなテキスト生成AIを呼び出すためのAPIです。ChatGPT APIにより、各種プログラムにテキスト生成AIを組み込むことが可能です。
ここでは、ChatGPT APIを使うため、cURL.exe やTalend API Testerから試用するまでの手順を(1)アカウントの登録(2)APIキーの取得(3)API呼出費用の支払い(4)APIの試用の段階に分けて説明します。
2.OpenAI(ChatGPT)のAPIを使うステップ
OpenAI(ChatGPT)のAPIを使うためには、以下の2つのステップが必要です。
2.1.アカウント登録
以下、アカウント登録について順次説明します。
(1)初期画面にて、画面右上の Get Started をクリックします。
https://openai.com/
(2)Create Your Account画面に遷移します。
Emailアドレスによる登録、Googleアカウントによる登録、マイクロソフトアカウントによる登録、AppleIDによる登録の4通りの方法があります。
2.1.1.Emailアドレスによる登録
・Create your Account画面にて、emailアドレスを入力して、Continueボタンをクリックします。
・Verify Your Email画面にてパスワードを入力して、Continueボタンをクリックします。
・以下のメールを受信したならば、"Verify email address"をクリックします。以下はoutlookのメール画面です。
・Email verified画面に自動遷移し、Emailが確認できたことが示されます。
・Tell us about you画面にて、このアカウントに紐づく名前と組織名(任意事項)と誕生日を入力して、Continueボタンをクリックします。
・Verify your phone number画面にて、このアカウントを検証するための携帯電話番号を入力して、Send Codeボタンをクリックします。すると、この携帯電話にSMS(ショートメッセージ)が来ますので、ショートメッセージ中のリンクをクリックして認証します。
・これにより、アカウントの登録は完了です。
2.1.2.Googleアカウントによる登録
Continue with Googleボタンをクリックすると、Googleにログイン画面に遷移します。ここで、選択するアカウントをクリックしてください。
・Tell us about you画面にて、このアカウントに紐づく名前と組織名(任意事項)と誕生日を入力して、Continueボタンをクリックします。
・Verify your phone number画面にて、このアカウントを検証するための携帯電話番号を入力して、Send Codeボタンをクリックします。すると、この携帯電話にSMS(ショートメッセージ)が来ます。
・Enter code画面にて、携帯電話のショートメッセージに書かれた6桁の番号を入力します。
・これにより、アカウントの登録は完了です。
2.1.3.マイクロソフトアカウントによる登録
・サインイン画面にて、アカウントを確認/入力して、次へボタンをクリックします。
・パスワードの入力画面にて、このアカウントのパスワードを入力します。
・Tell us about you画面にて、このアカウントに紐づく名前と組織名(任意事項)と誕生日を入力して、Continueボタンをクリックします。以下は上記と同様です。
2.1.4.AppleIDによる登録
・Continue with Appleをクリックすると、以下の画面に遷移します。
・この画面にて、AppleIDを入力します。
・AppleIDに紐づいた携帯電話にショートメッセージが飛びますので、ショートメッセージに記載された確認コードを入力します。
・「このプラウザを信頼しますか」画面にて、信頼するボタンをクリックします。
・「Appleでサインイン」画面にて、続けるボタンをクリックします。
・以下のアカウント作成画面にて、続けるボタンをクリックします。以降の登録方法は同様です。
2.2.API key の取得
・上記のOpenAIに登録したアカウントでログインすると、以下の画面が表示されます。ここでAPIを選択します。
・API画面の左側ののアカウントメニューから、View API keysをクリックします。
・API keys画面から、Create new secret keyボタンをクリックします。
・Create new secret keyダイアログで、テストキーを入力します。
・新しいAPIキーが生成されますので、記録しておきます。なお、この画面以外にキーを確認できる画面はありません。
・API keys画面では、APIキーを新規作成したり、削除するなどが可能です。
・なお、API Keyは、他人に知られないよう秘密に管理してください。APIを呼び出す度に費用が発生するためです。
2.3.API費用の支払い
APIを使う上では、所定の費用が必要です。以前は18ドルの無料枠があったようですが、2023年9月2日の時点では、無料枠はなくなっているようです。
・初期状態の残金額は $0.00 です。この状態ではAPIを呼び出すことができず、エラーとなります。
・法人(Company)なのか個人(Individual)なのかを選択します。
・クレジットカード情報を入力します。デフォルトでは 10ドル の支払いとなります。これにより OpenAI API を呼び出し可能となります。この費用で、ChatGPT4 (月額 20ドル)まで呼出可能となることを考えると安く感じます。
なお、各APIの呼び出し費用は以下に示されています。
2.4.APIの呼び出し
2.4.1.Windows 10上のcURL.exe による呼出
gpt-3.5-turbo による呼び出し
・gpt-3.5-turbo による呼び出し例です。ここでは、"tell me the height of Mt.Everest"と呼びかけるプロンプトを与えています。なお、APIキーのところには、上記手順で発行したAPIキーを記載してください。
curl https://api.openai.com/v1/chat/completions -H "Content-Type: application/json" -H "Authorization: Bearer APIキー" -d "{ \"model\": \"gpt-3.5-turbo\", \"messages\": [{\"role\": \"user\", \"content\": \"tell me the height of Mt.Everest\"}]}"
このAPIの応答jsonは以下です。回答は、"The height of Mount Everest is 8,848.86 meters (29,031.7 feet)." です。
{
"id": "chatcmpl-7uEAcU3U5Ct4ZEUjgXJ7o3Yg07Mi2",
"object": "chat.completion",
"created": 1693635194,
"model": "gpt-3.5-turbo-0613",
"choices": [
{
"index": 0,
"message": {
"role": "assistant",
"content": "The height of Mount Everest is 8,848.86 meters (29,031.7 feet)."
},
"finish_reason": "stop"
}
],
"usage": {
"prompt_tokens": 16,
"completion_tokens": 21,
"total_tokens": 37
}
}
なお、APIの費用を支払っていないときには、以下のようなjsonが返されます。
{
"error": {
"message": "You exceeded your current quota, please check your plan and billing details.",
"type": "insufficient_quota",
"param": null,
"code": "insufficient_quota"
}
}
text-davinci-003 による呼び出し
・以下 text-davinci-003 による呼び出し例です。ここでは、"特許を簡単に取得する方法を教えて"と呼びかけるプロンプトを与えています。なお、APIキーのところには、上記手順で発行したAPIキーを記載してください。
curl -i -X POST -H "Content-Type:application/json" -H "Authorization:Bearer APIキー" -d "{ \"model\": \"text-davinci-003\", \"prompt\": \"特許を簡単に取得する方法を教えて\", \"max_tokens\": 500, \"temperature\": 0}" https://api.openai.com/v1/completions
これに対する応答jsonです。回答は、「特許を取得するには、まず特許庁に特許申請を行う必要があります。特許申請には、特許を取得するために必要な書類や資料を提出する必要があります。特許庁は、申請者が提出した書類や資料を確認し、特許を取得するかどうかを決定します。特許庁が特許を取得することを承認した場合、特許が取得されます。」というものです。
なお、text-davinci-003の機械学習モデルは、2024年1月4日以降は使用てきなくなるようです。
{
"warning": "This model version is deprecated. Migrate before January 4, 2024 to avoid disruption of service. Learn more https://platform.openai.com/docs/deprecations",
"id": "cmpl-7uDZ75q6ti3ETg0tseSuWn1ld2Twp",
"object": "text_completion",
"created": 1693632869,
"model": "text-davinci-003",
"choices": [
{
"text": "ください\n\n特許を取得するには、まず特許庁に特許申請を行う必要があります。特許申請には、特許を取得するために必要な書類や資料を提出する必要があります。特許庁は、申請者が提出した書類や資料を確認し、特許を取得するかどうかを決定します。特許庁が特許を取得することを承認した場合、特許が取得されます。",
"index": 0,
"logprobs": null,
"finish_reason": "stop"
}
],
"usage": {
"prompt_tokens": 27,
"completion_tokens": 242,
"total_tokens": 269
}
}
2.4.2.Windows 10/chrome 上のTalend API Tester による呼出
ChromeのアドインであるTalend API Testerは、RestAPIのテストツールです。Chromeのウインドウ上で容易にテストできます。
gpt-3.5-turbo の呼び出し
・gpt-3.5-turbo の呼び出し例です。ここでは、"Hello, tell me the largest lake in the world"と呼びかけるプロンプトを与えています。
メソッド:POST
呼び出しURL:https://api.openai.com/v1/chat/completions
Headers:
Content-type : application/json
Authorization : Bearer APIキー
なお、Bearer の後には、上記手順で発行したAPIキーを記載してください。
Bodyには以下を設定します。
{
"model": "gpt-3.5-turbo",
"messages": [
{
"role": "system",
"content": "You are a helpful assistant."
},
{
"role": "user",
"content": "Hello, tell me the largest lake in the world"
}
]
}
・これに対する応答jsonです。回答は、"The largest lake in the world by surface area is the Caspian Sea, which is situated between Europe and Asia. It has a surface area of about 371,000 square kilometers (143,000 square miles)."です。
{
"id": "chatcmpl-7uE5PP1pEKIliKOkFGF3gKEvFvoW7",
"object": "chat.completion",
"created": 1693634871,
"model": "gpt-3.5-turbo-0613",
"choices": [
{
"index": 0,
"message": {
"role": "assistant",
"content": "The largest lake in the world by surface area is the Caspian Sea, which is situated between Europe and Asia. It has a surface area of about 371,000 square kilometers (143,000 square miles)."
},
"finish_reason": "stop"
}
],
"usage": {
"prompt_tokens": 27,
"completion_tokens": 44,
"total_tokens": 71
}
}
gpt-4 の呼び出し
・gpt-4 の呼び出し例です。ここでは、"特許明細書の明確性について教えてください。"と呼びかけるプロンプトを与えています。なお、Bearer の後には、上記手順で発行したAPIキーを記載してください。
メソッド:POST
呼び出しURL:https://api.openai.com/v1/chat/completions
Headers:
Content-type : application/json
Authorization : Bearer APIキー
なお、Bearer の後には、上記手順で発行したAPIキーを記載してください。
Bodyには以下を設定します。
{
"model": "gpt-4",
"messages": [
{
"role": "system",
"content": "あなたは有能な先生です"
},
{
"role": "user",
"content": "特許明細書の明確性について教えてください。"
}
]
}
・以下は、これに対する応答jsonです。回答は、"特許明細書の明確性は、特許法において極めて重要な要素の一つです。故意にあいまいにする場合もありますが、一般的には可能な限り詳細で明確に記述することが求められます。\n\n特許明細書の明確性とは、請求の範囲、詳細な説明、および図面、などの要素が、その発明の「何であるか」を明瞭にし、「どのように機能するか」を理解できるようにすることを意味します。これは、業界の専門家がその技術を理解し、実装できる程度に明確かつ具体的に書かれていなければならないという要件に関連しています。\n\n特許明細書の明確性の目的は二つあります。一つ目は、公共に対する公開性を保証すること、すなわち他の人がその特許情報を利用してさらに新しいアイデアを生み出すための基盤を提供することです。二つ目は、他人がその特許に侵害しないようにするため、特許の範囲が理解できるようにすることです。\n\nだからといって、細かすぎる説明は逆に理解を妨げる場合もあります。適切なバランスと視点で記述することが求められます。また、明確性は特許が認められるかどうかを判断する一因ともなるので注意が必要です。\n\n具体的な書き方や技巧については専門家に相談する等、適切なアドバイスを求めるのが最善です。"です。
{
"id": "chatcmpl-7tzC27ywchUABuFtH2FwW3lo2W4do",
"object": "chat.completion",
"created": 1693577622,
"model": "gpt-4-0613",
"choices": [
{
"index": 0,
"message": {
"role": "assistant",
"content": "特許明細書の明確性は、特許法において極めて重要な要素の一つです。故意にあいまいにする場合もありますが、一般的には可能な限り詳細で明確に記述することが求められます。\n\n特許明細書の明確性とは、請求の範囲、詳細な説明、および図面、などの要素が、その発明の「何であるか」を明瞭にし、「どのように機能するか」を理解できるようにすることを意味します。これは、業界の専門家がその技術を理解し、実装できる程度に明確かつ具体的に書かれていなければならないという要件に関連しています。\n\n特許明細書の明確性の目的は二つあります。一つ目は、公共に対する公開性を保証すること、すなわち他の人がその特許情報を利用してさらに新しいアイデアを生み出すための基盤を提供することです。二つ目は、他人がその特許に侵害しないようにするため、特許の範囲が理解できるようにすることです。\n\nだからといって、細かすぎる説明は逆に理解を妨げる場合もあります。適切なバランスと視点で記述することが求められます。また、明確性は特許が認められるかどうかを判断する一因ともなるので注意が必要です。\n\n具体的な書き方や技巧については専門家に相談する等、適切なアドバイスを求めるのが最善です。"
},
"finish_reason": "stop"
}
],
"usage": {
"prompt_tokens": 44,
"completion_tokens": 538,
"total_tokens": 582
}
}
DALL-E の呼び出し
・OpenAI社が提供する画像生成AIのDALL-E の呼び出し例です。ここでは、"A girl who has a umbrella"と呼びかけるプロンプトを与えています。なお、Bearer の後には、上記手順で発行したAPIキーを記載してください。
メソッド:POST
呼び出しURL:https://api.openai.com/v1/chat/completions
Headers:
Content-type : application/json
Authorization : Bearer APIキー
なお、Bearer の後には、上記手順で発行したAPIキーを記載してください。
Bodyには以下を設定します。
n は、画像の生成数を示します。
size は、画像の縦横サイズを示します。
{
"prompt": "A girl who has a umbrella",
"n": 1,
"size": "512x512"
}
・以下は、これに対する応答jsonです。json中に画像のURLが埋め込まれています。
{
"created": 1693644614,
"data":[
{
"url": "https://oaidalleapiprodscus.blob.core.windows.net/private/org-1gizimHLOt4DnMYxfwpX9Crp/user-5nEBjDM5jU7B046i7uAIHo7A/img-i2InKtqWijhva0fvGv9aWjpp.png?st=2023-09-02T07%3A50%3A14Z&se=2023-09-02T09%3A50%3A14Z&sp=r&sv=2021-08-06&sr=b&rscd=inline&rsct=image/png&skoid=6aaadede-4fb3-4698-a8f6-684d7786b067&sktid=a48cca56-e6da-484e-a814-9c849652bcb3&skt=2023-09-02T06%3A18%3A39Z&ske=2023-09-03T06%3A18%3A39Z&sks=b&skv=2021-08-06&sig=6cX4ijzHQ%2BAtXTUoCBwwJDW048i2EuzvuEDZ1lmA/p4%3D"
}
"black and white patent illustration that A girl who has a umbrella"と呼びかけるプロンプトに修正してみました。これならば、特許図面としてそのまま流用できそうてす。
更に"black and white patent illustration,office lady who are tapping smart-phone"と呼びかけるプロンプトに修正してみました。特許図面として違和感なさそうですがどうでしょうか。
3.おわりに
ここでは、OpenAIのChatGPT APIを、cURL.exe や Talend API Testerによって試用するまでの手順を確認しました。ChatGPT APIにより、任意のアプリケーションにテキスト生成AIの機能を組み込むことができ、ブラウザ上での使用の制限を無くすことが可能です。
ChatGPT APIは有償ですが、その費用は極めて廉価であり、ブラウザ上でChatGPT4 を使うより廉価な場合も多いと思います。この記事に基づき、ChatGPT APIが、広くに普及することを望みます。