技術(shù)頻道

娓娓工業(yè)
您現(xiàn)在的位置: 中國傳動網(wǎng) > 技術(shù)頻道 > 技術(shù)百科 > 基于ARM+FPGA的嵌入式數(shù)控系統(tǒng)

基于ARM+FPGA的嵌入式數(shù)控系統(tǒng)

時間:2008-10-30 10:17:00來源:ronggang

導(dǎo)語:?本文針對現(xiàn)有CNC系統(tǒng)中存在的一些問題,提出了一種基于ARM+ FPGA結(jié)構(gòu)的嵌入式數(shù)控系統(tǒng),并采用μC/OS-Ⅱ?qū)崟r操作系統(tǒng),詳細(xì)介紹了這種系統(tǒng)的硬件結(jié)構(gòu)和軟件設(shè)計
摘 要:本文針對現(xiàn)有CNC系統(tǒng)中存在的一些問題,提出了一種基于ARM+ FPGA結(jié)構(gòu)的嵌入式數(shù)控系統(tǒng),并采用μC/OS-Ⅱ?qū)崟r操作系統(tǒng),詳細(xì)介紹了這種系統(tǒng)的硬件結(jié)構(gòu)和軟件設(shè)計。 關(guān)鍵詞:ARM FPGA 嵌入式數(shù)控系統(tǒng) μC/OS-Ⅱ
Embeded CNC System based on ARM and FPGA
Abstract:A kind of embeded CNC system based on ARM with the real-time operation system μC/OS-Ⅱ is proposed to resolve the problems of the current computer numerical control (CNC). The hardware structure and software design of this system is introduced. Keywords: ARM; FPGA; embedded CNC system; μC/OS-Ⅱ 1 引言   自從1952年第一臺數(shù)控機床問世以來,隨著計算機技術(shù)的不斷發(fā)展,數(shù)控系統(tǒng)經(jīng)歷了由硬件數(shù)控到計算機數(shù)控(CNC)的發(fā)展過程。起初的硬件數(shù)控系統(tǒng),零件程序的輸入、運算、插補及控制功能均由硬件完成。CNC系統(tǒng)采用計算機作為數(shù)控系統(tǒng)的核心部件,減少了硬件電路,提高了系統(tǒng)的通用性和可靠性。但是這類系統(tǒng)仍然存在一些問題,如資源浪費,操作系統(tǒng)實時性差,硬件結(jié)構(gòu)復(fù)雜等。   本文介紹了一種基于PC的“ARM+FPGA”結(jié)構(gòu)的嵌入式數(shù)控系統(tǒng)。該系統(tǒng)是針對小型、便攜式機床開發(fā)生產(chǎn)的新一代控制全數(shù)字步進電機的數(shù)控系統(tǒng)。上位機PC用于復(fù)雜加工代碼的編程,“ARM+FPGA”結(jié)構(gòu)控制系統(tǒng)則用于實現(xiàn)運動控制的功能。采用ARM開發(fā)數(shù)控系統(tǒng)可以降低硬件成本,增強穩(wěn)定性,提高系統(tǒng)的可擴展性。 2 系統(tǒng)硬件設(shè)計   2.1 硬件結(jié)構(gòu)   本系統(tǒng)的設(shè)計中,以PC機作為上位機,ARM+FPGA為控制核心。系統(tǒng)的硬件結(jié)構(gòu)如圖1。 [align=center] 圖1 系統(tǒng)硬件結(jié)構(gòu)[/align]   在上位PC機中,應(yīng)用CAD軟件產(chǎn)生加工G代碼,通過USB把程序代碼串行傳送到系統(tǒng)的SDRAM中,ARM從數(shù)據(jù)存儲器中讀取G代碼,進行譯碼,刀補運算,粗插補[1]。FPGA接收ARM的控制指令,讀取數(shù)據(jù),完成精插補功能,輸出對電機的控制脈沖。另外,為了實現(xiàn)上位PC機與控制器之間的高速數(shù)據(jù)交換,系統(tǒng)除了具有串口通訊功能外,還采用了USB接口通訊,用DMA方式和上位PC機進行數(shù)據(jù)同步交換,這種方式可以使系統(tǒng)獲得更高的通訊速度。該系統(tǒng)有3路脈沖直接驅(qū)動步進電機,最高頻率為4MHz。   2.2 芯片選擇   (1)ARM微處理器   本系統(tǒng)采用了SAMSUNG公司推出的16/32位RISC嵌入式微處理器S3C44B0X,其最大主頻為66MHz。S3C44B0X采用了ARM7TDMI核,0.25um工藝的CMOS標(biāo)準(zhǔn)宏單元和存儲編譯器,還提供了非常豐富的內(nèi)置部件,包括8K高速緩存器,外部存儲控制器,2通道通用DMA,2通道外設(shè)DMA,2通道帶有握手協(xié)議的UART,71個通用I/O口,8通道外部中斷源,8通道10位ADC以及具有PLL的片上時鐘發(fā)生器。通過提供豐富的片上資源,可以減少外圍電路,降低系統(tǒng)成本。另外,芯片還采用了低電壓技術(shù),運算速度很快,功耗很低,非常適合數(shù)控系統(tǒng)的設(shè)計。  ?。?)FPGA   FPGA(Field Programmable Gate Array)是在PAL、GAL等邏輯器件的基礎(chǔ)上發(fā)展起來的,是一種特殊的ASIC芯片,具有豐富的邏輯資源以及I/O引腳,用戶可以重新配置其內(nèi)部的邏輯模塊和I/O模塊,以實現(xiàn)用戶的邏輯。此外,F(xiàn)PGA還具有規(guī)模大、體積小、可靠性高等優(yōu)點,符合數(shù)控系統(tǒng)的設(shè)計要求。本系統(tǒng)采用Lattice公司的LFXP6C-3Q208C芯片來實現(xiàn)插補運算。在系統(tǒng)中,F(xiàn)PGA接受ARM和外部RAM送來的控制指令和數(shù)據(jù)信息執(zhí)行插補運算,產(chǎn)生控制步進電機運轉(zhuǎn)的脈沖序列,并通過接口將脈沖序列送到步進電機驅(qū)動器。另外FPGA與主軸編碼器相連接,能識別其輸出的信號并計數(shù),計數(shù)結(jié)果存放在寄存器中,供ARM讀取。FPGA還通過ULN2083AC芯片與I /O接口連接,執(zhí)行各種信號的轉(zhuǎn)換和隔離功能。圖2 是FPGA的外圍連接。 [align=center] 圖2 FPGA的外圍連接[/align]   2.3 脈沖輸出信號的連接方式   脈沖輸出信號的連接有差動方式和單端方式兩種,單端方式適用于早期一些脈沖和方向的陽極連在一起的步進驅(qū)動器,而不適用于某些脈沖和方向的陰極連在一起的步進驅(qū)動器。差動方式適用于脈沖和方向獨立輸入的步進驅(qū)動器和大多數(shù)伺服驅(qū)動器,能夠獲得較好的抗干擾性。本系統(tǒng)采用的是差動方式連接,圖3為其連接方式 。 [align=center] 圖3 脈沖輸出信號的差動連接[/align] 3 系統(tǒng)的軟件結(jié)構(gòu)   系統(tǒng)的軟件結(jié)構(gòu)主要分為兩部分:操作系統(tǒng)軟件和數(shù)控應(yīng)用軟件。由于數(shù)控系統(tǒng)是個實時多任務(wù)系統(tǒng),實時性要求很高,為保證各個任務(wù)的協(xié)調(diào)執(zhí)行,本系統(tǒng)采用了μC/OS-Ⅱ?qū)崟r操作系統(tǒng)作為軟件平臺。   3.1 μC/OS-Ⅱ簡介[2]   μC/OS-Ⅱ是一種源代碼公開的實時操作系統(tǒng),是搶先式的內(nèi)核,在運行就緒條件下總是讓級別最高的任務(wù)優(yōu)先執(zhí)行,它還是一個多任務(wù)管理系統(tǒng),可管理64個任務(wù),其中8個保留給系統(tǒng),用戶任務(wù)最多可達(dá)56個,并且每個任務(wù)由自己獨立的??臻g。μC/OS-Ⅱ的大部分源代碼是用C語言編寫的,僅與微處理器相關(guān)部分使用匯編語言,因此具有很強的移植性。但是,由于μC/OS-Ⅱ在讀寫處理器、寄存器時只能通過匯編語言來實現(xiàn),所以需要用匯編語言完成一些與處理器相關(guān)的代碼。   3.2 μC/OS-Ⅱ的移植   要實現(xiàn)該操作系統(tǒng)在S3C44B0X微處理器平臺上的正常運行,需要修改與處理器類型有關(guān)部分的代碼[3],下面簡單的介紹了需要修改的相關(guān)文件:  ?。?)修改OS_CPU.H文件:包括定義數(shù)據(jù)類型及與處理器相關(guān)的基本信息。  ?。?)修改OS_CPU_C.C文件:編寫初始化任務(wù)的堆棧結(jié)構(gòu)函數(shù)OSTaskStkInit(),該函數(shù)由任務(wù)創(chuàng)建函數(shù)OSTaskCreate()或OSTaskCreateEXT()調(diào)用。例如創(chuàng)建一個插補任務(wù)為:   OSTaskCreate(InterpTask,(void*)0,(void*)&InterpTask_Stack\[STACKSIZE-1\],   InterpTask_Pri)。另外還必須聲明5個函數(shù):建立任務(wù)函數(shù)OSTaskCreateHook()、刪除任務(wù)函數(shù)OSTaskDelHook()、任務(wù)切換函數(shù)OSTaskSwHook()、產(chǎn)生時鐘節(jié)拍得函數(shù)OSTimeTickHook()和統(tǒng)計功能函數(shù)OSTimeTickHook()。  ?。?)修改OS_CPU_A.ASM文件:編寫4個與處理器相關(guān)的匯編語言函數(shù)OSStartHighRdy()、OSCtxSw()、OSIntCtxSw()、OSTickISR()。   3.3 數(shù)控系統(tǒng)的應(yīng)用軟件設(shè)計   根據(jù)數(shù)控系統(tǒng)所要實現(xiàn)的功能,可以將系統(tǒng)的應(yīng)用軟件主要分為幾個模塊:人機界面模塊、數(shù)據(jù)處理模塊、插補模塊。其中人機界面模塊的任務(wù)由PC機完成,包括數(shù)控代碼的編輯,加工過程中相關(guān)參數(shù)的設(shè)置,刀補參數(shù)的設(shè)置等[4]。  ?。?)數(shù)據(jù)處理模塊   數(shù)據(jù)處理模塊主要完成譯碼和刀具補償功能。譯碼就是將數(shù)控代碼的各種工件輪廓信息(如起點、直線或圓弧等)、加工速度F和其它輔助信息(M、S、T)按一定規(guī)律翻譯成系統(tǒng)能識別的數(shù)據(jù)形式。由于編制零件加工程序時,一般只考慮零件的輪廓外形,而實際切削控制時,是以刀具中心為控制中心的,所以經(jīng)過譯碼得到的數(shù)據(jù)不能直接由插補程序使用,必須經(jīng)過軌跡計算,進行刀具長度補償和刀具半徑補償,才能轉(zhuǎn)換為插補所需要的參數(shù)。  ?。?)插補模塊   數(shù)控系統(tǒng)的核心任務(wù)是插補,插補計算的精度影響到整個數(shù)控系統(tǒng)的精度。插補任務(wù)就是按照進給速度的要求,由譯碼得到的數(shù)據(jù)信息計算出零件輪廓起點和終點之間若干中間點的坐標(biāo)值,并轉(zhuǎn)化為脈沖數(shù)據(jù)送入步進驅(qū)動器。本系統(tǒng)采用了脈沖增量插補,脈沖輸出的頻率誤差小于0.1%。其脈沖輸出可用單脈沖(脈沖+方向)或雙脈沖(脈沖+脈沖)方式??梢詫崿F(xiàn)任意2-3軸直線、任意2軸圓弧插補,連續(xù)插補功能。 [align=center] 圖4 逐點比較法第一象限直線插補軟件流程圖[/align]   下面以第一象限直線插補為例,圖4為逐點比較法第一象限直線插補軟件流程圖。其中,(xe,ye)為直線的終點坐標(biāo),F(xiàn)為每一步直線插補運算后的偏差值。當(dāng)F≥0時,加工點在加工直線上或在直線上方,則向x軸正向產(chǎn)生一個脈沖,由步進電機驅(qū)動器驅(qū)動x軸步進電機正向進給一個步進角,并計算出新的偏差F=F-ye;當(dāng)F<0時,加工點位于直線下方,則向y軸正向產(chǎn)生一個脈沖,由步進電機驅(qū)動器驅(qū)動y軸步進電機正向進給一個步進角,并計算出新的偏差F=F+xe。n為終點判別,當(dāng)?shù)毒叩竭_(dá)終點時,停止插補。本系統(tǒng)采用VHDL語言編寫算法實現(xiàn)插補,如下為部分代碼:   ARCHITECTURE connect OF chabu IS   BEGIN   VERIABLE F:INTEGER:=0;   n:INTEGER:=ABS(xe)+ABS(ye);   xi,yi:INTEGER //(xi,yi)為插補運算過程中刀具的加工點坐標(biāo)   PROCESS(reset) //reset是復(fù)位信號,插補開始后對偏差值F和(xi,yi)清零, BEGIN 使刀具回到坐標(biāo)原點   F=0;   ……   END PROCESS;   PROCESS(clk) //clk是時鐘控制信號,當(dāng)clk上升沿到來時進行插補運算的處理   BEGIN   WHILE(n>0)LOOP   IF(F>=0)THEN   cqx=1; //cqx,cqy為x軸和y軸的輸出脈沖信號   cqy=0;   F=F-ye;   n=n-1;   ELSE   ……   END IF;   END LOOP;   END PROCESS;   END connect;   3.4 系統(tǒng)中數(shù)據(jù)信息的交換   在數(shù)控加工時,CNC系統(tǒng)各模塊之間需要傳遞大量的數(shù)據(jù)信息,主要通過各種緩沖存儲區(qū)實現(xiàn)該功能,如圖5為數(shù)據(jù)信息的交換過程。首先讀入數(shù)控加工程序到數(shù)控加工程序緩沖器,從中逐個讀入字符,經(jīng)譯碼處理送到譯碼結(jié)果緩沖器,再經(jīng)一系列插補準(zhǔn)備(包括刀補計算和速度處理),送到插補緩沖器中,插補程序執(zhí)行插補運算時,把插補緩沖存儲區(qū)的內(nèi)容讀入到插補工作存儲區(qū),然后用插補工作區(qū)的數(shù)據(jù)進行插補計算,并將結(jié)果送到插補輸出寄存器。 [align=center] 圖5 數(shù)據(jù)信息的交換[/align] 4 結(jié)論   嵌入式數(shù)控系統(tǒng)采用ARM和FPGA硬件平臺,減少了系統(tǒng)的外圍器件,具有體積小,性價比高,穩(wěn)定性好等優(yōu)點。并且利用μC/OS-Ⅱ?qū)崟r操作系統(tǒng)作為開發(fā)工具,使數(shù)控系統(tǒng)具有優(yōu)異的實時性,滿足了高速度、高精度的加工要求,很好的解決了傳統(tǒng)CNC系統(tǒng)中存在的問題。由此,嵌入式數(shù)控系統(tǒng)具有廣闊的發(fā)展前景。 參考文獻:   [1]劉艷霞,李淑芬.基于ARM的嵌入式數(shù)控系統(tǒng)[J].微計算機信息.2006,22(35):90-91,96   [2]Labrosse Jean J.邵貝貝譯,嵌入式實時操作系統(tǒng)μC/OS-Ⅱ[M].2版.北京:中國電力出版社.2003   [3]王曉鳴,王樹新,張宏偉.實時操作系統(tǒng)μC/OS-Ⅱ在ARM上的移植[J].機電一體化.2007,(1):56-58   [4]楊代華,陳志輝.基于實時操作系統(tǒng)μC/OS-Ⅱ的數(shù)控系統(tǒng)研制[J].制造技術(shù)與機床.2007,(12):21-23 作者簡介:   第一作者:朱曉潔(1983-),女,江蘇無錫人,碩士研究生,主要研究方向:數(shù)控系統(tǒng)。   通信地址:南京新模范馬路5號南京工業(yè)大學(xué)丁家橋校區(qū)119#信箱   郵編:210009 電話:13675122764   E-mail:stream_xu@126.com   第二作者:舒志兵(1965-),男,江蘇南京人,南京工業(yè)大學(xué)運動控制研究所所長,主要研究方向:交流伺服系統(tǒng)、DSP技術(shù)、現(xiàn)場總線、數(shù)控系統(tǒng)、運動控制、機電一體化系統(tǒng)等。   E-mail:shuzhibing@163.com

標(biāo)簽:

點贊

分享到:

上一篇:高速工業(yè)平縫機轉(zhuǎn)速測量方法研究

下一篇:微能WIN-V63矢量控制變頻器在...

中國傳動網(wǎng)版權(quán)與免責(zé)聲明:凡本網(wǎng)注明[來源:中國傳動網(wǎng)]的所有文字、圖片、音視和視頻文件,版權(quán)均為中國傳動網(wǎng)(m.u63ivq3.com)獨家所有。如需轉(zhuǎn)載請與0755-82949061聯(lián)系。任何媒體、網(wǎng)站或個人轉(zhuǎn)載使用時須注明來源“中國傳動網(wǎng)”,違反者本網(wǎng)將追究其法律責(zé)任。

本網(wǎng)轉(zhuǎn)載并注明其他來源的稿件,均來自互聯(lián)網(wǎng)或業(yè)內(nèi)投稿人士,版權(quán)屬于原版權(quán)人。轉(zhuǎn)載請保留稿件來源及作者,禁止擅自篡改,違者自負(fù)版權(quán)法律責(zé)任。

網(wǎng)站簡介|會員服務(wù)|聯(lián)系方式|幫助信息|版權(quán)信息|網(wǎng)站地圖|友情鏈接|法律支持|意見反饋|sitemap

傳動網(wǎng)-工業(yè)自動化與智能制造的全媒體“互聯(lián)網(wǎng)+”創(chuàng)新服務(wù)平臺

網(wǎng)站客服服務(wù)咨詢采購咨詢媒體合作

Chuandong.com Copyright ?2005 - 2024 ,All Rights Reserved 深圳市奧美大唐廣告有限公司 版權(quán)所有
粵ICP備 14004826號 | 營業(yè)執(zhí)照證書 | 不良信息舉報中心 | 粵公網(wǎng)安備 44030402000946號