Misplaced Pages

G-code: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 14:53, 27 December 2022 editActivelyDisinterested (talk | contribs)Extended confirmed users50,265 edits Clearing cs1 error← Previous edit Latest revision as of 00:15, 17 December 2024 edit undo76.69.142.126 (talk) History: Fixed grammar: verbal tense (are to were), readability (slightly shorter sentence).Tags: Mobile edit Mobile app edit Android app edit App section source 
(39 intermediate revisions by 29 users not shown)
Line 1: Line 1:
{{short description|Programming languages}} {{short description|Primary programming language used in CNC}}
{{other uses|G-code (disambiguation)|G programming language (disambiguation)}} {{other uses|G-code (disambiguation)|G programming language (disambiguation)}}
{{redirect|RS-274|the photoplotter format|Gerber format}} {{redirect|RS-274|the photoplotter format|Gerber format}}
{{Infobox programming language {{Infobox programming language
| name = machine codes | name = G-code
| logo =
| caption =
| file ext = .gcode, .mpt, .mpf, .nc and several others | file ext = .gcode, .mpt, .mpf, .nc and several others
| paradigm = ], ] | paradigm = ], ]
| released = 1950s (first edition)<!-- {{Start date|YYYY}} --> | released = {{Start date|1963}} (RS-274)
| designer = ] | designer = ]
| developer = ] (RS-274), ] (ISO-6983)
| developer =
| implementations = Numerous; mainly ] Sinumerik, ], ], ], ], ]
| latest release version =
| dialects =
| latest release date = <!-- {{start date and age|YYYY|MM|DD}} -->
| influenced by =
| latest preview version =
| influenced =
| latest preview date = <!-- {{start date and age|YYYY|MM|DD}} -->
| programming language =
| typing =
| platform =
| implementations = many, mainly ] Sinumerik, ], ], ], ], ]. Generally there is one international standard—] 6983.
| operating system =
| dialects =
| influenced by = | license =
| influenced = | website =
| wikibooks =
| programming language =
| platform =
| operating system =
| license =
| website =
| wikibooks =
}} }}
'''G-code''' (also '''RS-274''') is the most widely used ] (CNC) ]. It is used mainly in ] to control automated machine tools, and has many variants.


'''G-code''' (also '''RS-274''') is the most widely used ] (CNC) and ] ]. It is used mainly in ] to control automated ]s, as well as for ]. The ''G'' stands for geometry. G-code has many variants.
G-code instructions are provided to a machine controller (industrial computer) that tells the motors where to move, how fast to move, and what path to follow. The two most common situations are that, within a ] such as a ] or ], a ] is moved according to these instructions through a toolpath cutting away material to leave only the finished workpiece and/or an unfinished workpiece is precisely positioned in any of up to nine axes<ref>Karlo Apro (2008). ''''. Industrial Press Inc. {{ISBN|0-8311-3375-9}}.</ref> around the three dimensions relative to a toolpath and, either or both can move relative to each other. The same concept also extends to noncutting tools such as forming or burnishing tools, ], additive methods such as ], and measuring instruments.


G-code instructions are provided to a ] (industrial computer) that tells the motors where to move, how fast to move, and what path to follow. The two most common situations are that, within a machine tool such as a ] or ], a ] is moved according to these instructions through a toolpath cutting away material to leave only the finished workpiece and/or an unfinished workpiece is precisely positioned in any of up to nine axes<ref>Karlo Apro (2008). ''''. Industrial Press Inc. {{ISBN|0-8311-3375-9}}.</ref> around the three dimensions relative to a toolpath and, either or both can move relative to each other. The same concept also extends to noncutting tools such as ] or ] tools, ], additive methods such as 3D printing, and measuring instruments.
==Implementations==
The first implementation of a numerical control programming language was developed at the ] Servomechanisms Laboratory in the late 1950s. In the decades since, many implementations have been developed by many (commercial and noncommercial) organizations. G-code has often been used in these implementations. The main standardized version used in the United States was settled by the ] in the early 1960s.{{Citation needed|date=March 2010}} A final revision was approved in February 1980 as ''RS-274-D''.<ref>{{citation| title = EIA Standard RS-274-D Interchangeable Variable Block Data Format for Positioning, Contouring, and Contouring/Positioning Numerically Controlled Machines |publisher = Electronic Industries Association |location= Washington D.C. |date=February 1979}}</ref> In other countries, the standard ''] 6983'' is often used, but many European countries use other standards. For example, ''] 66025'' is used in Germany, and PN-73M-55256 and PN-93/M-55251 were formerly used in Poland.


== History ==
Extensions and variations have been added independently by control manufacturers and machine tool manufacturers, and operators of a specific controller must be aware of differences of each manufacturer's product.


The first implementation of a numerical control programming language was developed at the ] in the 1950s. In the decades that followed, many implementations were developed by numerous organizations, both commercial and noncommercial. Elements of G-code had often been used in these implementations.<ref>{{cite book | last=Xu | first=Xun | date=2009 | url=https://books.google.com/books?id=habcATPQWJ4C | title=Integrating Advanced Computer-aided Design, Manufacturing, and Numerical Control: Principles and Implementations | publisher=Information Science Reference | page=166 | isbn=978-1-59904-716-4 | via=Google Books}}</ref><ref>{{cite book | last=Harik | first=Ramy | author2=Thorsten Wuest | date=2019 | url=https://books.google.com/books?id=O3h0EAAAQBAJ | title=Introduction to Advanced Manufacturing | publisher=SAE International | page=116 | isbn=978-0-7680-9096-3 | via=Google Books}}</ref> The first ] version of G-code used in the United States, ''RS-274'', was published in 1963 by the ] (EIA; then known as Electronic Industries Association).<ref>{{cite book | last=Evans | first=John M. Jr. | date=1976 | url=https://www.govinfo.gov/content/pkg/GOVPUB-C13-2ef4aaa5a150eedcb85a1e6985e90bfa/pdf/GOVPUB-C13-2ef4aaa5a150eedcb85a1e6985e90bfa.pdf | title=National Bureau of Standards Information Report (NBSIR) 76-1094 (R): Standards for Computer Aided Manufacturing | publisher=National Bureau of Standards | page=43}}</ref> In 1974, EIA approved ''RS-274-C'', which merged ''RS-273'' (variable block for positioning and straight cut) and ''RS-274-B'' (variable block for contouring and contouring/positioning). A final revision of ''RS-274'' was approved in 1979, as ''RS-274-D''.<ref>{{cite journal | last=Schenck | first=John P. | date=January 1, 1998 | url=https://link.gale.com/apps/doc/A20429590/GPS?sid=wikipedia | title=Understanding common CNC protocols | journal=Wood & Wood Products | publisher=Vance Publishing | volume=103 | issue=1 | page=43 | via=Gale}}</ref><ref>{{citation| title = EIA Standard RS-274-D Interchangeable Variable Block Data Format for Positioning, Contouring, and Contouring/Positioning Numerically Controlled Machines |publisher = Electronic Industries Association |location= Washington D.C. |date=February 1979}}</ref> In other countries, the standard ''] 6983'' (finalized in 1982) is often used, but many European countries use other standards.<ref>{{cite book | last=Stark | first=J. | author2=V.&nbsp;K. Nguyen | date=2009 | url=https://books.google.com/books?id=RIgLRe12RD4C | chapter=STEP-compliant CNC Systems, Present and Future Directions | title=Advanced Design and Manufacturing Based on STEP | editor-last=Xu | editor-first=Xun | editor2=Andrew Yeh Ching Nee | publisher=Springer London | page=216 | isbn=978-1-84882-739-4 | via=Google Books}}</ref> For example, ''] 66025'' is used in Germany, and PN-73M-55256 and PN-93/M-55251 were formerly used in Poland.
One standardized version of G-code, known as ''BCL'' (Binary Cutter Language), is used only on very few machines. Developed at MIT, BCL was developed to control CNC machines in terms of straight lines and arcs.<ref>{{Cite book|url=https://books.google.com/books?id=GE8vBQAAQBAJ&q=binary+cutter+language+gcode&pg=PA321|title=Information Technology Standards : Quest for the Common Byte.|last=Martin.|first=Libicki|date=1995|publisher=Elsevier Science|isbn=9781483292489|location=Burlington|pages=321|oclc=895436474}}</ref>


During the 1970s through 1990s, many CNC machine tool builders attempted to overcome compatibility difficulties by standardizing on machine tool controllers built by ]. ] was another market dominator in CNC controls, especially in Europe. In the 2010s, controller differences and incompatibility are not as troublesome because machining operations are usually developed with CAD/CAM applications that can output the appropriate G-code for a specific machine through a software tool called a post-processor (sometimes shortened to just a "post"). During the 1970s through 1990s, many CNC machine tool builders attempted to overcome compatibility difficulties by standardizing on machine tool controllers built by ]. ] was another market dominator in CNC controls, especially in Europe. In the 2010s, controller differences and incompatibility were mitigated with the widespread adoption of CAD/CAM applications that were capable of outputting machine operations in the appropriate G-code for a specific machine through a software tool called a post-processor (sometimes shortened to just a "post").


== Syntax ==
Some CNC machines use "conversational" programming, which is a ]-like programming mode that either hides G-code or completely bypasses the use of G-code. Some popular examples are Okuma's Advanced One Touch (AOT), Southwestern Industries' ProtoTRAK, Mazak's Mazatrol, Hurco's Ultimax and Winmax, Haas' Intuitive Programming System (IPS), and Mori Seiki's CAPS conversational software.


G-code began as a limited language that lacked constructs such as loops, conditional operators, and programmer-declared variables with ]-word-including names (or the expressions in which to use them). It was unable to encode logic, but was just a way to "connect the dots" where the programmer figured out many of the dots' locations longhand. The latest implementations of G-code include macro language capabilities somewhat closer to a ]. Additionally, all primary manufacturers (e.g., Fanuc, Siemens, Heidenhain) provide access to ] (PLC) data, such as axis positioning data and tool data,<ref>{{cite web |url=http://www.machinetoolhelp.com/Applications/macro/system_variables.html |title=Fanuc macro system variables |access-date=2014-06-30}}</ref> via variables used by NC programs. These constructs make it easier to develop automation applications. G-code began as a limited language that lacked constructs such as loops, conditional operators, and programmer-declared variables with ]-word-including names (or the expressions in which to use them). It was unable to encode logic but was just a way to "connect the dots" where the programmer figured out many of the dots' locations longhand. The latest implementations of G-code include macro language capabilities somewhat closer to a ]. Additionally, all primary manufacturers (e.g., Fanuc, Siemens, ]) provide access to ] (PLC) data, such as axis positioning data and tool data,<ref>{{cite web |archive-date=2014-05-03 |url=http://www.machinetoolhelp.com/Applications/macro/system_variables.html |title=Fanuc macro system variables |access-date=2014-06-30 |archive-url=https://web.archive.org/web/20140503030834/http://www.machinetoolhelp.com/Applications/macro/system_variables.html }}</ref> via variables used by NC programs. These constructs make it easier to develop automation applications.


== Specific codes == == Extensions and variations ==
G-codes, also called preparatory codes, are any word in a CNC program that begins with the letter ]. Generally it is a code telling the machine tool what type of action to perform, such as:
* Rapid movement (transport the tool as quickly as possible in between cuts)
* Controlled feed in a straight line or arc
* Series of controlled feed movements that would result in a hole being bored, a workpiece cut (routed) to a specific dimension, or a profile (contour) shape added to the edge of a workpiece
* Set tool information such as offset
* Switch coordinate systems


Extensions and variations have been added independently by control manufacturers and machine tool manufacturers, and operators of a specific controller must be aware of the differences between each manufacturer's product.
There are other codes; the type codes can be thought of like ] in a computer.


One standardized version of G-code, known as ''BCL'' (Binary Cutter Language), is used only on very few machines. Developed at MIT, BCL was developed to control CNC machines in terms of straight lines and arcs.<ref>{{Cite book|url=https://books.google.com/books?id=GE8vBQAAQBAJ&q=binary+cutter+language+gcode&pg=PA321|title=Information Technology Standards: Quest for the Common Byte.|last=Martin.|first=Libicki|date=1995|publisher=Elsevier Science|isbn=978-1-4832-9248-9|location=Burlington|page=321|oclc=895436474}}</ref>
It has been pointed out over the years that the term "G-code" is imprecise because "G" is only one of many letter addresses in the complete language. It comes from the literal sense of the term, referring to one letter address and to the specific codes that can be formed with it (for example, G00, G01, G28), but every letter of the English alphabet is ]. Nevertheless, "G-code" is ] established as the common name of the language.


Some CNC machines use "conversational" programming, which is a ]-like programming mode that either hides G-code or completely bypasses the use of G-code. Some popular examples are Okuma's Advanced One Touch (AOT), Southwestern Industries' ProtoTRAK, Mazak's Mazatrol, Hurco's Ultimax and Winmax, Haas' Intuitive Programming System (IPS), and Mori Seiki's CAPS conversational software.
===Letter addresses===
Some letter addresses are used only in milling or only in ]; most are used in both. '''Bold''' below are the letters seen most frequently throughout a program.


== See also ==
Sources: Smid 2008;<ref name="Smid2008">{{Harvnb|Smid|2008}}.</ref> Smid 2010;<ref name="Smid2010">{{Harvnb|Smid|2010}}.</ref> Green et al. 1996.<ref name="Greenetal1996">{{Harvnb|Machinery's Handbook|1996|pp=1162–1226}}.</ref>

{| class="wikitable"
|-
! Variable !! Description !! Corollary info
|-
| valign="top" | {{Visible anchor|A}} || Absolute or incremental position of A axis (rotational axis around X axis) ||Positive rotation is defined as a counterclockwise rotation looking from X positive towards X negative.
|-
| valign="top" | {{Visible anchor|B}} || Absolute or incremental position of B axis (rotational axis around Y axis) ||
|-
| valign="top" | {{Visible anchor|C}} || Absolute or incremental position of C axis (rotational axis around Z axis) ||
|-
| valign="top" | {{Visible anchor|D}} || Defines diameter or radial offset used for cutter compensation. D is used for depth of cut on lathes. It is used for aperture selection and commands on photoplotters. ||]: left cutter compensation, ]: right cutter compensation
|-
| valign="top" | {{Visible anchor|E}} || Precision feedrate for threading on lathes ||
|-
| valign="top" | {{Visible anchor|F}} || Defines ] || Common units are distance per time for mills (inches per minute, IPM, or millimeters per minute, mm/min) and distance per revolution for lathes (inches per revolution, IPR, or millimeters per revolution, mm/rev)
|-
| valign="top" | '''{{Visible anchor|G}}''' || Address for preparatory commands || G commands often tell the control what kind of motion is wanted (e.g., rapid positioning, linear feed, circular feed, fixed cycle) or what offset value to use.
|-
| valign="top" | {{Visible anchor|H}} || Defines tool length offset; <br> Incremental axis corresponding to C axis (e.g., on a turn-mill) ||]: Negative tool length compensation, ]: Positive tool length compensation
|-
| valign="top" | {{Visible anchor|I}} || Defines arc center in X axis for ] or ] arc commands. <br> Also used as a parameter within some fixed cycles. ||The arc center is the relative distance from the current position to the arc center, not the absolute distance from the work coordinate system (WCS).
|-
| valign="top" | {{Visible anchor|J}} || Defines arc center in Y axis for ] or ] arc commands. <br> Also used as a parameter within some fixed cycles. ||Same corollary info as I above.
|-
| valign="top" | {{Visible anchor|K}} || Defines arc center in Z axis for ] or ] arc commands. <br> Also used as a parameter within some fixed cycles, equal to ] address. ||Same corollary info as I above.
|-
| valign="top" | {{Visible anchor|L}} || Fixed cycle loop count; <br> Specification of what register to edit using ] || ''Fixed cycle loop count:'' Defines number of repetitions ("loops") of a fixed cycle at ''each'' position. Assumed to be 1 unless programmed with another integer. Sometimes the ] address is used instead of L. With incremental positioning (]), a series of equally spaced holes can be programmed as a loop rather than as individual positions. <br> ''] use:'' Specification of what register to edit (work offsets, tool radius offsets, tool length offsets, etc.).
|-
| valign="top" | '''{{Visible anchor|M}}''' || Miscellaneous function || Action code, auxiliary command; descriptions vary. Many M-codes call for machine functions, which is why people often say that the "M" stands for "machine", although it was not intended to.
|-
| valign="top" | {{Visible anchor|N}} || Line (block) number in program; <br> System parameter number to change using ] || ''Line (block) numbers:'' Optional, so often omitted. Necessary for certain tasks, such as ] ] address (to tell the control which block of the program to return to if not the default) or ] statements (if the control supports those). ] numbering need not increment by 1 (for example, it can increment by 10, 20, or 1000) and can be used on every block or only in certain spots throughout a program. <br> ''System parameter number:'' ] allows changing of system parameters under program control.<ref name="Smid2004">{{Harvnb|Smid|2004|p=61}}</ref>
|-
| valign="top" | {{Visible anchor|O}} || Program name || For example, O4501. For many years it was common for CNC control displays to use ] glyphs to ensure effortless distinction of letter "O" from digit "0". Today's GUI controls often have a choice of fonts, like a PC does.
|-
| valign="top" | {{Visible anchor|P}} || Serves as parameter address for various G and M codes ||
* With ], defines dwell time value.
* Also serves as a parameter in some canned cycles, representing dwell times or other variables.
* Also used in the calling and termination of subprograms. (With ], it specifies which subprogram to call; with ], it specifies which block number of the main program to return to.)
|-
| valign="top" | {{Visible anchor|Q}} || Peck increment in canned cycles || For example, ], ] (peck drilling cycles)
|-
| valign="top" | {{Visible anchor|R}} || Defines size of arc radius, or defines retract height in milling canned cycles || For radii, not all controls support the R address for ] and ], in which case IJK vectors are used. For retract height, the "R level", as it's called, is returned to if ] is programmed.
|-
| valign="top" | {{Visible anchor|S}} || Defines ], either spindle speed or surface speed depending on mode || Data type = integer. In ] mode (which is usually the default), an integer after S is interpreted as a number of ] (rpm). In ] mode (Constant Surface Speed or CSS), an integer after S is interpreted as ]—sfm (]) or m/min (]). See also ]. On multifunction (turn-mill or mill-turn) machines, which spindle gets the input (main spindle or subspindles) is determined by other M codes.
|-
| valign="top" | {{Visible anchor|T}} || Tool selection || To understand how the T address works and how it interacts (or not) with ], one must study the various methods, such as lathe turret programming, ATC (Automatic Tool Change, set by ]) fixed tool selection, ATC random memory tool selection, the concept of "next tool waiting", and empty tools.<ref name="Smid2008" /> Programming on any particular machine tool requires knowing which method that machine uses.<ref name="Smid2008" />
|-
| valign="top" | {{Visible anchor|U}} || Incremental axis corresponding to X axis (typically only lathe group A controls) <br> Also defines dwell time on some machines (instead of "]" or "]"). || In these controls, X and U obviate ] and ], respectively. On these lathes, G90 is instead ].
|-
| valign="top" | {{Visible anchor|V}} || Incremental axis corresponding to Y axis || Until the 2000s, the V address was very rarely used because most lathes that used U and W didn't have a Y-axis, so they didn't use V. (Green ''et al.'' 1996<ref name="Greenetal1996"/> did not even list V in their table of addresses.) That is still often the case, although the proliferation of live lathe tooling and turn-mill machining has made V address usage less rare than it used to be (Smid 2008<ref name="Smid2008"/> shows an example). See also ].
|-
| valign="top" | {{Visible anchor|W}} || Incremental axis corresponding to Z axis (typically only lathe group A controls) || In these controls, Z and W obviate ] and ], respectively. On these lathes, G90 is instead ].
|-
| valign="top" | '''{{Visible anchor|X}}''' || Absolute or incremental position of X axis. <br> Also defines dwell time on some machines (instead of "]" or "]"). ||
|-
| valign="top" | '''{{Visible anchor|Y}}''' || Absolute or incremental position of Y axis ||
|-
| valign="top" | '''{{Visible anchor|Z}}''' || Absolute or incremental position of Z axis || The main spindle's axis of rotation often determines which axis of a machine tool is labeled as Z.
|}

==={{anchor|List of G-codes}} List of G-codes commonly found on ] and similarly designed controls for milling and turning===

Sources: Smid 2008;<ref name="Smid2008"/> Smid 2010;<ref name="Smid2010"/> Green et al. 1996.<ref name="Greenetal1996"/>

::<small>'''Note''': '''''Modal''''' means a code stays in effect until replaced, or cancelled, by another permitted code. '''''Non-Modal''''' means it executes only once. See, for example, codes G09, G61 & G64 below.</small>

{| class="wikitable"
! style="width: 3em;" | Code
! style="width: 12em;" | Description
! style="width: 4em;" | Milling <br> ( M )
! style="width: 4em;" | Turning <br> ( T )
! Corollary info
|-
| valign="top" | {{Visible anchor|G00}} || Rapid positioning || M || T || On 2- or 3-axis moves, G00 (unlike ]) traditionally does not necessarily move in a single straight line between start point and endpoint. It moves each axis at its max speed until its vector quantity is achieved. A shorter vector usually finishes first (given similar axis speeds). This matters because it may yield a dog-leg or hockey-stick motion, which the programmer needs to consider, depending on what obstacles are nearby, to avoid a crash. Some machines offer interpolated rapids as a feature for ease of programming (safe to assume a straight line).
|-
| valign="top" | {{Visible anchor|G01}} || ] || M || T || The most common workhorse code for feeding during a cut. The program specs the start and endpoints, and the control automatically calculates (]) the intermediate points to pass through that yield a straight line (hence "]"). The control then calculates the angular velocities at which to turn the axis ]s via their servomotors or stepper motors. The computer performs thousands of calculations per second, and the motors react quickly to each input. Thus the actual toolpath of the machining takes place with the given feed rate on a path that is accurately linear to within very small limits.
|-
| valign="top" | {{Visible anchor|G02}} || Circular interpolation, clockwise || M || T || Very similar in concept to G01. Again, the control ] intermediate points and commands the servo- or stepper motors to rotate the amount needed for the leadscrew to translate the motion to the correct tooltip positioning. This process repeated thousands of times per minute generates the desired toolpath. In the case of G02, the interpolation generates a circle rather than a line. As with G01, the actual toolpath of the machining takes place with the given feed rate on a path that accurately matches the ideal (in ]'s case, a circle) to within very small limits. In fact, the interpolation is so precise (when all conditions are correct) that milling an interpolated circle can obviate operations such as drilling, and often even find boring. '''Addresses for radius or arc center:''' G02 and G03 take either an ] address (for the radius desired on the part) or ] addresses (for the component vectors that define the vector from the arc start point to the arc center point). '''Cutter comp:''' On most controls you cannot start ] or ] in ] or ] modes. You must already have compensated in an earlier ] block. Often, a short linear lead-in movement is programmed, merely to allow cutter compensation before the main action, the circle-cutting begins. '''Full circles:''' When the arc start point and the arc endpoint are identical, the tool cuts a 360° arc (a full circle). (Some older controls do not support this because arcs cannot cross between quadrants of the cartesian system. Instead, they require four quarter-circle arcs programmed back-to-back.)
|-
| valign="top" | {{Visible anchor|G03}} || Circular interpolation, counterclockwise || M || T || Same corollary info as for G02.
|-
| valign="top" | {{Visible anchor|G04}} || Dwell || M || T || Takes an address for dwell period (may be ], ], or ]). The dwell period is specified by a control parameter, typically set to ]s. Some machines can accept either X1.0 (]) or P1000 (]), which are equivalent. '''{{Visible anchor|Choosing dwell duration}}''': Often the dwell needs only to last one or two full spindle rotations. This is typically much less than one second. Be aware when choosing a duration value that a long dwell is a waste of cycle time. In some situations, it won't matter, but for high-volume repetitive production (over thousands of cycles), it is worth calculating that perhaps you only need 100 ], and you can call it 200 to be safe, but 1000 is just a waste (too long).
|-
| valign="top" | {{Visible anchor|G05}} P10000 || High-precision contour control (HPCC) || M || &nbsp; || Uses a deep look-ahead ] and simulation processing to provide better axis movement acceleration and deceleration during contour milling
|-
| valign="top" | {{Visible anchor|G05.1 Q1.}} || AI Advanced Preview Control || M || &nbsp; || Uses a deep look-ahead ] and simulation processing to provide better axis movement acceleration and deceleration during contour milling
|-
| valign="top" | {{Visible anchor|G06.1 }} || ] (NURBS) Machining || M || &nbsp; || Activates Non-Uniform Rational B Spline for complex curve and waveform machining (this code is confirmed in Mazatrol 640M ISO Programming)
|-
| valign="top" | {{Visible anchor|G07}} || Imaginary axis designation || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G09}} || Exact stop check, non-modal || M || T || The modal version is ].
|-
| valign="top" | {{Visible anchor|G10}} || Programmable data input || M || T || Modifies the value of work coordinate and tool offsets<ref>{{cite web|url=http://atyourservice.haascnc.com/faqs/clearing-all-offsets/|title=FAQ's - At Your Service|website=atyourservice.haascnc.com|access-date=5 April 2018|archive-url=https://web.archive.org/web/20150101054250/http://atyourservice.haascnc.com/faqs/clearing-all-offsets/|archive-date=1 January 2015|url-status=dead}}</ref><ref name="Smid2004"/>
|-
| valign="top" | {{Visible anchor|G11}} || Data write cancel || M || T || &nbsp;
|-
| valign="top" | {{Visible anchor|G17}} || XY plane selection || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G18}} || ZX plane selection || M || T ||
|-
| valign="top" | {{Visible anchor|G19}} || YZ plane selection || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G20}} || Programming in ]es || M || T || Somewhat uncommon except in USA and (to lesser extent) Canada and UK. However, in the global marketplace, competence with both G20 and G21 always stands some chance of being necessary at any time. The usual minimum increment in G20 is one ten-thousandth of an inch (0.0001"), which is a larger distance than the usual minimum increment in G21 (one thousandth of a millimeter, .001&nbsp;mm, that is, one ]). This physical difference sometimes favors G21 programming.
|-
| valign="top" | {{Visible anchor|G21}} || Programming in ]s (mm) || M || T || Prevalent worldwide. However, in the global marketplace, competence with both G20 and G21 always stands some chance of being necessary at any time.
|-
| valign="top" | {{Visible anchor|G28}} || Return to home position (machine zero, aka machine reference point) || M || T || Takes X Y Z addresses which define the intermediate point that the tool tip will pass through on its way home to machine zero. They are in terms of part zero (aka program zero), NOT machine zero.
|-
| valign="top" | {{Visible anchor|G30}} || Return to secondary home position (machine zero, aka machine reference point) || M || T || Takes a P address specifying ''which'' machine zero point to use ''if'' the machine has several secondary points (P1 to P4). Takes X Y Z addresses that define the intermediate point that the tooltip passes through on its way home to machine zero. These are expressed in terms of part zero (aka program zero), NOT machine zero.
|-
| valign="top" | {{Visible anchor|G31}} || Feed until skip function || M || &nbsp; || &nbsp;Used for probes and tool length measurement systems.
|-
| valign="top" | {{Visible anchor|G32}} || Single-point threading, longhand style (if not using a cycle, e.g., ]) || &nbsp; || T || Similar to ] linear interpolation, except with automatic spindle synchronization for ].
|-
| valign="top" | {{Visible anchor|G33}} || Constant-] threading || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G33}} || Single-point threading, longhand style (if not using a cycle, e.g., ]) || &nbsp; || T || Some lathe controls assign this mode to G33 rather than G32.
|-
| valign="top" | {{Visible anchor|G34}} || Variable-pitch threading || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G40}} || Tool radius compensation off || M || T || Turn off ]. Cancels G41 or G42.
|-
| valign="top" | {{Visible anchor|G41}} || Tool radius compensation left || M || T || Turn on ], left, for climb milling. <br> '''Milling:''' Given righthand-helix cutter and ] spindle direction, G41 corresponds to ]. Takes an address (] or ]) that calls an offset register value for radius. <br> '''Turning:''' Often needs no D or H address on lathes, because whatever tool is active automatically calls its geometry offsets with it. (Each turret station is bound to its geometry offset register.)

G41 and G42 for milling have been partially automated and obviated (although not completely) since ] programming has become more common. CAM systems let the user program as if using a zero-diameter cutter. The fundamental concept of cutter radius compensation is still in play (i.e., that the surface produced will be distance R away from the cutter center), but the programming mindset is different. The human does not choreograph the toolpath with conscious, painstaking attention to G41, G42, and G40, because the CAM software takes care of that. The software has various CRC mode selections, such as ''computer, control, wear, reverse wear, off'', some of which do not use G41/G42 at all (good for roughing, or wide finish tolerances), and others that use it so that the wear offset can still be tweaked at the machine (better for tight finish tolerances).
|-
| valign="top" | {{Visible anchor|G42}} || Tool radius compensation right || M || T || Turn on ], right, for conventional milling. Similar corollary info as for ]. Given righthand-helix cutter and M03 spindle direction, G42 corresponds to ].
|-
| valign="top" | {{Visible anchor|G43}} || Tool height offset compensation negative || M || &nbsp; || Takes an address, usually H, to call the tool length offset register value. The value is ''negative'' because it will be ''added'' to the gauge line position. G43 is the commonly used version (vs G44).
|-
| valign="top" | {{Visible anchor|G44}} || Tool height offset compensation positive || M || &nbsp; || Takes an address, usually H, to call the tool length offset register value. The value is ''positive'' because it will be ''subtracted'' from the gauge line position. G44 is the seldom-used version (vs G43).
|-
| valign="top" | {{Visible anchor|G45}} || Axis offset single increase || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G46}} || Axis offset single decrease || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G47}} || Axis offset double increase || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G48}} || Axis offset double decrease || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G49}} || Tool length offset compensation cancel || M || &nbsp; || Cancels ] or ].
|-
| valign="top" | {{Anchor|G50_RPM_clamp}} G50 || Define the maximum spindle speed || &nbsp; || T || Takes an ] address integer, which is interpreted as rpm. Without this feature, ] mode (CSS) would rev the spindle to "wide open throttle" when closely approaching the axis of rotation.
|-
| valign="top" | {{Anchor|G50_scaling_off}} G50 || Scaling function cancel || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Anchor|G50_position_register}} G50 || Position register (programming of vector from part zero to tooltip) || &nbsp; || T || Position register is one of the original methods to relate the part (program) coordinate system to the tool position, which indirectly relates it to the ], the only position the control really "knows". Not commonly programmed anymore because ] (WCSs) are a better, newer method. Called via G50 for turning, ] for milling. Those G addresses also have alternate meanings (''which see''). Position register can still be useful for datum shift programming. The "manual absolute" switch, which has very few useful applications in WCS contexts, was more useful in position register contexts because it allowed the operator to move the tool to a certain distance from the part (for example, by touching off a 2.0000" gage) and then declare to the control what the distance-to-go shall be (2.0000).
|-
| valign="top" | {{Visible anchor|G52}} || Local coordinate system (LCS) || M || &nbsp; || Temporarily shifts program zero to a new location. It is simply "an offset from an offset", that is, an additional offset added onto the ] offset. This simplifies programming in some cases. The typical example is moving from part to part in a multipart setup. With '''G54''' active, {{Code|G52 X140.0 Y170.0|gcode}} shifts program zero 140&nbsp;mm over in X and 170&nbsp;mm over in Y. When the part "over there" is done, {{Code|G52 X0 Y0|gcode}} returns program zero to normal G54 (by reducing G52 offset to nothing). The same result can also be achieved (1) using multiple WCS origins, G54/G55/G56/G57/G58/G59; (2) on newer controls, G54.1 P1/P2/P3/etc. (all the way up to P48); or (3) using ] for programmable data input, in which the program can write new offset values to the offset registers.<ref name="Smid2004"/> The method to use depends on the shop-specific application.
|-
| valign="top" | {{Visible anchor|G53}} || ] || M || T || Takes absolute coordinates (X,Y,Z,A,B,C) with reference to machine zero rather than program zero. Can be helpful for tool changes. Nonmodal and absolute only. Subsequent blocks are interpreted from the previously selected Work Coordinate System, ], even if it is not explicitly programmed.
|-
| valign="top" | {{Visible anchor|G54 to G59}} || Work coordinate systems (WCSs) || M || T || Have largely replaced position register (] and ]). Each tuple of axis offsets relates program zero directly to machine zero. Standard is 6 tuples (G54 to G59), with optional extensibility to 48 more via G54.1 P1 to P48.
|-
| valign="top" | {{Visible anchor|G54.1 P1 to P48}} || Extended work coordinate systems || M || T || Up to 48 more WCSs besides the 6 provided as standard by G54 to G59. Note floating-point extension of G-code data type (formerly all integers). Other examples have also evolved (e.g., ]). Modern controls have the ] to handle it.
|-
| valign="top" | {{Visible anchor|G61}} || Exact stop check, modal || M || T || Can be canceled with ]. The non-modal version is ].
|-
| valign="top" | {{Visible anchor|G62}} || Automatic corner override || M || T || &nbsp;
|-
| valign="top" | {{Visible anchor|G64}} || Default cutting mode (cancel exact stop check mode) || M || T || Cancels ].
|-
| valign="top" | {{Visible anchor|G68}} || Rotate coordinate system || M || &nbsp; || Rotates coordinate system in the current plane given with ], ], or ]. Center of rotation is given with two parameters, which vary with each vendor's implementation. Rotate with angle given with argument R. This can be used, for instance, to align the coordinate system with a misaligned part. It can also be used to repeat movement sequences around a center. Not all vendors support coordinate system rotation.
|-
| valign="top" | {{Visible anchor|G69}} || Turn off coordinate system rotation || M || &nbsp; || Cancels ].
|-
| valign="top" | {{Visible anchor|G70}} || Fixed cycle, multiple repetitive cycle, for finishing (including contours) || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|G71}} || Fixed cycle, multiple repetitive cycle, for roughing (Z-axis emphasis) || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|G72}} || Fixed cycle, multiple repetitive cycle, for roughing (X-axis emphasis) || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Anchor|G73_rough_turn_pattern_repeat}} G73 || Fixed cycle, multiple repetitive cycle, for roughing, with pattern repetition || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Anchor|G73_peck_drill}} G73 || Peck drilling cycle for milling – high-speed (NO full retraction from pecks) || M || &nbsp; || Retracts only as far as a clearance increment (system parameter). For when chipbreaking is the main concern, but chip clogging of flutes is not. Compare ].
|-
| valign="top" | {{Anchor|G74_pecking}} G74 || Peck drilling cycle for turning || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Anchor|G74_tapping}} G74 || Tapping cycle for milling, ], ] || M || &nbsp; || See notes at ].
|-
| valign="top" | {{Visible anchor|G75}} || Peck grooving cycle for turning || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Anchor|G76_bore_on_mill}} G76 || Fine boring cycle for milling || M || &nbsp; || Includes OSS and shift (oriented spindle stop and shift tool off centerline for retraction)
|-
| valign="top" | {{Anchor|G76_thread_on_lathe}} G76 || Threading cycle for turning, multiple repetitive cycle || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|G80}} || Cancel ] || M || T || '''Milling:''' Cancels all cycles such as ], ], ], etc. Z-axis returns either to Z-initial level or R&nbsp;level, as programmed (] or ], respectively). <br> '''Turning:''' Usually not needed on lathes, because a new group-1 G address (] to ]) cancels whatever cycle was active.
|-
| valign="top" | {{Visible anchor|G81}} || Simple drilling cycle || M || &nbsp; || No dwell built in
|-
| valign="top" | {{Visible anchor|G82}} || Drilling cycle with dwell || M || &nbsp; || Dwells at hole bottom (Z-depth) for the number of ]s specified by the ] address. Good for when hole bottom finish matters. Good for spot drilling because the divot is certain to clean up evenly. Consider the "]" note at ].
|-
| valign="top" | {{Visible anchor|G83}} || Peck drilling cycle (full retraction from pecks) || M || &nbsp; || Returns to R-level after each peck. Good for clearing flutes of ]. Compare ].
|-
| valign="top" | {{Visible anchor|G84}} || ] cycle, ], ] spindle direction || M || &nbsp; || ] and G84 are the righthand and lefthand "pair" for old-school tapping with a non-rigid toolholder ("tapping head" style). Compare the rigid tapping "pair", ] and ].
|-
| valign="top" | {{Visible anchor|G84.2}} || Tapping cycle, ], ] spindle direction, rigid toolholder || M || &nbsp; || See notes at ]. Rigid tapping synchronizes speed and feeds according to the desired thread helix. That is, it synchronizes degrees of spindle rotation with microns of axial travel. Therefore, it can use a rigid tool holder to hold the tap. This feature is not available on old machines or newer low-end machines, which must use "tapping head" motion (]/]).
|-
| valign="top" | {{Visible anchor|G84.3}} || Tapping cycle, ], ] spindle direction, rigid toolholder || M || &nbsp; || See notes at ] and ].
|-
| valign="top" | {{Visible anchor|G85}} || boring cycle, feed in/feed out || M || &nbsp; ||
* Good cycle for a reamer.
* In some cases good for single-point boring tool, although in other cases the lack of depth of cut on the way back out is bad for surface finish, in which case, ] (OSS/shift) can be used instead.
* If need dwell at hole bottom, see ].
|-
| valign="top" | {{Visible anchor|G86}} || boring cycle, feed in/spindle stop/rapid out || M || &nbsp; || Boring tool leaves a slight score mark on the way back out. Appropriate cycle for some applications; for others, ] (OSS/shift) can be used instead.
|-
| valign="top" | {{Visible anchor|G87}} || boring cycle, backboring || M || &nbsp; || For ]. Returns to initial level only (]); this cycle cannot use ] because its ] is on the far side of the part, away from the spindle headstock.
|-
| valign="top" | {{Visible anchor|G88}} || boring cycle, feed in/spindle stop/manual operation || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Visible anchor|G89}} || boring cycle, feed in/dwell/feed out || M || &nbsp; || G89 is like ] but with dwell added at bottom of hole.
|-
| valign="top" | {{Anchor|G90_absolute}} G90 || Absolute programming || M || T (B) || Positioning defined with reference to part zero. <br> '''Milling:''' Always as above. <br> '''Turning:''' Sometimes as above (Fanuc group type B and similarly designed), but on most lathes (Fanuc group type A and similarly designed), G90/G91 are not used for absolute/incremental modes. Instead, ] and ] are the incremental addresses and ] and ] are the absolute addresses. On these lathes, G90 is instead a fixed cycle address for roughing.
|-
| valign="top" | {{Anchor|G90_roughing}} G90 || Fixed cycle, simple cycle, for roughing (Z-axis emphasis) || &nbsp; || T (A) || When not serving for absolute programming (above)
|-
| valign="top" | {{Visible anchor|G90.1}} || Absolute arc programming || M || &nbsp; || I, J, K positioning defined with reference to part zero.
|-
| valign="top" | {{Visible anchor|G91}} || Incremental programming || M || T (B) || Positioning defined with reference to previous position. <br> '''Milling:''' Always as above. <br> '''Turning:''' Sometimes as above (Fanuc group type B and similarly designed), but on most lathes (Fanuc group type A and similarly designed), G90/G91 are not used for absolute/incremental modes. Instead, ] and ] are the incremental addresses and ] and ] are the absolute addresses. On these lathes, G90 is a fixed cycle address for roughing.
|-
| valign="top" | {{Visible anchor|G91.1}} || Incremental arc programming || M || &nbsp; || I, J, K positioning defined with reference to previous position.
|-
| valign="top" | {{Anchor|G92_position_register}} G92 || Position register (programming of vector from part zero to tool tip) || M || T (B) || Same corollary info as at ]. <br> '''Milling:''' Always as above. <br> '''Turning:''' Sometimes as above (Fanuc group type B and similarly designed), but on most lathes (Fanuc group type A and similarly designed), position register is ].
|-
| valign="top" | {{Anchor|G92_threading}} G92 || Threading cycle, simple cycle || &nbsp; || T (A) || &nbsp;
|-
| valign="top" | {{Anchor|G94_feed_per_minute}} G94 || Feedrate per minute || M || T (B) || On group type A lathes, feedrate per minute is ].
|-
| valign="top" | {{Anchor|G94_roughing}} G94 || Fixed cycle, simple cycle, for roughing (]-axis emphasis) || &nbsp; || T (A) || When not serving for feedrate per minute (above)
|-
| valign="top" | {{Anchor|G95_feed_per_rev}} G95 || Feedrate per revolution || M || T (B) || On group type A lathes, feedrate per revolution is ].
|-
| valign="top" | {{Visible anchor|G96}} || Constant surface speed (CSS) || &nbsp; || T || Varies spindle speed automatically to achieve a constant surface speed. See ]. Takes an ] address integer, which is interpreted as ] in ] mode or as m/min in ] mode.
|-
| valign="top" | {{Visible anchor|G97}} || Constant spindle speed || M || T || Takes an S address integer, which is interpreted as rev/min (rpm). The default speed mode per system parameter if no mode is programmed.
|-
| valign="top" | {{Anchor|G98_return_to_initial}} G98 || Return to initial Z level in canned cycle || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Anchor|G98_feed_per_minute}} G98 || Feedrate per minute (group type A) || &nbsp; || T (A) || Feedrate per minute is ] on group type B.
|-
| valign="top" | {{Anchor|G99_return_to_R_level}} G99 || Return to ] in canned cycle || M || &nbsp; || &nbsp;
|-
| valign="top" | {{Anchor|G99_feed_per_rev}} G99 || Feedrate per revolution (group type A) || &nbsp; || T (A) || Feedrate per revolution is ] on group type B.
|-
| valign="top" | {{Anchor|G100_Tool_Length_Measurement}} G100 || Tool length measurement || M || &nbsp; || &nbsp;
|-
|}

==={{anchor|List of M-codes}} List of M-codes commonly found on FANUC and similarly designed controls for milling and turning===

Sources: Smid 2008;<ref name="Smid2008"/> Smid 2010;<ref name="Smid2010"/> Green et al. 1996.<ref name="Greenetal1996"/>

Some older controls require M codes to be in separate blocks (that is, not on the same line).

{| class="wikitable"
! Code&nbsp;&nbsp; !! Description !! Milling <br> ( M ) !! Turning <br> ( T ) !! Corollary info
|-
| valign="top" | {{Visible anchor|M00}} || Compulsory stop || M || T || Non-optional—machine always stops on reaching M00 in the program execution.
|-
| valign="top" | {{Visible anchor|M01}} || Optional stop || M || T || Machine only stops at M01 if operator pushes the optional stop button.
|-
| valign="top" | {{Visible anchor|M02}} || End of program || M || T || Program ends; execution may or may not return to program top (depending on the control); may or may not reset register values. M02 was the original program-end code, now considered obsolete, but still supported for backward compatibility.<ref name="Smid2010pp29-30">{{Harvnb|Smid|2010|pp=29–30}}.</ref> Many modern controls treat M02 as equivalent to ].<ref name="Smid2010pp29-30"/> See ] for additional discussion of control status upon executing M02 or M30.
|-
| valign="top" | {{Visible anchor|M03}} || Spindle on (clockwise rotation) || M || T || The speed of the spindle is determined by the address ], in either ] (] mode; default) or ] or meters per minute (] mode under either ] or ]). The ] can be used to determine which direction is clockwise and which direction is counter-clockwise.
Right-hand-helix screws moving in the tightening direction (and right-hand-helix flutes spinning in the cutting direction) are defined as moving in the M03 direction, and are labeled "clockwise" by convention. The M03 direction is always M03 regardless of the local vantage point and local CW/CCW distinction.
|-
| valign="top" | {{Visible anchor|M04}} || Spindle on (counterclockwise rotation) || M || T || See comment above at M03.
|-
| valign="top" | {{Visible anchor|M05}} || Spindle stop || M || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M06}} || Automatic tool change (ATC) || M || T (some-times) || Many lathes do not use M06 because the ] address itself indexes the turret. <br> Programming on any particular machine tool requires knowing which method that machine uses. To understand how the T address works and how it interacts (or not) with M06, one must study the various methods, such as lathe turret programming, ATC fixed tool selection, ATC random memory tool selection, the concept of "next tool waiting", and empty tools.<ref name="Smid2008" />
|-
| valign="top" | {{Visible anchor|M07}} || ] on (mist) || M || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M08}} || Coolant on (flood) || M || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M09}} || Coolant off || M || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M10}} || Pallet clamp on || M || &nbsp; || For machining centers with pallet changers
|-
| valign="top" | {{Visible anchor|M11}} || Pallet clamp off || M || &nbsp; || For machining centers with pallet changers
|-
| valign="top" | {{Visible anchor|M13}} || Spindle on (clockwise rotation) and coolant on (flood) || M || &nbsp; || This one M-code does the work of both ] and ]. It is not unusual for specific machine models to have such combined commands, which make for shorter, more quickly written programs.
|-
| valign="top" | {{Visible anchor|M19}} || Spindle orientation || M || T || Spindle orientation is more often called within cycles (automatically) or during setup (manually), but it is also available under program control via '''M19'''. The abbreviation ] (oriented spindle stop) may be seen in reference to an oriented stop within cycles.

The relevance of spindle orientation has increased as technology has advanced. Although 4- and 5-axis contour milling and CNC ] have depended on spindle position encoders for decades, before the advent of widespread live tooling and mill-turn/turn-mill systems, it was not as often relevant in "regular" (non-"special") machining for the operator (as opposed to the machine) to know the angular orientation of a spindle as it is today, except in certain contexts (such as ], or ] fine boring cycles with choreographed tool retraction). Most milling of features indexed around a turned workpiece was accomplished with separate operations on ] setups; in a sense, indexing heads were originally invented as separate pieces of equipment, to be used in separate operations, which could provide precise spindle orientation in a world where it otherwise mostly didn't exist (and didn't need to). But as CAD/CAM and multiaxis CNC machining with multiple rotary-cutter axes becomes the norm, even for "regular" (non-"special") applications, machinists now frequently care about stepping just about ''any'' spindle through its 360° with precision.
|-
| valign="top" | {{Visible anchor|M21}} || Mirror, ]-axis || M || &nbsp; || &nbsp;
|-
| M21 || Tailstock forward || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M22}} || Mirror, ]-axis || M || &nbsp; || &nbsp;
|-
| M22 || Tailstock backward || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M23}} || Mirror OFF || M || &nbsp; || &nbsp;
|-
| M23 || Thread gradual pullout ON || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M24}} || Thread gradual pullout OFF || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M30}} || End of program, with return to program top || M || T || Today, M30 is considered the standard program-end code, and returns execution to the top of the program. Most controls also still support the original program-end code, ], usually by treating it as equivalent to M30. '''Additional info:''' Compare ] with M30. First, M02 was created, in the days when the ] was expected to be short enough to splice into a continuous loop (which is why on old controls, M02 triggered no tape rewinding).<ref name="Smid2010pp29-30"/> The other program-end code, M30, was added later to accommodate longer punched tapes, which were wound on a ] and thus needed rewinding before another cycle could start.<ref name="Smid2010pp29-30"/> On many newer controls, there is no longer a difference in how the codes are executed—both act like M30.
|-
| valign="top" | {{Visible anchor|M41}} || Gear select – gear&nbsp;1 || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M42}} || Gear select – gear&nbsp;2 || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M43}} || Gear select – gear&nbsp;3 || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M44}} || Gear select – gear&nbsp;4 || &nbsp; || T || &nbsp;
|-
| valign="top" | {{Visible anchor|M48}} || Feedrate override allowed || M || T || ] (manual feedrate override)
|-
| valign="top" | {{Visible anchor|M49}} || Feedrate override NOT allowed || M || T || Prevent ] (manual feedrate override). This rule is also usually called (automatically) within tapping cycles or single-point threading cycles, where feed is precisely correlated to speed. Same with ] (spindle speed override) and feed hold button. Some controls are capable of providing ].
|-
| valign="top" | {{Visible anchor|M52}} || Unload Last tool from spindle || M || T || Also empty spindle.
|-
| valign="top" | {{Visible anchor|M60}} || Automatic pallet change (APC) || M || &nbsp; || For machining centers with pallet changers
|-
| valign="top" | {{Visible anchor|M98}} || Subprogram call || M || T || Takes an address ] to specify which subprogram to call, for example, "M98 P8979" calls subprogram O8979.
|-
| valign="top" | {{Visible anchor|M99}} || Subprogram end || M || T || Usually placed at end of subprogram, where it returns execution control to the main program. The default is that control returns to the block following the M98 call in the main program. Return to a different block number can be specified by a P address. M99 can also be used in main program with block skip for endless loop of main program on bar work on lathes (until operator toggles block skip).
|-
|M100
|Clean Nozzle
|
|
|Some 3d printers have a predefined routine for wiping the extruder nozzle in the X and Y direction often against a flexible scraper mounted to the dump area.
|-
|}

==Example program==
This is a generic program that demonstrates the use of G-Code to turn a part that is 1" diameter by 1" long. Assume that a bar of material is in the machine and that the bar is slightly oversized in length and diameter and that the bar protrudes by more than 1" from the face of the chuck. (Caution: This is generic, it might not work on any real machine! Pay particular attention to point 5 below.)

{| class="wikitable"
!Block / Code
!Description
|-
| {{codett|%|gcode}} || Signals start of data during file transfer. Originally used to stop tape rewind, not necessarily start of the program. For some controls (FANUC) the first LF (EOB) is the start of the program. ISO uses {{mono|%}}, EIA uses ER ({{mono|0x0B}}).
|-
| {{nowrap|{{mono|&nbsp;&nbsp;&nbsp;&nbsp;}}{{codett|O4968 (OPTIONAL PROGRAM DESCRIPTION OR COMMENT)|gcode}}}} || Sample face and turn program. Comments are enclosed in parentheses.
|-
| {{codett|N01 M216 |gcode}} || Turn on load monitor
|-
| {{codett|N02 G20 G90 G54 D200 G40|gcode}} || Inch units. Absolute mode. Activate work offset. Activate tool offset. Deactivate tool nose radius compensation. <br/> ''Significance:'' This block is often called the '''safe block''' or safety block. Its commands can vary but are usually similar to the ones shown here. The idea is that a safety block should always be given near the top of any program, as a general default, unless some very specific/concrete reason exists to omit it. The safety block is like a ] or a ]: it explicitly ensures conditions that otherwise would be implicit, left merely to assumption. The safety block reduces risk of crashes, and it can also helpfully refocus the thinking of the humans who write or read the program under hurried conditions.
|-
| {{codett|N03 G50 S2000 |gcode}} || Set maximum spindle speed in rev/min — This setting affects Constant Surface Speed mode
|-
| {{codett|N04 T0300 |gcode}} || Index turret to tool 3. Clear wear offset (00).
|-
| {{codett|N05 G96 S854 M03 |gcode}} || Constant surface speed , 854 ], start spindle CW rotation
|-
| {{codett|N06 G41 G00 X1.1 Z1.1 T0303 M08 |gcode}} || Enable cutter radius compensation mode, rapid position to 0.55" above axial centerline (1.1" in diameter) and {{val|1.1 |u=inches}} positive from the work offset in Z, activate flood coolant
|-
| {{codett|N07 G01 Z1.0 F.05 |gcode}} || Feed in horizontally at rate of 0.050" per revolution of the spindle until the tool is positioned 1" positive from the work offset
|-
| {{codett|N08 X-0.016 |gcode}} || Feed the tool slightly past center—the tool must travel by at least its nose radius past the center of the part to prevent a leftover scallop of material.
|-
| {{codett|N09 G00 Z1.1|gcode}} || Rapid positioning; retract to start position
|-
| {{codett|N10 X1.0 |gcode}} || Rapid positioning; next pass
|-
| {{codett|N11 G01 Z0.0 F.05 |gcode}} || Feed-in horizontally cutting the bar to 1" diameter all the way to the datum, ]
|-
| {{codett|N12 G00 X1.1 M05 M09 |gcode}} || Clear the part, stop the spindle, turn off the coolant
|-
| {{codett|N13 G91 G28 X0 |gcode}} || Home X axis — return the machine's home position for the X axis
|-
| {{codett|N14 G91 G28 Z0 |gcode}} || Home Z axis — return to machine's home position for the Z axis
|-
| {{codett|N15 G90 |gcode}} || Return to absolute mode. Turn off load monitor
|-
| {{codett|N16 M30 |gcode}} || Program stop, rewind to the top of the program, wait for cycle start
|-
| {{codett|%|gcode}} || Signal end of data during file transfer. Originally used to mark the end of the tape, not necessarily the end of the program. ISO uses {{mono|%}}, EIA uses ER ({{mono|0x0B}}).
|}

]

Several points to note:
# There is room for some programming style, even in this short program. The grouping of codes in line {{mono|N06}} could have been put on multiple lines. Doing so may have made it easier to follow program execution.
# Many codes are ''modal'', meaning they remain in effect until cancelled or replaced by a contradictory code. For example, once variable speed cutting (CSS) had been selected ({{mono|{{pslink|G96}}}}), it stays in effect until the end of the program. In operation, the spindle speed increases as the tool near the center of the work to maintain constant surface speed. Similarly, once rapid feed is selected ({{mono|{{pslink|G00}}}}), all tool movements are rapid until a feed rate code ({{mono|G01, G02, G03}}) is selected.
# It is common practice to use a load monitor with CNC machinery. The load monitor stops the machine if the spindle or feed loads exceed a preset value that is set during the set-up operation. The jobs of the load monitor are various:
## Prevent machine damage in the event of tool breakage or a programming mistake.
##* This is especially important because it allows safe "lights-out machining", in which the operators set up the job and start it during the day, then go home for the night, leaving the machines running and cutting parts during the night. Because no human is around to hear, see, or smell a problem such as a broken tool, the load monitor serves an important sentry duty. When it senses overload condition, which semantically suggests a dull or broken tool, it commands a stop to the machining. Technology is available nowadays to send an alert to someone remotely (e.g., the sleeping owner, operator, or owner-operator) if desired, which can allow them to come to intercede and get production going again, then leave once more. This can be the difference between profitability or loss on some jobs because lights-out machining reduces labor hours per part.
## Warn of a tool that is becoming dull and must be replaced or sharpened. Thus, an operator tending multiple machines is told by a machine, essentially, "Pause what you're doing over there, and come attend to something over here."
# It is common practice to bring the tool in rapidly to a "safe" point that is close to the part—in this case, 0.1" away—and then start feeding the tool. How close that "safe" distance is, depends on the preference of the programmer and/or operator and the maximum material condition for the raw stock.
# If the program is wrong, there is a high probability that the machine will ''crash'', or ram the tool into the part, vice, or machine under high power. This can be costly, especially in newer machining centers. It is possible to intersperse the program with optional stops ({{mono|{{pslink|M01}}}} code) that let the program run piecemeal for testing purposes. The optional stops remain in the program but are skipped during normal running. Fortunately, most CAD/CAM software ships with CNC simulators that display the movement of the tool as the program executes. Nowadays the surrounding objects (chuck, clamps, fixture, tailstock, and more) are included in the ]s, and the simulation is much like an entire video game or virtual reality environment, making unexpected crashes much less likely.
##Many modern CNC machines also allow programmers to execute the program in a simulation mode and observe the operating parameters of the machine at a particular execution point. This enables programmers to discover semantic errors (as opposed to syntax errors) before losing material or tools to an incorrect program. Depending on the size of the part, wax blocks may be used for testing purposes as well. Additionally, many machines support operator overrides for both rapid and feed rate that can be used to reduce the speed of the machine, allowing operators to stop program execution before a crash occurs.
# The line numbers that have been included in the program above (i.e. {{mono|N0}} ... {{mono|N16}}) are usually not necessary for the operation of a machine and increase file sizes, so they are seldom used in the industry. However, if branching or looping statements are used in the code, then line numbers may well be included as the target of those statements (e.g. {{mono|GOTO N99}}).
# Some machines do not allow multiple M codes in the same line.

==Programming environments==
{{Original research section|date=January 2016}}
G-code's programming environments have evolved in parallel with those of general programming—from the earliest environments (e.g., writing a program with a pencil, typing it into a tape puncher) to the latest environments that combine CAD (]), CAM (]), and richly featured G-code editors. (G-code editors are analogous to ]s, using colors and indents semantically to aid the user in ways that basic ]s can't. CAM packages are analogous to ] in general programming.)

Two high-level paradigm shifts have been toward:

# abandoning "manual programming" (with nothing but a pencil or text editor and a human mind) for ] systems that generate G-code automatically via postprocessors (analogous to the development of ] techniques in general programming)
# abandoning hardcoded constructs for parametric ones (analogous to the difference in general programming between hardcoding a constant into an equation versus declaring it a variable and assigning new values to it at will; and to the ] approach in general).

Macro (parametric) CNC programming uses human-friendly variable names, ]s, and loop structures, much as general programming does, to capture information and logic with machine-readable semantics. Whereas older manual CNC programming could only describe particular instances of parts in numeric form, macro programming describes abstractions that can easily apply in a wide variety of instances.

The tendency is comparable to a computer programming evolution from ]s to ].{{Citation needed|date=January 2022}}

] reflects the same theme, which can be viewed as yet another step along a path that started with the development of machine tools, jigs and fixtures, and numerical control, which all sought to "build the skill into the tool." Recent developments of G-code and STEP-NC aim to build the information and semantics into the tool. This idea is not new; from the beginning of numerical control, the concept of an end-to-end CAD/CAM environment was the goal of such early technologies as ] and ]. Those efforts were fine for huge corporations like GM and Boeing. However, ] went through an era of simpler implementations of NC, with relatively primitive "connect-the-dots" G-code and manual programming until CAD/CAM improved and disseminated throughout the industry.

Any machine tool with a great number of axes, spindles, and tool stations is difficult to program well manually. It has been done over the years, but not easily. This challenge has existed for decades in CNC screw machine and rotary transfer programming, and it now also arises with today's newer machining centers called "turn-mills", "mill-turns", "multitasking machines", and "multifunction machines". Now that ] systems are widely used, CNC programming (such as with G-code) requires CAD/CAM (as opposed to manual programming) to be practical and competitive in the market segments these classes of machines serve.<ref name="MMS_2010-12-20_CAM_Sys">{{Citation |last=MMS editorial staff |date=2010-12-20 |title=CAM system simplifies Swiss-type lathe programming |journal=Modern Machine Shop |volume=83 |issue=8 |pages=100–105 |url=http://www.mmsonline.com/articles/cam-system-simplifies-swiss-type-lathe-programming}} ''Online ahead of print.''</ref> As Smid says, "Combine all these axes with some additional features, and the amount of knowledge required to succeed is quite overwhelming, to say the least."<ref name="Smid2008p457">{{Harvnb|Smid|2008|p=457}}.</ref> At the same time, however, programmers still must thoroughly understand the principles of manual programming and must think critically and second-guess some aspects of the software's decisions.

Since about the mid-2000s, it seems "the death of manual programming" (that is, of writing lines of G-code without CAD/CAM assistance) may be approaching. However, it is currently only in ''some'' contexts that manual programming is obsolete. Plenty of CAM programming takes place nowadays among people who are rusty on, or incapable of, manual programming—but it is not true that ''all'' CNC programming can be done, or done ''as well'' or ''as efficiently'', without knowing G-code.<ref name="Lynch_MMS_2010-01-18">{{Citation |last=Lynch |first=Mike |date=2010-01-18 |title=When programmers should know G code |journal=Modern Machine Shop |edition=online |url=http://www.mmsonline.com/columns/when-programmers-should-know-g-code |postscript=.}}</ref><ref name="Lynch_MMS_2011-10-19">{{Citation |last=Lynch |first=Mike |date=2011-10-19 |title=Five CNC myths and misconceptions |journal=Modern Machine Shop |edition=online |url=http://www.mmsonline.com/columns/five-cnc-myths-and-misconceptions |postscript=. |access-date=2011-11-22 |archive-url=https://web.archive.org/web/20170527082655/http://www.mmsonline.com/columns/five-cnc-myths-and-misconceptions |archive-date=2017-05-27 |url-status=dead }}</ref> Tailoring and refining the CNC program at the machine is an area of practice where it can be easier or more efficient to edit the G-code directly rather than editing the CAM toolpaths and re-post-processing the program.

Making a living cutting parts on computer-controlled machines has been made both easier and harder by CAD/CAM software. Efficiently written G-code can be a challenge for CAM software. Ideally, a CNC machinist should know both manual and CAM programming well so that the benefits of both brute-force CAM and elegant hand programming can be used where needed. <!-- True, and the references from Mike Lynch above touch on the same concept. --> Many older machines were built with limited ] at a time when memory was very expensive; 32K was considered plenty of room for manual programs whereas modern CAM software can post gigabytes of code. CAM excels at getting a program out quickly that may take up more machine memory and take longer to run. This often makes it quite valuable to machining a low quantity of parts. But a balance must be struck between the time it takes to create a program and the time the program takes to machine a part. It has become easier and faster to make just a few parts on the newer machines with much memory. This has taken its toll on both hand programmers and manual machinists. Given natural ] into retirement, it is not realistic to expect to maintain a large pool of operators who are highly skilled in manual programming when their commercial environment ''mostly'' can no longer provide the countless hours of deep experience it took to build that skill; and yet the loss of this experience base can be appreciated, and there are times when such a pool is sorely missed because some CNC runs still cannot be optimized without such skill.

==Abbreviations used by programmers and operators==
This list is only a selection and, except for a few key terms, mostly avoids duplicating the many abbreviations listed at ].
<!--
| valign="top" | {{Visible anchor|}} || expansion || &nbsp;
|-
-->

{| class="wikitable"
|-
! Abbreviation !! Expansion !! Corollary info
|-
| valign="top" | {{Visible anchor|APC}} || automatic pallet changer || See ].
|-
| valign="top" | {{Visible anchor|ATC}} || automatic tool changer || See ].
|-
| valign="top" | {{Visible anchor|CAD/CAM}} || ] and ] || &nbsp;
|-
| valign="top" | {{Visible anchor|CCW}} || ] || See ].
|-
| valign="top" | {{Visible anchor|CNC}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|CRC}} || ] || See also ], ], and ].
|-
| valign="top" | {{Visible anchor|CS}} || cutting speed || Referring to ] in ] (sfm, sfpm) or meters per minute (m/min).
|-
| valign="top" | {{Visible anchor|CSS}} || constant surface speed || See ] for explanation.
|-
| valign="top" | {{Visible anchor|CW}} || ] || See ].
|-
| valign="top" | {{Visible anchor|DNC}} || ] || &nbsp;Sometimes referred to as "Drip Feeding" or "Drip Numerical Control" due to the fact that a file can be "drip" fed to a machine, line by line, over a serial protocol such as RS232. DNC allows machines with limited amounts of memory to run larger files.
|-
|DOC
|depth of cut
|Refers to how deep (in the Z direction) a given cut will be
|-
| valign="top" | {{Visible anchor|EOB}} || end of block || The G-code synonym of ''end of line (EOL)''. A ] equating to ]. In many implementations of G-code (as also, more generally, in many ]s), a ] (;) is synonymous with EOB. In some controls (especially older ones) it must be explicitly typed and displayed. Other software treats it as a nonprinting/nondisplaying character, much like ] treat the ] (¶).
|-
| valign="top" | {{Visible anchor|E-stop}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|EXT}} || external || On the operation panel, one of the positions of the mode switch is "external", sometimes abbreviated as "EXT", referring to any external source of data, such as tape or DNC, in contrast to the ] that is built into the CNC itself.
|-
| valign="top" | {{Visible anchor|FIM}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|FPM}} || feet per minute || See ].
|-
| valign="top" | {{Visible anchor|HBM}} || horizontal boring mill || A type of machine tool that specializes in boring, typically large holes in large workpieces.
|-
| valign="top" | {{Visible anchor|HMC}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|HSM}} || high speed machining || Refers to machining at ] considered high by traditional standards. Usually achieved with special geared-up spindle attachments or with the latest high-rev spindles. On modern machines HSM refers to a cutting strategy with a light, constant chip load and high feed rate, usually at or near the full depth of cut.<ref>{{Cite web|url=https://www.mmsonline.com/articles/tool-path-strategies-for-high-speed-machining|title=Tool Path Strategies For High-Speed Machining|last=Marinac|first=Dan|website=www.mmsonline.com|access-date=2018-03-06}}</ref>
|-
| valign="top" | {{Visible anchor|HSS}} || ] || A type of ] used to make cutters. Still widely used today (versatile, affordable, capable) although carbide and others continue to erode its share of commercial applications due to their higher rate of material removal.
|-
| valign="top" | {{Visible anchor|in}} || ](es) || &nbsp;
|-
| valign="top" | {{Visible anchor|IPF}} || inches per flute || Also known as ''chip load'' or ]. See ] and ].
|-
| valign="top" | {{Visible anchor|IPM}} || inches per minute || See ] and ].
|-
| valign="top" | {{Visible anchor|IPR}} || inches per revolution || See ] and ].
|-
| valign="top" | {{Visible anchor|IPT}} || inches per tooth || Also known as ''chip load'' or ]. See ] and ].
|-
| valign="top" | {{Visible anchor|MDI}} || manual data input || A mode of operation in which the operator can type in lines of program (blocks of code) and then execute them by pushing cycle start.
|-
| valign="top" | {{Visible anchor|MEM}} || memory || On the operation panel, one of the positions of the mode switch is "memory", sometimes abbreviated as "MEM", referring to the ] that is built into the CNC itself, in contrast to any external source of data, such as tape or DNC.
|-
| valign="top" | {{Visible anchor|MFO}} || manual feed rate override || The MFO dial or buttons allow the CNC operator or machinist to multiply the programmed feed value by any percentage typically between 10% and 200%. This is to allow fine-tuning of ] to minimize ], improve ], lengthen tool life, and so on. The ] and MFO features can be locked out for various reasons, such as for synchronization of speed and feed in threading, or even to prevent "soldiering"/"dogging" by operators. {{Anchor|Arbitrary-speed_threading}} On some newer controls, the synchronization of speed and feed in threading is sophisticated enough that SSO and MFO can be available during threading, which helps with fine-tuning speeds and feeds to reduce chatter on the threads or in repair work involving the picking up of existing threads.<ref name="Korn_2014-05-06">{{Citation |last=Korn |first=Derek |date=2014-05-06 |title=What is arbitrary speed threading? |journal=] |url=http://www.mmsonline.com/blog/post/what-is-arbitrary-speed-threading |postscript=.}}</ref>
|-
| valign="top" | {{Visible anchor|mm}} || ](s) || &nbsp;
|-
| valign="top" | {{Visible anchor|MPG}} || ] || Referring to the handle (handwheel) (each click of the handle generates one pulse of servo input)
|-
| valign="top" | {{Visible anchor|NC}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|OSS}} || oriented spindle stop || See comments at ].
|-
| valign="top" | {{Visible anchor|SFM}} || ] || See also ] and ].
|-
| valign="top" | {{Visible anchor|SFPM}} || ] || See also ] and ].
|-
| valign="top" | {{Visible anchor|SPT}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|SSO}} || spindle speed override || The SSO dial or buttons allow the CNC operator or machinist to multiply the programmed speed value by any percentage typically between 10% and 200%. This is to allow fine-tuning of ] to minimize ], improve ], lengthen tool life, and so on. The SSO and ] features can be locked out for various reasons, such as for synchronization of speed and feed in threading, or even to prevent "] by operators. On some newer controls, the synchronization of speed and feed in threading is sophisticated enough that SSO and MFO can be available during threading, which helps with fine-tuning speeds and feeds to reduce chatter on the threads or in repair work involving the picking up of existing threads.<ref name="Korn_2014-05-06"/>
|-
| valign="top" | {{Visible anchor|TC}} or T/C || tool change, tool changer || &nbsp;See ].
|-
| valign="top" | {{Visible anchor|TIR}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|TPI}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|USB}} || ] || One type of connection for data transfer
|-
| valign="top" | {{Visible anchor|VMC}} || ] || &nbsp;
|-
| valign="top" | {{Visible anchor|VTL}} || ] || A type of machine tool that is essentially a lathe with its Z-axis turned vertical, allowing the faceplate to sit like a large turntable. The VTL concept overlaps with the vertical boring mill concept.
|-
|}

==See also==
* ]
* ] * ]
* ]
* ] - a free CNC software with many resources for G-code documentation
* ]
* ]
* ]
* ]

===Extended developments===
*] (DNC)
*]
*]

===Similar concepts===
*]

===Concerns during application===
*], cutter compensation, offset parameters
*]s


==References== == References ==
{{Reflist|30em}} {{Reflist}}


==Bibliography== == Bibliography ==
* {{MachinerysHandbook25e}} * {{MachinerysHandbook25e}}
* {{Smid2008}} * {{Smid2008}}
* {{Smid2010}} * {{Smid2010}}
* {{Citation |last=Smid |first=Peter |year=2004 |title=Fanuc CNC Custom Macros |publisher=Industrial Press |url=https://books.google.com/books?id=YKvH-zYd3VwC&pg=PR11 |isbn=978-0831131579 |postscript=.}} * {{Citation |last=Smid |first=Peter |year=2004 |title=Fanuc CNC Custom Macros |publisher=Industrial Press |url=https://books.google.com/books?id=YKvH-zYd3VwC&pg=PR11 |isbn=978-0-8311-3157-9 |postscript=.}}


==External links== == External links ==
* *
* {{Citation |last1=Kramer |first1=T. R. |last2=Proctor |first2=F. M. |last3=Messina |first3=E. R. |title=The NIST RS274NGC Interpreter – Version 3 |date=1 Aug 2000 |id=NISTIR 6556 |journal=] |url=https://www.nist.gov/manuscript-publication-search.cfm?pub_id=823374 |ref=none}} * {{Citation |last1=Kramer |first1=T. R. |last2=Proctor |first2=F. M. |last3=Messina |first3=E. R. |title=The NIST RS274NGC Interpreter – Version 3 |date=1 Aug 2000 |id=NISTIR 6556 |journal=] |url=https://www.nist.gov/manuscript-publication-search.cfm?pub_id=823374 |ref=none}}
* http://museum.mit.edu/150/86 {{Webarchive|url=https://web.archive.org/web/20160319102859/http://museum.mit.edu/150/86 |date=2016-03-19 }} Has several links (including history of MIT Servo Lab) * http://museum.mit.edu/150/86 {{Webarchive|url=https://web.archive.org/web/20160319102859/http://museum.mit.edu/150/86 |date=2016-03-19 }} Has several links (including history of MIT Servo Lab)
* * at reprap.org
* *
* *
Line 617: Line 71:
{{Metalworking navbox|machopen}} {{Metalworking navbox|machopen}}


{{DEFAULTSORT:G-Code}}
] ]
] ]

Latest revision as of 00:15, 17 December 2024

Primary programming language used in CNC For other uses, see G-code (disambiguation) and G programming language (disambiguation). "RS-274" redirects here. For the photoplotter format, see Gerber format.
G-code
ParadigmProcedural, imperative
Designed byMassachusetts Institute of Technology
DeveloperElectronic Industries Association (RS-274), International Organization for Standardization (ISO-6983)
First appeared1963 (1963) (RS-274)
Filename extensions.gcode, .mpt, .mpf, .nc and several others
Major implementations
Numerous; mainly Siemens Sinumerik, FANUC, Haas, Heidenhain, Mazak, Okuma

G-code (also RS-274) is the most widely used computer numerical control (CNC) and 3D printing programming language. It is used mainly in computer-aided manufacturing to control automated machine tools, as well as for 3D-printer slicer applications. The G stands for geometry. G-code has many variants.

G-code instructions are provided to a machine controller (industrial computer) that tells the motors where to move, how fast to move, and what path to follow. The two most common situations are that, within a machine tool such as a lathe or mill, a cutting tool is moved according to these instructions through a toolpath cutting away material to leave only the finished workpiece and/or an unfinished workpiece is precisely positioned in any of up to nine axes around the three dimensions relative to a toolpath and, either or both can move relative to each other. The same concept also extends to noncutting tools such as forming or burnishing tools, photoplotting, additive methods such as 3D printing, and measuring instruments.

History

The first implementation of a numerical control programming language was developed at the MIT Servomechanisms Laboratory in the 1950s. In the decades that followed, many implementations were developed by numerous organizations, both commercial and noncommercial. Elements of G-code had often been used in these implementations. The first standardized version of G-code used in the United States, RS-274, was published in 1963 by the Electronic Industries Alliance (EIA; then known as Electronic Industries Association). In 1974, EIA approved RS-274-C, which merged RS-273 (variable block for positioning and straight cut) and RS-274-B (variable block for contouring and contouring/positioning). A final revision of RS-274 was approved in 1979, as RS-274-D. In other countries, the standard ISO 6983 (finalized in 1982) is often used, but many European countries use other standards. For example, DIN 66025 is used in Germany, and PN-73M-55256 and PN-93/M-55251 were formerly used in Poland.

During the 1970s through 1990s, many CNC machine tool builders attempted to overcome compatibility difficulties by standardizing on machine tool controllers built by Fanuc. Siemens was another market dominator in CNC controls, especially in Europe. In the 2010s, controller differences and incompatibility were mitigated with the widespread adoption of CAD/CAM applications that were capable of outputting machine operations in the appropriate G-code for a specific machine through a software tool called a post-processor (sometimes shortened to just a "post").

Syntax

G-code began as a limited language that lacked constructs such as loops, conditional operators, and programmer-declared variables with natural-word-including names (or the expressions in which to use them). It was unable to encode logic but was just a way to "connect the dots" where the programmer figured out many of the dots' locations longhand. The latest implementations of G-code include macro language capabilities somewhat closer to a high-level programming language. Additionally, all primary manufacturers (e.g., Fanuc, Siemens, Heidenhain) provide access to programmable logic controller (PLC) data, such as axis positioning data and tool data, via variables used by NC programs. These constructs make it easier to develop automation applications.

Extensions and variations

Extensions and variations have been added independently by control manufacturers and machine tool manufacturers, and operators of a specific controller must be aware of the differences between each manufacturer's product.

One standardized version of G-code, known as BCL (Binary Cutter Language), is used only on very few machines. Developed at MIT, BCL was developed to control CNC machines in terms of straight lines and arcs.

Some CNC machines use "conversational" programming, which is a wizard-like programming mode that either hides G-code or completely bypasses the use of G-code. Some popular examples are Okuma's Advanced One Touch (AOT), Southwestern Industries' ProtoTRAK, Mazak's Mazatrol, Hurco's Ultimax and Winmax, Haas' Intuitive Programming System (IPS), and Mori Seiki's CAPS conversational software.

See also

References

  1. Karlo Apro (2008). Secrets of 5-Axis Machining. Industrial Press Inc. ISBN 0-8311-3375-9.
  2. Xu, Xun (2009). Integrating Advanced Computer-aided Design, Manufacturing, and Numerical Control: Principles and Implementations. Information Science Reference. p. 166. ISBN 978-1-59904-716-4 – via Google Books.
  3. Harik, Ramy; Thorsten Wuest (2019). Introduction to Advanced Manufacturing. SAE International. p. 116. ISBN 978-0-7680-9096-3 – via Google Books.
  4. Evans, John M. Jr. (1976). National Bureau of Standards Information Report (NBSIR) 76-1094 (R): Standards for Computer Aided Manufacturing (PDF). National Bureau of Standards. p. 43.
  5. Schenck, John P. (January 1, 1998). "Understanding common CNC protocols". Wood & Wood Products. 103 (1). Vance Publishing: 43 – via Gale.
  6. EIA Standard RS-274-D Interchangeable Variable Block Data Format for Positioning, Contouring, and Contouring/Positioning Numerically Controlled Machines, Washington D.C.: Electronic Industries Association, February 1979
  7. Stark, J.; V. K. Nguyen (2009). "STEP-compliant CNC Systems, Present and Future Directions". In Xu, Xun; Andrew Yeh Ching Nee (eds.). Advanced Design and Manufacturing Based on STEP. Springer London. p. 216. ISBN 978-1-84882-739-4 – via Google Books.
  8. "Fanuc macro system variables". Archived from the original on 2014-05-03. Retrieved 2014-06-30.
  9. Martin., Libicki (1995). Information Technology Standards: Quest for the Common Byte. Burlington: Elsevier Science. p. 321. ISBN 978-1-4832-9248-9. OCLC 895436474.

Bibliography

External links

Metalworking
Machining and computing
Computer-aided
engineering
Drilling and
threading
Grinding and
lapping
Machining
Machine tools
Terminology
Categories: