精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

ChatGPT能否幫助FPGA設計彌補能力的缺失呢?

FPGA技術江湖 ? 來源:OpenFPGA ? 作者:碎碎思 ? 2023-03-25 15:07 ? 次閱讀

科技即生產力,最近,OpenAI 發布了 ChatGPT,在各大論壇和許多網站上受到了廣泛關注,ChatGPT是由 OpenAI 提出的大型預訓練語言模型,使用了許多深度學習技術,可以生成文本內容,也可以進行文本分類、問答等任務。這么強大的功能,自然會有很多人想著測試它的能力,讓它設計生成一些“代碼”或者“文章”來了解他的能力,而我注意到很少有人用 Verilog 去試試他的能力,所以今天我們去試一試,最后再看看它未來能為FPGA領域帶來什么。

810a4bca-cadb-11ed-bfe3-dac502259ad0.png

ChatGPT簡介

FPGA工程師在“軟件”方面能力基本都是比較欠缺的,比如一些腳本等,在這方面ChatGPT能否幫助我們彌補這些能力的缺失?

首先我們先簡單測試一下GPT的HDL編碼能力

下面是GPT給的例程:

GPT BEGIN

以下是一個簡單的流水燈程序:

moduleshift_register(
inputclk,
inputreset,
outputreg[7:0]led
);

reg[7:0]shift_reg;

initialbegin
shift_reg=8'h01;
end

always@(posedgeclk)begin
if(reset)begin
shift_reg<=?8'h01;
????end?else?begin
????????shift_reg?<=?{shift_reg[6:0],?shift_reg[7]};
????end
end

assign?led?=?shift_reg;

endmodule

該模塊包含一個8位移位寄存器,通過時鐘來推進并且每個周期將寄存器向左移動一位。模塊還包含一個復位信號,當復位信號為高時,寄存器將重新置為初始狀態,并從第二個LED燈開始閃爍。最后,將移位寄存器的輸出分配給LED燈。

GPT END

上面就是GPT生成的代碼,效果很好,基本功能實現,但是上面代碼不能綜合,有點小BUG,比較簡單,大家自己可以試著看看有什么問題。

接下來我們測試一個復雜的代碼:

GPT BEGIN

以下是一個簡單的Verilog代碼實現HDB3編碼器和解碼器。代碼假定輸入信號是一個序列,而不是一個單獨的位。

modulehdb3_encoder(inputclk,inputrst,input[7:0]data_in,outputreg[7:0]tx_out);

reg[3:0]polarity;
reg[3:0]zero_count;

always@(posedgeclk)begin
if(rst)begin
tx_out<=?8'b00000000;
????????polarity?<=?4'b0000;
????????zero_count?<=?4'b0000;
????end?else?begin
????????if?(data_in?==?8'b00000000)?begin
????????????zero_count?<=?zero_count?+?1;
????????????if?(zero_count?==?4)?begin
????????????????if?(polarity?==?4'b0011)?begin??//?Positive?pulse
????????????????????tx_out?<=?8'b00000010;
????????????????????polarity?<=?4'b1100;
????????????????end?else?begin??//?Negative?pulse
????????????????????tx_out?<=?8'b00000001;
????????????????????polarity?<=?4'b0011;
????????????????end
????????????????zero_count?<=?0;
????????????end?else?begin
????????????????tx_out?<=?8'b00000000;
????????????end
????????end?else?begin
????????????if?(data_in[7]?==?1)?begin??//?Ones?count?as?positive
????????????????if?(polarity?==?4'b1100)?begin??//?Positive?pulse
????????????????????tx_out?<=?8'b00000010;
????????????????????polarity?<=?4'b0011;
????????????????end?else?begin??//?No?pulse
????????????????????tx_out?<=?data_in;
????????????????????polarity?<=?polarity?+?1;
????????????????end
????????????????zero_count?<=?0;
????????????end?else?begin??//?Zeros?alternate
????????????????if?(polarity?==?4'b0011)?begin??//?Negative?pulse
????????????????????tx_out?<=?8'b00000001;
????????????????????polarity?<=?4'b1100;
????????????????end?else?begin??//?No?pulse
????????????????????tx_out?<=?data_in;
????????????????????polarity?<=?polarity?+?1;
????????????????end
????????????????zero_count?<=?0;
????????????end
????????end
????end
end

endmodule


module?hdb3_decoder(
input?clk,
input?rst,
input?[7:0]?rx_in,
output?reg?[7:0]?data_out,
output?reg?valid
);

reg?[3:0]?polarity;
reg?[3:0]?zero_count;

always?@(posedge?clk)?begin
????if?(rst)?begin
????????data_out?<=?8'b00000000;
????????polarity?<=?4'b0000;
????????zero_count?<=?4'b0000;
????????valid?<=?0;
????end?else?begin
????????if?(rx_in?==?8'b00000000)?begin
????????????zero_count?<=?zero_count?+?1;
????????????if?(zero_count?==?4)?begin
????????????????if?(polarity?==?4'b0011)?begin??//?Positive?pulse
????????????????????data_out?<=?8'b00000000;
????????????????????valid?<=?1;
????????????????end?else?if?(polarity?==?4'b1100)?begin??//?Negative?pulse
????????????????????data_out?<=?8'b00000000;
????????????????????valid?<=?1;
????????????????end
????????????????polarity?<=?4'b0000;
????????????????zero_count?<=?0;
????????????end?else?begin
????????????????data_out?<=?8'b00000000;
????????????????valid?<=?0;
????????????end
????????end?else?begin
????????????if?(rx_in?==?8'b00000010)?begin??//?Positive?pulse
????????????????data_out?<=?8'b00000000;
????????????????valid?<=?1;
????????????????polarity?<=?4'b0011;
????????????????zero_count?<=?0;
????????????end?else?if?(rx_in?==?8'b00000001)?begin??//?Negative?pulse
????????????????data_out?<=?8'b00000000;
????????????????valid?<=?1;
????????????????polarity?<=?4'b1100;
????????????????zero_count?<=?0;
????????????end?else?begin
????????????????data_out?<=?rx_in;
????????????????polarity?<=?polarity?+?1;
????????????????if?(polarity?==?4'b1111)
????????????????????polarity?<=?4'b0000;
????????????????zero_count?<=?0;
????????????????valid?<=?1;
????????????end
????????end
????end
end

endmodule

GPT END

對于剛接觸這個行業的人,上面的代碼足夠給初學者提供一個代碼思路,順著這個思路進行修改理解,很快就可以實現一個復雜一點的Verilog代碼。

我們在使用Vivado時候,TCL也是一個重要的腳本語言,需要我們熟練掌握,首先我們讓GPT給我們出一個無GUI創建工程的示例:

GPT BEGIN

以下是一個簡單的Vivado無GUI的TCL工程腳本示例:

#設置工程名和工作目錄
setproject_name"my_project"
setproject_dir"/path/to/project/dir"

#創建工程
create_project$project_name$project_dir-partxcku115-flvb2104-2-e-force

#添加源文件
add_files-norecurse/path/to/source/file1.v
add_files-norecurse/path/to/source/file2.v

#設置仿真模塊
set_propertysimulator_languageVerilog[current_project]
set_propertytop_modulemy_top_module[current_fileset]

#運行綜合
synth_design

#運行實現
implement_design

#導出比特文件
write_bitstream-force/path/to/bitstream_file.bit

這只是一個基本示例,實際的腳本可能需要更多的命令和參數來完成所需的操作。您可以參考Vivado的TCL命令參考手冊來學習更多使用方式。

GPT END

基本命令都是有的,每一個命令的中文注釋都有,真的方便極了。

此外,還嘗試了寫小作文,爬蟲等都是可以完成一個完整度較高的答案。

總的來說,ChatGPT 給我留下了深刻的印象,因為它可以生成和迭代代碼,就像正在與辦公室里的另一位工程師交談一樣。不過它的功能也有限。也就是說,它可以在幾分鐘內提供一個很好的開發起點和一個可行的框架。

由于GPT的中文訓練量遠遠不及英文的,所以在這方面會有一些欠缺,隨著發展的越來越快,以下是本人覺得的發展方向:

首先,ChatGPT可以作為一個問答機器人,對設計人員的問題進行回答。設計人員可以向ChatGPT提問關于FPGA的問題,比如FPGA的官方文檔、產品手冊、參考設計、IP核等內容,ChatGPT會根據用戶提問的問題提供最佳答案,同時在一些FPGA大廠進行訓練后的情景肯定完美。這對于剛剛接觸FPGA的設計人員來說,肯定是一個非常好的學習工具。

其次,ChatGPT可以協助設計人員進行設計驗證和測試。在設計過程中,由于各種器件互相影響,可能會出現很多問題,如電性能等。ChatGPT可以根據設計人員的需求,給出適當的方法和步驟,以協助驗證功能、測試性能和診斷問題。此功能可以幫助設計人員提高設計質量、加快設計速度,并避免出現故障。

第三,ChatGPT可以協助設計人員優化設計流程。設計FPGA需要計算資源和時間,設計人員需要花費大量時間來優化設計,例如電路拓撲、時序約束等。ChatGPT可以根據經驗、文獻和實踐,為設計人員提供優化建議,幫助提高設計效率和質量。

最后,ChatGPT還可以協助設計人員進行調試和維護工作。FPGA設計一旦完成,像其他電路一樣,也需要進行維護和調試工作,比如在更新版本或漏洞修復時。ChatGPT可以為設計人員提供有關這些方面的幫助,從而使他們更好地處理問題。

對于我們個人來說,其實用GPT作為自己的個人助手,平時用來記一些筆記、知識點,都是很完美的“容器”。

總之,ChatGPT作為一款人工智能聊天工具,將來能夠為FPGA設計人員提供許多便利。回答問題、協助設計驗證和測試、優化設計流程、協助調試和維護。這一切都可以幫助設計人員提高設計質量和效率,節省時間和成本。






審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA設計
    +關注

    關注

    9

    文章

    428

    瀏覽量

    26489
  • HDL
    HDL
    +關注

    關注

    8

    文章

    327

    瀏覽量

    47344
  • OpenAI
    +關注

    關注

    9

    文章

    1045

    瀏覽量

    6411
  • ChatGPT
    +關注

    關注

    29

    文章

    1549

    瀏覽量

    7506

原文標題:在FPGA設計中怎么應用ChatGPT?

文章出處:【微信號:HXSLH1010101010,微信公眾號:FPGA技術江湖】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    FPGA設計中怎么應用ChatGPT

    ,也可以進行文本分類、問答等任務。這么強大的功能,自然會有很多人想著測試它的能力,讓它設計生成一些“代碼”或者“文章”來了解他的能力,而我注意到很少有人用 Verilog 去試試他的能力,所以今天我們去試一試,最后再看看它未來能
    的頭像 發表于 03-14 10:03 ?1826次閱讀

    探索ChatGPT的信息抽取能力

    通過人工檢查ChatGPT的回復,發現ChatGPT傾向于識別比標注的跨度更長的sapn,以更接近人類的偏好。因此,之前的硬匹配(hard-matching)策略可能不適合如ChatGPT的LLM,所以本文提出了一種軟匹配(so
    的頭像 發表于 06-01 14:45 ?1127次閱讀
    探索<b class='flag-5'>ChatGPT</b>的信息抽取<b class='flag-5'>能力</b>

    ChatGPT炒熱GPU,ASIC和FPGA能否分一杯羹?

    有著不小需求的應用來說,ASIC和FPGA是否也能借上這股東風? ? 不同硬件的成本對比 ? 在機器學習推理場景中,除了GPU外,還有一大通用AI硬件適合這一負載,那就是FPGA。與GPU一樣,在技術和算法還未成熟且仍在打磨階
    的頭像 發表于 02-22 09:23 ?5882次閱讀

    【國產FPGA+OMAPL138開發板體驗】(原創)6.FPGA連接ChatGPT 4

    OMAP-L138(定點/浮點DSP C674x+ARM9)+ FPGA處理器的開發板。 編寫一個用于FPGA訪問ChatGPT 4的程序代碼是一個相當復雜的任務,涉及到硬件設計、網絡通信、數據處理等多個
    發表于 02-14 21:58

    FPGA設計中是否可以應用ChatGPT生成想要的程序

    當下AI人工智能崛起,很多開發領域都可看到ChatGPT的身影,FPGA設計中,是否也可以用ChatGPT輔助設計
    發表于 03-28 23:41

    OpenAI 深夜拋出王炸 “ChatGPT- 4o”, “她” 來了

    和情緒的選項 實時視頻捕捉,在與ChatGPT 交互時無需發送照片 有能力在會議和視頻通話中提供協助 發布會為其潛在影響提供了清晰的愿景。隨著企業駕馭不斷變化的技術領域,擁抱ChatGPT-4o對于實現持續增長和創新至關重要。
    發表于 05-27 15:43

    新手求幫助FPGA開發版上能否裝有ADDA集成芯片?市面上有沒有這樣的開發板?

    同題,FPGA開發版上能否裝有ADDA集成芯片?市面上有沒有這樣的開發板?求大神幫助
    發表于 10-16 09:10

    ARM在片上資源確定的情況下能否具備類似FPGA自由分配管腳功能的能力

    ARM在片上資源確定的情況下,能否具備類似FPGA自由分配管腳功能的能力?比如說集成UART的TX/RX可以分配到任意管腳,而并不是只能分配到指定的幾個管腳?謝謝
    發表于 08-01 14:17

    在IC設計/驗證中怎么應用ChatGPT

    好用,那么對于工程師群體應該幫助很大!按照官網的介紹,工程師們完全可以把所要實現的邏輯步驟用自然語言描述清楚,然后ChatGPT會翻譯出滿足相應要求的代碼進行實現。話不多說,如圖2直接上干貨進行測試!圖
    發表于 02-21 15:16

    科技大廠競逐AIGC,中國的ChatGPT在哪?

    來看,國內大模型開發廠商一是布局以大模型為基礎的通用對話、生成等能力;二是將其能力整合到搜索引擎、智能客服、智能音箱等產品線中;三是通過能力調用為中小企業滿足具體場景落地需求。”董曉飛說。 隨著
    發表于 03-03 14:28

    請問變頻器能否彌補異步電機的滑差?

    變頻器能否彌補異步電機的滑差?
    發表于 11-20 07:27

    10分鐘教你如何ChatGPT最詳細注冊教程

    ChatGPT 以其強大的信息整合和對話能力驚艷了全球,在自然語言處理上面表現出了驚人的能力。這么強大的工具我們都想體驗一下,那么? ChatGPT ?怎么用
    發表于 02-08 14:46 ?108次下載

    微信接入ChatGPT 利用ChatGPT的對話能力

      當前ChatGPT是一個爆火的項目,近來瀏覽 Github 的時候,發現一個好玩的項目:微信接入ChatGPT,利用ChatGPT的對話能力,實現微信的自動聊天回復。   在
    發表于 02-13 10:31 ?3次下載
    微信接入<b class='flag-5'>ChatGPT</b> 利用<b class='flag-5'>ChatGPT</b>的對話<b class='flag-5'>能力</b>

    ChatGPT處理文本分段任務的能力如何

    作為一個兼具分析&生成能力的AI,ChatGPT最近一段時間熱度都非常高,它的確顛覆了很多人的認知,它的出現一定程度上是強人工智能的出現。
    發表于 02-16 14:27 ?2270次閱讀

    ChatGPT軍事運用的幾個誤區

    判斷人與機器的區別,最經典的測試是圖靈測試。讓無關的第三人,從人與機器的對話中,能否準確區分于人與機器。如果把這一測試應于ChatGPT與人類之間,或許能夠騙過第三人,把機器看作人。可見,ChatGPT在自然語言處理方面的杰出
    的頭像 發表于 05-17 09:44 ?744次閱讀