Ⅰ 加工中心宏程序
一、變數
1、變數的表示
FANUC系統使用「#」表示變數,例如:#1、#100等。變數根據變數號可以分成四種類型,見下表。
變數號 變數類型 功能
#0 空變數 該變數總是空,任何值都不能賦給該變數
#1~#33
局部變數 局部變數只能用在宏程序中存儲數據,例如,運算結果。當斷電時,局部變數被初始化為空。調用宏程序時,自變數對局部變數賦值
#100~#109
#500~#999 公共變數 公共變數在不同的宏程序中的意義相同。當斷電時,變數#500~#999的數據保存,即使斷電也不會丟失
#1000以上 系統變數 系統變數用於讀寫CNC運行時的各種數據,例如,刀具當前位置和補償
2、關於變數的說明
(1)變數引用時,為在程序中使用變數值,指定後跟變數號的地址。當用表達式指定變數時,要把表達式放在括弧中,例如,GO X[#1+#2]F#3。式中X後的坐標什即是由#1、#2這兩個變數組成的表達式來表示。
(2)表達式可以用於指定變數號。此時,表達式必須封閉在括弧中,例如,#[#1+#2-12]。
注意:
1) 宏程序中,方括弧用於封閉表達式,圓括弧只表示注釋內容,使用變數時必須注意,FANUC系統通過參數來切換圓括弧和方括弧。
2) 表達式可以表示變數號和變數。這兩者並不一樣,例如,X#[#1+#2]並不等於X[#1+#2]。
3) 當在程序中定義變數時,小數點可以省略。例如,當定義#1=123;變數#1的實際值是123.000。
4) 被引用變數的值根據地址的最小設定單位自動舍入。例如:G00X #1。
5) 改變引用的變數值的符號,要把負號放在「#」的前面。例如:G00X-#1。
6) 當變數值未定義時,這樣的變數成為「空」變數。當引用未定義的變數時,變數及地址字都被忽略。例如,當變數#1的值是0,並且變數#2的值是空時,G00X#1Z#2的執行結果為G00X0。
7) 變數#0總是空變數。它不能寫,只能讀。
二、變數的運算
1、算術、邏輯運算和運算符(見下表)
功能 格式 備注
定義 #i=#j
加法 #i=#j+#k
減法 #i=#j-#k
乘法 #i=#j*#k
除法 #i=#j/#k
正弦 #i=SIN[#j] 角度以度指定。90°30』表示90.5°
反正弦 #i=ASIN[#j]
餘弦 #i=COS[#j]
反餘弦 #i=ACOS[#j]
正切 #i=TAN[#j]
反正切 #i=ATAN[#j]/[#k]
平方根 #i=SQRT[#j]
絕對值 #i=ABS[#j]
舍入 #i=ROUND[#j]
上取整 #i=FUP[#j]
下取整 #i=FIX[#j]
自然對數 #i=LN[#j]
指數函數 #i=EXP[#j]
或 #i=#jOR#k 邏輯運算一位一位地按二進制數執行
異或 #i=#jXOR#k
與 #i=#jEXP#k
從BCD轉為BIN #i=BIN[#j] 用於與PMC的信號交換
從BIN轉為BCD #i=BCD[#j]
2、關於運算符的說明
(1)角度單位
函數SIN、COS、ASIN、ACOS、TAN和ATAN的角度單位是度(°)
(2)上取整和下取整
CNC處理數值運算時,若操作後產生的整數絕對大於原數的絕對值時為上取整;若小於原數的絕對值為下取整。對於負數的處理應小心。
例如:假定#1=1.2,並且#2=-1.2。
當執行#3=FUP[#1]時,2.0賦給#3。
當執行#3=FIX[#1]時,1.0賦給#3。
當執行#3=FUP[#2]時 ,-2.0賦給#3。
當執行#3=FIX[#2]時,-1.0賦給#3。
(3)運算符的優先順序
按優先的先後順序依次是函數→乘和除運算(*、∕、AND、MOD)→加和減運算(+、﹣、OR、XOR)。
(4)括弧嵌套
括弧用於改變運算優先順序。括弧最多可以嵌套使用5級,包括函數內部使用的括弧。
三、功能語句
1、無條件轉移(GOTO)語句——轉移到有順序號n的程序段
格式:
GOTOn ;n指行號
例如:
GOTO1 轉移至第一行
GOTO#10 轉移至變數#10所決定的行
2、運算符(見下表)
運算符 含義 運算符 含義
EQ 等於(=) GE 大於或等於(≥)
NE 不等於(≠) LT 小於(<)
GT 大於(>) LE 小於或等於(≤)
3、條件轉移(IF)語句
(1)IF[表達式] GOTOn
說明:如果指定的條件表達式滿足時,轉移到標有順序號n的程序段;如果指定的條件表達式不32滿足時,則執行下一個程序段。
(2)IF[表達式]THEN
說明:如果表達式滿足,執行預先決定的宏程序語句,且只執行一個宏程序語句。例如,條件語句IF[#1EQ#2]THEN#3=0表示如果#1和#2的值相同,0賦給#3。
4、循環功能(WHILE)語句
格式:WHILE[表達式]DOm ;(m=1,2,3)
……
ENDm
說明:在WHILE後指定一個條件表達式,當指定條件滿足時,執行從DO到END之間的程序;否則,轉到END後的程序段。
提示:通過上述介紹,完全可以藉助系統提供的二次開發功能定製出個性化的宏程序,例如,可以將例4—23中刀具軌跡路徑定製在宏程序中,然後通過G65方式或直接用G代碼調用.常見結構的宏程序定製是有效提高編程效率的手段之一.
Ⅱ 「宏程序」是什麼意思
大家都在問宏程序~其實說起來宏就是用公式來加工零件的,比如說橢圓,如果沒有宏的話,我們要逐點算出曲線上的點,然後慢慢來用直線逼近,如果是個光潔度要求很高的工件的話,那麼需要計算很多的點,可是應用了宏後,我們把橢圓公式輸入到系統中然後旦察段我們給出Z坐標並且每沒螞次加10um那麼宏就會自動算出X坐標並且進行切削,實際上宏在程序中主要起到的是運算作用..宏一般分為A類宏和B類宏.A類宏是以G65 Hxx P#xx Q#xx R#xx的格式輸入的,而B類宏程序則是 x0dx0a以直接的公式和語言輸入的和C語言很相似在0i系統中應用比較廣.由於現在B類宏程序的大量使 x0dx0a用很多書都進行了介紹這里我就不再重復了,但在一些老系統中,比如法蘭克OTD系統中由於它的MDI鍵盤上沒有公式符號,連最簡單的等於號都沒有,為此如果應用B類宏程序的話就只能在計算機上編好再通過RSN-32介面傳輸的數控系統中,可是如果我們沒有PC機和RSN-32電纜的話怎麼辦呢,那麼只有通過A類宏程序來進行宏程序編制了,下面我介紹一下A類宏的引用; x0dx0aA類宏是用G65 Hxx P#xx Q#xx R#xx或G65 Hxx P#xx Qxx Rxx格式輸入的xx的意思就是數值,是以um級的量輸入的,比如你輸入100那就是0.1MM~~~~~.#xx就是變數號,關於變數號是什麼意思再不知道的的話我也就沒治了,不過還是教一下吧,變數號就是把數值代入到一個固定的模譽地址中,固定的地址就是變數,一般OTD系統中有#0~~~#100~#149~~~#500~#531關閉電源時變數#100~#149被初始化成「空」,而變數#500~#531保持數據.我們如果說#100=30那麼現在#100地址內的數據就是30了,就是這么簡單.好現在我來說一下H代碼,大家可以看到A類宏的標准格式中#xx和xx都是數值,而G65表示使用A類宏,那麼這個H就是要表示各個數值和變數號內的數值或者各個變數號內的數值與其他變數號內的數值之間要進行一個什麼運算,可以說你了解了H代碼A類宏程序你基本就可以應用了,好,現在說一下H代碼的各個含義: x0dx0a以下都以#100和#101和#102,及數值10和20做為例子,應用的時候別把他們當格式就行, x0dx0a基本指令: x0dx0aH01賦值;格式:G65H01P#101Q#102:把#102內的數值賦予到#101中 x0dx0aG65H01P#101Q#10:把10賦予到#101中 x0dx0aH02加指令;格式G65 H02 P#101 Q#102 R#103,把#102的數值加上#103的數值賦予#101 x0dx0aG65 H02 P#101 Q#102 R10 x0dx0aG65 H02 P#101 Q10 R#103 x0dx0aG65 H02 P#101 Q10 R20 x0dx0a上面4個都是加指令的格式都是把Q後面的數值或變數號內的數值加上R後面的數 x0dx0a值或變數號內的數值然後等於到P後面的變數號中. x0dx0aH03減指令;格式G65 H03 P#101 Q#102 R#103,把#102的數值減去#103的數值賦予#101 x0dx0aG65 H03 P#101 Q#102 R10 x0dx0aG65 H03 P#101 Q10 R#103 x0dx0aG65 H03 P#101 Q20 R10 x0dx0a上面4個都是減指令的格式都是把Q後面的數值或變數號內的數值減去R後面的數 x0dx0a值或變數號內的數值然後等於到P後面的變數號中. x0dx0aH04乘指令;格式G65 H04 P#101 Q#102 R#103,把#102的數值乘上#103的數值賦予#101 x0dx0aG65 H04 P#101 Q#102 R10 x0dx0aG65 H04 P#101 Q10 R#103 x0dx0aG65 H04 P#101 Q20 R10 x0dx0a上面4個都是乘指令的格式都是把Q後面的數值或變數號內的數值乘上R後面的數 x0dx0a值或變數號內的數值然後等於到P後面的變數號中. x0dx0aH05除指令;格式G65 H05P#101 Q#102 R#103,把#102的數值除以#103的數值賦予#101 x0dx0aG65 H05 P#101 Q#102 R10 x0dx0aG65 H05 P#101 Q10 R#103 x0dx0aG65 H05 P#101 Q20 R10 x0dx0a上面4個都是除指令格式都是把Q後面的數值或變數號內的數值除以R後面的數 x0dx0a值或變數號內的數值然後等於到P後面的變數號中.(余數不存,除數如果為0的話會出現112報警) x0dx0a三角函數指令: x0dx0aH31 SIN正玄函數指令:格式G65 H31 P#101 Q#102 R#103;含義Q後面的#102是三角形的斜邊R後面的#103內存的是角度.結果是#101=#102*SIN#103,也就是說可以直接用這個求出三角形的另 x0dx0a一條邊長.和以前的指令一樣Q和R後面也可以直接寫數值. x0dx0aH32 COS余玄函數指令:格式G65 H32 #101 Q#102 R#103;含義Q後面的#102是三角形的斜邊 x0dx0aR後面的#103內存的是角度.結果是#101=#102*COS#103,也就是說可以直接用這個求出三角形的 x0dx0a另一條邊長.和以前的指令一樣Q和R後面也可以直接寫數值. x0dx0aH33和H34本來應該是TAN 和ATAN的可是經過我使用得數並不準確,希望有知道的人能夠告訴我是為什麼? x0dx0a開平方根指令: x0dx0aH21;格式G65 H21 P#101 Q#102 ;意思是把#102內的數值開了平方根然後存到#101中(這個指令是非常重要的如果在車橢圓的時候沒有開平方跟的指令是沒可能用宏做到的. x0dx0a無條件轉移指令: x0dx0aH80;格式:G65 H80 P10 ;直接跳到第10程序段 x0dx0a有條件轉移指令: x0dx0aH81 H82 H83 H84 H85 H86 ,分別是等於就轉的H81;不等於就轉的H82;小於就轉的H83;大於就轉的H84;小於等於就轉的H85;大於等於就轉的H86; x0dx0a格式:G65 H8x P10 Q#101 R#102;將#101內的數值和#102內的數值相比較,按上面的H8x的碼帶入H8x中去,如果條件符合就跳到第10程序段,如果不符合就繼續執行下面的程序段. x0dx0a用 戶 宏 程 序 x0dx0a能完成某一功能的一系列指令像子程序那樣存入存儲器,用一個總指令來它們,使用時只需給出這個總指令就能執行其功能。 x0dx0al 所存入的這一系列指令——用戶宏程序 x0dx0al 調用宏程序的指令————宏指令 x0dx0al 特點:使用變數 x0dx0a一. 變數的表示和使用 x0dx0a(一) 變數表示x0dx0a#I(I=1,2,3,…)或#[<式子>] x0dx0a例:#5,#109,#501,#[#1+#2-12] x0dx0a(二) 變數的使用x0dx0a1. 地址字後面指定變數號或公式 x0dx0a格式:<地址字>#I x0dx0a<地址字>-#I x0dx0a<地址字>[<式子>] x0dx0a例:F#103,設#103=15則為F15 x0dx0aZ-#110,設#110=250則為Z-250 x0dx0aX[#24+#18*COS[#1]] x0dx0a2. 變數號可用變數代替 x0dx0a例:#[#30],設#30=3則為#3 x0dx0a3. 變數不能使用地址O,N,I x0dx0a例:下述方法下允許 x0dx0aO#1; x0dx0aI#26.00×100.0; x0dx0aN#3Z200.0; x0dx0a4. 變數號所對應的變數,對每個地址來說,都有具體數值范圍 x0dx0a例:#30=1100時,則M#30是不允許的 x0dx0a5. #0為空變數,沒有定義變數值的變數也是空變數 x0dx0a6. 變數值定義: x0dx0a程序定義時可省略小數點,例:#123=149 x0dx0aMDI鍵盤輸一. 變數的種類 x0dx0a1. 局部變數#1~#33 x0dx0a一個在宏程序中局部使用的變數 x0dx0a例:A宏程序B宏程序 x0dx0a…… x0dx0a#10=20X#10不表示X20 x0dx0a…… x0dx0a斷電後清空,調用宏程序時代入變數值 x0dx0a2. 公共變數#100~#149,#500~#531 x0dx0a各用戶宏程序內公用的變數 x0dx0a例:上例中#10改用#100時,B宏程序中的 x0dx0aX#100表示X20 x0dx0a#100~#149斷電後清空 x0dx0a#500~#531保持型變數(斷電後不丟失) x0dx0a3. 系統變數 x0dx0a固定用途的變數,其值取決於系統的狀態 x0dx0a例:#2001值為1號刀補X軸補償值 x0dx0a#5221值為X軸G54工件原點偏置值 x0dx0a入時必須輸入小數點,小數點省略時單位為μm x0dx0a一. 運算指令 x0dx0a運算式的右邊可以是常數、變數、函數、式子 x0dx0a式中#j,#k也可為常量 x0dx0a式子右邊為變數號、運算式 x0dx0a1. 定義 x0dx0a#I=#j x0dx0a2. 算術運算 x0dx0a#I=#j+#k x0dx0a#I=#j-#k x0dx0a#I=#j*#k x0dx0a#I=#j/#k x0dx0a3. 邏輯運算 x0dx0a#I=#JOK#k x0dx0a#I=#JXOK#k x0dx0a#I=#JAND#k x0dx0a4. 函數 x0dx0a#I=SIN[#j] 正弦 x0dx0a#I=COS[#j] 餘弦 x0dx0a#I=TAN[#j] 正切 x0dx0a#I=ATAN[#j] 反正切 x0dx0a#I=SQRT[#j]平方根 x0dx0a#I=ABS[#j]絕對值 x0dx0a#I=ROUND[#j]四捨五入化整 x0dx0a#I=FIX[#j]上取整 x0dx0a#I=FUP[#j]下取整 x0dx0a#I=BIN[#j]BCD→BIN(二進制) x0dx0a#I=BCN[#j]BIN→BCD x0dx0a1. 說明 x0dx0a1) 角度單位為度 x0dx0a例:90度30分為90.5度 x0dx0a2) ATAN函數後的兩個邊長要用「1」隔開 x0dx0a例:#1=ATAN[1]/[-1]時,#1為了35.0 x0dx0a3) ROUND用於語句中的地址,按各地址的最小設定單位進行四捨五入 x0dx0a例:設#1=1.2345,#2=2.3456,設定單位1μm x0dx0aG91X-#1;X-1.235 x0dx0aX-#2F300;X-2.346 x0dx0aX[#1+#2];X3.580 x0dx0a未返回原處,應改為 x0dx0aX[ROUND[#1]+ROUND[#2]]; x0dx0a4) 取整後的絕對值比原值大為上取整,反之為下取整 x0dx0a例:設#1=1.2,#2=-1.2時 x0dx0a若#3=FUP[#1]時,則#3=2.0 x0dx0a若#3=FIX[#1]時,則#3=1.0 x0dx0a若#3=FUP[#2]時,則#3=-2.0 x0dx0a若#3=FIX[#2]時,則#3=-1.0 x0dx0a5) 指令函數時,可只寫開頭2個字母 x0dx0a例:ROUND→RO x0dx0aFIX→FI x0dx0a6) 優先順序 x0dx0a函數→乘除(*,1,AND)→加減(+,-,OR,XOR) x0dx0a例:#1=#2+#3*SIN[#4]; x0dx0a7) 括弧為中括弧,最多5重,園括弧用於注釋語句 x0dx0a例:#1=SIN[[[#2+#3]*#4+#5]*#6];(3重) x0dx0a一. 轉移與循環指令 x0dx0a1.無條件的轉移 x0dx0a格式:GOTO1; x0dx0aGOTO#10; x0dx0a2.條件轉移 x0dx0a格式:IF[<條件式>]GOTOn x0dx0a條件式: x0dx0a#jEQ#k 表示= x0dx0a#jNE#k 表示≠ x0dx0a#jGT#k 表示> x0dx0a#jLT#k 表示< x0dx0a#jGE#k 表示≥ x0dx0a#jLE#k 表示≤ x0dx0a例:IF[#1GT10]GOTO100; x0dx0a… x0dx0aN100G00691X10; x0dx0a例:求1到10之和 x0dx0aO9500; x0dx0a#1=0 x0dx0a#2=1 x0dx0aN1IF[#2GT10]GOTO2 x0dx0a#1=#1+#2; x0dx0a#2=#2+1; x0dx0aGOTO1 x0dx0aN2M301.循環 x0dx0a格式:WHILE[<條件式>]DOm;(m=1,2,3) x0dx0a… x0dx0a… x0dx0a… x0dx0aENDm x0dx0a說明:1.條件滿足時,執行DOm到ENDm,則從DOm的程序段 x0dx0a不滿足時,執行DOm到ENDm的程序段 x0dx0a2.省略WHILE語句只有DOm…ENDm,則從DOm到ENDm之間形成死循環 x0dx0a3.嵌套 x0dx0a4.EQNE時,空和「0」不同 x0dx0a其他條件下,空和「0」相同 x0dx0a例:求1到10之和 x0dx0aO0001; x0dx0a#1=0; x0dx0a#2=1; x0dx0aWHILE[#2LE10]DO1; x0dx0a#1=#1+#2; x0dx0a#2=#2+#1; x0dx0aEND1; x0dx0aM30;
Ⅲ 數控 程序 宏程序 邏輯運算
宏指令G65可以實現豐富的宏功能,包括算術運算、邏輯運算等處理功能。
一般形式: G65 Hm P#i Q#j R#k
式中:
m--宏程序功能,數值范圍01~99;
#i--運算結果存放處的變數名;
#j--被操作的第一個變數,也可以是一個常數;
#k--被操作的第二個變數,也可以是一個常數。
例如,當程序功能為加法運算時:
程序P#100 Q#101 R#102......含義為#100=#101+#102
程序P#100 Q-#101 R#102......含義為#100=-#101+#102
程序P#100 Q#101 R15......含義為#100=#101+15
1、宏功能指令
(1)算術運算指令(表4.4)
表4.4 算術運算指令
G碼 H碼 功 能 定 義
G65 H01 定義,替換 # i=# j
G65 H02 加 # i=# j+# k
G65 H03 減 # i=# j-# k
G65 H04 乘 # i=# j × # k
G65 H05 除 # i=# j/# k
G65 H21 平方根 # i=√# j
G65 H22 絕對值 # i=|# j|
G65 H23 求余 # i=# j-trunc﹙# j/# k﹚· # k
Trunc;丟棄小於1的分數部分
G65 H24 BCD碼→二進制碼 # i=BIN﹙# j﹚
G65 H25 二進制碼→BCD碼 # i=BCD﹙# j﹚
G65 H26 復合乘/除 # i=﹙# i × # j﹚÷# k
G65 H27 復合平方根1 # i=√# j2+# k2
G65 H28 復合平方根2 # i=√# j2-# k2
1)變數的定義和替換 #i=#j
編程格式 G65 H01 P#i Q#j
例 G65 H01 P#101 Q1005; (#101=1005)
G65 H01 P#101 Q-#112;(#101=-#112)
2)加法 #i=#j+#k
編程格式 G65 H02 P#i Q#j R#k
例 G65 H02 P#101 Q#102 R#103;(#101=#102+#103)
3)減法 #i=#j-#k
編程格式 G65 H03 P#i Q#j R#k
例 G65 H03 P#101 Q#102 R#103;(#101=#102-#103)
4)乘法 #i=#j×#k
編程格式 G65 H04 P#i Q#j R#k
例 G65 H04 P#101 Q#102 R#103;(#101=#102×#103)
5)除法 #i=#j / #k
編程格式 G65 H05 P#i Q#j R#k
例 G65 H05 P#101 Q#102 R#103;(#101=#102/#103)
6)平方根 #i=
編程格式 G65 H21 P#i Q#j
例 G65 H21 P#101 Q#102;(#101= )
7)絕對值 #i=│#j│
編程格式 G65 H22 P#i Q#j
例 G65 H22 P#101 Q#102;(#101=│#102│)
8)復合平方根1 #i=
編程格式 G65 H27 P#i Q#j R#k
例 G65 H27 P#101 Q#102 R#103;(#101=
9)復合平方根2 #i=
編程格式 G65 H28 P#i Q#j R#k
例 G65 H28 P#101 Q#102 R#103(#101=
(2)邏輯運算指令(表4.5)
表4.5 邏輯運算指令
G碼 H碼 功 能 定 義
G65 H11 邏輯「或」 # i=# j · OR · # k
G65 H12 邏輯「與」 # i=# j · AND · # k
G65 H13 異或 # i=# j · XOR · # k
1)邏輯或 #i=#j OR #k
編程格式 G65 H11 P#i Q#j R#k
例 G65 H11 P#101 Q#102 R#103;(#101=#102 OR #103)
2)邏輯與 #i=#j AND #k
編程格式 G65 H12 P#i Q#j R#k
例 G65 H12 P#101 Q#102 R#103;(#101=#102 AND #103)
(3)三角函數指令(表4.6)
表4.6 三角函數指令
G碼 H碼 功 能 定 義
G65 H31 正弦 # i=# j · SIN ﹙# k﹚
G65 H32 餘弦 # i=# j · COS ﹙# k﹚
G65 H33 正切 # i=# j · TAN﹙# k﹚
G65 H34 反正切 # i=ATAN﹙# j/# k﹚
1)正弦函數 #i=#j×SIN(#k)
編程格式 G65 H31 P#i Q#j R#k (單位:度)
例 G65 H31 P#101 Q#102 R#103;(#101=#102×SIN(#103))
2)餘弦函數 #i=#j×COS(#k)
編程格式G65 H32 P#i Q#j R#k (單位:度)
例 G65 H32 P#101 Q#102 R#103;(#101=#102×COS(#103))
3)正切函數 #i=#j×TAN#k
編程格式G65 H33 P#i Q#j R#k (單位:度)
例 G65 H33 P#101 Q#102 R#103;(#101=#102×TAN(#103))
4)反正切 #i=ATAN(#j/#k)
編程格式G65 H34 P#i Q#j R#k (單位:度,0o≤ #j ≤360o)
例 G65 H34 P#101 Q#102 R#103;(#101=ATAN(#102/#103))
(4)控制類指令(表4.7)
表4.7 控制類指令
G碼 H碼 功 能 定 義
G65 H80 無條件轉移 GO TO n
G65 H81 條件轉移1 IF # j=# k,GOTOn
G65 H82 條件轉移2 IF # j≠# k,GOTOn
G65 H83 條件轉移3 IF # j># k,GOTOn
G65 H84 條件轉移4 IF # j<# k,GOTOn
G65 H85 條件轉移5 IF # j≥# k,GOTOn
G65 H86 條件轉移6 IF # j≤# k,GOTOn
G65 H99 產生PS報警 PS報警號500+n出現
1)無條件轉移
編程格式G65 H80 Pn (n為程序段號)
例G65 H80 P120;(轉移到N120)
2)條件轉移1 #j EQ #k(=)
編程格式G65 H81 Pn Q#j R#k (n為程序段號)
例 G65 H81 P1000 Q#101 R#102
當#101=#102,轉移到N1000程序段;若#101≠ #102,執行下一程序段。
3)條件轉移2 #j NE #k(≠)
編程格式G65 H82 Pn Q#j R#k (n為程序段號)
例 G65 H82 P1000 Q#101 R#102
當#101≠ #102,轉移到N1000程序段;若#101=#102,執行下一程序段。
4)條件轉移3 #j GT #k (> )
編程格式G65 H83 Pn Q#j R#k (n為程序段號)
例 G65 H83 P1000 Q#101 R#102
當#101 > #102,轉移到N1000程序段;若#101 ≤#102,執行下一程序段。
5)條件轉移4 #j LT #k(<)
編程格式 G65 H84 Pn Q#j R#k (n為程序段號)
例 G65 H84 P1000 Q#101 R#102
當#101 < #102,轉移到N1000;若#101≥ #102,執行下一程序段。
6)條件轉移5 #j GE #k(≥)
編程格式 G65 H85 Pn Q#j R#k (n為程序段號)
例 G65 H85 P1000 Q#101 R#102
當#101≥ #102,轉移到N1000;若#101<#102,執行下一程序段。
7)條件轉移6 #j LE #k(≤)
編程格式 G65 H86 Pn Q#j Q#k (n為程序段號)
例 G65 H86 P1000 Q#101 R#102
當#101≤#102,轉移到N1000;若#101>#102,執行下一程序段。
2、使用注意
為保證宏程序的正常運行,在使用用戶宏程序的過程中,應注意以下幾點;
(1)由G65規定的H碼不影響偏移量的任何選擇;
(2)如果用於各算術運算的Q或R未被指定,則作為0處理;
(3)在分支轉移目標地址中,如果序號為正值,則檢索過程是先向大程序號查找,如果序號為負值,則檢索過程是先向小程序號查找。
(4)轉移目標序號可以是變數。[em24][em27][em24]鐧懼害鍦板浘
Ⅳ 宏程序什麼意思
問題一:宏程序什麼意思 大家都在問宏程序~其實說起來宏就是用公式來加工零件的,比如說橢圓,如果沒有宏的話,我們要逐點算出曲線上的點,然後慢慢來用直線逼近,如果是個光潔度要求嘩旅友很高的工件的話,那麼需要計算很多的點,可是應用了宏後,我們把橢圓公式輸入到系統中然後我們給出Z坐標並且每次加10um那麼宏就會自動算出X坐標並且進行切削,實際上宏在程序中主要起到的是運算作用..宏一般分為A類宏和B類宏.A類宏是以G65 Hxx P#xx Q#xx R#xx的格式輸入的,而B類宏程序則是
以直接的公式和語言輸入的和C語言很相似在0i系統中應用比較廣.由於現在B類宏程序的大量使
用很多書都進行了介紹這里我就不再重復了,但在一些老系統中,比如法蘭克OTD系統中由於它的MDI鍵盤上沒有公式符號,連最簡單的等於號都沒有,為此如果應用B類宏程序的話就只能在計算機上編好再通過RSN-32介面傳輸的數控系統中,可是如果我們沒有PC機和RSN-32電纜的話怎麼辦呢,那麼只有通過A類宏程序來進行宏程序編制了,下面我介紹一下A類宏的引用;
A類宏是用鎮橡G65 Hxx P#xx Q#xx R#xx或G65 Hxx P#xx Qxx Rxx格式輸入的xx的意思就是數值,是以um級的量輸入的,比如你輸入100那就是0.1MM~~~~~.#xx就是變數號,關於變數號是什麼意思再不知道的的話我也就沒治了,不過還是教一下吧,變數號就是把數值代入到一個固定的地址中,固定的地址就是變數,一般OTD系統中有#0~~~#100~#149~~~#500~#531關閉電源時變數#100~#149被初始化成「空」,而變數#500~#531保持數據.我們如果說#100=30那麼現在#100地址內的數據就是30了,就是這么簡單.好現在我來說一下H代碼,大家可以看到A類宏的標准格式中#xx和xx都是數值,而G65表示使用A類宏,那麼這個H就是要表示各個數值和變數號內的數值或者各個變數號內的數值與其他變數號內的數值之間要進行一個什麼運算,可以說你了解了H代碼A類宏程序你基本就可以應用了,好,現在說一下H代碼的各個含義:
以下都以#100和#101和#102,及數值10和20做為例子,應用的時候別把他們當格式就行,
基本指令:
H01賦值;格式:G65H01P#101Q#102:把#102內的數值賦予到#101中
G65H01P#101Q#10:把10賦予到#101中
H02加指令;格式G65 H02 P#101 Q#102 R#103,把#102的數值加上#103的數值賦予#101
G65 H02 P#101 Q#102 R10
G65 H02 P#101 Q10 R#103
G65 H02 P#101 Q10 R20
上面4個都是加指令的格式都是把Q後面的數值或變數號內的數值加上R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H03減指令;格式G65 H03 P#101 Q#102 R#103,把#102的數值減去#103的數值賦予#101
G65 H03 P#101 Q#102 R10
G65 H03 P#101 Q10 R#103
G65 H03 P#101 Q20 R10
上面4個都是減指令的格式都是把Q後面的數值或變數號內的數值減去R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H04乘指令;格式G65 H04 P#101 Q#102 R#103,把#102的數值乘上#103的數值賦予#1......>>
問題二:宏程序中EQ是什麼意思? 是等於的意思,GT是大於,NE是不等於,GE是大於等於,LT是小於,LE是小於等於,希望對你有幫助
問題三:數控編程宏程序中#1#2……是什麼意思 宏程序中的代號,他好比我們小學學的X(愛克斯),我舉個例子哈。當X=2時,那麼5+X就等於7.如果我在程序中寫上#1=5,那麼下一段只亂槐要讀到#1系統就知道是5了。如果下面有一行程序為G0X[#1+2]Z30. 那麼系統就會把刀具走刀X是7的位置,Z走刀30的位置。如果在指令#1=#1-1的話那麼系統每讀到#1的時候都會在上一個#1的數據減掉1毫米。這就是他的作用,也就是不單單表示一個數據,他還能運用計算來完成一些編程比較麻煩的環境中,希望我的解答能夠使你了解宏!
問題四:宏程序#0什麼意思 詳細點 #0代表的是空變數,不管給#0賦值多少它的變數值都為零.
問題五:宏程序中fix什麼意思 截斷取整。例:fix(3.7)=3
區別於四捨五入取整round,如round(3.7)=4
問題六:誰知道數控宏程序是什麼意思啊? 宏就是用公式來加工零件的,比如說橢圓,如果沒有宏的話,我們要逐點算出曲線上的點,然後慢慢來用直線逼近,如果是個光潔度要求很高的工件的話,那麼需要計算很多的點,可是應用了宏後,我們把橢圓公式輸入到系統中然後我們給出Z坐標並且每次加10um那麼宏就會自動算出X坐標並且進行切削, 實際上宏在程序中主要起到的是運算作用..宏一般分為A類宏和B類宏.A類宏是以G65 Hxx P#xx Q#xx R#xx的格式輸入的,而B類宏程序則是以直接的公式和語言輸入的和C語言很相似在0i系統中應用比較廣.
問題七:宏程序裡面的#j 是什麼意思 #表示變數號,j表示某個數字。
問題八:宏程序里GE GT IF等 那些都是什麼意思啊? 5分 分別是大於等於,大於,如果,有興趣可以網路中國寧波數控交流群
來自UC瀏覽器
問題九:加工中心宏程序#1#2是什麼意思? 這只是一個代號而已,與XY的作用差不多
問題十:宏程序中的then是什麼意思 然後啊,這個一般是跟if一起用的,
if ... then ...
如果解決了您的問題請採納!
如果未解決請繼續追問
Ⅳ 加工中心宏程序
宏程序的作用:
數控系統為用戶配備了強有力的類似於高級語言的宏程序功能,用戶可以使用變數進行算術運算、邏輯運算和函數的混合運算,此外宏程序還提供了循環語句、分支語句和子程序調用語句,利於編制各種復雜的零件加工程序,減少乃至免除手工編程時進行繁瑣的數值計算,以及精簡程序量。
宏程序指令適合拋物線、橢圓、雙曲線等沒有插補指令的曲線編程;適合圖形一樣,只是尺寸不同的系列零件的編程;適合工藝路徑一樣,只是位置參數不同的系列零件的編程。較大地簡化編程;擴展應用范圍。
加工中心宏程序應用:
以下都以#100和#101和#102,及數值10和20做為例子,應用的時候別把他們當格式就行,
基本指令
H01賦值;格式:G65H01P#101Q#102:把#102內的數值賦予到#101中
G65H01P#101Q#10:把#10賦予到#101中
H02加指令;格式G65 H02 P#101 Q#102 R#103,把#102的數值加上#103的數值賦予#101
G65 H02 P#101 Q#102 R10
G65 H02 P#101 Q10 R#103
G65 H02 P#101 Q10 R20
上面4個都是加指令的格式都是把Q後面的數值或變數號內的數值加上R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H03減指令;格式G65 H03 P#101 Q#102 R#103,把#102的數值減去#103的數值賦予#101
G65 H03 P#101 Q#102 R10
G65 H03 P#101 Q10 R#103
G65 H03 P#101 Q20 R10
上面4個都是減指令的格式都是把Q後面的數值或變數號內的數值減去R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H04乘指令;格式G65 H04 P#101 Q#102 R#103,把#102的數值乘上#103的數值賦予#101
G65 H04 P#101 Q#102 R10
G65 H04 P#101 Q10 R#103
G65 H04 P#101 Q20 R10
上面4個都是乘指令的格式都是把Q後面的數值或變數號內的數值乘上R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H05除指令;格式G65 H05P#101 Q#102 R#103,把#102的數值除以#103的數值賦予#101
G65 H05 P#101 Q#102 R10
G65 H05 P#101 Q10 R#103
G65 H05 P#101 Q20 R10
上面4個都是除指令格式都是把Q後面的數值或變數號內的數值除以R後面的數
值或變數號內的數值然後等於到P後面的變數號中.(余數不存,除數如果為0的話會出現112報警)
以上內容參考:網路--宏程序
Ⅵ 宏程序什麼意思
大家都在問宏程序~其實說起來宏就是用公式來加工零件的,比如說橢圓,如果沒有宏的話,我們要逐點算出曲線上的點,然後慢慢來用直線逼近,如果是個光潔度要求很高的工件的話,那麼需要計算很多的點,可是應用了宏後,我們把橢圓公式輸入到系統中然後我們給出Z坐標並且每次加10um那麼宏就會自動算出X坐標並且進行切削,實際上宏在程序中主要起到的是運算作用..宏一般分為A類宏和B類宏.A類宏是以G65 Hxx P#xx Q#xx R#xx的格式輸入的,而B類宏程序則是
以直接的公式和語言輸入的和C語言很相似在0i系統中應用比較廣.由於現在B類宏程序的大量使
用很多書都進行了介紹這里我就不再重復了,但在一些老系統中,比如法蘭克OTD系統中由於它的MDI鍵盤上沒有公式符號,連最簡單的等於號都沒有,為此如果應用B類宏程序的話就只能在計算機上編好再通過RSN-32介面傳輸的數控系統中,可是如果我們沒有PC機和RSN-32電纜的話怎麼辦呢,那麼只有通過A類宏程序來進行宏程序編制了,下面我介紹一下A類宏的引用;
A類宏是用G65 Hxx P#xx Q#xx R#xx或G65 Hxx P#xx Qxx Rxx格式輸入的xx的意思就是數值,是以um級的量輸入的,比如你輸入100那就是0.1MM~~~~~.#xx就是變數號,關於變數號是什麼意思再不知道的的話我也就沒治了,不過還是教一下吧,變數號就是把數值代入到一個固定的地址中,固定的地址就是變數,一般OTD系統中有#0~~~#100~#149~~~#500~#531關閉電源時變數#100~#149被初始化成「空」,而變數#500~#531保持數據.我們如果說#100=30那麼現在#100地址內的數據就是30了,就是這么簡單.好現在我來說一下H代碼,大家可以看到A類宏的標准格式中#xx和xx都是數值,而G65表示使用A類宏,那麼這個H就是要表示各個數值和變數號內的數值或者各個變數號內的數值與其他變數號內的數值之間要進行一個什麼運算,可以說你了解了H代碼A類宏程序你基本就可以應用了,好,現在說一下H代碼的各個含義:
以下都以#100和#101和#102,及數值10和20做為例子,應用的時候別把他們當格式就行,
基本指令:
H01賦值;格式:G65H01P#101Q#102:把#102內的數值賦予到#101中
G65H01P#101Q#10:把10賦予到#101中
H02加指令;格式G65 H02 P#101 Q#102 R#103,把#102的數值加上#103的數值賦予#101
G65 H02 P#101 Q#102 R10
G65 H02 P#101 Q10 R#103
G65 H02 P#101 Q10 R20
上面4個都是加指令的格式都是把Q後面的數值或變數號內的數值加上R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H03減指令;格式G65 H03 P#101 Q#102 R#103,把#102的數值減去#103的數值賦予#101
G65 H03 P#101 Q#102 R10
G65 H03 P#101 Q10 R#103
G65 H03 P#101 Q20 R10
上面4個都是減指令的格式都是把Q後面的數值或變數號內的數值減去R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H04乘指令;格式G65 H04 P#101 Q#102 R#103,把#102的數值乘上#103的數值賦予#101
G65 H04 P#101 Q#102 R10
G65 H04 P#101 Q10 R#103
G65 H04 P#101 Q20 R10
上面4個都是乘指令的格式都是把Q後面的數值或變數號內的數值乘上R後面的數
值或變數號內的數值然後等於到P後面的變數號中.
H05除指令;格式G65 H05P#101 Q#102 R#103,把#102的數值除以#103的數值賦予#101
G65 H05 P#101 Q#102 R10
G65 H05 P#101 Q10 R#103
G65 H05 P#101 Q20 R10
上面4個都是除指令格式都是把Q後面的數值或變數號內的數值除以R後面的數
值或變數號內的數值然後等於到P後面的變數號中.(余數不存,除數如果為0的話會出現112報警)
三角函數指令:
H31 SIN正玄函數指令:格式G65 H31 P#101 Q#102 R#103;含義Q後面的#102是三角形的斜邊R後面的#103內存的是角度.結果是#101=#102*SIN#103,也就是說可以直接用這個求出三角形的另
一條邊長.和以前的指令一樣Q和R後面也可以直接寫數值.
H32 COS余玄函數指令:格式G65 H32 #101 Q#102 R#103;含義Q後面的#102是三角形的斜邊
R後面的#103內存的是角度.結果是#101=#102*COS#103,也就是說可以直接用這個求出三角形的
另一條邊長.和以前的指令一樣Q和R後面也可以直接寫數值.
H33和H34本來應該是TAN 和ATAN的可是經過我使用得數並不準確,希望有知道的人能夠告訴我是為什麼?
開平方根指令:
H21;格式G65 H21 P#101 Q#102 ;意思是把#102內的數值開了平方根然後存到#101中(這個指令是非常重要的如果在車橢圓的時候沒有開平方跟的指令是沒可能用宏做到的.
無條件轉移指令:
H80;格式:G65 H80 P10 ;直接跳到第10程序段
有條件轉移指令:
H81 H82 H83 H84 H85 H86 ,分別是等於就轉的H81;不等於就轉的H82;小於就轉的H83;大於就轉的H84;小於等於就轉的H85;大於等於就轉的H86;
格式:G65 H8x P10 Q#101 R#102;將#101內的數值和#102內的數值相比較,按上面的H8x的碼帶入H8x中去,如果條件符合就跳到第10程序段,如果不符合就繼續執行下面的程序段.
用 戶 宏 程 序
能完成某一功能的一系列指令像子程序那樣存入存儲器,用一個總指令來它們,使用時只需給出這個總指令就能執行其功能。
l 所存入的這一系列指令——用戶宏程序
l 調用宏程序的指令————宏指令
l 特點:使用變數
一. 變數的表示和使用
(一) 變數表示
#I(I=1,2,3,…)或#[<式子>]
例:#5,#109,#501,#[#1+#2-12]
(二) 變數的使用
1. 地址字後面指定變數號或公式
格式:<地址字>#I
<地址字>-#I
<地址字>[<式子>]
例:F#103,設#103=15則為F15
Z-#110,設#110=250則為Z-250
X[#24+#18*COS[#1]]
2. 變數號可用變數代替
例:#[#30],設#30=3則為#3
3. 變數不能使用地址O,N,I
例:下述方法下允許
O#1;
I#26.00×100.0;
N#3Z200.0;
4. 變數號所對應的變數,對每個地址來說,都有具體數值范圍
例:#30=1100時,則M#30是不允許的
5. #0為空變數,沒有定義變數值的變數也是空變數
6. 變數值定義:
程序定義時可省略小數點,例:#123=149
MDI鍵盤輸一. 變數的種類
1. 局部變數#1~#33
一個在宏程序中局部使用的變數
例:A宏程序B宏程序
……
#10=20X#10不表示X20
……
斷電後清空,調用宏程序時代入變數值
2. 公共變數#100~#149,#500~#531
各用戶宏程序內公用的變數
例:上例中#10改用#100時,B宏程序中的
X#100表示X20
#100~#149斷電後清空
#500~#531保持型變數(斷電後不丟失)
3. 系統變數
固定用途的變數,其值取決於系統的狀態
例:#2001值為1號刀補X軸補償值
#5221值為X軸G54工件原點偏置值
入時必須輸入小數點,小數點省略時單位為μm
一. 運算指令
運算式的右邊可以是常數、變數、函數、式子
式中#j,#k也可為常量
式子右邊為變數號、運算式
1. 定義
#I=#j
2. 算術運算
#I=#j+#k
#I=#j-#k
#I=#j*#k
#I=#j/#k
3. 邏輯運算
#I=#JOK#k
#I=#JXOK#k
#I=#JAND#k
4. 函數
#I=SIN[#j] 正弦
#I=COS[#j] 餘弦
#I=TAN[#j] 正切
#I=ATAN[#j] 反正切
#I=SQRT[#j]平方根
#I=ABS[#j]絕對值
#I=ROUND[#j]四捨五入化整
#I=FIX[#j]上取整
#I=FUP[#j]下取整
#I=BIN[#j]BCD→BIN(二進制)
#I=BCN[#j]BIN→BCD
1. 說明
1) 角度單位為度
例:90度30分為90.5度
2) ATAN函數後的兩個邊長要用「1」隔開
例:#1=ATAN[1]/[-1]時,#1為了35.0
3) ROUND用於語句中的地址,按各地址的最小設定單位進行四捨五入
例:設#1=1.2345,#2=2.3456,設定單位1μm
G91X-#1;X-1.235
X-#2F300;X-2.346
X[#1+#2];X3.580
未返回原處,應改為
X[ROUND[#1]+ROUND[#2]];
4) 取整後的絕對值比原值大為上取整,反之為下取整
例:設#1=1.2,#2=-1.2時
若#3=FUP[#1]時,則#3=2.0
若#3=FIX[#1]時,則#3=1.0
若#3=FUP[#2]時,則#3=-2.0
若#3=FIX[#2]時,則#3=-1.0
5) 指令函數時,可只寫開頭2個字母
例:ROUND→RO
FIX→FI
6) 優先順序
函數→乘除(*,1,AND)→加減(+,-,OR,XOR)
例:#1=#2+#3*SIN[#4];
7) 括弧為中括弧,最多5重,園括弧用於注釋語句
例:#1=SIN[[[#2+#3]*#4+#5]*#6];(3重)
一. 轉移與循環指令
1.無條件的轉移
格式:GOTO1;
GOTO#10;
2.條件轉移
格式:IF[<條件式>]GOTOn
條件式:
#jEQ#k 表示=
#jNE#k 表示≠
#jGT#k 表示>
#jLT#k 表示<
#jGE#k 表示≥
#jLE#k 表示≤
例:IF[#1GT10]GOTO100;
…
N100G00691X10;
例:求1到10之和
O9500;
#1=0
#2=1
N1IF[#2GT10]GOTO2
#1=#1+#2;
#2=#2+1;
GOTO1
N2M301.循環
格式:WHILE[<條件式>]DOm;(m=1,2,3)
…
…
…
ENDm
說明:1.條件滿足時,執行DOm到ENDm,則從DOm的程序段
不滿足時,執行DOm到ENDm的程序段
2.省略WHILE語句只有DOm…ENDm,則從DOm到ENDm之間形成死循環
3.嵌套
4.EQNE時,空和「0」不同
其他條件下,空和「0」相同
例:求1到10之和
O0001;
#1=0;
#2=1;
WHILE[#2LE10]DO1;
#1=#1+#2;
#2=#2+#1;
END1;
M30;