了解云原生 JuiceFS 如何賦能量化對沖基金以增強 AI 訓練并在云端實現彈性吞吐。
這不是編程或 ChatGPT API 集成教程,這些是使用 ChatGPT API 時需要牢記的一些關鍵思想和要點。
大型語言模型為您的軟件產品提供前所未有的功能。作為開發人員,學習這項技術并將其集成到我們的項目中至關重要。像 OpenAI 這樣的平臺提供了與這些模型交互的 API,我們可以利用它來增強我們的軟件。
最近,我完成了一門引人入勝的課程,“面向開發人員的 ChatGPT 提示工程”。我學習了一些令人難以置信的技術來充分利用 OpenAI 的 ChatGPT API,我很樂意在這篇文章中與您分享這些見解。
準則
與 ChatGPT 交互時,清晰度至關重要。以下是一些有用的策略:
- 單獨的指令和輸入文本:這使您可以使用各種輸入來測試您的指令。例如,如果您要求 ChatGPT 總結一篇文章,請將“總結以下文章:”指令與文章文本本身分開。
- 使用定界符:它們有助于指定指令和輸入之間的界限,減少提示注入的可能性。冒號或換行符可以作為簡單但有效的分隔符。
- 請求結構化輸出:如果您需要以編程方式解析 ChatGPT 的響應,請要求它以特定方式構建其輸出。例如,您可能會要求“將以下文本中的關鍵點列為要點:”。
- 檢查輸入條件:為減少模型產生不相關或不準確響應(稱為“幻覺”的現象)的機會,請指定輸入必須滿足的任何條件。例如,“如果文本包含日期,請提供該日期是星期幾。”
- Few-Shots Prompting:如果可能,提供一些所需輸入輸出模式的示例可以指導模型產生類似的結果。
迭代提示開發
使用 ChatGPT 制作完美的提示確實是一個迭代過程,它需要對目標有敏銳的理解,并且愿意嘗試和學習。
讓我們將其分解為可操作的步驟:
- 定義目標:快速制作的第一步是清楚地了解所需的輸出。問問自己,您希望 ChatGPT 生成什么?例如,如果您的目標是從文本中提取關鍵點,那么您的目標就是列出輸入文本中的主要思想。
- 編寫初始提示:根據您的目標,編寫初始提示。提示是給 ChatGPT 的命令或問題,以指導其響應。對于上述目標,初始提示可以是“在以下文本中列出主要思想:”。
- 測試提示:現在,是時候測試提示了。通過模型運行它,看看你得到什么樣的輸出。符合你的目標嗎?如果沒有,是時候迭代了。
- 分析輸出:分析模型的輸出。響應的哪些方面符合您的目標,哪些部分偏離目標?這將為您提供有關如何調整提示的線索。
- 優化提示:根據您的分析,調整您的提示。例如,如果模型沒有完全按照您的預期捕捉主要思想,您可以將提示細化為更具體,例如“將以下文本總結為要點:”。
- 重復該過程:繼續測試、分析和完善您的提示,直到它始終如一地生成所需的輸出。請記住,這是一個迭代過程。可能需要幾輪改進才能使其恰到好處。
- 概括提示:一旦你有一個適用于特定案例的提示,請嘗試將其概括為其他類似案例。這意味著使用各種輸入文本測試提示以確保它適用于廣泛的場景。
總結
摘要是 ChatGPT API 的一個強大用例,但了解如何有效使用它至關重要。以下是一些準則:
- 定義目的:如果要以特定方式使用摘要,請確保在說明中明確說明。
- 保持專注:如果需要,讓模型專注于輸入的特定部分。例如,如果您只對商業報告的財務方面感興趣,您可能會問,“總結以下報告中的財務信息:”。
- 提取而不是總結:在某些情況下,提取關鍵信息而不是總結可能更有用。例如,您可以提示“列出以下文本中提到的所有人的姓名:”。
推理
ChatGPT 還可以從文本中推斷出見解,執行情感分析、分類、分類和標記等任務。以下是您可以利用此功能的一些方法:
- 多任務:您可以要求模型在同一指令中執行多個任務,并以特定格式生成輸出。例如,“分析以下評論的情緒并將其分類為正面、負面或中性:”。
- 測試多個示例:在一組輸入上運行良好的提示可能在其他輸入上表現不佳。為確保您的指令在廣泛的輸入范圍內都能正常工作,請使用各種示例對其進行測試。
- 包含您自己的標簽:如果您有一組預定義的類別,您可以將它們包含在指令中,并要求模型為給定的輸入選擇最相關的類別。例如,“將以下文本歸入以下類別之一:技術、環境、政治或文化:”。
轉型
ChatGPT 還能夠執行各種文本轉換,包括語言翻譯和格式轉換。
- 語言識別和翻譯:您可以要求模型識別輸入文本的語言,或將其翻譯成另一種語言。例如,“將以下西班牙語文本翻譯成英語:”。
- 語氣轉換:您可以將輸入文本轉換為不同的語氣,例如正式、隨意或對話。例如,“用隨意的語氣重寫以下正式文本:”。
- 格式轉換:該模型可以將文本從一種格式轉換為另一種格式,例如從 JSON 到 html 或從 CSV 到 JSON。例如,“將以下 JSON 數據轉換為 HTML 表格格式:”。
- 校對:您可以要求模型校對文本,對語法、標點符號和拼寫進行更正。例如,“校對并更正以下文本中的任何錯誤:”。
擴展
ChatGPT 還可以將簡短的輸入文本擴展為更長、更詳細的文章,例如博客文章、文章或電子郵件回復。這里有一些要考慮的事情:
- 提供上下文:如果在特定上下文中使用輸出,請確保在提示中提供該上下文。例如,“寫回復以下郵件,對發件人的建議表示感謝并同意實施:”。
- 披露 AI 參與:如果將輸出傳達給用戶,建議披露它是 AI 生成的以保持透明度。
- 調整溫度:溫度參數控制模型的創造力。較低的溫度(接近 0)使模型的輸出更具確定性,而較高的溫度(接近 1)允許更具創造性的響應。
開發聊天機器人
您可以使用 ChatGPT 創建具有特定行為的聊天機器人:
- 設置角色:使用“系統”角色來構建對話。此消息告訴模型它應該如何響應“用戶”消息。例如,“你是一個樂于助人的助手,總是提供詳細的答復:”。
- 提供用戶上下文:在初始用戶消息中包括用戶的姓名、詳細信息和任何其他相關上下文。例如,“用戶是一名初級程序員,尋求有關 Python/ target=_blank class=infotextkey>Python 語法錯誤的幫助:”。
- 請記住該模型的局限性:ChatGPT 模型無法記住之前的交互,因此您每次發出請求時都必須提供之前的消息。例如,如果用戶在之前的消息中問了一個問題,如果它與正在進行的對話相關,則在下一個請求中包含該消息。
- 控制熱度:對于旨在呈現給用戶的輸出,您可以使用更高的熱度來獲得更不可預測的響應。對于打算以編程方式解析的輸出,使用較低的熱度以獲得更可靠的結果。
了解這些提示工程概念可以顯著改善您與 ChatGPT API 的交互,使您的應用程序更加有效和用戶友好。