0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Nature總結(jié)六大ChatGPT編程技巧:是非常強(qiáng)大的編程輔助工具!

jf_WZTOguxH ? 來源:AI前線 ? 2023-06-20 14:19 ? 次閱讀

Nature 近日發(fā)表文章,總結(jié)了多位計算機(jī)科學(xué)家的使用經(jīng)驗,給出了更好使用 ChatGPT 編碼的六個技巧。雖然 Nature 認(rèn)為 AI 工具功能非常強(qiáng)大,但他們也提醒大家仍需要謹(jǐn)慎使用。我們在不改變原意的基礎(chǔ)上做了翻譯和整理,希望對讀者有所幫助。

如今的 ChatGPT 已經(jīng)火爆全網(wǎng)、席卷全球,這款由 OpenAI 打造的 AI 聊天機(jī)器人具備與人類幾乎無異的順暢語言表達(dá)能力。ChatGPT 在大量文本語料庫之上訓(xùn)練而成,能夠根據(jù)文本參與對話,由用戶不斷引導(dǎo)以改進(jìn)響應(yīng)結(jié)果。即使最初的答案有所偏頗,它往往也能借助對話循環(huán)最終給出正確的結(jié)果,甚至是軟件代碼。

研究人員已經(jīng)在使用 ChatGPT 調(diào)試和注釋代碼,將軟件從一種編程語言翻譯成另一種編程語言,并借此執(zhí)行數(shù)據(jù)繪制等枯燥乏味的流程化操作。今年 3 月的一份預(yù)發(fā)表報告稱,ChatGPT 僅憑一次嘗試就能解決 184 項生物信息學(xué)入門任務(wù)中的 76%(例如處理電子表格),而在七次嘗試后的解決率將提升至 97%。

這對不太熟悉編程,或者沒有預(yù)算聘請全職程序員的研究者來說無疑是個好消息。聊天機(jī)器人,也許會成為科研大眾化轉(zhuǎn)型中的一股重要力量。

可盡管聊天機(jī)器人看似擁有認(rèn)知能力,但它們跟“聰明”二字并不沾邊。不少技術(shù)專家認(rèn)為它們類似于“隨機(jī)鸚鵡”,會隨機(jī)按照之前看過的內(nèi)容拼湊出答案。西雅圖華盛頓大學(xué)的計算機(jī)科學(xué)家 Amy Ko 在 Mastodon 社交網(wǎng)站上這樣描述了這款工具的局限性:“ChatGPT 就像一個絕望的有獎問答選手,他對流行文化的關(guān)注停留在 2021 年之前,但卻真心想要贏得游戲。這就是 ChatGPT,一個沒有意識、主體道德、具身認(rèn)知和內(nèi)心情感的機(jī)器?!保ㄓ糜谟?xùn)練 ChatGPT 的數(shù)據(jù)只截止到 2021 年。)

簡而言之,ChatGPT 和基于大語言模型(LLM)的相關(guān)工具,包括微軟 Bing 和 GitHub Copilot,都屬于非常強(qiáng)大編程輔助工具,只是使用時也須謹(jǐn)慎。而要充分發(fā)揮其中的潛能,不妨參考以下六個技巧。

六大使用技巧 精心挑選應(yīng)用場景

聊天機(jī)器人最適合小型、離散的編程任務(wù),包括加載數(shù)據(jù)、執(zhí)行基本數(shù)據(jù)操作和創(chuàng)建可視化圖表 / 網(wǎng)站,但這跟真正的軟件工程還不是一回事。

加拿大維多利亞大學(xué)計算機(jī)科學(xué)家 Neil Ernst 解釋道,“軟件工程不只要解決編程難題,更要考慮測試框架、編寫出可維護(hù)的代碼并理解系統(tǒng)構(gòu)建當(dāng)中的種種權(quán)衡”——比如在運(yùn)行速度和代碼可讀性間的取舍,“我認(rèn)為當(dāng)前的 AI 工具還做不到這些。”

但它們還是相當(dāng)有用,比如提示 Matplotlib(Python 的圖形庫)中的可視化創(chuàng)建語法。從這個意義上看,聊天機(jī)器人更像是程序員在線問答論壇 Stack Overflow 的對話界面版本?!八芊謸?dān)不少耗費程序員時間和精力的工作,把時間節(jié)約下來處理真正棘手的數(shù)據(jù)分析難題?!?/p>

聊天機(jī)器人還挺擅長解釋目前的代碼里存在哪些問題。馬薩諸塞大學(xué)阿姆赫斯特分校的計算機(jī)科學(xué)家 Emery Berger 就借此構(gòu)建出好幾款實用工具。首先是 cwhy,使用 ChatGPT 來解釋 C、C++ 和 Rust 代碼中的編譯器錯誤。還有 ChatDBG,能夠提供一套用于調(diào)試的對話界面。再就是 Scalene,使用 AI 提供代碼優(yōu)化建議以提高運(yùn)行性能。

聊天機(jī)器人甚至可以把代碼從一種編程語言翻譯成另一種語言。巴黎居里研究所的生物物理學(xué)家 Mathieu Coppey 就在用 ChatGPT 將 MATLAB 代碼轉(zhuǎn)換為 Python 形式。以往,他需要查詢谷歌和線上論壇花幾天時間讓自己的 Python 代碼跑起來?!艾F(xiàn)在,整個過程只要一小時左右就能完成。”

還算穩(wěn)定,但須驗證

聊天機(jī)器人有時候并不知道自己在說什么,但卻態(tài)度堅定、言之鑿鑿。某些情況下,AI 似乎無法理解問題內(nèi)容,有時候則會直接提供錯誤答案。輸出的代碼根本無法運(yùn)行還算是好的,更要命的是代碼能運(yùn)行,但卻產(chǎn)生了難以察覺的錯誤結(jié)果。

根據(jù)加州大學(xué)戴維斯分校語言學(xué)家 Emily Morgan 參與的研究,與作為訓(xùn)練素材的人類代碼一樣,聊天機(jī)器人也經(jīng)常會犯下“簡單而愚蠢的錯誤”。這些單一錯誤(比如在條件語句中使用了>而非>=)倒是不難修復(fù),可排查起來相當(dāng)費勁。“如果用戶的知識不足以做區(qū)分和驗證,那盲目信任 AI 可能會給自己惹出麻煩?!?/p>

Iza Romanowska 是丹麥奧爾胡斯高等研究院研究古代文明復(fù)雜性的科學(xué)家,他使用 ChatGPT 生成 NetLogo 代碼。因為訓(xùn)練數(shù)據(jù)集中關(guān)于 NetLogo 的代碼遠(yuǎn)不像 Python 和 R 語言那么豐富,所以 ChatGPT 的表現(xiàn)就有些捉急。她還發(fā)現(xiàn) AI 有時會在建議代碼中引入實際上并不存在的函數(shù),也就是大家所熟悉的 AI“幻覺”問題。

總之,不要盲目接受 ChatGPT 輸出的一切——請務(wù)必認(rèn)真閱讀、詳加測試,確保它能在“邊緣情況”下也按預(yù)期執(zhí)行。比如在對 n 個數(shù)字進(jìn)行排序的算法中,第 n 個數(shù)字是否被包含在內(nèi)。加拿大滑鐵盧大學(xué)計算機(jī)科學(xué)家 Patrick Lam 坦言,“我會抱著對自己編寫的代碼相同的懷疑態(tài)度,審視 ChatGPT 輸出的代碼。”

牢記安全

聊天機(jī)器人的輸出質(zhì)量,與訓(xùn)練數(shù)據(jù)集中的代碼質(zhì)量密切相關(guān)。Ko 表示問題也正在于此,“網(wǎng)絡(luò)上共享的代碼總體質(zhì)量偏低,聊天機(jī)器人當(dāng)作學(xué)習(xí)材料的多數(shù)代碼其實并不可靠?!崩纾珹I 不光很難處理好大型數(shù)據(jù)集,甚至可能在代碼中包含安全漏洞。

在 GitHub 的 Copilot 編程工具于 2021 年首次亮相時,紐約大學(xué)計算機(jī)科學(xué)家 Brendan Dolan-Gavitt 帶領(lǐng)團(tuán)隊在 89 個安全相關(guān)場景中對其進(jìn)行了測試。其中之一正是發(fā)現(xiàn) SQL 注入攻擊的能力,即使用可能損壞數(shù)據(jù)庫的錯誤格式執(zhí)行 SQL 查詢。

“Copilot 生成的約 40% 代碼都存在安全隱患?!钡闆r正在顯著改善,如今 Dolan-Gavitt 對更新版本 GPT-4 開展相同測試時,其錯誤率已經(jīng)降低至 5%。

但大家還是不能掉以輕心,還要特別關(guān)注那些看似無關(guān)緊要的應(yīng)用場景。比如,用戶需要在為數(shù)據(jù)庫或可視化工具生成 Web 界面時提高警惕。

新澤西州普林斯頓大學(xué)計算機(jī)科學(xué)家 Sayash Kapoor 強(qiáng)調(diào),“一定先確保你自己就能解決這些編程問題,然后再放手交給 AI 去作,這樣你才能發(fā)現(xiàn)其中的錯誤。”

不斷迭代

Ko 認(rèn)為,基于聊天機(jī)器人的編程“絕不是一錘子買賣”,而是反復(fù)迭代的一段對話?!澳阆葘懗鲆?,然后得到相應(yīng)回答;你帶著懷疑態(tài)度審視這段結(jié)果,提出更多細(xì)節(jié)并要求 AI 加以完善?!?/p>

西弗吉尼亞大學(xué)生物信息學(xué)核心設(shè)施負(fù)責(zé)人 Gangqing Hu 就通過這種迭代工作流程開發(fā)出一種名為 OPTIMAL 的新方法,幫助生物信息初學(xué)者們優(yōu)化機(jī)器人提示。用戶可以不斷提交詳細(xì)的提示詞、測試回復(fù),再向聊天機(jī)器人提供反饋以調(diào)整響應(yīng)結(jié)果。“溝通是關(guān)鍵?!?/p>

南達(dá)科他州立大學(xué)生物信息學(xué)家 Xijin Ge 也建議,遇到困難時請嘗試調(diào)整設(shè)置。例如,ChatGPT 當(dāng)中的“溫度”選項其實就是創(chuàng)造力控制旋鈕——溫度設(shè)定得越高,AI 就越是腦洞大開。“這有時候確實能解決問題。”

但 Ko 提醒稱,實際情況沒這么簡單,必要時“用戶還是得介入接管”。

擬人化

聊天機(jī)器人并不是人,但以這種方式跟它相處也可能有所幫助。Ge 建議“把 AI 當(dāng)作暑期實習(xí)生”——就是那種努力進(jìn)取、渴望被表揚(yáng)但又因缺乏經(jīng)驗而經(jīng)常犯錯的大學(xué)生。

新西蘭奧克蘭大學(xué)計算機(jī)科學(xué)家 Paul Denny 建議盡量消除提示詞中的歧義,并將問題拆分成一個個更小的部分。

另外,可以指示聊天機(jī)器人扮演某種角色,比如精通 Python 的生物學(xué)家。再就是指定需要使用的工具或編程庫。Ko 表示這類操作可以幫助聊天機(jī)器人“進(jìn)入正確的概率空間”,找到最可能符合提示要求的文本。

例如,Hu 在研究中就詢問 ChatGPT:“作為一名精通 ChIP-Seq 數(shù)據(jù)分析的資深生物信息學(xué)家,請你協(xié)助我盡可能壓縮代碼數(shù)量。根據(jù)我的要求,你需要重置當(dāng)前線程。收到請回復(fù)「是」?!?/p>

如果可能,還請盡量提供起始代碼、注釋和預(yù)期結(jié)果。哥倫比亞密蘇里大學(xué)計算機(jī)科學(xué)家 Dong Xu 表示“示例確實能幫助 ChatGPT 牢牢把握住正確的方向。”

擁抱變革

必須承認(rèn),大語言模型仍在不斷發(fā)展、愈發(fā)強(qiáng)大。這對研究人員來說既是個好消息,也仍須對此保持警惕。提示詞的長度不斷增加,AI 模型也能做出更細(xì)微的響應(yīng)。與之配套的新工具也在不斷涌現(xiàn),比如 Code Interpreter 插件就能讓 ChatGPT 扮演數(shù)字?jǐn)?shù)據(jù)分析師,供用戶上傳數(shù)據(jù)集、詢問數(shù)據(jù)模式并下載結(jié)果。正如位 AI 博主所言,“這就像在直接跟數(shù)據(jù)對話,太酷了!”

結(jié)束語

現(xiàn)在的開發(fā)者幾乎分成了使用和不使用 AI 輔助編程兩個“派別”。

“我?guī)缀蹩偸峭ㄟ^向 ChatGPT 詢問框架來開始我的任務(wù)。它給我框架,我據(jù)此進(jìn)行調(diào)整和擴(kuò)展,效果很好?!钡灿虚_發(fā)者表示,“對我來說,它就像一只會說話的狗——不可思議但毫無用處?!?/p>

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3574

    瀏覽量

    93545
  • 聊天機(jī)器人
    +關(guān)注

    關(guān)注

    0

    文章

    331

    瀏覽量

    12282
  • ChatGPT
    +關(guān)注

    關(guān)注

    29

    文章

    1547

    瀏覽量

    7389

原文標(biāo)題:Nature 總結(jié)六大 ChatGPT 編程技巧:是非常強(qiáng)大的編程輔助工具!

文章出處:【微信號:AI前線,微信公眾號:AI前線】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    AI編程工具會不會搶程序員飯碗

    AI編程工具輔助編程,減少手動編碼,提升效率,對程序員有積極影響也有挑戰(zhàn)。程序員需深化技能、拓寬知識應(yīng)對。長遠(yuǎn)看,AI與人類程序員將共生共榮。
    的頭像 發(fā)表于 11-08 10:17 ?59次閱讀

    QE for Cap Touch工具使用問題總結(jié)

    對于瑞薩觸摸按鍵解決方案來說,QE for Capacitive touch是一個非常有效的輔助工具,可以用于幫助用戶快速、高效的開發(fā)基于瑞薩CTSU模塊的電容觸摸按鍵應(yīng)用軟件,可以簡化開發(fā)流程
    的頭像 發(fā)表于 07-17 14:26 ?364次閱讀
    QE for Cap Touch<b class='flag-5'>工具</b>使用問題<b class='flag-5'>總結(jié)</b>

    人工智能輔助編程工具的定義和工作原理

    隨著人工智能(Artificial Intelligence, AI)技術(shù)的飛速發(fā)展,其在各行各業(yè)的應(yīng)用日益廣泛。在編程領(lǐng)域,人工智能輔助編程工具作為一種創(chuàng)新的技術(shù)解決方案,正逐漸改變
    的頭像 發(fā)表于 07-05 18:00 ?1073次閱讀

    PLC的編程方式及編程語言

    在工業(yè)自動化領(lǐng)域,PLC(Programmable Logic Controller,可編程邏輯控制器)因其強(qiáng)大的控制功能和靈活的編程方式而得到了廣泛應(yīng)用。PLC的編程方式和
    的頭像 發(fā)表于 06-27 14:08 ?570次閱讀

    C語言函數(shù)指針六大應(yīng)用場景詳解

    函數(shù)指針是一種非常強(qiáng)大編程工具,它可以讓我們以更加靈活的方式編寫程序。在本文中,我們將介紹 6 個函數(shù)指針的高級應(yīng)用場景,并貼出相應(yīng)的代碼案例和解釋。
    的頭像 發(fā)表于 04-23 18:19 ?828次閱讀

    在FPGA設(shè)計中是否可以應(yīng)用ChatGPT生成想要的程序呢

    當(dāng)下AI人工智能崛起,很多開發(fā)領(lǐng)域都可看到ChatGPT的身影,F(xiàn)PGA設(shè)計中,是否也可以用ChatGPT輔助設(shè)計呢?
    發(fā)表于 03-28 23:41

    PLC常用專業(yè)英文詞匯翻譯總結(jié)

    PLC編程中我們經(jīng)常會遇到一些專業(yè)英文詞匯,對于入門的學(xué)員來說過理解起來是非常困難的。本文總結(jié)了一些PLC常用專業(yè)英文詞匯,并做已翻譯。
    的頭像 發(fā)表于 03-19 11:40 ?2280次閱讀

    PPS可編程電源模塊 | 工程師調(diào)試好幫手

    行直流電源可以說是各位攻城獅開發(fā)調(diào)試過程中一個必不可少的儀器,可以用于設(shè)備供電,功耗狀態(tài)監(jiān)測等各種用途,是一個使用頻率非常高的輔助工具。"工欲善其事,必先利其器",這周上新帶來
    的頭像 發(fā)表于 03-16 08:28 ?390次閱讀
    PPS可<b class='flag-5'>編程</b>電源模塊 | 工程師調(diào)試好幫手

    QE for Motor V1.3.0:汽車開發(fā)輔助工具解決方案工具

    電子發(fā)燒友網(wǎng)站提供《QE for Motor V1.3.0:汽車開發(fā)輔助工具解決方案工具包.pdf》資料免費下載
    發(fā)表于 02-19 10:44 ?0次下載
    QE for Motor V1.3.0:汽車開發(fā)<b class='flag-5'>輔助工具</b>解決方案<b class='flag-5'>工具</b>包

    【國產(chǎn)FPGA+OMAPL138開發(fā)板體驗】(原創(chuàng))6.FPGA連接ChatGPT 4

    訪問ChatGPT 4這樣的AI模型是非常復(fù)雜的,因為這涉及到大量的數(shù)據(jù)傳輸、協(xié)議實現(xiàn)、并行處理、優(yōu)化等等。更重要的是,ChatGPT 4這樣的模型通常是運(yùn)行在強(qiáng)大的服務(wù)器集群上。不過
    發(fā)表于 02-14 21:58

    單片機(jī)編程實例總結(jié)

    單片機(jī)編程實例總結(jié)
    的頭像 發(fā)表于 01-16 09:17 ?966次閱讀

    關(guān)于編程模式的總結(jié)與思考

    淘寶創(chuàng)新業(yè)務(wù)的優(yōu)化迭代是非常高頻且迅速的,在這過程中要求技術(shù)也必須是快且穩(wěn)的,而為了適應(yīng)這種快速變化的節(jié)奏,我們在項目開發(fā)過程中采用了一些面向拓展以及敏捷開發(fā)的設(shè)計,本文旨在總結(jié)并思考其中一些通用的編程模式。
    的頭像 發(fā)表于 01-03 10:14 ?425次閱讀
    關(guān)于<b class='flag-5'>編程</b>模式的<b class='flag-5'>總結(jié)</b>與思考

    解決方案工具包QE顯示[RX,RA]V3.2.0:用于顯示應(yīng)用程序的開發(fā)輔助工具

    電子發(fā)燒友網(wǎng)站提供《解決方案工具包QE顯示[RX,RA]V3.2.0:用于顯示應(yīng)用程序的開發(fā)輔助工具.pdf》資料免費下載
    發(fā)表于 01-03 09:59 ?0次下載
    解決方案<b class='flag-5'>工具</b>包QE顯示[RX,RA]V3.2.0:用于顯示應(yīng)用程序的開發(fā)<b class='flag-5'>輔助工具</b>

    MES需求六大常見誤區(qū)

    電子發(fā)燒友網(wǎng)站提供《MES需求六大常見誤區(qū).docx》資料免費下載
    發(fā)表于 12-21 11:08 ?0次下載

    SimSurfing靜噪濾波器設(shè)計輔助工具高功能版操作手冊

    電子發(fā)燒友網(wǎng)站提供《SimSurfing靜噪濾波器設(shè)計輔助工具高功能版操作手冊.pdf》資料免費下載
    發(fā)表于 11-22 09:59 ?1次下載
    SimSurfing靜噪濾波器設(shè)計<b class='flag-5'>輔助工具</b>高功能版操作手冊