{Change Comments ***********************************************************}
{
10/24/94 [cwh]
B001.81.4 ( from B001.81.3 )
Made changes to ZOnlyRep and FinishSub1 subs to properly handle
Feed connects and clearance moves.
}
{11/8/94
Modified: Fanuc 6M (FW) B001.81.4
For: Gibbs & Associates
Versions: Catalyst v2.14.12C/Compost 4.21.23
Changes made per Pete Jackson
Charles reported a problem involving operations that do not change coordinate systems from
previous operations.
Added ClearCSOffset at NotSameToolWFO and SameToolWFO subs.
DWB}
{
12/01/94
B001.81.6
Changed FirstOp3 to call out A0B0 to move to the first CS.
When possible, this should be changed to check the MDD and only call out the axes that
make sense.
Added RecallWFO sub-routine to NotSameToolWFO and SameToolWFO to ouput the current fixture offset
and A0B0. Added for easier restarts at the machine. Both are only called from NoMPs.
When possible, this should be changed to check the MDD and only call out the axes that
make sense.
}
{
12/02/94
Changed version number to .00 from .81
TH}
{
Format: Fanuc 6M (FW) B001.00.01
12/08/94
Added AAxisAvail? and BAxisAvail? checks to CSAngleA and CSAngleB subs
Added WFO1 and A0B0 if AxisAvail to End2:
TH}
{
Format: Fanuc 6M (FW) B001.00.01
12/09/94
Fixed RecalWFO to check AAxisAvail? and BAxisAvail?
Cleaned up FirstOp3 to use new checks placed in CSAngleA and CSAngleB
TH}
{
Format: Fanuc 6M (FW) B001.00.03
12/19/94
Added ClearCSOffset to OpenMP: CloseMP: and SubCSMP:
Added if AChange? OR BChange? to home postition call-out in SameToolOp1
Started using Flag('3') to determine toggle between incrementing through MPs and decrementing through MPs
Changed CloseMP to check Flag('3'). If true, the WFOs will increment from first to last. If false, the WFOs will
decrement from last to first.
Example:
TRUE for 4 parts: G54P1, G54P2, G54P3, G54P4
FALSE for 4 parts: G54P4, G54P3, G54P2, G54P1
This is most useful for tombstone machining on rotary tables. With this method, the code will machine part1, rotate, part2,
rotate, part3, rotate, part4, tool change, part4, part3, part2, part1, toolchange, etc. It minimizes the rotation and also
stops the machine from "winding up".
To do this a new sub was created called ToggleIncDecWFO. The flag is set to true in ProgStart and toggled inside CloseMP
after running through the parts
Replaced SetZRepInc and RestoreAbsOrInc with one sub called DoAbsOrInc. Any line with SetZRepInc now
has DoAbsOrInc as the first command after the SeqC.
TH}
{
Format: Fanuc 6M (FW) B001.00.04
1/10/95
NewToolOp3 now has an AbsOrInc on the line that calls out the Plane 'G80' CRCOff
NewToolOp5 no longer has the AbsOrInc command
NewToolOp5b has been created and has the AbsOrInc command
Changed MP1ToollAllPfu to call NewToolOp5b
Added AbsOrInc and Rapid to the FirstOperation? section of MP1ToollAllPXcp
Added Rapid to the NewTool? section of MP1ToollAllPXcp
Started using Flag ('4') to turn on Inc/Dec WFO's (See above). True means use Inc/Dec WFO's.
MP1ToollAllPXcp, MP1ToollAllPFU, and MPallTools1P now output WFO if NOT WorkFixtureOffsets?
TH}
{
Format: Fanuc 6M (FW) B001.00.05
1/13/95
Replaced TrackZNO# ZDepth# with TrackZNO# FIRST SPZ# in the drilling section
Formatted TrackZNO# to #4
}
{
Format: Fanuc 6M (FW) B001.00.06
2/15/95
Fixed RecallWFO: to output correct WFO# if WFOCS
TH}
{ Added ClearCSOffset to SubCSMP TH}
{
Format: Fanuc 6M (FW) B001.10
7/27/95
Added G52 style output for too many coordinate systems
Updated to .10 format
TH}
{1/17/96, Updated .10 to .11 version, MPK}
{2/26/96
Initial: Fanuc 6M (FW) B001.11
Created: Fanuc 6M (FW) B001.11.01
Develop: ComPost 4.21.34, Catalyst68K v3.02.02C
Comment: Corrections to Processor.
Corrected format of CSOffsetA# and CSOffsetB#.
To correct multiple parts output:
Added "OR Flag?('2')" to "IF WFOCS?" in "SubCSMP:".
To Simplify prog subs and correct errors in MP1ToollAllPXcp:
Changed FirstOp3a/NewToolOp5a to FirstOp4/NewToolOp6
Deleted NewToolOp5b sub and changed call to NewToolOp5 (they were identical!)
Deleted OfstOn and Cool On from FirstOp3/NewToolOp5
Added calls to FirstOp4/NewToolOp6 after calls to FirstOp3/NewToolOp5.
Changed StrtPos in MP1ToollAllPXcp to FirstOp3/NewToolOp5.
To correct a literal number 2 from being output when processing multiple parts:
Changed order of booleans from:
IF WFOCS? OR Flag?('2')
to:
IF Flag?('2') OR WFOCS?
Modified WFO Handling:
Changes:
Deleted RecallWFO sub. It was not used!
Deleted NotSameToolWFO & SameToolWFO subs.
Added WFOStuff sub.
Changed all WFO calls in main loops to WFOStuff.
Results:
Changes do not effect Multiple Parts output.
Correct WFO is output by default at the beginning of each tool.
G52, if used, is output by default at the beginning of each tool.
G52, without WFO, is output at SameTool only if there is a change.
Jim Radcliffe}
{2/26/96
Initial: Fanuc 6M (FW) B001.11.01
Created: Fanuc 16M Makino A55 Cxxx.11
ForUser: Rocklin Precision
Control: Makino PRO3 (Fanuc 16M)
Machine: Leblond Makino A55 Delta
Develop: ComPost 4.21.34, Catalyst68K v3.02.02C
Comment: New Processor per instructions from Rolf at Rocklin.
Summary:
No sub-programs output except for MultipleParts.
Extended Work Fixture Offsets, G54 -> G59 then G54.1P1 thru G54.1P48
G10 lines at beginning od program to set work offsets used.
Jim Radcliffe}
{3/25/96, Tested ZOnlyRepAutoCycle, Changed version # to .12, MPK}
{7/12/96
Intial: Fanuc 16M Makino A55 C948.12
Created: Fanuc 16M Makino A55 C948.13
Most changes for .13 format were already made.
Added support for rigid tapping:
Machine needs 'G8P0' code before RigidTapping and 'G8P1' when finished. Added Flag('7') to test for RigidTap
in order to avoid reoutputting in SameTool situations.
Added 'M135' literal to IF Drilling? This puts in rigid tapping mode.
Suppresses Speed and Feed for Rigid Tapping cycle, added Speed command in IF Drilling? that only outputs when R. Tapping.
Added 'G4P500' literal after DrillOff command in IF Drilling? when rigid tapping.
Changed Workgroup comment and tool comments to only output at a new tool
Modified CSAngleA and CSAngleB to only output when SameTool if there is a rotation.
Only outputs CSWFO comment it using a 4 or 5 axis MDD.
Added OfstOff to CloseMP when OTAP FullUp? is true. Machine does not use a tool offset cancel, so G28 had to be
inserted for this. When it is the last tool, the G28 is output in End1.
Made RapidF# at beginning of OpGuts conditional upon SameTool? being false.
Deleted All G10 stuff.
Made drilling canned cycle FeedEnt conditional.
Deleted 'G80' CRCOff at FirstOp1 and NewToolOp3.
Added ToolChng to NewToolOp2 : M6 for this control sends it home, turns off spindle and coolant, and cancels offfsets. It must
be called twice, once to send home, once at the normal location in NewToolOp3 to change the tool.
Eliminated ToolChangeAtHome stuff, tool change command sends it home automatically.
Put OpToolId and ToolDChng on separate lines.
Moved Speed and SpinOn from FirstToolOp2, NewToolOp4 to FirstToolOp3, NewToolOp5.
Added M11 (unclamp) and M11 (clamp) with all rotary axis output.
Deleted 'M300' from End3
SpinOff in End section outputs in End2 for all cases except FullUp? and in End3 for FullUp?
MPK}
{8/1/96
Intial: Fanuc 16M Makino A55 C948.13
Created: Fanuc 16M Makino A55 C948.13.1
Raised MaxSpindleSpeed to 20000
Made output of Speed in NewTool unconditional
eliminated output of SpinOn for drilling with SameTool, except after a program stop
MPK}
{3/4/97
Intial: Fanuc 16M Makino A55 C948.13.1
Created: Fanuc 16M Makino A55 C948.13.2
ForUser: Rocklin Precision
Fixed so I and J words are output by adding Plane command to StartToolComment.
Customer didn't want Plane command output and he doesn't output the StartToolComment, I have placed it here.
Raised MaxSpindleSpeed to 30000
WS}
{5/22/97,
Initial: Fanuc 16M Makino A55 C948.13.2
Created: Fanuc 16M Makino A55 C948.13.3
Removed
IF FullUp? AND NOT LastTool?
SeqC IncValue OfstOff EOL
END
from CloeMP,
added
IF MulitiplePats? AND OneToolAllParts? AND FullUp?
SeqC IncValue OfstOff EOL
END
to NewToolOp1, MPK}
{2/10/98
Initial: Fanuc 16M Makino A55 C948.13.3
Created: Fanuc 16M Makino A55 C948.13.4
ForUser: NIST
Develop: ComPost2 1.1b3, Virtual 4.21.21
Comment: Updates per Fanuc 6M NoSubs M877.89.4
Replaced TrackZNO# ZDepth# with TrackZNO# FIRST SPZ# in the drilling section
Return to the StrtPos before next iteration of CutAutoCycle Repeats ZshiftOnly
Rewrote AutoCycle positioning in ToolPath to overcome bug with FirstFeat?
Jim Radcliffe}
{2/19/98,
Initial : Fanuc 16M Makino A55 C948.13.4
Created: Fanuc 16M Makino A55 C948.13.5
Customer: NIST
Changes to "Prog":
1. Removed AND G17 PLANE from StartToolComment.
2. Added Plane (G17) to FirstOp3 and PlaneC to NewToolOp5.
JHE}
{Prog Numeric Format Definitions *******************************}
#1 = '#.00'
#2 = '#####.###;0.'
#3 = '*#####.###;0.'
#4 = '####.####;0.'
#5 = '#######0'
#6 = '####^##0'
#7 = '#;'
FORMAT(FileFeet#,1)
FORMAT(FileMeters#,1)
FORMAT(CSOffsetA#,3)
FORMAT(CSOffsetB#,3)
FORMAT(ToolDiameter#,4)
FORMAT(CSOffsetX#,4)
FORMAT(CSOffsetY#,4)
FORMAT(CSOffsetZ#,4)
FORMAT(TrackZNO#,4)
FORMAT(Program#,5)
FORMAT(Operation#,5)
FORMAT(Tool#,5)
FORMAT(NewWFO#,5)
FORMAT(ADD#,5)
FORMAT(SUB#,5)
FORMAT(Recall#,5)
FORMAT(CS#,5)
FORMAT(Parts#,5)
FORMAT(CallMasterNum#,5)
FORMAT(Dwell#,6)
FORMAT(RapidF#,7)
{Prog Subroutines ****}
RestoreScale:
IF Metric? {CAM file is in Metric, tools and tool path}
SetScale('.03937007874') { change to English, this is an English post}
END
RETURN
DoSubComment:
IF UseComments? AND SubComment?
'( SUB NUMBER: ' Program# ' )' EOL
END
RETURN
DoRepComment:
IF UseComments? AND SubComment?
'( CYCLE START )' EOL
END
RETURN
DoOpComments:
IF UseComments?
SetScale('1')
IF OperationIDComment?
'( OPERATION ' Operation# ': ' OperationType$ ' )' EOL
END
IF OperationComment?
'( ' OperationComment$ ' )' EOL
END
IF NOT SameTool?
IF WorkGroupComment?
'( ' WorkGroupComment$ ' )' EOL
END
IF ToolTypeComment?
'( TOOL ' Tool# ': ' ToolDiameter# ' ' ToolType$ ' )' EOL
END
IF ToolComment?
'( ' ToolComment$ ' )' EOL
END
END
RestoreScale
END
RETURN
CalcCSWFO#: {(iPart-1)*NumOfCS#)}
ADD# MUL# NumOfCS# SUB# PartNum# Num#('1') ADD# CS# SUB# NewWFO# Num#('1')
RETURN
CSWFO:
'G'
IF GreaterThan? CalcCSWFO# Num#('59')
'54.1P' SUB# CalcCSWFO# Num#('59')
ELSE
CalcCSWFO#
END
RETURN
CSAngleA:
IF AAxisAvail?
IF SameTool?
IF AChange?
'A' CSOffsetA#
END
ELSE
'A' CSOffsetA#
END
END
RETURN
CSAngleB:
IF BAxisAvail?
IF SameTool?
IF BChange?
'B' CSOffsetB#
END
ELSE
'B' CSOffsetB#
END
END
RETURN
DoCSWFOComment:
IF AAxisAvail? OR BAxisAvail?
'( CS#' CS# ' - ' CSComment$ ' )' EOL
'( ' CSWFO '= X' CSOffsetX# ' Y' CSOffsetY# ' Z' CSOffsetZ# ' )' EOL
END
RETURN
DoCSG52Comment:
'( CS#' CS# ' - ' CSComment$ ' )' EOL
RETURN
PSInit:
MasterOpF
CallMasterOpF
RETURN
PSStuff:
RETURN
DoPostScript:
PSInit
EachPS
SeqC PostScript EOL
PSStuff
NextPS
RETURN
DoEndOpPS:
PSInit
EachEOPS
SeqC EndOpPS EOL
PSStuff
NextPS
RETURN
ExitType:
IF FIFO?
FeedC
ELSE
RapidC
END
RETURN
ExitFeed:
IF FIFO?
FeedEntC
END
RETURN
StartSub:
OpenSub
SubID EOL
DoSubComment
RETURN
ToggleIncDecWFO:
IF Flag?('3')
SetFlagF('3')
ELSE
SetFlag('3')
END
RETURN
OpenMP:
IF Flag?('2') OR WFOCS?
NewProg
StartSub
SaveCSProg
SaveCSOpStart
ClearCSOffset
ELSE
NewProg
IF WorkFixtureOffsets?
NewWFO
EachWFO {simple eachPart}
SeqC SetWFO SubCall CallLab RepLab OnePart EOL
IncWFO
NextWFO {simple NextPart}
ELSE
SeqC SubCall CallLab RepLab Parts EOL
END
StartSub
END
RETURN
CloseMP:
IF Flag?('2') OR WFOCS?
SeqC EndSub EOL
CloseSub
IF Flag?('3')
NewWFO
EachWFO {simple eachPart}
IF Flag?('2')
SeqC SetWFO EOL
EachCSOp
DoCSG52Comment
ClearCSOffset
SeqC 'G52X' CSOffsetX# 'Y' CSOffsetY# 'Z' CSOffsetZ# EOL
SeqC SubCall CallLabB CSSubID# RepLab OnePart EOL
NextCSOp
ELSE
EachCSOp
DoCSWFOComment
ClearCSOffset
SeqC CSWFO SubCall CallLabB CSSubID# RepLab OnePart EOL
NextCSOp
END
ClearCSOffset
IncWFO
NextWFO {simple NextPart}
ELSE
LastWFO
EachWFO {simple eachPart}
IF Flag?('2')
SeqC SetWFO EOL
EachCSOp
DoCSG52Comment
ClearCSOffset
SeqC 'G52X' CSOffsetX# 'Y' CSOffsetY# 'Z' CSOffsetZ# EOL
SeqC SubCall CallLabB CSSubID# RepLab OnePart EOL
NextCSOp
ELSE
EachCSOp
DoCSWFOComment
ClearCSOffset
SeqC CSWFO SubCall CallLabB CSSubID# RepLab OnePart EOL
NextCSOp
END
ClearCSOffset
DecWFO
NextPrevWFO {simple NextPart}
END
IF Flag?('4')
ToggleIncDecWFO
END
ELSE
IF WorkFixtureOffsets?
SeqC EndSub EOL
CloseSub
SeqC WFO1 EOL
ELSE
SeqC Preset ShiftPC EOL
SeqC EndSub EOL
CloseSub
SeqC Preset UnshftPC EOL
END
END
RETURN
SubCSMP:
IF Flag?('2') OR WFOCS?
IF ChangeCS?
SeqC EndSub EOL
CloseSub
NewProg
StartSub
SaveCSProg
END
ClearCSOffset
END
RETURN
FormatArc:
IF ArcCW?
CWArcC
ELSE
CCWArcC
END
MoveXYZC
IF ArcIJFormat?
ArcIJC
ELSE
ArcRC
END
RETURN
StdRapid:
IF LastFeat?
SeqC CRCOffC RapidC MoveXYZC EOL
ELSE
IF ZMove? {skip CRCOn until first non-Z move line, skipping ramps}
SeqC RapidC MoveXYZC EOL
ELSE
IF XMove? OR YMove? OR ZMove?
SeqC CRCOnC RapidC MoveXYZC CRCOffsetC EOL
END
END
END
RETURN
StdLine: {enables CRC on first call, .70}
IF LastFeat?
SeqC CRCOffC FeedC MoveXYZC FeedRateC EOL
ELSE
IF ZMove? {skip CRCOn until first non-Z move line, skipping ramps}
SeqC FeedC MoveXYZC FeedRateC EOL
ELSE
IF Decelerate?
IF RoomToDecel?
DecelMove1
SeqC CRCOnC FeedC MoveXYZC FeedRateC CRCOffsetC EOL
DecelMove2
END
SeqC CRCOnC FeedC MoveXYZC DecelFeed CRCOffsetC EOL
ELSE
IF XMove? OR YMove? OR ZMove?
SeqC CRCOnC FeedC MoveXYZC FeedRateC CRCOffsetC EOL
END
END
END
END
RETURN
StdArc:
EACHQuadrant
IF LastQuadrant? AND Decelerate?
IF RoomToDecel?
DecelMove1
SeqC FormatArc ArcFeedC EOL
DecelMove2
END
SeqC FormatArc DecelFeed EOL
ELSE
SeqC FormatArc ArcFeedC EOL
END
NEXTQuadrant
RETURN
ToolPath2: {for AutoCycle element moves}
EACHFeat
IF RapidFeat?
StdRapid
ELSE
IF LineFeat?
StdLine
ELSE
IF ArcFeat?
StdArc
END
END
END
NEXTFeat
RETURN
EntryMove:
IF FeedEntry?
SeqC FeedC ZInC FeedEntC EOL
ELSE
SeqC RapidC ZInC EOL
END
RETURN
CutAutoCycle:
SaveSubStatus {save tool position}
SetPass1 {element cut moves}
SetSRXYtoSP
SeqC IncValue EOL
IF Repeats? AND ZshiftOnly?
EachRep
IF NOT FirstCycle?
IF SPXMove? OR SPYMove?
IF FeedConnect?
SeqC FeedC StrtPosC EOL
ELSE
SeqC RapidC StrtPosC EOL
END
END
END
EntryMove
ToolPath2
IF NOT FeedConnect?
SeqC ExitType PRIME ZCP2 ExitFeed EOL
END
NextRep
ELSE
EntryMove
ToolPath2
END
SeqC AbsOrInc ExitType ZCP2 ExitFeed EOL
SetSRSubXY {restore tool position}
SetSRSubMove
ReSetPass2 {restore for positioning moves}
RETURN
ToolPath:
EACHFeat
IF PointFeat?
IF AutoCycle?
SeqC
IF FIFO? AND NOT FirstFeat?
Rapid
END
MoveSXYC EOL
CalcACSRXY {calc tool position after sub call, CalcAutoCycleStatusRecordXY}
CutAutoCycle
ELSE
SeqC MoveSXYZC EOL {.80.01}
END
ELSE
IF RapidFeat?
StdRapid
ELSE
IF LineFeat?
StdLine
ELSE
IF ArcFeat?
StdArc
END
END
END
END
NEXTFeat
RETURN
CheckPass:
IF AutoCycle? {use the correct StrtPos}
SetPass2
ELSE
SetPass1
END
RETURN
ProgStart:
InitProg
ReverseXZArcs
InitWFONum
SetFlood
SetFlagF('1') {not std sep sub Zreps in effect} {rep change 2}
SetFlagF('2') {not using G52's for multiple parts }
SetFlag('3') {True = incrementing WFO numbers for MP. False = decrementing WFO numebrs for MP}
SetFlag('4') {True = toggle between incrementing/decrementing WFO's }
SetFlag('7') {True = in rigid tapping Mode }
UseSeparateSubCalls
SetMaxSeparateSubCalls('50')
SetMaxRPM('30000')
SetMaxFeed('500')
IF PSComment? AND UseComments?
'PostScript:' EOL
' Literals: put between single or double quotes.' EOL
' Separate commands and literals with at least one space.' EOL
' A CR ( RETURN key ) will start a new line.' EOL
' Commands: may be capital and/or lower case letters. Separate commands with a space.' EOL
' EndOP -' EOL
' all literals and commands before an ENDOP command' EOL
' will appear at the beginning of the operation. All ' EOL
' literals and commands after an ENDOP command will appear' EOL
' at the end of the operation. ' EOL
END
IF MultipleParts?
IF WorkFixtureOffsets?
IF LTEqual? MUL# Parts# NumOfCS# Num#('54')
SetWFOCS { use WFO for CS changes }
ELSE
SetFlag('2')
IF UseComments?
'( Not enough Work Fixture Offsets to handle this part. )' EOL
'( Number of parts [ ' Parts# ' ] times CSs [ ' NumOfCS# ' ] )' EOL
'( exceeds the machine limit. Switching to G52 style output. )' EOL
END
END
END
ELSE
IF LTEqual? NumOfCS# Num#('54') {****}
SetWFOCS { use WFO for CS changes }
ELSE
IF UseComments?
'( Not enough Work Fixture Offsets to handle this part. )' EOL
'( Number of CSs [ ' NumOfCS# ' ] exceeds the machine limit. )' EOL
'( Switching to G52 style output. )' EOL
END
END
END
RETURN
OpGuts:
IF NOT SameTool?
RapidF# {forces the output of a conditional feedrate}
END
IF Milling?
SeqC ZCP2C EOL
IF Repeats?
IF ZshiftOnly? AND AutoCycle?
{done in CutAutoCycle called from ToolPath}
ELSE
EACHRep
DoRepComment
IF NOT FirstCycle?
SeqC Connect StrtPos EOL
IF NOT FeedConnect?
SeqC ZCP2C EOL
END
END
END
END
IF NOT AutoCycle?
EntryMove
END
ToolPath
IF Repeats?
IF ZshiftOnly? AND AutoCycle?
{done in CutAutoCycle called from ToolPath}
ELSE
SeqC CRCOffC
IF NOT FeedConnect?
ExitType PRIME ZCP3C
END
ExitFeed EOL
NEXTRep
END
END
IF AutoCycle?
SeqC ZCP3C EOL
ELSE
SeqC CRCOffC ExitType ZCP3C ExitFeed EOL
END
ELSE
IF Drilling?
IF Repeats?
EACHRep
DoRepComment
END
SeqC DrillCP EOL
GetCycle
IF RigidTap?
SeqC Speed EOL
SeqC 'M135' EOL
SeqC Cycle FromCP ZDepth RLevel FeedEntC EOL
ELSE
SeqC Cycle FromCP ZDepth RLevel Dwell Peck Retract FeedEntC EOL
END
TrackZNO# FIRST SPZ# {.81}
ToolPath
IF RetractToCP1? {.81}
TrackZNO# ClearancePlane1#
ELSE
TrackZNO# ClearancePlane2#
END
SeqC DrillOff ZCP3
IF RigidTap?
'G4P500' {Dwells after Rigid Tapping cycle}
END
EOL
IF Repeats?
NEXTRep
END
SeqC RapidC ZCP3C EOL
END
END
RETURN
DefaultWFO:
IF NOT SameTool?
IF NeedWFO1?
SeqC WFO1 EOL
END
END
RETURN
DoCSG52:
DoCSG52Comment
DefaultWFO
SeqC 'G52X' CSOffsetX# 'Y' CSOffsetY# 'Z' CSOffsetZ# EOL
RETURN
DefaultCSG52:
IF NOT SameTool?
DoCSG52
END
RETURN
DefaultCSWFO:
IF NOT SameTool?
SeqC CSWFO EOL
END
RETURN
WFOStuff:
IF MultipleParts?
IF NOT WorkFixtureOffsets?
DefaultWFO
END
ELSE
IF WFOCS?
IF ChangeCS?
DoCSWFOComment
SeqC CSWFO EOL
ELSE
DefaultCSWFO
END
ELSE
IF ChangeCS?
DoCSG52
ELSE
DefaultCSG52
END
END
ClearCSOffset
END
RETURN
InitOp:
EOR EOL
ProgID1
IF UseComments? AND ProgramNameComment?
'( PROGRAM: ' ProgramName$ ' )'
END
EOL
IF ToolChangeAtHome?
SetHome
END
IF UseComments?
IF ProgramComment?
'( ' ProgramComment$ ' )' EOL
END
IF FormatNameComment?
'( FORMAT: ' FormatName$ ' )' EOL
END
IF TimeComment?
'( ' Date$ ' AT ' Time$ ' )' EOL
END
IF MovesComment?
'( OUTPUT IN ' MoveType$ ' INCHES )' EOL
END
IF PartsComment?
'( PARTS PROGRAMMED: ' Parts# ' )' EOL
END
IF StartToolComment?
'( FIRST TOOL NOT IN SPINDLE )' EOL {Removed AND ' Plane ' Plane - JHE}
END
END
OpenSub
RestoreScale
RETURN
FirstOp1:
Seq OpToolID EOL
DoOpComments
SeqC ToolChng EOL
DoPostScript
RETURN
FirstOp2:
GetCycle
IF Drilling? AND RigidTap?
SeqC 'G8P0' EOL
SetFlag('7')
ELSE
SetFlagF('7')
END
RETURN
FirstOp3:
CheckPass
IF AAxisAvail? OR BAxisAvail?
SeqC 'M11' EOL {Unclamp rotary table}
END
SeqC AbsOrInc Plane Rapid StrtPos CSAngleA CSAngleB {Added Plane - JHE}
IF Drilling?
IF NOT RigidTap?
SpeedC SpinOn
END
ELSE
SpeedC SpinOn
END
EOL
IF AAxisAvail? OR BAxisAvail?
SeqC 'M10' EOL {Clamp rotary table}
END
RETURN
FirstOp4:
SeqC OfstOn CoolOn
IF NOT LastTool?
PreTool
END
EOL
RETURN
NewToolOp1:
IF MultipleParts? AND OneToolAllParts? AND FullUp?
SeqC IncValue OfstOff EOL {Does not cancel offset in NewToolOp1}
END
RETURN
NewToolOp2:
IF Flag?('7')
SeqC 'G8P1' EOL
END
DoEndOpPS
SeqC ToolChng EOL {M6 calls toolchange macro, must be called twice per tool change.}
IF LAST ProgStop?
SeqC 'M0' EOL
ELSE
SeqC ProgStop EOL
END
RETURN
NewToolOp3: {Start new Operation}
Seq OpToolID EOL
DoOpComments
SeqC ToolChng EOL
DoPostScript
RETURN
NewToolOp4:
GetCycle
IF Drilling? AND RigidTap?
SeqC 'G8P0' EOL
SetFlag('7')
ELSE
SetFlagF('7')
END
RETURN
NewToolOp5:
CheckPass
IF AAxisAvail? OR BAxisAvail?
SeqC 'M11' EOL {Unclamp rotary table}
END
SeqC AbsOrInc PlaneC Rapid StrtPos CSAngleA CSAngleB {Added PlaneC - JHE}
IF Drilling?
IF NOT RigidTap?
Speed SpinOn
END
ELSE
Speed SpinOn
END
EOL
IF AAxisAvail? OR BAxisAvail?
SeqC 'M10' EOL {Clamp rotary table}
END
RETURN
NewToolOp6:
SeqC OfstOn CoolOn
IF NOT LastTool?
PreTool
END
EOL
RETURN
SameToolOp1:
DoEndOpPS
IF LAST ProgStop?
SeqC CoolOff EOL
IF AbsoluteMoves?
SeqC IncValue OfstOff EOL
SeqC AbsValue EOL
ELSE
SeqC OfstOff EOL
END
SeqC SpinOff EOL
SeqC 'M0' EOL
ELSE
IF CoolOff? AND LAST NOT CoolOff?
SeqC CoolOff EOL
END
IF NewToolOffset? or ChangeCS?
IF AbsoluteMoves?
SeqC IncValue OfstOff EOL
SeqC AbsValue EOL
ELSE
SeqC OfstOff EOL
END
END
END
RETURN
SameToolOp2: {Start new Operation}
DoOpComments
DoPostScript
CheckPass
RETURN
SameToolOp3: {Start new Operation}
IF LAST ProgStop?
IF AAxisAvail? OR BAxisAvail?
IF SameTool?
IF AChange? OR BChange?
SeqC 'M11' EOL {Unclamp rotary table}
END
END
END
SeqC AbsOrInc PlaneC Rapid StrtPos CSAngleA CSAngleB
IF Drilling?
IF NOT RigidTap?
SpeedC
END
ELSE
SpeedC
END
EOL
IF AAxisAvail? OR BAxisAvail?
IF SameTool?
IF AChange? OR BChange?
SeqC 'M10' EOL {clamp rotary table}
END
END
END
SeqC OfstOn CoolOn EOL
ELSE
IF AAxisAvail? OR BAxisAvail?
IF SameTool?
IF AChange? OR BChange?
SeqC 'M11' EOL {Unclamp rotary table}
END
END
END
SeqC PlaneC RapidC StrtPos CSAngleA CSAngleB
IF Drilling?
IF NOT RigidTap?
SpeedC
END
ELSE
SpeedC SpinOn
END
EOL
IF AAxisAvail? OR BAxisAvail?
IF SameTool?
IF AChange? OR BChange?
SeqC 'M10' EOL {clamp rotary table}
END
END
END
SeqC
IF NewToolOffset? OR ChangeCS?
OfstOn
END
IF NOT CoolOff? AND LAST CoolOff?
CoolOn
END
EOL
END
RETURN
End1:
IF Flag?('7')
SeqC 'G8P1' EOL {Used For rigid Tapping}
END
SeqC CoolOff EOL
IF AbsoluteMoves?
SeqC IncValue OfstOff
ELSE
SeqC OfstOff
END
IF OneToolAllParts? AND FullUp?
ELSE
SeqC SpinOff EOL
END
EOL
RETURN
End2:
DoEndOpPS
IF NOT Equal? CSOffsetA# Num#('0') OR NOT Equal? CSOffsetB# Num#('0')
IF AAxisAvail?
SeqC CSAngleA
END
IF BAxisAvail?
SeqC CSAngleB
END
EOL
SeqC 'G92'
IF AAxisAvail?
'A0'
END
IF BAxisAvail?
'B0'
END
EOL
END
IF ProgStop?
SeqC 'M0' EOL
END
RETURN
End3:
IF OneToolAllParts? AND FullUp?
SeqC SpinOff EOL
END
SeqC 'G30X0Y0' EOL
SeqC AbsValue EOL
SeqC EOP EOL
CloseSub
Post2 {organize Subs into one program}
EOR EOL
Close
IF UseComments?
SetScale('1') {restore scale for comments}
Reopen
IF FileBytesComment?
'( FILE LENGTH: ' FileBytes# ' CHARACTERS )' EOL
END
IF FileFeetComment?
'( FILE LENGTH: ' FileFeet# ' FEET )' EOL
END
IF FileMetersComment?
'( FILE LENGTH: ' FileMeters# ' METERS )' EOL
END
Close
END
RETURN
MPallTools1P: {Multiple Parts, All Tools 1 Part}
EachOp {Start of post processing}
IF FirstOperation?
InitOp
OpenMP
FirstOp1
WFOStuff
FirstOp2
FirstOp3
FirstOp4
ELSE
IF NewTool?
NewToolOp1
NewToolOp2 {to tool change, CS problem}
SubCSMP
NewToolOp3
WFOStuff
NewToolOp4
NewToolOp5
NewToolOp6
ELSE {implied SameTool?}
SameToolOp1
SubCSMP
SameToolOp2
SameToolOp3
END
END {common point for all operations}
OpGuts
NextOp {loops back to EachOP until last Operation}
End1 {End of program}
End2
CloseMP
End3
RETURN
MP1ToollAllPfu: {Multiple Parts, 1 Tool all Parts, full up}
EachOp {Start of post processing}
IF FirstOperation?
InitOp
FirstOp1
WFOStuff
FirstOp2
OpenMP
FirstOp3
FirstOp4
ELSE
IF NewTool?
NewToolOp1
CloseMP
NewToolOp2 {to tool change, CS problem}
NewToolOp3
WFOStuff
NewToolOp4
OpenMP
NewToolOp5
NewToolOp6
ELSE {implied SameTool?}
SameToolOp1
SubCSMP
SameToolOp2
SameToolOp3
END
END {common point for all operations}
OpGuts
NextOp {loops back to EachOP until last Operation}
End1 {End of program}
CloseMP
End2
End3
RETURN
MP1ToollAllPXcp: {Multiple Parts, 1 Tool all Parts, exit Clearance plane}
EachOp {Start of post processing}
IF FirstOperation?
InitOp
FirstOp1
WFOStuff
FirstOp2
FirstOp4
OpenMP
FirstOp3 {can't XY position before WFO}
ELSE
IF NewTool?
CloseMP
NewToolOp1
NewToolOp2 {to tool change, CS problem}
NewToolOp3
WFOStuff
NewToolOp4
NewToolOp6
OpenMP
NewToolOp5 {can't XY position before WFO}
ELSE {implied SameTool?}
SameToolOp1
SubCSMP
SameToolOp2
SameToolOp3
END
END {common point for all operations}
OpGuts
NextOp {loops back to EachOP until last Operation}
CloseMP {End of program}
End1
End2
End3
RETURN
NoMPs: {no multiple parts}
EachOp {Start of post processing}
IF FirstOperation?
InitOp
FirstOp1
WFOStuff
FirstOp2
FirstOp3
FirstOp4
ELSE
IF NewTool?
NewToolOp1
NewToolOp2
NewToolOp3
WFOStuff
NewToolOp4
NewToolOp5
NewToolOp6
ELSE {implied SameTool?}
SameToolOp1
SameToolOp2
WFOStuff
SameToolOp3
END
END {common point for all operations}
OpGuts
NextOp {loops back to EachOP until last Operation}
End1 {End of program}
End2
End3
RETURN
{Start of executable Prog, top level ****}
ProgStart {setup and initializations}
IF MultipleParts?
IF AllToolsOnePart?
MPallTools1P
ELSE {implied OneToolAllParts?}
IF FullUp?
MP1ToollAllPfu
ELSE {implied ExitClearancePlane?}
MP1ToollAllPXcp
END
END
ELSE
NoMPs
END
Wyszukiwarka
Podobne podstrony:
Fanuc 16M Makino [MM] CX91 13Fanuc 16M Makino [EE] NMT56 16Fanuc 16M Makino [APM] C427 12Fanuc 16M Makino [MM] CX91 13mFanuc 16M Makino M833 89mFanuc 16M Makino [EE] NMT56 16mFanuc 16M [AP] C789 13 5mFanuc 16M [SB] CX54 13 1Fanuc 16M [AP] C789 13 5Fanuc 16M LM [M&L] CT52 13 4Fanuc 16M Edgetec L570 85Fanuc 6M Makino [NRC] M869 89Fanuc 11M MTS LH M059 13 1Fanuc 3000C HS [NI] D384 13Fanuc 16M [NM] M834 89 5mwięcej podobnych podstron