c語言fpga
① fpga和c語言速度比較
FPGA快。
微處理器用C,FPGA用HDL。論演算法實現速度,FPGA肯定比微處理器快多了,因為FPGA可以算準每一個時鍾周期的任務,而微處理器執行C程序可能會浪費很多時鍾周期。
② C程序和FPGA程序
這是兩個不同的概率,c語言程序是軟體程序,可以在做一直在運行。而fpga程序首先先從外部存儲設備裝載進來,然後經過布線就生產了實際的電路,所以它應該看成實際的電路。而生成了實際電路,你外部信號如何變化,對應的fpga就會有相應的反映,即你看成的程序運行。
③ C程序和FPGA程序
C語言是目前世界上流行、使用最廣泛的面向過程的高級程序設計語言。 C語言對操作系統和系統使用程序以及需要對硬體進行操作的場合,用C語言明顯優於其它高級語言,許多大型應用軟體都是用C語言編寫的。
C語言一共只有32個關鍵字,9種控制語句,程序書寫自由,主要用小寫字母表示。它把高級語言的基本結構和語句與低級語言的實用性結合起來。 C 語言可以象匯編語言一樣對位、位元組和地址進行操作, 而這三者是計算機最基本的工作單元。
運算符豐富
C的運算符包含的范圍很廣泛,共有種34個運算符。C語言把括弧、賦值、強制類型轉換等都作為運算符處理。從而使C的運算類型極其豐富表達式類型多樣化,靈活使用各種運算符可以實現在其它高級語言中難以實現的運算。
數據結構豐富
C的數據類型有:整型、實型、字元型、數組類型、指針類型、結構體類型、共用體類型等。能用來實現各種復雜的數據類型的運算。並引入了指針概念,使程序效率更高。另外C語言具有強大的圖形功能, 支持多種顯示器和驅動器。且計算功能、邏輯判斷功能強大。
FPGA(Field-Programmable Gate Array),即現場可編程門陣列,它是在PAL、GAL、CPLD等可編程器件的基礎上進一步發展的產物。它是作為專用集成電路(ASIC)領域中的一種半定製電路而出現的,既解決了定製電路的不足,又克服了原有可編程器件門電路數有限的缺點。
以硬體描述語言(Verilog或VHDL)所完成的電路設計,可以經過簡單的綜合與布局,快速的燒錄至 FPGA 上進行測試,是現代 IC設計驗證的技術主流。這些可編輯元件可以被用來實現一些基本的邏輯門電路(比如AND、OR、XOR、NOT)或者更復雜一些的組合功能比如解碼器或數學方程式。在大多數的FPGA裡面,這些可編輯的元件里也包含記憶元件例如觸發器(Flip-flop)或者其他更加完整的記憶塊。
系統設計師可以根據需要通過可編輯的連接把FPGA內部的邏輯塊連接起來,就好像一個電路試驗板被放在了一個晶元里。一個出廠後的成品FPGA的邏輯塊和連接可以按照設計者而改變,所以FPGA可以完成所需要的邏輯功能。
FPGA一般來說比ASIC(專用集成電路)的速度要慢,實現同樣的功能比ASIC電路面積要大。但是他們也有很多的優點比如可以快速成品,可以被修改來改正程序中的錯誤和更便宜的造價。廠商也可能會提供便宜的但是編輯能力差的FPGA。因為這些晶元有比較差的可編輯能力,所以這些設計的開發是在普通的FPGA上完成的,然後將設計轉移到一個類似於ASIC的晶元上。另外一種方法是用CPLD(Complex Programmable Logic Device,復雜可編程邏輯器件)。
④ FPGA的C語言建模
FPGA肯定不會用C做,畢竟概念完全不一樣,但現在有些類似C的HDL,比如systemC這種語言,其實更像C++,可以完成一些數字系統建模,主要是事件觸發,就是激勵和響應。
用systemC,完全看工程師個人愛好,不用也可以,verilog、systemverilog都可以做,只是效率不同而已。
寫過程序的都知道,無論是C、還是java等,都是順序程序語言,和FPGA開發用的HDL完全不是一個概念,如果牽涉到順序思維設計,在可以模擬的前提下,可以先用牽涉C的工具,比如openCV做視頻等,來模擬下,最後換成HDL在FPGA里實現,因為大量的順序處理,會讓FPGA設計難度加大。
⑤ 請問FPGA可以拿C語言寫嗎今天朋友拿的黑金的板子,用的好像是C語言
只要在FPGA中移植了nois核,相當於是CPU的一種東西,就可以使用其他的軟體語言。
C語言是一種軟體語言,需要CPU一條一條的執行。
VHDL全名Very-High-Speed Integrated Circuit HardwareDescription Language,這是一種硬體描述語言,根據EDA軟體綜合後會生成實實在在的電路,可以並行執行。
弊端的話應該是各有優劣的,C語言的好處是靈活,方便,編譯速度快。但是在嵌入式運行的時候可靠性和速度稍差。
硬體描述語言(VHDL)則相反,在嵌入式運行的時候可靠性和速度強,但是修改起來由於受到系統中時序的諸多限制修改需要考慮更多的問題,編譯速度也大受影響。
⑥ FPGA的編程語言跟C語言有什麼不同
學FPGA給我最大的體會就是它的編程語言是並行執行的,不像C語言那樣一行一行的執行。verilog裡面有個always語句,所有的always語句塊全部並發執行,而always語句塊內部是逐行執行的(前提是只是用阻塞賦值)。
verilog中沒有中斷的概念,而逐行執行指令的C語言卻離不開中斷。
學習verilog必須要掌握最基本的概念,像上面的阻塞賦值等等,新手都要經歷這一關的,呵呵。
還有,verilog是始終離不開硬體,c語言中可以不限制循環次數,而verilog就不行,因為每循環一次就會增加FPGA內部資源的佔用。
最後在說一點兒,verilog中有的語句不能被綜合(Oh,什麼是綜合?,網路吧),像定義浮點的float就不可以,在編程時慎用。
好啦就說這些吧。。