Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

Vericut 6

Download as pdf or txt
Download as pdf or txt
You are on page 1of 1012

VERICUT HELP

1
Table of Contents
VERICUT HELP

TRANSITION TO VERICUT 6.0 ................................................................................. 15


V5.4 to V6.0 Menu Location Changes ....................................................................................... 15
Introduction to the Project Setup menu ...................................................................................... 17
Project Tree ................................................................................................................................ 19

GETTING STARTED WITH VERICUT .................................................................... 22


Introduction to VERICUT .......................................................................................................... 22
VERICUT Licenses and Options ............................................................................................... 25
VERICUT System Requirements............................................................................................... 42
VERICUT with SpaceBall/SpaceMouse .................................................................................... 45
Performance Considerations....................................................................................................... 46
VERICUT Files .......................................................................................................................... 50
Summary of VERICUT File Types ............................................................................................ 50
VERICUT File Descriptions ...................................................................................................... 53
APT Output File ......................................................................................................................... 53
APT Table File ........................................................................................................................... 55
AUTO-DIFF Report File............................................................................................................ 57
AVI File...................................................................................................................................... 58
Batch Script File ......................................................................................................................... 59
CGTECH Macro Executable File............................................................................................... 61
Control File................................................................................................................................. 62
Control Report File..................................................................................................................... 63
CSYS File................................................................................................................................... 64
Design Points File....................................................................................................................... 65
Die Sinking Simulation Report File ........................................................................................... 67
G-Code Log File......................................................................................................................... 68
G-Code Report File .................................................................................................................... 69
IGES Model File......................................................................................................................... 70
Image File................................................................................................................................... 71
In Process File ............................................................................................................................ 72
Inspection Sequence Custom Tolerance File.............................................................................. 73

2
Inspection Sequence File............................................................................................................ 74
Log File ...................................................................................................................................... 75
Machine File............................................................................................................................... 77
NC Program File......................................................................................................................... 78
Operations File ........................................................................................................................... 80
OptiPath Library File.................................................................................................................. 84
Post-Processor File ..................................................................................................................... 85
Preferences File .......................................................................................................................... 86
Project File.................................................................................................................................. 88
Report Template File.................................................................................................................. 89
Status File ................................................................................................................................... 90
Stereolithography Model File..................................................................................................... 91
Tool Library File ........................................................................................................................ 93
Tool Manager Report File .......................................................................................................... 99
User File ................................................................................................................................... 101
VERICUT Linear Sweep File .................................................................................................. 103
VERICUT Polygon File ........................................................................................................... 104
VERICUT Solid File ................................................................................................................ 107
VERICUT Solid-of-Revolution File ........................................................................................ 108
Library Files ............................................................................................................................. 110
Library File Overview .............................................................................................................. 110
General Purpose Library Files.................................................................................................. 111
Library Control Files ................................................................................................................ 112
Library Machine Files .............................................................................................................. 120
Environment variables.............................................................................................................. 132
"CGTECH" environment variables .......................................................................................... 132
Adding custom environment variables for shortcuts ................................................................ 136
Interacting with VERICUT ...................................................................................................... 137
VERICUT main window.......................................................................................................... 137
Menu Bar .................................................................................................................................. 139
VERICUT menu descriptions................................................................................................... 140
Tool Bar.................................................................................................................................... 141
Graphics area ............................................................................................................................ 142
Message Area ........................................................................................................................... 144
Animation Speed Slider............................................................................................................ 145

3
BUSY-OptiPath lights .............................................................................................................. 146
Progress bar .............................................................................................................................. 147
Simulation (VCR) controls....................................................................................................... 148
Look & Feel.............................................................................................................................. 149
Right Mouse Button Shortcut Menus ....................................................................................... 150
Personalizing the VERICUT Main Window ............................................................................ 159
Dockable Windows .................................................................................................................. 161
Docking and Un-docking windows .......................................................................................... 162

VERICUT MENUS AND FEATURES ....................................................................... 165


File menu.................................................................................................................................. 165
New Project .............................................................................................................................. 165
Open (Project) .......................................................................................................................... 166
Save Project .............................................................................................................................. 167
Save As..................................................................................................................................... 168
Save All .................................................................................................................................... 169
In Process.................................................................................................................................. 170
Open (In Process file)............................................................................................................... 170
Save (In Process file)................................................................................................................ 171
Save As (In Process file) .......................................................................................................... 172
Save Cut Stock ......................................................................................................................... 173
Save Cut Stock - STL ............................................................................................................... 174
CAD Model .............................................................................................................................. 175
Export Cut Stock window ........................................................................................................ 175
Export Cut Stock window, Settings tab.................................................................................... 177
Export Model window, Options tab ......................................................................................... 179
Model Export Boundaries window........................................................................................... 182
Export Cut Stock, Preview and Combine window ................................................................... 185
Export Cut Stock, "Combine" Example ................................................................................... 186
Export Cut Stock, Preview and Combine Techniques.............................................................. 189
Working Directory.................................................................................................................... 196
Properties.................................................................................................................................. 197
Properties Window ................................................................................................................... 197
Properties, General tab ............................................................................................................. 199
Properties, Tolerance tab .......................................................................................................... 200

4
Preferences ............................................................................................................................... 203
Custom Interface ...................................................................................................................... 204
Introduction to VERICUT Customizer..................................................................................... 205
Setting up the Custom Interface Default Project File............................................................... 207
Creating the Custom Interface Notebook ................................................................................. 209
Adding pages to the notebook: ................................................................................................. 214
Sizing the Custom Interface Notebook..................................................................................... 216
Creating Custom Interface Feature Pages ................................................................................ 217
Adding Features: ...................................................................................................................... 219
Connecting the Features to VERICUT:.................................................................................... 220
Custom Interface - Labels and Text Fields............................................................................... 221
Custom Interface - Label/Text Field Parameter List ................................................................ 223
Custom Interface - Numeric Fields .......................................................................................... 224
Custom Interface - Numeric Fields .......................................................................................... 224
Custom Interface - Numeric Field Parameter List.................................................................... 225
Custom Interface - File Selection ............................................................................................. 229
Custom Interface - File Selection Parameter List..................................................................... 230
Custom Interface - Choice Lists and Radio Buttons ................................................................ 232
Custom Interface - Choice List/Radio Button Parameter List.................................................. 235
Return to Custom Interface - Choice Lists and Radio Buttons.Custom Interface - Check Boxes237
Custom Interface - Check Boxes .............................................................................................. 238
Custom Interface - Check Box Parameter List ......................................................................... 239
Return to Custom Interface - Check Boxes.Custom Interface - Buttons.................................. 244
Custom Interface - Buttons....................................................................................................... 245
Custom Interface - Button Parameter List................................................................................ 246
Custom Interface - MDI Buttons and Numeric Fields.............................................................. 250
Example - Automatic Stock Block Placement ......................................................................... 252
Creating Custom Interface Help Pages..................................................................................... 254
Sample Help Page: ................................................................................................................... 256
Testing the Custom Interface.................................................................................................... 257
Making the Custom Interface Available for Use...................................................................... 258
Using a VERICUT Custom User Interface .............................................................................. 259
Introduction to VERICUT Reports........................................................................................... 262
Create Report............................................................................................................................ 264
Print View................................................................................................................................. 265

5
Images ...................................................................................................................................... 266
Record Movie ........................................................................................................................... 266
VERICUT Image Record window ........................................................................................... 267
AVI Image Record window...................................................................................................... 269
Playback VERICUT Movie...................................................................................................... 271
Playback Options window features: ......................................................................................... 272
Playback AVI Movie................................................................................................................ 273
View Capture window.............................................................................................................. 274
View Capture window, Attributes tab ...................................................................................... 276
View Capture window, Postscript Settings tab......................................................................... 279
View Capture window, Render tab........................................................................................... 280
AutoSave .................................................................................................................................. 281
In Process tab............................................................................................................................ 283
View Capture tab...................................................................................................................... 286
VERICUT Solid tab ................................................................................................................. 288
Recent Files .............................................................................................................................. 290
Exit ........................................................................................................................................... 291

EDIT MENU.................................................................................................................. 292


Text File ................................................................................................................................... 292
NC Program (Edit) ................................................................................................................... 294
Colors ....................................................................................................................................... 295
Color window ........................................................................................................................... 295
Color window, Assign tab ........................................................................................................ 297
Color window, Cut Colors tab.................................................................................................. 299
Color window, Define tab ........................................................................................................ 302

VIEW MENU................................................................................................................. 304


Layout....................................................................................................................................... 304
View Orient window ................................................................................................................ 306
View Attributes window........................................................................................................... 310
Section window ........................................................................................................................ 314
Select/Store View window ....................................................................................................... 317
View Axes window .................................................................................................................. 319
View Toolbar window.............................................................................................................. 324
Resolution................................................................................................................................. 327

6
Look & Feel "Metal" example.................................................................................................. 328
Look & Feel "Motif" example.................................................................................................. 329
Look & Feel "Windows" example............................................................................................ 330
Look & Feel "Windows Classic" example ............................................................................... 331
Look & Feel "Text Larger" example ........................................................................................ 332
Look & Feel "Text Smaller" example ...................................................................................... 333

INFO MENU.................................................................................................................. 336


NC Program (Info) ................................................................................................................... 336
Status ........................................................................................................................................ 338
Status window, configuration mode ......................................................................................... 340
Graphs window......................................................................................................................... 344
Graphs window, configuration mode ....................................................................................... 348
Machine Offsets........................................................................................................................ 350
File Summary ........................................................................................................................... 355
G-Code Report.......................................................................................................................... 357
Control Report .......................................................................................................................... 358
VERICUT Log ......................................................................................................................... 359
Clear Log File and Logger ....................................................................................................... 360

PROJECT SETUP MENU ........................................................................................... 361


Current Setup............................................................................................................................ 361
Add New Setup......................................................................................................................... 362
Delete Current Setup ................................................................................................................ 363
Import Setup ............................................................................................................................. 365
CNC Machine........................................................................................................................... 366
Setup Models ............................................................................................................................ 367
Modeling window..................................................................................................................... 367
Modeling window, Model tab .................................................................................................. 370
Modeling window, Position tab................................................................................................ 374
Modeling window, Position tab, Translate tab ......................................................................... 376
Modeling window, Position tab, Rotate tab ............................................................................. 377
Modeling window, Position tab, Assemble tab ........................................................................ 378
Modeling window, Position tab, Matrix tab ............................................................................. 381
Modeling window, Position tab, Csys tab ................................................................................ 383
Modeling window, Position tab, Mirror tab ............................................................................. 384

7
Modeling window, Component Attributes tab ......................................................................... 387
Toolchain Parameters window ................................................................................................. 390
Modeling window, Import tab.................................................................................................. 392
Load Stocks .............................................................................................................................. 394
Delete Detached Stock ............................................................................................................. 395
Delete Detached Stock - Update While Simulating Example .................................................. 397
Create Model File ..................................................................................................................... 399
Profile Sketcher Features.......................................................................................................... 400
DXF Geometry window ........................................................................................................... 405
NC Programs ............................................................................................................................ 410
NC Program window................................................................................................................ 410
NC Program Curve Fitting Control window ............................................................................ 415
Tool Change List window ........................................................................................................ 420
Tools......................................................................................................................................... 423
Tool Manager window ............................................................................................................. 423
Tool Manager window, Menu Bar ........................................................................................... 425
Milling Tool Wizard................................................................................................................. 428
Tool Manager window, Tool Table.......................................................................................... 431
Tool Manager window, Tool Display....................................................................................... 437
Tool Manager window, Message Area..................................................................................... 438
Tool Manager - Tool Add/Modify window.............................................................................. 439
Tool Component tab - Revolved Cutter ................................................................................... 441
Tool Component tab - Mill Insert Cutter.................................................................................. 445
Tool Component tab - Turn Insert Cutter................................................................................. 446
Tool Component tab - Probe Tip.............................................................................................. 447
Tool Component tab - Holder................................................................................................... 448
Common Features..................................................................................................................... 450
Reference feature...................................................................................................................... 450
General Insert features.............................................................................................................. 452
Groove Insert features .............................................................................................................. 459
Thread Insert features ............................................................................................................... 462
Model File features................................................................................................................... 466
View Attributes window........................................................................................................... 467
Assembly tab ............................................................................................................................ 468
Search Tool............................................................................................................................... 471

8
OptiPath window ...................................................................................................................... 475
OptiPath window, Feed/Speed tab............................................................................................ 478
OptiPath window, Settings tab ................................................................................................. 481
OptiPath window, Hard Material tab........................................................................................ 486
OptiPath window, Spindle tab.................................................................................................. 489
OptiPath window, Plunge tab ................................................................................................... 490
OptiPath window, Entry/Exit tab.............................................................................................. 491
OptiPath window, Angle tab .................................................................................................... 493
OptiPath window, Depth Table tab .......................................................................................... 495
OptiPath window, Width Table tab .......................................................................................... 498
Search OptiPath Record window.............................................................................................. 500
Processing Options ................................................................................................................... 502
Activate .................................................................................................................................... 502
Motion ...................................................................................................................................... 503
G-Code ..................................................................................................................................... 512
G-Code Settings window.......................................................................................................... 512
G-Code Settings window, Settings tab ..................................................................................... 514
G-Code Settings window, Tables tab ....................................................................................... 517
Add/Modify Tables window..................................................................................................... 519
G-Code Settings window, Subroutines tab............................................................................... 523
G-Code Settings window, Block Skip tab ................................................................................ 525
G-Code Settings window, Sync tab.......................................................................................... 526
G-Code Settings window, WireEDM tab ................................................................................. 527
Variables................................................................................................................................... 528
G-Code Variables window ....................................................................................................... 528
Add Variable window............................................................................................................... 531
Process Options ........................................................................................................................ 533
Process Options window .......................................................................................................... 533
Process Options window, G-Code Output Files tab ................................................................. 535
Process Options window, Messages tab ................................................................................... 537
Process Options window, Debug tab........................................................................................ 539
Process Options window, User Defined tab ............................................................................. 541
APT Settings............................................................................................................................. 542
APT Settings window............................................................................................................... 542
APT Settings window, Motion tab ........................................................................................... 544

9
APT Settings window, Rotary tab ............................................................................................ 547
APT Settings window, Turning tab .......................................................................................... 550
APT Settings window, Cycles tab ............................................................................................ 552
Supported APT-CLS tool path records..................................................................................... 554
Output window ......................................................................................................................... 572
Logs tab .................................................................................................................................... 574
G-Code Files tab....................................................................................................................... 576
Movie tab.................................................................................................................................. 578
Report ....................................................................................................................................... 579
Report Template ....................................................................................................................... 579
Report Template window, Page Layout tab ............................................................................. 581
Report Template window, Styles tab........................................................................................ 588
Report Template window, User-Defined Tags tab................................................................... 590
User-Defined Tag Values ......................................................................................................... 592
MDI .......................................................................................................................................... 593
Coordinate Systems .................................................................................................................. 595
Coordinate System window...................................................................................................... 595
Coordinate System window, Translate tab ............................................................................... 600
Coordinate System window, Rotate tab ................................................................................... 601
Coordinate System window, Construct tab .............................................................................. 602
Coordinate System window, Matrix tab ................................................................................... 604
Active Coordinate System........................................................................................................ 605

MACHINE CONFIGURATION MENU .................................................................... 606


Machine .................................................................................................................................... 606
Open (Machine file) ................................................................................................................. 606
Save (Machine file) .................................................................................................................. 607
Save As (Machine file)............................................................................................................. 608
Machine Settings ...................................................................................................................... 609
Machine Settings window ........................................................................................................ 609
Machine Settings window, Collision Detect tab....................................................................... 611
Machine Settings window, Tables tab...................................................................................... 613
Machine Settings window, Travel Limits tab........................................................................... 615
Machine Settings window, Axis Priority tab............................................................................ 617
Component Tree ....................................................................................................................... 619

10
Control...................................................................................................................................... 624
Open (Control file) ................................................................................................................... 624
Save (Control file) .................................................................................................................... 625
Save As (Control file)............................................................................................................... 626
Word Format ............................................................................................................................ 627
Word Table Features ................................................................................................................ 628
Conditionals - listed alphabetically .......................................................................................... 634
Functions - listed alphabetically............................................................................................... 638
Word/Address........................................................................................................................... 641
Add/Modify Word/Address window ........................................................................................ 644
Find Word window................................................................................................................... 649
Macros - listed alphabetically................................................................................................... 650
Macros Sorted by Function ...................................................................................................... 760
Macros Sorted by Status........................................................................................................... 786
Control Settings ........................................................................................................................ 813
Control Settings window .......................................................................................................... 813
Control Settings window, General tab...................................................................................... 815
Control Settings window, Motion tab....................................................................................... 817
Control Settings window, Circles tab....................................................................................... 819
Control Settings window, Cycles tab ....................................................................................... 821
Control Settings window, Tooling tab...................................................................................... 824
Control Settings window, Rotary tab ....................................................................................... 826
Control Settings window, Wire EDM tab ................................................................................ 834
Control Settings window, Cutter Compensation tab ................................................................ 835
Control Settings window, Offsets tab....................................................................................... 836
Control Settings window, Subroutines tab ............................................................................... 837
OptiPath & Curve Fit tab.......................................................................................................... 838
Control Settings window, User Defined tab............................................................................. 840
Control Settings window, Sync tab .......................................................................................... 841
Control Settings window, Turning tab ..................................................................................... 844
Adv. Options............................................................................................................................. 845
Advanced Control Options window ......................................................................................... 845
Advanced Control Options, Subroutines tab ............................................................................ 847
Advanced Control Options, Events tab .................................................................................... 849
EventsAddMod window........................................................................................................... 851

11
Advanced Control Options, Substitute tab ............................................................................... 854
Advanced Control Options, OptiPath Substitute tab ................................................................ 856
Advanced Control Options, Dev Kit CME tab......................................................................... 857

ANALYSIS TOOLS MENU......................................................................................... 859


X-Caliper window .................................................................................................................... 859
X-Caliper window, Feature/History ......................................................................................... 863
X-Caliper, Distance/Angle ....................................................................................................... 865
X-Caliper window, Stock Thickness ........................................................................................ 868
X-Caliper window, Air Distance .............................................................................................. 869
X-Caliper window, Closest Point ............................................................................................. 871
X-Caliper, Scallop .................................................................................................................... 872
X-Caliper window, Volume ..................................................................................................... 874
X-Caliper window, Stock/Design Distance.............................................................................. 875
X-Caliper window, Highlight Same Plane ............................................................................... 877
AUTO-DIFF ............................................................................................................................. 879
AUTO-DIFF, Settings tab ........................................................................................................ 882
AUTO-DIFF window, Options tab........................................................................................... 889
AUTO_DIFF window, Compare By Region tab...................................................................... 891
AUTO-DIFF window, Constant Gouge Check tab .................................................................. 894
AUTO-DIFF "Point" method example..................................................................................... 896
AUTO-DIFF "Profile" method example .................................................................................. 897
AUTO-DIFF "Solid" method example..................................................................................... 898
AUTO-DIFF "Surface" method example ................................................................................. 899
Comparator ............................................................................................................................... 900
NC Program Review................................................................................................................. 903
NC Program Listing area.......................................................................................................... 905
NC Program Review, Error Listing area .................................................................................. 908
NC Program Review, Graphics Area ....................................................................................... 909
Inspection ................................................................................................................................. 912
Introduction to VERICUT Inspection ...................................................................................... 912
Inspection ................................................................................................................................. 914
Geometric Tolerance window .................................................................................................. 921
Feature Identifier window ........................................................................................................ 923
Inspection Programming window............................................................................................. 925

12
Die Sinking Simulation ............................................................................................................ 927

OPTIPATH MENU....................................................................................................... 930


OptiPath Control window......................................................................................................... 930
OptiPath Control window, Settings tab .................................................................................... 932
OptiPath Control window, G-Code Output Options tab........................................................... 936
OptiPath Control window, OptiPath & Curve Fit tab............................................................... 937
OptiPath Control window, General tab .................................................................................... 938
OptiPath Control window, Learn Mode Options tab................................................................ 939
OptiPath Control window, APT Output Options tab................................................................ 942
OptiPath Compare Files ........................................................................................................... 943

TABLES FOR PROCESSING G-CODES ................................................................. 945


Tables - listed alphabetically .................................................................................................... 945
Cutter Compensation table ....................................................................................................... 947
Base Work Offset table ............................................................................................................ 949
Gage Offset table...................................................................................................................... 950
Initial Machine Location table.................................................................................................. 952
Machine Zero table................................................................................................................... 953
Input Program Zero (Special Z) table....................................................................................... 954
Machine Reference Location table ........................................................................................... 956
Part Transformation table ......................................................................................................... 957
Probe Offset table ..................................................................................................................... 958
Program Zero Table.................................................................................................................. 960
RPCP Pivot Offset table ........................................................................................................... 962
RTCP Pivot Offset table........................................................................................................... 963
Tool Change Location table ..................................................................................................... 964
Tool Change Retraction table................................................................................................... 965
Tool Length Compensation table ............................................................................................. 966
Tool Nose Compensation table................................................................................................. 968
Turret Rotations table ............................................................................................................... 970
Work Offsets table.................................................................................................................... 971

AUTOMATING VERICUT ......................................................................................... 973


Batch VERICUT ...................................................................................................................... 973
Batch processing....................................................................................................................... 973

13
Batch Wizard ............................................................................................................................ 974
Configuring for batch process output ....................................................................................... 976
Command Line Options ........................................................................................................... 979
Command line options for CGTech converters ........................................................................ 990
Controlling VERICUT with comment records......................................................................... 994
VERICUT-BEGINTABLE record ........................................................................................... 995
VERICUT-COMMAND records ............................................................................................. 996
VERICUT-CUTCOLOR record............................................................................................... 999
VERICUT-ENDTABLE record ............................................................................................. 1000
VERICUT-MATRIX record .................................................................................................. 1001
VERICUT-MODAL record.................................................................................................... 1003
VERICUT-MOTION record .................................................................................................. 1004
VERICUT-OPTIPATH record............................................................................................... 1005
VERICUT-TC record ............................................................................................................. 1006
VERICUT-TOOLID record ................................................................................................... 1008
VERICUT-USERTAG record................................................................................................ 1009

CNC MACHINE PROBING...................................................................................... 1010


CNC Machine Probe Simulation ............................................................................................ 1010

14
Transition to VERICUT 6.0

V5.4 to V6.0 Menu Location Changes


This topic is intended help VERICUT 5.4 users find the menus that they are already
familiar with in the V6.0 user interface.

V5.4 Location V6.0 Location


File menu:
File menu > New Session File menu > New Project
File menu > Save User File menu > Save Project
File menu > Export Model File menu > Save Cut Stock > CAD Model
File menu > Edit > Toolpath File Edit menu > NC Program
File menu > Edit > Text File Edit menu > Text File
File menu > Colors Edit menu > Colors
File menu > Report > Create Report File menu > Create Report
File menu > Report > Report Template Project menu > Report > Report Template
File menu > Report > User-Defined Tag Project menu > Report > User-Defined Tag
Values Values
File menu > Print File menu > Print View
File menu > Images Record File menu > Record Movie
File menu > VERICUT Playback File menu > Playback VERICUT Movie
File menu > AVI Playback File menu > Playback AVI Movie
File menu > ShadeCopy File menu > View Capture
File menu > AutoSave : ShadeCopy tab File menu > AutoSave : View Capture tab

Info menu:
Info menu > Toolpath Info menu > NC Program
Info menu > Status Info menu > Status
Info menu > Graphs

Model menu:
Model menu > Model Definition Project menu > Setup Models > Define
Configuration menu > Define
Model menu > Component Tree Configuration menu > Component Tree
Model menu > Load Stocks Project menu > Setup Models > Load
Stocks
Model menu > Delete Material Project menu > Setup Models > Delete
Detached Stock
Model menu > Create Model File Project menu > Setup Models > Create
Model File

15
Model menu > Save Cut Stock File menu > Save Cut Stock > VERICUT
Solid

Setup menu:
Setup menu > Toolpath Project menu > NC programs
Setup menu > Motion Project menu > Processing Options >
Motion
Setup menu > G-Code > Settings, Variable, Project menu > Processing Options > G-
Process Options Code > ...
Setup menu > APT Settings Project menu > Processing Options > APT
Settings
Setup menu > Coord. System Project menu > Coordinate Systems
Setup menu > Tool Manager Project menu > Tools
Setup menu > Control > Open, Save, Save Configuration menu > Control > ...
As
Setup menu > Control > Word Format Configuration menu > Word Format
Setup menu > Control > Word/Address Configuration menu > Word/Address
Setup menu > Control > MDI Configuration menu > MDI
Setup menu > Control > Settings Configuration menu > Control Settings
Setup menu > Control > Adv. Options Configuration menu > Adv. Options
Setup menu > Machine > Open, Save, Save Configuration menu > Machine
as
Setup menu > Machine > Settings Configuration menu > Machine Settings

Analysis menu:
Analysis menu > Toolpath Review Analysis menu > NC Program Review
Analysis menu > Inspection Sequence Analysis menu > Inspection

OptiPath menu:
OptiPath menu > Manager Project menu > Tools
Tool Manager: Add menu > Optipath >
New, Find Existing

16
Introduction to the Project Setup menu
The features on the Project Setup menus provide the tools required for the day to day use
of VERICUT for setting up jobs for verification and simulation. The following basic
concepts are needed to understand the process of setting up a job for VERICUT.

Project — A project consists of one or more setups (see Setup below) enabling you to
simulate multiple operations in a single VERICUT session. Multiple Setups within a
project can be for the same, or different machines. A Project with a single Setup is
logically equivalent to the User file of past VERICUT releases.
Setup — A Setup is a collection of VERICUT settings and files (machine, control, tool
library, etc.), NC program files, and Setup models (Stock, Fixture, Design) that define the
machine operation to be simulated. A Setup is logically equivalent to the User file of past
VERICUT releases.
Current Setup — The Setup menu choices such as CNC Machine, NC Programs, etc.,
apply only to the Current Setup. A setup can be designated "current" either by selecting it
using the Current Setup option in the Project menu, or by selecting selecting it in the
Project Tree. The "current" setup is indicated by a checkmark in the Current Setup menu
and is displayed as bold in the Project Tree (See Setup 3 in the picture below).
Active / Inactive Setup — A Setup can be designated as being in either an Active, or
Inactive state. When a Setup is designated as Inactive, it is not simulated, as if it were not
present in the overall process. An Inactive setup can however be designated as the
"current" setup and modified. Inactive Setups are indicated by red text in both the Current
Setup menu and in the Project Tree (See Setup 2 in the picture below).

17
18
Project Tree
Location: Project menu > Project Tree

VERICUT toolbar short cut:

The Project Tree is one of the dockable windows enabling you to dock it inside the
VERICUT main window if you choose.

The Project Tree shows all Setups and each Setup's configuration in a tree hiearchy. A
project can consist of one or more setups. VERICUT processes each "active" setup
sequentially, starting at the top of the tree. The functionality available in the Project
Tree duplicates the functionality available in the Project menu, but in a more visual tree
format.

The following examples describe some of the information available to you from the way
that the items in the Project Tree are displayed.

Project Tree Example 1: "New" project with a single setup.

The picture at the left shows the


Project Tree for a "new" project
containing a single setup. Since it is
the only setup, it is by default the
"current" setup, indicated by the bold
text.

The red text here indicates that no


data has been assigned to any of these
items.

The initial machine is defined with


Stock, Design and Fixture
components but no models have been
assigned

19
Project Tree Example 2: A project with multiple setups.

The picture at the left shows the


Project Tree for a two setup job.
Both setups are fully defined.

Setup: 1 is displayed in black text


indicating that it is in an "active"
state. The bold text indicated that
Setup 1 is the "current" setup.

The NC Subroutines label in Setup:


1 is displayed in red text indicating
that no subroutines are used for
Setup 1.

All of the items in Setup: 2 are


displayed in red text indicating that
Setup 2 is in an "inactive" state.

Each item in the Project Tree has a Right Mouse Button Shortcut menu containing
features specific to the particular item. Click on any of following Project Tree items to
see the features contained in the shortcut menu:

Project Branch
Setup Branch
CNC Machine Branch

20
Control Branch
Machine Branch
Attach Component
Component Branch
Model
Tooling
NC Programs — displays a button enabling you to display the NC Program
window.
NC Program file
NC Subroutines — displays a button enabling you to display the G-Code Settings
window, Subroutines tab.

21
Getting Started with VERICUT

Introduction to VERICUT
VERICUT simulates or replaces costly steps of the NC data verification process, plus
optimizes the efficiency of material removal. By simulating NC programs, VERICUT
can reduce or eliminate the time-consuming and expensive steps of the traditional data
prove-outs. The program also optimizes program feed and speeds to increase the
efficiency of the machining process. This all adds up to lower costs and higher profits for
your business.
Need training? Visit the CGTech web site at www.cgtech.com and click "TRAINING"
for training course descriptions, schedules, and online registration.
NC program verification process with VERICUT:

VERICUT interactively simulates the material removal process of NC program data.


Instead of messy wax or foam models, or costly prove-outs that waste valuable
production time, a simulated VERICUT part is graphically produced on your computer
screen. VERICUT then verifies the accuracy of the NC program and makes certain the
finished part matches the design model. Before any machine time is spent, VERICUT
catches discrepancies that could corrupt the cutting process and identifies the responsible
NC program records for fast and easy adjustment.

22
The input into VERICUT is NC program data from almost any source. G and M code
data as well as APT type CL-files are directly processed by VERICUT. Similar to the
requirements of machining a real part, VERICUT needs the NC program data, a
description of the raw stock material to be machined, and descriptions of the cutting tools
used to machine the part. The result of the verification process is a solid model of the
machined part and an error Log file reporting any machining errors detected during the
simulation. The VERICUT model can be inspected, saved, or used as the stock material
for another NC program.
In addition to streamlining the verification process, VERICUT dramatically boosts
productivity on the shop floor. Automated and user-selectable optimization settings in
VERICUT let you maximize the material removal process. The feed rate and cutting
speed of each NC program automatically adjust based on the depth, width, and angle of
each cut. In fact, you can even set VERICUT to compensate for dull or custom cutters or
other elements unique to your operation.
VERICUT simulates up to 5-axis milling, drilling and wire EDM operations, as well as
turning and combination mill/turn machining. With a complete line of specialization
modules for added features and functionality, VERICUT is truly the total simulation,
verification, and optimization solution for unleashing NC productivity.
Installing VERICUT
In most cases installing VERICUT is a straight-forward and easy task, requiring only a
few minutes of time. Prior to installing any software, review the system requirements and
the installation procedure for the computer type on which you intend to operate
VERICUT.
Detailed step-by-step instructions are provided in the online VERICUT Installation
Guide. Follow all applicable steps to ensure smooth VERICUT installation and
successful operation.
Accessing VERICUT
The method of accessing VERICUT is different, depending on the environment in which
it is operated. All methods described below are for accessing VERICUT as installed
using instructions provided by CGTech. Your VERICUT installation may be different.
Access VERICUT on a Windows computer:
From the Taskbar, click Start > All Programs > CGTech VERICUT 6.x >
VERICUT 6.x where "6.x" is the desired VERICUT version number.
For example, to run VERICUT 6.0 you would click: Start > All Programs >
CGTech VERICUT 6.0 > VERICUT 6.0
Access VERICUT on a UNIX computer:
Type "vericut". If the command is not found, include the full path, e.g.
"/<cgtech6x>/<computertype>/commands/vericut" where <cgtech6x>
represents the directory path to where CGTech products were installed, and
<computertype> is the type of computer on which VERICUT is being operated,
for example: hp, rs, sgi, or solaris.

23
For example, to run VERICUT installed in "/server/apps/cgtech60" on an HP700
computer, you would type: /server/apps/cgtech60/hp/commands/vericut
Hint: Copy the "vericut" command file to the /usr/bin directory and the next time
you log in, you should be able to just type "vericut".
Access VERICUT from CATIA:
Assuming you have the CATIA-to-VERICUT Interface, choose the "CATV"
function. Use CATV functions to select the CATIA data to use in the
verification session (geometry models, NC programs, etc.) and transfer the data
to VERICUT. Then access VERICUT via choosing PROCESS menu >
VERICUT.
Access VERICUT from UG:
Assuming you have CGTech's Unigraphics-to-VERICUT Interface installed,
access VERICUT from UG as follows:
- UG V17 and V16—Click on the Verification icon in the UG CAM icon bar.
- UG V15—Click Tools Manufacturing menu > VERICUT.
Access VERICUT from WorkNC:
Assuming you have CGTech's WorkNC-to-VERICUT Interface installed, access
VERICUT via choices in the WorkNC Utilities menu. VERICUT can be run
interactively or in batch, to perform NC program verification or optimization.
Access VERICUT from Pro/Engineer:
Access VERICUT from ProE as follows:
- Click NC Sequence Play Path menu > NC Check => simulates the current
selected NC sequence.
- Click CL Data menu > NC Verification => enables users to select a single NC
sequence, multiple sequences, or an entire NC operation for simulation. Note:
the NC data must be selected prior to selecting starting the verification process.
Access VERICUT from Mastercam-to-VERICUT Interface:
Access VERICUT from Mastercam as follows:
- Hold down the Alt key and click the C key (referred to as Alt-C). You will see a
file selection dialog offering all the installed C-Hooks. Pick "VERICUT.dll" and
click on the Open button.

24
VERICUT Licenses and Options
VERICUT licenses and capabilities differ, depending on the environment in which
VERICUT is being operated. A modular approach provides the flexibility to purchase
only the capabilities you need. As your needs change, you can add the appropriate
licenses to increase VERICUT’s functionality. It is not necessary to install any additional
software to add a license CGTech provides a license that allows immediate access.
CGTech software licenses allow you to share VERICUT over a network. One user may
access a given license at a time. CGTech's license system supports Windows 2000, XP
and UNIX. See VERICUT System Requirements for more detailed information. The
server and networked workstations can be different computer types.
Licensing for VERICUT
VERICUT 6.0 licensing is required. Pre-5.4 licensing is incompatible with the 6.0
CGTech Network License Server. If you do not have a 6.0 license, obtain licensing from
CGTech as described below.
6.0 licenses are issued via email only. Your6.0 license will be emailed to the primary
VERICUT user at your company. If you do not have licensing, submit an application via
our website at www.cgtech.com.
Note to new customers—You will need to know the machine ID (ethernet address) of
the machine on which the CGTech Network License Server is to operate. To determine
the machine ID, see the steps described in the VERICUT Installation Guide (ref. pre-
installation procedure for your computer type: Windows or UNIX).
Licenses and Options available for VERICUT by CGTech
The sections that follow describe the software products obtained from and licensed by
CGTech. The terms "licenses" and "options" are synonymous, since each option for
VERICUT is licensed by CGTech.

25
Mold & Die
The Mold & Die module is a new base module designed for the mold and die machinist
or NC programmer. It is a packaging of existing Verification and OptiPath features,
controlled by a default custom interface. The interface can be tailored by CGTech for
specific end-users, or by anyone with a license for the new Customizer module.
Mold & Die is targeted at new customers. It is intended to be attractive to the Mold and
Die tooling manufacturer who would not consider standard VERICUT for a variety of
reasons, such as: too difficult to setup and use, no perceived value in verification, not
enough advantages for the mold or die making process. It is not intended for existing
customers, but some existing customers may want to add Mold & Die licenses rather than
Verification licenses.
The goal of Mold & Die is to provide enough useful features for mold or die makers to
justify the cost, while not affecting the value of standard VERICUT and modules.
The Mold & Die base module license contains some features found in OptiPath.
However, do not confuse these OptiPath features with an OptiPath license. The OptiPath
features are included with the Mold & Die license, and cannot be accessed with a
standard Verification base license.
The Mold & Die base module restricts some access to Verification and OptiPath features
due to the interface customization, but the feature restriction is mainly controlled by
licensing.
The following Verification features ARE NOT available in the Mold & Die base module:
Multiple stock components
Fixture collision checking
X-caliper measuring (feature info is available)
Machine and Machine/Cut Stock views
Toolpath Review
Comparator
Save a control file
Save a machine file
Turning
Wire EDM

The following OptiPath features ARE NOT available in the Mold & Die base module:
Optimize Circles & NURBS

The following add-on modules MAY NOT be added to the Mold & Die base module:
OptiPath
Machine Simulation
Machine Developer's Kit
Cutter Grinder Machine Simulation

26
Add-on modules available with Mold & Die Machining are:
Multi-Axis
AUTO-DIFF
EDM Die Sinking Simulation
Model Export
Inspection Sequence

There are no pre-requisites for this base module.


Return to Licenses and Options available.

Verification
The Verification license is the foundation of VERICUT. It includes everything necessary
to simulate and verify 3-axis milling and multi-axis positioning operations to detect errors
such as:
y Inaccurate programming
y Rapid motion contact
y Incorrect tool path motions
y Collisions with fixtures & clamps
y Incorrect or misread blueprints
y Tool shank and holder collisions
y CAD/CAM and post-processor errors
VERICUT has two viewing options: Workpiece, and Machine. The Workpiece view
interactively displays material removal and the tool assembly, stock and fixtures. The
Machine view displays the CNC machine tool and the complete machining environment,
including the cut model as material is removed. On it’s own, the Verification license
supports the Workpiece view. The Machine view requires a Machine Simulation license.
y Model analysis—You can move, zoom, reverse, and rotate the model at any point
in the cutting process. You can also cross-section it multiple times at any
orientation, and view it in translucent mode enabling you to check areas that
would be impossible to see in a solid model (such as the intersection of drilled
holes). X-Caliper, a comprehensive measurement tool is included to check
thickness, volume, depth, gaps, distances, angles, hole diameters, corner radii,
scallop height, and edges. Delta X, Y, Z component distance measurements are
included.
y Cutter simulation—You can accurately simulate the material removal process
using the exact cutter used to machine the part. VERICUT includes a library of
standard cutters provided by Ingersoll Cutting Tool Company. You can also
define your own cutters. Holders can be specified as a "non-cutting" portion of the
tool in order to check for any potential collisions. VERICUT supports concave
bottom, or non-center cutting end mills, such as carbide insert end mills. Although
designed to remove large volumes of material at high speeds during planar or XY
cutting, carbide insert roughing end mills are often used to ramp into material. If
the angle of the cut is too steep, the "non-cutting" portion of the tool collides with

27
the material and can break the tool and ruin the part. VERICUT enables you to
define inserts as cutting edges and the body as a non-cutting portion of the tool,
helping you take full advantage of your equipment without fear of destroying the
workpiece or cutting tool because of an incorrect ramp motion.
y FastMill—The FastMill cutting mode is designed to quickly process large NC
programs and is especially useful for mold and die manufacturers. A single mouse
click switches cutting operations to FastMill mode. FastMill provides complete
control of the speed, accuracy, and quality of the model. Accuracy is calculated
independently of the display, enabling you to create highly accurate models and
display them at lower resolutions for quick manipulation and high resolution for
detailed analysis. FastMill uses the same trajectory logic for calculating material
removal as the standard cutting mode (e.g. it’s built with the same robust
simulation technology developed and refined for a decade in VERICUT).
FastMill is not a replacement for VERICUT’s standard machining mode; it is
designed to work with large tool paths at a single setup orientation.
y Convert NC data—VERICUT is a powerful reverse post-processor. By
translating NC programs to APT or other NC data formats, the program saves
valuable machine tool and programmer time. Because obsolete or incompatible
NC programs can be recycled or made to run on different machines, you can take
advantage of all your programming resources – present and past.
There are no pre-requisites for this base module.
Return to Licenses and Options available.

Model Export
With a few mouse clicks, the Model Export license enables you to export a cut model at
any stage in the machining process, as an in-process CAD model complete with
machined features!

28
CGTech's unique algorithm minimizes file size, while preserving manufacturing features
such as holes, fillets, corner radii, pocket floors and walls. The result is a highly accurate
IGES or STL model.
Why Model Export?—Since the invention of the first NC machine tools, NC
programming languages, and CAD/CAM systems, manufacturing engineers have needed
an accurate electronic model of the initial and in-process state of material. It's difficult to
confidently create tool paths for each subsequent operation without an accurate
representation of the initial material. The accuracy, efficiency, and "correctness" depend
on the material's initial geometric shape.
Access to the correct geometric workpiece shape in the CAD/CAM environment, at each
manufacturing stage, helps avoid problems when creating subsequent cuts. Until now the
only way to get an in-process CAD model is with expensive, labor-intensive, error-prone,
and inaccurate methods. These include manually modeling the material state for each
operation, or using scanning equipment and surfacing software on the physical workpiece
produced by the previous operation.
Some CAD/CAM systems attempt to provide this by using their CAD solid modeling
tools. This approach is typically limited to 2½ axis operations, and does not simulate
motion. Instead it estimates the region to be removed, creates a solid feature for that
region, and subtracts it from the initial stock model. Often details produced by cutter
radius, step-over, or step-down are not included. And the size of the model can grow such
that it becomes unmanageable.
Another CAD/CAM technique produces a rough faceted approximation of the in-process
material. Typically limited to 3-axis motions and from a single setup position, the
accuracy is only as good as the facet tolerance. Manufactured features such as holes, and
radii are often lost. The models can be gigantic, requiring millions of facets to represent
even relatively simple shapes.
Both of these techniques seek to avoid the difficulty of using an "as-machined"
verification model to generate a usable CAD model. After simulating an NC tool path,
the verification model contains much more data than a traditional CAD solid model
algorithm can process. Because it is designed to create verification models, VERICUT
has the unique advantage of being able to manage the data without failing and export an
accurate CAD model in a manageable size.
Model Export requires a Verification, or Mold & Die Machining, base module license as
a pre-requisite.
Return to Licenses and Options available.

AUTO-DIFF
AUTO-DIFF enables you to compare a design model to the "as-machined" VERICUT
solid model to automatically detect differences and protect against gouges. Using this
license, anyone involved in the production process can identify incorrectly machined
areas. AUTO-DIFF is also used to detect a possible weakness or mistake in the design.
Why use AUTO-DIFF?—Often, from the time a part is designed to when it is ready to
be machined, the design has passed through several people, departments, companies, and
CAD/CAM systems. In the end, it is difficult to tell if the tool path accurately reflects the
original design model. Without AUTO-DIFF, the only way to be sure is to cut the part

29
and do a first article inspection. By using AUTO-DIFF to compare the simulated model
to the design model, you are assured the tool path accurately represents the original
design concept. This reduces the time it takes to cut the first production-worthy part.
AUTO-DIFF also reduces the time it takes to prepare an NC tool path. You can check for
gouges or excess material during the programming stage – not at the machine.
Solid, Surface, & Point comparisons
y SOLID—Solid models from most popular CAD/CAM systems can be used.
AUTO-DIFF embeds the solid model in the simulated part. You can identify
gouges and excess material by setting a user-defined tolerance level. You can also
compare the cut model with another VERICUT model – ideal for comparing
different operations such as roughing and semi-finishing cuts.
y SURFACE—A surface, a set of surfaces, or the skin of a solid model can be
compared with the simulated part. The surface is overlaid on top of the simulated
part, and gouges and excess material are displayed. Large amounts of data from
very complex tool paths can be quickly compared. The design model does not
need to be watertight, nor does the entire part need to be included.
y POINT—When solid or surface model data does is not available, you can lay 3-D
points from CMM or manual methods over the top of the simulated part. The
points are compared to the NC tool path to accurately detect errors or out-of-
tolerance conditions.
Gouge checking—With AUTO-DIFF, you can perform constant gouge-checking
interactively during simulation with virtually no degradation in speed or performance. It’s
not necessary to simulate the entire NC program first – you can identify and correct
problems as they occur. To identify gouges, AUTO-DIFF embeds the design model
inside the rough material. When the tool path cuts into the embedded model, the gouge is
highlighted and the error is reported.
AUTO-DIFF also detects collisions between a tool and components nested inside the
stock model, such as tooling pins, hardened inserts, or bearings. Previous cutting
operations can be "protected" from any further machining. Any material removed from a
protected area is highlighted and reported as an error. To make identifying gouges,
collisions, or excess material easy, you can assign different colors to the design models,
rough stock, and errors. Excess material boundaries can be exported as IGES or point
data.
AUTO-DIFF reports—You can view automatically generates error reports which
include information such as type of error, tolerance value, all tool path records out of
tolerance, error location, and summary of results. AUTO-DIFF error reports are
interactively linked to the graphics. Picking on an item in the report screen highlights the
error on the screen. A report can be printed or saved as .TXT files. Both reports and
graphical results can be generated in batch mode.
AUTO DIFF requires a either a Verification, or a Mold & Die Machining, base module
license as a pre-requisite.
Return to Licenses and Options available.

30
EDM Die Sinking Simulation
EDM Die Sinking Simulationprovides the ability to simulate the EDM die sinking
process in VERICUT by using VERICUT models (polygon, STL, block/cylinder/cone) to
represent EDM electrodes, and subtracting those "electrode" models from the VERICUT
stock model. In addition to using the usual VERICUT models to represent electrodes, the
new VERICUT Solid model can be used.
The EDM Die Sinking Simulation module provides a new tool to the mold tooling
designer and fabricator. No other technology exists today to allow the mold builder to
simulate the EDM burn process and produce the final mold cavity directly from solid
models created by NC tool path. VERICUT's simulation of the EDM burn process gets as
close as possible to the physical process by using VERICUT "as machined" solid models
of the rough machined mold components and machined electrodes used to produce the
completed mold tooling.
The EDM Die Sinking Simulation module allows several different views of the burn
process, including display of the rough machined stock, the electrodes, and the burn
material (material removed by the electrodes). All can be displayed, blanked, or
displayed translucent. The burn process also displays the volume removed by each
electrode, and allows specification of an "overburn" offset on each electrode.
The resulting burned mold component can then be compared to a design model of the
final desired mold component using AUTO-DIFF. AUTO-DIFF is NOT included with
the Die Sinking module.
EDM Die Sinking Simulation requires either a Verification, or a Mold & Die Machining,
base module license as a pre-requisite.
Return to Licenses and Options available.

OptiPath
The OptiPath license automatically modifies feed rates based on cutting conditions and
amount of material removed. Using OptiPath can dramatically reduce the time it takes
you to machine parts and increase the productivity (and profitability) of the NC machine
tools at your shop.
The feed rate problem—With the current advances in cutting tools, materials, and
automatic tool path generation software, it is increasingly critical to use the right feed rate
for each and every cut in the NC tool path. However, determining and setting the
optimum feed rate has traditionally presented NC programmers and machinists with a
number of problems. Because an incorrect estimate can break the cutting tool, damage
the fixture, and scrap the part, usually only one or two conservative feed rates are used.
Typically, the ‘safe’ feed rates chosen are a compromise between tool life, cycle time and
the worst-case cutting condition encountered.
These 'worst-case' feed rates are fine for the cuts that remove the largest amount of
material or encounter the worst cutting conditions. Unfortunately, these slow, poorly
controlled speeds waste time, increase manufacturing costs, and create poor cutting
conditions elsewhere on the part.
CAM software does not provide the material removal information necessary to determine
optimum feed rates. And many CAM systems have limited cut patterns that do not fit the

31
workpiece geometry. Their machining strategies and cut patterns are not very efficient for
common operations such as open boundaries, roughing cuts on complex shapes, complex
pocketing, or planar roughing on mold cavities or cores. Cutters therefore waste a lot of
time while "cutting air" and feeding slowly across the surface of the part, in contact with
it, but not removing any material. Additionally, an automatically generated tool path may
plunge the cutter into material at an incorrect or inefficient angle. The end results can
include excessive machining time, bad workpiece finishes, increased cutter wear, and
broken tools.
Even if you somehow know the optimal feed rates to use for each individual cut, inserting
them into the tool path program is time consuming and error prone.
Optimizing the operation—OptiPath works by reading the NC tool path file and
dividing motion into a number of smaller segments. Where necessary, based on the
amount of material removed in each segment, the software assigns the best feed rate for
each cutting condition encountered. It then outputs a new tool path, identical to the
original one but with improved feed rate settings. It does not alter the tool path trajectory.
This solution offers the best of both worlds. On one hand, it is automatic and determines
the best feed rates before the NC program is even loaded on the machine. On the other, it
uses the expertise of the NC programmer and machinist to determine the best feed rates
for specific cutting conditions. You input ideal feed rates for a number of pre-determined
machining conditions. Factors such as machine tool capacity (horse-power, spindle type,
rapid traverse speed, coolant, etc.); fixture and clamp rigidity; and cutting tool type
(material, design, number of teeth, length, etc.) all affect the process. These factors
determine settings (chip thickness, volume removal rate, entry feed rate, spindle speeds,
etc.) used to calculate the optimum feed rate for each segment of each cut.
Typically, different optimization techniques are best suited for certain materials or
machining processes:
y ROUGHING—During planar roughing of aluminum structural components,
material is removed at a constant axial depth, but the radial width of cut varies
greatly from cut to cut. The goal is to remove as much material as quickly as
possible. Maintaining a constant volume removal rate keeps the cutter at its
maximum rate of advance into material for the varying cutting conditions. Using
the information provided while verifying the tool path, the software is able to
determine the amount of material removed in each segment of the tool path. The
software then assigns the best feed rate using the information supplied by the NC
programmer and/or machine tool operator.
y FINISHING—Another example would be semi-finishing or finishing operations
in a tool steel mold cavity. Cutting is typically characterized by widely varying
chip loads as the tool profiles through the roughing cuts and over the contours of
the workpiece to near net shape. In order to achieve a constant chip load, feed
rates are optimized to based on the maximum chip thickness for each cut segment.
The software takes into account where the material is in contact with the cutter
and adjusts the feed rate to maintain a constant chip thickness. This is especially
critical when tip cutting with a ball end mill, or when touring a surface with a
small step-over. The feed rates continually change over the course of the cut in
order to maintain a constant maximum chip thickness. The result is an
improvement in tool life and a higher-quality surface finish.

32
Benefits of OptiPath
y Faster time-to-market... Optimized tool paths reduce the over-all cycle time
required to produce parts so they can be brought to market more quickly.
y Save money... Reducing the time it takes to machine each part adds up to huge
savings over the course of a year.
y Increase productivity... Existing machine tools produce more parts in the same
amount of time. It's almost like getting another NC machine for free!
y Reduced fatigue... Machinists are not forced to keep a close eye on the machining
process. They can set up other jobs or attend to other duties while the optimized
program is running.
y Reduced cutter wear... Less time required to cut each part means less cutter wear.
Cutting at optimum conditions also prolongs tool life, so they are used longer
before needing to be re-ground or replaced. Machinists are less frequently
required to change tools or inserts.
y Reduced machine wear... Machines are subject to less wear because optimized
feed rates maintain a more constant cutting pressure between the machine tool and
the workpiece. This reduces variable forces on the axis motors which leads to
smoother NC machine tool operation.
y Better quality... Optimized tool paths produce a better finish because constant
cutting pressure causes little or no variation in cutter deflection. Finishes on
corners, edges, and blend areas are significantly better. This reduces the amount
of time required to bench finish the completed part.
High-speed machining—During high speed machining, the way the cutter contacts
material is critical. Too low a feed rate produces chatter, vibration and work hardening,
leading to poor surface finishes and premature cutter failure. Too high a chip load causes
excessive cutting pressure and unsafe conditions that can lead to catastrophic failure of
the tool, spindle, fixture and machine. Adjusting feed rates to maintain a constant chip
load or volume removal rate help reduce these problems typically found in high speed
machining – and are recommended by cutting tool manufacturers to solve the "chip
thinning" problem. Constant chip thickness works especially well with high speed
finishing with ball end mills where very small volumes of material are removed at high
feed rates and spindle speeds. Spindle speed can also be optimized to maintain a constant
surface speed at the maximum contact diameter on the cutter. Depending on the
capabilities of the machine, constant surface speed optimization can help improve the
surface finish.
Optimization settings—Feed rates are adjusted based on a number of user-defined
settings. Feed rates are affected by machining conditions such as: machine tool capacities
(horse-power, spindle type, rapid traverse speed, coolant, etc.); fixture and clamp rigidity;
and cutting tool type (material, number of teeth, length, etc.).
Other settings are dependent on the nature of the tool path and determine the optimum
feed rate for each cut:
y Cut depth
y Cut width
y Cut angle

33
y Entry feed rate
y Cutter wear
y Volume removal rate
The OptiPath Library—A library of feeds rates and surface speeds for different cutting
tools, materials, and cutting conditions is included. Provided by Ingersoll Cutting Tool
Company, this library serves as a useful starting point for determining the ideal feeds and
speeds for particular machining conditions.
All optimization settings are stored in this central library, organized by type (different
cutting tools, NC machines, etc.). Because everyone can access the same cutting
information from the library, OptiPath is an excellent tool for achieving more consistent
machining results between different operators, machines, shifts, etc. – even if your
'resident expert' is unavailable.
Acceleration / deceleration & NURBS support—OptiPath accounts for changes in
velocity as each axis accelerates and decelerates during changes in direction. With this
information, feed rates settings are based on the physical capabilities and limitations of
the machine tool. OptiPath supports NURBS interpolation. It examines the machining
conditions and amount of material removed by each segment of the curve – then
calculates an ideal feed rate for each NURBS span, while maintaining the original
geometric shape of the curve.
OptiPath requires a Verification base module license as a pre-requisite.
Return to Licenses and Options available.

Machine Simulation
In complex multi-axis machine work where tool orientation changes frequently, the
possibility of costly collisions is a frightening reality. A machine crash can cost
thousands of dollars, ruin the NC machine, and delay the entire production schedule.
Machine Simulation supports 3-D modeling machines and detects collisions and near-
misses between all machine tool components such as axis slides, heads, turrets, rotary
tables, spindles, tool changers, fixtures, work pieces, cutting tools, and other user-defined
objects.
VERICUT’s Machine Simulation enables you to perform realistic 3-D simulation of
entire NC machines, just like they behave in the shop, with extremely accurate collision-
detection.
A complete library of pre-assembled machine tools is included. All models can be easily
customized to match your machine. A partial list includes machines from: Bostomatic,
Maho, Cincinnati Milacron, Makino, Mazak, Fadal, Mitsui Seikii, Okuma, SNK (Shin
Nippon Kok), Kearney & Trecker, Sundstrand, Giddings & Lewis, Toyoda, Ingersoll
Milling, and many more.
You can also build machine components and job-specific components (such as work
pieces, cutting tools, rotary tables, spindles, fixtures, and clamps) in your CAD system
and import them into VERICUT. By mixing imported CAD data with VERICUT solid
primitives you can easily modify an existing machine or to create a new one. Any
machines you modify or build from scratch can be saved to the machine tool library.

34
Simulating controls—VERICUT is developed by industry professionals who understand
the complexities of NC code and control functions. This technical expertise makes
VERICUT an excellent tool for verifying complex code using advanced programming
functions such as:
y Look-ahead or 3-D cutter compensation
y Tool tip programming & tool length compensation
y Gage length reference point programming
y Canned cycles & fixture offsets
y Rotary axis pivot points
y Variables, subprograms & macros
y Subroutines, looping & branching logic
With this license, you can accurately simulate every control in your shop and account for
different machines, programs, parts, and functions. No programming language is required
to simulate most NC controls. Machine Simulation includes an extensive library of
flexible, easily modified controls, including: Fanuc, Allen-Bradley, Mazak, NUM,
Cincinnati Acramatic, Okuma, Fadal, Maho Phillips,General Electric, Siemens
Sinumerik, Giddings & Lewis, Heidenhain, Yasnac, and many more.
Collision checking—VERICUT is the fastest, most accurate NC machine collision
checking program available.
Rather than checking only start and end points, or checking a number of points along a
path, VERICUT uses a set of unique algorithms to check for potential collisions along the
entire machine path.
The program also detects axis travel limit errors (user-defined limits for machine
component movement). The program checks for and highlights collisions between all
machine tool components such as axis slides, heads, turrets, rotary tables, spindles, tool
changers, fixtures, work pieces, cutting tools, and other user-defined objects. The
program also allows near-miss zones to be defined around the components.
Machine Simulation requires a Verification base module license as a pre-requisite.
Return to Licenses and Options available.

Multi-Axis
As complexity increases, so does the chance for error. Tool positioning is critical in four
and five-axis milling operations, further increasing the importance of verification. While
it is nearly impossible to predict how these machines will respond to complex motion
commands, Multi-Axis enables VERICUT to graphically display the results and take the
guesswork out of multi-axis tool path prove-outs.
y Milling—The Multi-Axis license accurately displays material removal during
multi-axis milling of complex profiles and surfaces. The Multi-Axis license
simulates and verifies four and five axis milling/drilling machining operations.
y Turning—The Multi-Axis license also simulates and verifies up to 2-4-axis
turning operations. VERICUT supports 4-axis synchronized (merged) turning
operations with multiple tools.

35
When combined with Machine Simulation, CGTech's comprehensive 3-D collision-
checking can be applied to the in-process workpiece as it is machined. This is useful for
detecting interference between the machined part and tool holders, boring bars, tool
blocks, turrets, head assemblies, and other machine components, in addition to standard
collision checking between machine components.
Multi-Axis requires a Verification base module license as a pre-requisite.
Return to Licenses and Options available.

Advanced Machine Features


The Advanced Machine Features option accesses advanced NC machine and control
features during the simulation. These features simulate complex or special machine or
control functions. Some advanced features are developed to meet specific user's custom
requirements and may need additional development work to expand them to other
applications.
Examples of advanced features that have already been implemented include:
y Facing Heads (or "programmable boring bar")
y Simulation of the Index mill/turn multi-channel control programming and
synchronization technology
y The use of certain macros requires an Advanced Machine Features license. The
macros in this category are:
ClampOnOff
Ijk2AbcType (with a non-zero value)
ModeAsymTurningOnOff (with a non-zero value)
As new advanced NC machine and control features are added to VERICUT in the future,
having this option provides access to them as well as those listed above. If you have
advanced or custom requirements to be simulated by VERICUT, contact your CGTech
representative to learn how we can help.
Advanced Machine Features requires a Verification base module license as a pre-
requisite.
Return to Licenses and Options available.

Machine Developer's Kit


While VERICUT's capabilities are ideal for most, some users with special simulation or
unusual processing requirements may require the Machine Developer’s Kit – a high-level
programming tool designed to increase VERICUT’s ability to interpret and translate
complex or unusual NC machine code data.
Do you need the Machine Developer’s Kit?—VERICUT strives to support all the codes
that are typically executed when running a job. However, it does not support all codes for
every available control. (A special milling cycle, for example, may not be supported.)
Under special circumstances some customization may be necessary. Based on a
programming language similar to C, the Machine Developer's Kit provides a great deal of
flexibility for interpreting and translating NC file formats. There are a number of
additional benefits. For example, new functions can be written for new or enhanced

36
control capabilities. Hardware and NC controls can be retrofitted or replaced without
retiring NC code. VERICUT can be set to output NC code compatible with new
equipment. Some programming experience is recommended.
Machine Developer's Kit requires a Verification base module license as a pre-requisite.
Return to Licenses and Options available.

Cutter Grinder Verification


The Cutter Grinder Verification module is a new base module designed to make the use
of VERICUT more accessible to Cutter Grinder machine users. Cutter Grinder
Verification is a packaging of the current Verification and Multi-Axis modules,
controlled by a default custom interface (see "Customizer" below). The interface can be
tailored by CGTech for specific end-users, or by anyone with a license for the new
Customizer module.
Cutter Grinder Verification is expected to be launched from a grinder programming
system. Currently the only known functioning systems are NUMROTO by Schnieder
Electric (NUM) from Switzerland, and the software produced by Alfred Schuette in
Germany.

The following Verification and Multi-Axis features ARE NOT available in the Cutter
Grinder Verification base module:
APT CL formats other than VERICUT APT
Multiple tool path files
Multiple stock components
Toolpath Review
Save a control file
Save a machine file
Wire EDM
4-axis merged turning

The following add-on modules MAY NOT be added to the Cutter Grinder Verification
base module:
AUTO-DIFF
Multi-Axis
OptiPath
EDM Die Sinking Simulation
Model Export
Machine Simulation
Machine Developer's Kit

There are no pre-requisites for this base module.


Return to Licenses and Options available.

37
Cutter Grinder Machine Simulation
The Cutter Grinder Machine Simulation module is an add-on module available only with
Cutter Grinder Verification. It allows you to simulate and detect collisions using a
grinding machine file and appropriate control file.
Cutter Grinder Machine Simulation requires a Cutter Grinder Verification license as a
pre-requisite.
Return to Licenses and Options available.

CNC Machine Probing


CNC Machine Probing enables you to simulate the use of probing devices on a CNC
machining center and detect errors that could break the probe... before your program even
leaves for the shop!
If you use your CNC for probing operations, CNC Machine Probing will help ensure that
you will not destroy the probe or crash the machine during tasks such as:
y Locating the stock and/or fixture and adjusting offsets
y Measuring and adjusting for stock variations
y Identifying stock and/or fixture configuration or part number on the machine
y Measuring and adjusting tool or fixture offsets
y Detecting tool failure
y Inspecting critical machined features
Why Simulate Probing Operations? —
When using a CNC machine to perform probing operations a number of errors can occur.
The probe tip/stem could contact another object while not in probe mode, likely breaking
it. The probe body or other machine component could hit something when moving and
destroy an expensive inspection probe. Or, an error in the probe cycle logic could cause
unexpected machine motion — which could crash the machine, destroy the probe body,
or break the probe tip!
With VERICUT simulation, there is no reason your probing operations should ever cause
a headache! It notifies you when the probe tip contacts an object while not in 'probe
mode,' and detects any collisions. It even verifies that the probe cycle’s logic (which
alters machine motion based on information gathered during probing) will not cause an
error!
How it works —
It’s easy to create a probe tool. Simply specify the spherical "tip" diameter and shank
diameter and length. Adding a holder completes the assembly and protects the entire
inspection probe! VERICUT detects collisions when anything other than the probe tip
contacts another object.
VERICUT then moves the simulated probe device along the specified path. Motion stops
when the probe tip contacts an object, or when it reaches the end of the programmed
motion. The probe motion results (such as machine axis locations) are applied in the
probe sub-program with VERICUT's standard control emulation, just like on your CNC.

38
VERICUT simulates all aspects of probe cycle subroutines/programs, including complex
logic and Type II formats used to set offsets and make decisions based on probe results.
Contact CGTech to learn how VERICUT can simulate your custom probe cycles!
CNC Machine Probing requires a Verification base module license as a pre-requisite.
Return to Licenses and Options available.

Inspection Sequence
The Inspection Sequence module is an add-on module that enables you to save time and
improve accuracy by generating in-process inspection instructions and documentation
from VERICUT’s simulated in-process machined features.
Inspection Sequence requires a Verification, or Mold & Die Machining, base module
license as a pre-requisite.
Return to Licenses and Options available.

Pro/E-to-VERICUT Interface (PROEV)


The Pro/E-to-VERICUT Interface gives Pro/Engineer users a better way to work with
VERICUT from within their CAD/CAM environment.
VERICUT is launched from within Pro/Engineer’s NC menus and can be run
interactively or in batch mode. Tool path motions for the selected Operation or NC
Sequence; tool descriptions; and reference, workpiece and fixture models from the
current manufacturing session are automatically transferred to VERICUT.
The VERICUT session runs as an external process, allowing you to work in Pro/Engineer
while VERICUT verifies the tool path.
Return to Licenses and Options available.

Unigraphics-to-VERICUT Interface (UGV)


The Unigraphics-to-VERICUT Interface, or "UGV" license provides a fully integrated
Unigraphics-to-VERICUT interface that streamlines the verification and optimization of
UG-generated tool paths.
y Verify individual paths, a series of selected paths, or a complete sequence of
operations.
y Stock, fixture, and design models are automatically transferred to VERICUT,
along with tool path and tooling information.
y VERICUT runs independently from UG, so you can work in UG while verifying a
tool path.
NOTE: The following Unigraphics products, ufunc_execute (P2_ufunc_execute
for NX2) (product name "UG/Open API Execute") and the grip_execute (product
name "UG/Open Grip Execute") are required prerequisites to running the
Unigraphics-to-VERICUT Interface.
Return to Licenses and Options available.

39
CATIA V5-to-VERICUT Interface
The CATIA V5-to-VERICUT Interface integrates VERICUT into the CATIA V5 NC
programming process, making set up, simulation, and optimization of NC programs
easier and more efficient! You can simulate and verify individual operations, a series of
operations, or a set of NC programs. All stock, fixture, and design geometry is
automatically transferred to VERICUT in the correct orientation, along with tool path,
tooling, machine and control data and other simulation parameters. VERICUT runs
independently, so you can continue working in CATIA while simulating and optimizing
your NC programs.
Return to Licenses and Options available.

CATIA V4-to-VERICUT Interface (CATV)


The CATIA V4-to-VERICUT Interface, or "CATV" license provides a fully integrated
CATIA-to-VERICUT interface that provides an improved way to work with the two
programs. Using CATV, you can run VERICUT directly from CATIA. The VERICUT
process runs independently, so you can work in CATIA while verifying a tool path.
CATV transfers CATIA geometry to VERICUT for stock, fixture, and design models. It
converts CATIA line and arc elements (2D tool profiles) into VERICUT cutter and
holder tool definitions. Based on CATIA coordinate systems, CATV automatically
calculates translations and rotations. CATV exports STL data so there is no need for
expensive STL converters. Unlike converters which only output STL from solids, CATV
outputs faces, skins, surfaces, and volumes.
Return to Licenses and Options available.

WorkNC-to-VERICUT Interface (WNCV)


The WorkNC-to-VERICUT Interface, or "WNCV" license provides WorkNC users with
an easy and convenient way to verify and optimize tool paths. VERICUT can be run
directly from WorkNC, either interactively or in batch mode. Tool descriptions from
WorkNC are automatically transferred to VERICUT. For quick setup, VERICUT creates
a stock workpiece for you based on WorkNC settings.
Return to Licenses and Options available.

Mastercam-to-VERICUT Interface (MCAMV)


The Mastercam-to-VERICUT Interface, or "MCAMV" is a base module allowing users to
launch VERICUT from within Mastercam. Setup information, including tools, tool paths,
and models are automatically sent to VERICUT in their proper orientation and location.
You can work in Mastercam while VERICUT verifies the tool path.
There are no pre-requisites for this base module.
Return to Licenses and Options available.

40
EdgeCAM-to-VERICUT Interface
The EdgeCAM-to-VERICUT Interface enables you to easily send model, tool assembly,
and NC program information to VERICUT from EdgeCAM. Developed using
Pathtrace’s PDI development tools, it simplifies VERICUT setup for seamless simulation
of EdgeCAM NC programs. VERICUT is launched from within EdgeCAM, but runs
externally so you can work in EdgeCAM while verifying and optimizing NC programs in
VERICUT.
Return to Licenses and Options available.

TDM Interface
The TDM Interface provides direct access to the TDM Systems', Tool Data Management
(TDM) system. Lists of tools can be extracted from TDM and used in VERICUT. No
intermediate files are produced, so the tool data used is the latest available from the TDM
database.
Return to Licenses and Options available.

41
VERICUT System Requirements
Version 6.0

Review the latest system requirements on VERICUT 6.0's Requirements webpage.

NOTE: Requirements have changed – review carefully.

General Requirements
• CD-ROM drive
• Two or three button mouse
• Network interface card
NOTE: The VERICUT license server may not work correctly with more than one
network card on some UNIX computers.
• Graphics device capable of displaying at least 16K colors
• Hardware graphics accelerators are optionally used in a machine simulation view.

Due to the large amount of graphics memory required to display the cut stock, graphics
memory of 128mb minimum is recommended, and 256mb is preferred.

Disk space: 240 Mb for Windows (includes Library, Samples and help files and
Java Run-Time)
200 Mb for the first UNIX platform (includes Library, Samples and
help files)
20 Mb for each additional UNIX platform type
Physical 512 Mb (1 Gb preferred, 2Gb if you want to run VERICUT concurrent
Memory: with another large program)
UNIX Swap 2X Physical Memory
partition or
Windows page
file size:
Temporary disk 120 Mb required during installation, in addition to the disk space
space: required for the installed files, as described in "Disk Space" above.
By default the installation program temporarily uses disk space on:
C:\TEMP on Windows or /tmp on UNIX.
The temporary disk space used during installation can optionally be
redirected by defining the IATEMPDIR environment variable prior to
running the installation program.

42
Windows Requirements

Windows Windows 2000 Professional SP2


Windows XP Professional
Java Run Time Environment 1.4.2 (included with VERICUT for
Windows)
Microsoft recommends Windows be allowed to dynamically manage
the page file size.
Windows Script 5.3 or later is required for the CATIA V5 Interface
Processor Intel Pentium or 100% Pentium-compatible Processor.
1 ghz or faster recommended.
Dual processors improve performance, especially when running other
large programs concurrently with VERICUT.

UNIX Requirements

HP HP-UX 11.0 plus required patches


Java RTE v1.3.1.07 dated October 14, 2002 or later (installation files
included on the VERICUT CD)

IBM AIX 4.3.3 plus fixes


Java Run-Time 1.3.1 build ca1311-20011123a or later (included in the
installed VERICUT files and used locally by VERICUT)

SGI IRIX 6.5.x plus required patches


Java eoe 1.3.1 20020611 or later (installation files included on the
VERICUT CD)
MIPS4 processors (R10000, R12000 series processors).
Not recommended with R5000 processors.
Sun/Solaris Solaris 2.6 plus required patches
Java Run-Time 1.3.1_06-b01 or later (installation files included on the
VERICUT CD)

43
Java Run-Time Environment (JRE) for Unix Systems
Java Run-Time Environment (JRE) files required by VERICUT are included on the
VERICUT CD for all UNIX platforms.
For IBM RS6000 only, the Java Run-Time files are automatically copied into the
VERICUT directory tree during VERICUT installation, but are not installed by the
operating system's installation utility, and will not disturb any existing Java installation.
These files are used exclusively by VERICUT. The Java Run-Time version documented
above in the "UNIX Requirements" section is the version included on the VERICUT CD,
and is the minimum recommended version.
For proper behavior of VERICUT the minimum JRE described above must be used. Later
versions should work, but for practical reasons not all JRE versions can be tested with
VERICUT on all platforms. VERICUT has been tested and is shipped with JRE V1.4.2
on Windows. At the time of release, JRE 1.4.2 was not available for all supported UNIX
platforms. Earlier versions of JRE 1.4 (for example 1.4.0 and 1.4.1) do not work with
VERICUT.
It may be necessary to apply operating system patches for the Java Run-Time version
supplied. Some sites may want to use their currently installed Java Run-Time or install
and use another Java Run-Time. Please ensure that the JRE is equal or later that the
versions described above.
Following are links to each UNIX vendor's java information and download site. UNIX
system administrators should check these sites for the latest operating system patch
information, and ensure that the computer used for VERICUT is at the minimum patch
level for the Java Run-Time version being used.

HP www.hp.com/products1/unix/java/java2/sdk
rte1_3/downloads/index_pa-risc.html.
SGI www.sgi.com/products/evaluation/6.x_java
2_1.3/
Sun java.sun.com/j2se/1.3/download.html
IBM http://www-
106.ibm.com/developerworks/java/jdk/aix/s
ervice.html

44
VERICUT with SpaceBall/SpaceMouse
VERICUT now supports 3Dconnexion 6 axis input devices (SpaceBall and
SpaceMouse) on Windows. Use of these devices require a driver known as 3DxWare.

These devices have at least 8 buttons, some of which we have designated as follows:
Toggles translations on and off.
Toggles rotations on and off (you can't have both of these off together, so turning one
off will turn the other on if necessary).
Toggles the dominant axis filter on and off (when on, only one axis moves at once).
Fit.
Decreases sensitivity.
Increase sensitivity.
Reverse
Refine
With the exception of buttons 4, 7 and 8, these functions are a de-facto standard for
software that supports the devices. PTC uses button 4 as "Fit" in Pro/E. A configuration
file (VERICUT.scg) is required and is accessed by the 3DxWare driver on startup. This
file is distributed by 3Dconnexion with the most recent version of their driver.
While beta testing has shown that VERICUT generally works correctly with various
older models and older versions of the device drivers, CGTech recommends using the
latest driver version. It can be downloaded from www.3dconnexion.com. The VERICUT
configuration file was added to 3DxWare version 2.3 build 5, September 4, 2002.

NOTE: 3Dconnexion motion control devices currently work with VERICUT on


Windows platforms only.

45
Performance Considerations
This section describes ways to help increase VERICUT productivity.

System considerations

y Computer speed— VERICUT runs faster on faster computers. When comparing


computers made by different manufacturers, you can get a general idea how
VERICUT will perform by comparing the processor speed for floating point
computations.
y Multiple processors— VERICUT runs 10-20% faster on computers with dual
processors over a comparable computer with a single processor.
y Memory— The amount of memory available to VERICUT can make a
difference. See "VERICUT System Requirements" for memory
recommendations. If you intend to process large tool paths, complex cutting
operations, or use AUTO-DIFF, you may need more memory. VERICUT uses
virtual memory (hard disk) when physical memory (RAM) is exhausted. Best
performance is obtained when sufficient physical memory is available to
VERICUT. Excessive memory does not make VERICUT run faster, however,
insufficient memory will slow it down.
y Running concurrently with other applications— Even though your system may
run VERICUT or other large applications (e.g. CAD/CAM packages)
comfortably, running them concurrently may cause competition for resources:
memory, disk space, etc. Under these conditions the computer begins "paging" or
"swapping" memory (a.k.a. "disk thrashing"), which adversely affects
performance. Symptoms of disk thrashing are: constant hard drive activity or
noise, active applications are slow, "Out of memory" error messages or warnings
appear. In the worst case you can run out of all available memory which can cause
your to crash or hang. When determining the amount of memory the system needs
to run your applications, be sure to consider the memory requirements of ALL
applications that will be run concurrently.
y Graphics cards— VERICUT uses 2-D raster (pixmap) graphics. It does not use
triangle shading (such as with a 3-D API like OpenGL or Direct3D), texture
mapping, or much (if any) vector drawing. All graphics cards (even the cheapest)
do pixmap graphics. The card needs enough display or video memory to drive the
display resolution at the desired number of colors. For example, 8mb of display
memory may be enough to do a 1024 x 768 display at True Color, but may only
be able to do 64k colors at 1600 x 1024 resolution. VERICUT 5.0 or higher
performs best in a True Color display environment. More expensive does not
necessarily mean "better for VERICUT". Lower cost cards frequently outperform
expensive cards when running VERICUT.

46
Tolerances
y Cutting Tolerance— The "Cutting Tolerance" value (ref. File menu >
Properties, Tolerance tab) controls the accuracy of cuts applied to the workpiece.
This value directly affects the speed and quality of the results from comparing or
exporting models, optimizing tool paths, checking for holder collisions, "Fast
Feed" errors, dynamic rotation speed, and zoom speed. A larger cutting tolerance
value makes VERICUT go faster, but the resulting cut model and collision
checking will be less accurate. A smaller cutting tolerance value may slow the
simulation, but provides the high level of accuracy needed to perform detailed
model analysis or export, optimization, etc.
- A larger cutting tolerance value is probably okay for quick visual checks, or
when only X-Caliper will be used to analyze the model (no AUTO-DIFF).
- Use a smaller cutting tolerance value if you expect to use AUTO-DIFF, Model
Export, OptiPath, or examine very small model details.
y How VERICUT uses Cutting Tolerance to determine model accuracy— The
"Base Cut Tolerance on" option on the File menu > Properties: Tolerance tab
controls how VERICUT applies the Cutting Tolerance value to set cut model
accuracy.
- Choose "Stock Size" to achieve consistent performance on similar sized parts,
regardless of the variety of cutting tools used. However, cuts made by very
small cutters or cutters with complicated shapes should be evaluated closely to
determine if sufficient accuracy has been maintained.
- Choose "Tool Size" to consider sizes of cutting tools in addition to the stock
model size, or when optimal results must be achieved for all cutting tools. Be
aware that with this option, very small cutters such as tiny drills, scribe
endmills, etc. can severely impact overall performance.
y Model file tolerances— Model files, such as Stereolithography (STL) or
VERICUT model files, exported from CAD systems should be created using
tolerances appropriate for how they will be used in VERICUT. For example,
models that will be used as stock workpieces, holding fixtures, or NC machine
components probably do not need to be as accurate as models that will be used by
AUTO-DIFF to check for gouges or excess material. Outputting CAD models
with excessively small tolerance values can result in very large model file sizes
that cause VERICUT to use large amounts of memory. Similar considerations
apply to tolerances for converting IGES model files that will be used in
VERICUT. Assuming you have enough memory, model file size/complexity does
not affect cutting speed in VERICUT.

Other tips and tricks


y Axes display— Axes displayed in the graphics area (e.g. via View menu > View
Axes or right-click shortcut menu) slow cutting speed. For best performance clear
all axes before cutting.

47
y Fixture display— Fixtures displayed in the "Workpiece" view slow cutting
speed. For best performance, set Visibility to Machine View on the Component
Attributes tab of the Modeling window .(e.g. via Project menu > Setup Models >
Define: Component Attributes tab or double-click on the fixture component in the
Component Tree)
y Skip Cut and Animation Speed control— These features on the Project menu >
Processing Options > Motion window directly affect cutting speed. Skipping cuts
can make VERICUT run faster by updating the display less frequently, especially
when multi-axis cuts, large cutters, or tools with holders are involved. Also, for
best performance ensure the Animation Speed slider, located at the bottom of the
VERICUT main window, is positioned as far right as it will go ("Fast").
y No Animation— This feature on the Project menu > Processing Options >
Motion window enables you to reduce processing time. When No Animation is
toggled "on", the graphics display is not updated until either processing is
complete or you Stop the processing. At that time the cut model is displayed in it
"final" state or the state that it was in when processing was stopped.
y Tool holders— Using tool holders enables VERICUT to detect when non-cutting
portions of the tool assembly remove material or crash into clamps/fixtures
holding the workpiece. You can minimize this effect by modeling only portions of
the tool assembly that can be involved in a collision. For example, don't bother
modeling the taper of a milling tool holder (portion that seats inside the spindle).
If you don't have concerns about tool holder collisions, VERICUT will run faster
if tool holders are not displayed, e.g.: Project menu > NC Programs: clear "Use
Holders" checkbox.
y Status and Toolpath windows— Opening these windows via the Info menu
provides valuable information about the machining process. However, since
VERICUT updates them with each tool path record processed, having them open
while cutting slows performance. For best performance, close them before
cutting. You can reopen them later, as needed for reference.
y Address unsupported codes in G-code tool paths— When processing G-code
tool paths, "unsupported" codes cause messages to be written to the VERICUT
Log file and the VERICUT main window message area. Reporting numerous
unsupported codes can slow performance dramatically. Avoid writing "false"
errors and the corresponding time loss by addressing unsupported codes via the
NC control configuration. To ignore codes that are unimportant to the simulation,
use Configuration menu > Word/Address to add groups that will have
unsupported codes call the "IgnoreMacro".
y Faster zooming— Following is a technique to improve the zoom and display
speed, and eliminate the post zoom delay between pressing Play and resuming
cutting. Create a second, smaller view window (View menu > Layout > Add
View) and position it to the side. Cut the part. When you want to see an area in
more detail, use the smaller window for zooming. This protects the refined
display in the larger window. Because VERICUT needs only to update the
smaller image, you get zoom images much faster than performing the operation in
the larger window. Also, when you restart the simulation there is virtually no
delay before VERICUT starts cutting again.

48
y Disable Report— This feature on the Analysis menu > AUTO-DIFF window:
Settings tab enables you to turn off the AUTO-DIFF Report feature to reduce
AUTO-DIFF processing time. For large toolpath files, generating the report can
take a significant amount of time. When toggled "off", you will still see the
AUTO-DIFF results in the graphics area.

Want more VERICUT tips and tricks from the experts? Visit the CGTech web site at
www.cgtech.com and click "SUPPORT PAGE", then look for "Tips and Tricks".

49
VERICUT Files
Summary of VERICUT File Types
The sections that follow provide information about the files VERICUT uses and typical
file extensions.
Types of VERICUT files
Files provided by CGTech to assist with simulating NC program and machine tool
motions can be divided into two categories:
Library files—General purpose files for configuring VERICUT to simulate NC program
and machine motions. Library files are included in every installation, and include:
y VERICUT default files—Default files opened by VERICUT. The files are
configured to perform a short simulation when Play is pressed. Two sets of files
provide demonstrations for inch (vericut.VCProject) and metric
(vericutm.VCProject) environments.
y VERICUT initialization files—Initialization files opened by VERICUT via File
menu > New Project. Two sets of files provide initialization for inch
(init.VCProject) and metric (initm.VCProject) environments.
y Machine and Control files—NC machines and controls intended to help you
configure VERICUT for simulating G-Code NC programs that run on popular NC
machining centers. See "Library Machine files" and "Library Control files"for
details.
For information about these files, see "Library Files".
Sample files—Files used to demonstrate VERICUT capabilities and options. Sample
files are included with CGTech software on the CD, and are available to all users who
choose to load them. For information about these files, see "Sample-Demo Files".
Files Types and Extensions
The types of files used by VERICUT to load and save various types of data are listed
below in alphabetical order. See the appropriate section for a description of file contents
and formats, and how to open and save them.
File type: Typical extension(s):
APT Output file .tp
APT Table file .tbl
AUTO-DIFF Report file .rpt
AVI file .avi
Batch Script file .vcs

50
CGTech Macro Executable file .cme
(CME file)
Control file .ctl
Control Report file .rpt
CSYS File .txt
Die Sinking Simulation Report file .htm
Design Points file .pts
G-Code Log file .log
G-Code Report file .rpt
IGES model file .igs
Image file .img
In Process file .ip
Inspection Sequence Custom .txt
Tolerance file
Inspection Sequence file .VcInspect
Log file (VERICUT log file) .log
Machine file .mch
NC program file .mcd (G-Code), .tp (APT), many
other extensions depending on
CAM system
Operations File .VcTmp
Optimized file (optimized NC .opti, .mco (G-Code), .tpo (APT)
program file)
OptiPath Library file .olb
Post-Processor file .VcPost
Preferences file .prefs ("cgtech_user.prefs")
Project file .VcProject
Report Template file .VcTemplate
Status file .txt
Stereolithography model file .stl

51
Tool Library file .tls
Tool Manager Report file .htm (HTML version), .txt (test
version)
User file .usr
VERICUT Linear-sweep file .swp
VERICUT Polygon file .dsn (design), .fix (fixture), .stk
(stock), .ply (any)
VERICUT Solid file .vct
VERICUT Solid-of-revolution file .sor

52
VERICUT File Descriptions

APT Output File


Typical file extension: .apt

An ASCII text file containing APT NC program records resulting from reverse post-
processing by VERICUT. By default when sequenced G-Code data is converted, columns
73-80 in the output file indicate the block numbers of the G-Code data block where the
converted records came from. Sequence number output is controlled via the Output
Block Sequence Numbers feature on the Project menu > Processing Options > G-Code
> Process Options: Messages tab.
An APT Output file is created when a G-Code NC program is processed with Create
APT Output File feature on the Project menu > Processing Options > G-Code > Process
Options: G-Code Output Files tab is active. You can view this file using the View APT
Output File feature on the Project menu > Processing Options > G-Code > Process
Options: G-Code Output Files tab or the View feature, under APT Output File, on the
Project menu > Output: G-Code Files tab.

Sample G-Code NC Program file:

53
Sample of resulting APT Output file:

54
APT Table File
Typical file extension: .tbl

An ASCII text file used by the Binary CL Converter that contains information necessary
to convert binary APT data into ASCII APT NC program records. Such information
includes: blocking factor, major and minor word classes, sub-classes, etc.
APT Table files are loaded into VERICUT via the File menu > Convert > Binary CL
function. APT Table files can also be specified on the command line when the Binary CL
Converter is executed, such as during batch processing to simulate NC programs without
user interaction.
Sample APT Table file "aptwords.tbl" (located in the \vericut\ directory of your
VERICUT installation):

55
Tips:
y The default blocking factor for interpreting binary CL data is 3228. If this does
not produce favorable results, use any text editor to change the blocking factor.
Other typical blocking factors you can try are: 512, 4628, 15476.
y If the ASCII NC program file output by the converter has major or minor words
other than what you expected, try editing the APT Table file to change the
"Word" output for a specific APT class/subclass.

56
AUTO-DIFF Report File
Typical file extension: .rpt

An ASCII text file that contains information about an AUTO-DIFF model comparison
operation, such as identification of all detected errors, and the NC program history related
to each error. This information is valuable when determining the correctness of the
VERICUT simulated cut model, and NC program records responsible for discrepancies
detected by AUTO-DIFF.
An AUTO-DIFF Report file is created when an AUTO-DIFF comparison is performed,
and can be viewed via the "Report" feature. (Ref. Analysis menu > AUTO-DIFF)
The exact format of the report varies, but generally includes a summary of the results,
information about tolerances and models used in the comparison, error types
(gouge/excess) and amounts, NC program history associated with errors, etc.

Sample AUTO-DIFF Report file:

57
AVI File
Typical file extension: .avi

Also known as an Audio-Video Interleaved file, this file contains recorded images of
VERICUT. AVI files are saved (recorded) via the File menu > Images > Record Movie
function, and replayed via File menu > Images > Playback AVI Movie.

58
Batch Script File
Multiple VERICUT batch sessions can be run via a single executable command by
including VERICUT batch commands in an executable script file. The script file is then
submitted to the operating system for processing. After each batch execution terminates,
the operating system then executes the next command in the script file.
Batch files for different operating systems differ slightly in format. Details will follow
later in this document. In general, each batch command in the script file appears as it
would when entered by itself on the command line. Other operating system commands,
such as those that delete or rename files can also be included in the script file.

Tip: VERICUT batch files can be easily created using VERICUT's Batch Wizard.

UNIX batch script files


A batch script file to be executed in UNIX must have "executable" permissions. Use the
"chmod" command to give the file executable permissions, for example the following
command makes a file named "batchfile" executable by all users: chmod 777
batchfile
The "batchfile" file is executed via typing the file name on the command line, for
example type: batchfile

Windows batch script files


A batch file to be run on Windows is named with a ".bat" extension, for example
"batchfile.bat". Windows NT batch execution lines in the script file are "called" via the
"call" command to return control to the script file after each VERICUT execution.

Batch script file examples


The examples that follow show two sample script files. Example 1 executes two batch
sessions, each processing a part unrelated to the other. Example 2 represents a part
machined in two setups: the first is configured to automatically save an In-process file
named "setup1.ai" via the AutoSave function. The second uses the ip=<ipfile> option to
load the "setup1.ai" In-process file so cutting can be continued with the session
configuration saved in the "setup2.usr" User file.

UNIX batch script file examples:


Example 1:
vericut batch vcp=part1.VcProject
vericut batch vcp=part2.VcProject

59
Example 2:
vericut batch vcp=setup1.VcProject
vericut batch vcp=setup2.VcProject ip=setup1.ai

Windows XP batch script file examples:


Example 1:
call vericut batch “vcp=part1.VcProject”
call vericut batch “vcp=part2.VcProject”
Example 2:
call vericut batch “vcp=setup1.VcProject”
call vericut batch “vcp=setup2.VcProject”
“ip=setup1.ai”

60
CGTECH Macro Executable File
Typical file extension: .cme

A platform-independent binary file also known as a "CME file", that is compiled using
the Machine Developer's Kit and contains custom macros that control processing G-Code
data. In addition to macros, this file can also establish modals which allow users to
further customize how machine code data is interpreted, and provide access to custom
tables containing job and machine related data. The CME file used to perform these tasks
is specified via the Control file- ref. "Dev Kit CME" under the Configuration menu >
Adv. Options function.

61
Control File
Typical file extension: .ctl

An ASCII text file that contains data describing how the NC control processes G-Codes.
Data in this file includes: a list of interpretable machine codes, machine code format
information, rules for grouping machine codes, and rules for calling macros. This file is
required to interpret G-Code data via the G-Code Data NC program type. When the
Machine Developer's Kit is used to create a custom CME file, the Control file can also
specify a custom CME file to assist with the simulation.
By default, VERICUT is configured with a "Fanuc" control. Many control configurations
are available in the library that is installed with VERICUT software- see "Library Control
Files" in the VERICUT Files chapter for more information.
A different Control file can be loaded into VERICUT via the Configuration menu >
Control > Open function. NC control configurations are changed via other "Control"
functions in the Configuration menu. Save the new file via Configuration menu >
Control > Save As.

62
Control Report File
Typical file extension: .rpt

An ASCII text file that contains information about how the current NC control
configuration will interpret various codes. Reported information includes:
G-Codes present in the NC program and macros (actions) the control will perform,
variables used (if any), cutting tools used, subroutines defined and referenced, and more.
Control Report files are created via the Info menu > Control Report function.

Sample Control Report file:

63
CSYS File
An ASCII text file containing information necesary to create a VERICUT Coordinate
System using the CSYS from File feature in the Coordinate System window. The file
contains a collection of APT CL matrices, possibly with different syntaxes in a single
file. The CSYS File is also used by the csys_file command line argument.

The CSYS file may contain one or all combinations of:

CATIA syntax:

$$*CATIA0
$$*AXS1
$$ 1.00000 …
Use "$$*AXS xx" to name the coordinate system, for example "AXS1" in the
above snippet.

UG syntax:

TOOL PATH/P1
.
.
MSYS/ …
Use "TOOL PATH/ xx" to name the coordinate system, for example "P1" in the
above snippet.

PTC syntax:

$$-> FEATNO / 102


.
.
TRANS / …
$$-> CSYS / …
Use "FEATNO / xxx" to name the coordinate system, for example "102" in the
above snippet.

VERICUT-MATRIX syntax:
Modify the syntax to allow an optional name. The code needs to support both with
a quoted name string and without.
PPRINT/VERICUT-MATRIX "name" 1,0,0 …

64
Design Points File
Typical file extension: .pts

An ASCII text file also known as an "inspection point file", that contains point locations
used to inspect the VERICUT model when performing an AUTO-DIFF Point comparison
operation.

Design Point files are loaded into VERICUT via the Project menu > Setup Models >
Define function. Point record formats support specifying surface normals, tolerances, and
check distances with any or all inspection points. Example point record formats follow.

Design Points file record formats:

y GOTO/X,Y,Z -where "X,Y,Z" represents the design point location, for example:
"GOTO/1,2,3".
y GOTO/X,Y,Z,I,J,K -as above plus "I,J,K" represents the surface normal vector,
for example: "GOTO/1,2,3,1,0,0".
y GOTO/X,Y,Z,I,J,K,intol,outtol -as above plus "intol"and "outtol" override the
Gouge Tolerance and Excess Tolerance values, for example:
"GOTO/1,2,3,1,0,0,.0005,.015". The overrides are only applied to the point where
they are listed.
y GOTO/X,Y,Z,I,J,K,intol,outtol,incheck,outcheck -as above plus "incheck" and
"outcheck" override the Gouge Check Distance and Excess Check Distance
values, for example: "GOTO/1,2,3,.1,0,0,.015,.015,.300,.300". The overrides are
only applied to the point where they are listed.

Any combination of the above formats can be included in the Design Points file. There is
no limit to number of records that the file can contain. "$$" comment records and spaces
are permitted.

65
Sample Design Points file:

66
Die Sinking Simulation Report File
Typical file extension: .htm

An HTML file that contains data describing a particular die sinking process.

67
G-Code Log File
Typical file extension: .log

An ASCII text file that contains error, warning and informational messages about G-
Code processing. One of the most valuable pieces of information this file provides is a
copy of each input G-Code data block followed by the converted ASCII APT NC
program record indented by 4 spaces. This allows you to see a direct translation of G-
Code versus equivalent ASCII APT output for all NC program records processed.
G-Code Log files are created when a name is entered in the Project menu > Processing
Options > G-Code > Process Options: G-Code Output File tab, Log File field, and
are viewed via Project menu > Processing Options > G-Code > Process Options: G-
Code Output Files tab, View G-Code Log File. For help with interpreting error and
warning messages in this file, consult ERRORS and Problem Solving at
http://www.cgtech.com/support/errors_problems/errors.htm.

Sample G-Code Log file:

68
G-Code Report File
Typical file extension: .rpt

An ASCII text file that contains information about how the current NC control
configuration will interpret a G-Code NC program file. Reported information includes:
G-Codes present in the NC program and macros (actions) the control will perform,
variables used (if any), cutting tools used, subroutines defined and referenced, and more.
G-Code Report files are created via the Info menu > G-Code Report function.

Sample G-Code Report file:

69
IGES Model File
Typical file extension: .igs

An IGES (Initial Graphics Exchange Specification) model file, also known as an "IGES
file", is an ASCII text file which describes virtually anything that can be modeled in a
CAD system. IGES data is widely accepted as an industry standard for transferring model
data. While IGES model files containing only 2-D data (lines and arcs) are not useful in
VERICUT, files containing 3-D surfaces and solids can be used to describe stock, fixture,
or design models, as well as machine component shapes.
IGES model files are imported into VERICUT via the Project menu > Setup Models >
Define function, or can be converted into STL or VERICUT Polygon model files using
the IGES converter.

70
Image File
Typical file extension: .img

A platform-independent binary file that contains recorded images of a NC program


simulation. Image files can contain any combination of snapshot (single still image) and
animation images (similar to a movie). These files can be recorded and replayed on any
supported computer platform.
Two types of VERICUT images can be recorded. Both types can be recorded into the
same file. Machining status is automatically recorded with either image type.
Snapshot — single-frame image. These images are also used to mark stop points in an
animation.
Animation — multiple images that when replayed, appear like a simulation (like a
movie).
Image files are saved (recorded) via the File menu > Images > Record Movie function,
and replayed via File menu > Images > Playback VERICUT Movie.

NOTE: Image files are not intended for printing. Use File menu > Print View or
File menu > Images > View Capture to print VERICUT images.

71
In Process File
Typical file extension: .ip

A part ASCII text-part binary file also known as an "IP file" that contains the data
necessary to re-establish a VERICUT session, including the current VERICUT model
(with cuts), user interface settings, and a copy of the Log file. IP files are also used to
“backup” the verification session, safeguarding against lost work if the session is
interrupted by computer or power failure.
Save an In-process file interactively via File menu > In Process > Save As, or
automatically via the Auto Save function. Due to differences in math processing on
various computer types, IP files are usable on computers of the same type on which they
were saved.
Load IP files via File menu > In Process > Open to re-establish a VERICUT session or
provide a VERICUT model for additional machining and analysis. IP files can also be
specified on the command line when VERICUT is executed, such as during batch
processing to simulate NC programs without user interaction.

NOTE: Environment variables can be used to affect VERICUT's use of IP files.


For more information, see "Environment variables".

72
Inspection Sequence Custom Tolerance File
Typical file extension: .txt

A custom inspection tolerance file is an ASCII text file that contains default tolerances
that are automatically used when creating inspection record in an Inspection Sequence
data table.

73
Inspection Sequence File
Typical file extension: .VcInspect

An inspection sequence file is an XML (Extensible Markup Language) text file used to
retain all the information needed to reproduce the Inspection Sequence data table and the
corresponding inspection markers on the workpiece for a single inspection report.

74
Log File
Typical file extension: .log

An ASCII text file that contains information about a VERICUT session, such as: names
of NC programs processed, errors, warnings, simulated machining times, and other
informational messages.
When VERICUT is run, it must always be able to open a Log file. When an existing Log
file of the same name is found VERICUT responds differently, depending on the run
mode:

y VERICUT run in interactive mode—Log file is automatically reset, unless the


"append_log" command line options is used.
y VERICUT run in batch mode—Log file is automatically reset, unless the
"reset_log" command line options is used.
For more information on command line options used with VERICUT, see
"Command line options for VERICUT".

Using the Info menu > VERICUT Log function, Log file contents can be viewed,
edited, or the file name changed. For help with interpreting error and warning messages
in this file, consult ERRORS and Problem Solving at
http://www.cgtech.com/support/errors_problems/errors.htm.

75
Sample VERICUT Log file:

76
Machine File
Typical file extension: .mch

An ASCII text file that contains data describing the construction, kinematics, and other
properties of an NC machine tool. By default, VERICUT is configured with a 3-axis
vertical mill machine. Many machine configurations are available in the library that is
installed with VERICUT software- see Library Machine files in the VERICUT Files
section for more information.
A different Machine file can be loaded into VERICUT via the Configuration menu >
Machine > Open function. NC machine configurations are changed via other "Machine"
functions in the Configuration menu. Save the new file via Configuration menu >
Machine > Save As.

77
NC Program File
Typical file extension: .mcd (G-Code), .tp (APT), many other extensions depending on
CAM system

NC program, or "NC program" files are ASCII text files that contain data describing
cutting tool positions, machine information, and other information required to operate NC
machine tools.
NC program files to be simulated or optimized are referenced in VERICUT via the
Project menu > NC Programs function. VERICUT does not actually keep a copy of the
NC program files, but instead stores NC program file names and keep tracks of which
record in the file is being processed.
NC programs files can be divided into two general types:

y APT-CLS NC program files


y G-Code NC program files

A general discussion of each type follows.

APT-CLS NC program files


APT and CLS NC program files are generic file formats output by CAM systems
that are intended to be easily read by the NC programmer. They are intermediate
file formats that typically are not used directly by the NC machine. Before the data
can be used by an NC machine these files must be post-processed to a G-Code NC
program file format containing codes specific to that machine tool (see "G-Code
NC program files" below).
VERICUT processes "Simple ASCII APT" NC programs-meaning all macros,
motion commands, and motion copy routines are pre-processed into an ASCII
centerline file containing GOTO, CIRCLE, CYCLE, and miscellaneous machine
commands. No geometry definitions, symbolic substitutions, macros, or complex
motions (such as GORGT, GOLFT, etc.) are present.
Common APT-CLS NC program variations that VERICUT can process are listed
below.

y ACL
y CADRA CL data
y CATIA workstation APT
y CV APT
y ProManufacturing APT
y UG CLS

To process one of the APT-CLS NC program variations listed above, be sure to


specify the appropriate NC Program Type under Project menu > NC programs.

78
G-Code NC program files
G-Code NC program files are formatted for use directly by the NC machine. These
files typically originated as APT-CLS NC program files (see "APT-CLS NC
program files" above), and have been post-processed to contain specific codes for a
given machine tool.

To process G-Code NC program file, be sure to specify NC program Type=G-


Code Data under Project menu > NC programs. While VERICUT easily
processes G-Code data that conforms to the EIA Standard RS-274 format, other
variations can also be simulated with a little configuration effort. Configuration
menu functions provide most of the configurability needed to support various NC
machine and control combinations.

79
Operations File
Typical file extension: .VcTmp

Introduction
An Operations File, or Ops File, can be used to assemble a project with multiple setups
from several VERICUT project files, which typically have the extension ".VcProject".
This assembly process can only be triggered from the command line that invokes
VERICUT. The necessary command line syntax is;

For Windows ... "ops=D:\My\Path\MyOperationsFile.VcTmp" ...


For Unix ... "ops=/My/Path/MyOperationsFile.VcTmp" ...

Any extension can be used in the file name, but by convention ".VcTmp" denotes a
temporary file.

An Operations File is a man-readable text file. Each line of the file is independent and
references a VERICUT project file. A line requests that information from its project file
should be transferred to the project being assembled. A line can request that the entire
project and all its setups be transferred, or that information from one setup be transferred,
or that all the setup-independent information, which we will refer to as project
information, be transferred. It is suggested that the first line of the file should always
request at least the project information from a ".VcProject" file that was saved by
VERICUT, so that the new project will have a good foundation.

Syntax
In the following explanation the Windows path delimiter, "\", is used. For a Unix
platform you should substitute the "/" character. Names should be enclosed in double
quotation characters ("). Fields are separated by one or more spaces.

To request that the entire project, with all its setups, be transferred to the new project
being assembled, the syntax of the required line is;

ALL FILE="My\Path\MyProjectTemplate.VcProject"

To request that the project information from a file be transferred to the new project being
assembled, the syntax of the required line is;

PROJECT FILE="My\Path\MyProjectTemplate.VcProject"

80
Setup independent information in a project file pertains to the following VERICUT menu
items;

y Model Export
y Colors
y Image Recording and Playback
y View Capture
y AutoSave
y View Select/Store
y Status
y Graphs
y Cycle Definitions
y AUTO-DIFF

To request that setup information from a file be transferred to the new project, the syntax
of the required line is;

SETUP NAME="Setup A" INDEX=1 FILE="My\Path\MySetupTemplate.VcProject"

The NAME field specifies the name that the setup will have in the new project. The
INDEX field selects which of the setups in the referenced file will be transferred. An
index value of "1" selects the first setup in the file, "2" would use the second setup,
etcetera. The FILE field references the VERICUT project file that contains the required
setup.

Note that more than one SETUP line in the Operations File can have the same NAME
field. The first such line would cause a new setup to be appended to the project being
assembled, and subsequent lines could adjust the parameters of that same setup. Setup
specific information in a project file pertains to the following VERICUT menu items;

y Properties
y Views
y Sections
y Components and Models
y NC Programs and Filters
y Tools and Tool Changes
y APT and G-Code Settings
y Coordinate Systems
y Control
y Machine
y Inspection
y Die Sinking
y OptiPath

81
Project Naming
The name and location of the assembled project file will be derived from the name and
location of the Operations File. The extension ".VcProject" will replace any extension
that the Operations File's name has, and the assembled project will be placed in the same
folder. This assumes that the user saves the project before explicitly renaming it and
before exiting VERICUT. To remind the user that he needs to save the project before
exiting, you can include another keyword on the command line. Thus you may have;

... "ops=D:\My\Path\MyOperationsFile.VcTmp" usr_changed ...

82
Optimized File
Typical file extension: .opti, .mco (G-Code NC program file) or .tpo (APT NC program
file)

The Optimized NC program file is created from optimizing NC program feed rates via
OptiPath.
For details about using OptiPath and sample optimized NC program files, see the
OptiPath menu functions.

83
OptiPath Library File
Typical file extension: .olb

An ASCII text file that contains optimization data for use by VERICUT's OptiPath feed
rate optimization module. Specific optimization data values are defined per tool intended
to be used in specific machining conditions, e.g. workpiece material, NC machine, etc.

NC program optimization can performed in a variety of ways, including: configuring


cutting tools-to-optimization library records, storing optimization information with tools
in a VERICUT Tool Library, or interactive prompting.

84
Post-Processor File
Typical file extension: .VcPost

A Post-Processor file is an ASCII text file, created using the CGTech Post Processor, that
contains all the information required to read machine independent NC Program data and
convert it to G-Code files for a specific machine/control combination.

85
Preferences File
Typical file extension: .prefs

Also known as a "Prefs file", thisASCII text file is automatically saved when you exit
VERICUT and stores such user preferences as:

y VERICUT user interface Look & Feel


y size and locations of VERICUT windows
y state of menu toggles in any window that has them, for example: View menu >
Toolbar, View Axes, etc.
y filters for VERICUT file selection windows
y recent User files opened in VERICUT

The Preferences file is unique for each VERICUT version and each user, based on your
login. The file is named "cgtech_user.prefs" for VERICUT 5.0, and follows the naming
convention "cgtech_<ver#>_user.prefs" for subsequent versions. For example, a Prefs file
for VERICUT 5.1 has the name "cgtech_51_user.prefs". The Prefs file is automatically
stored in your home directory and are updated each time you exit VERICUT. When you
run a new VERICUT version for the first time (no Prefs file exists for that version), it
will attempt to use the Prefs file from the previous version.

When users share a machine (or an account), CGTech recommends that each user set a
unique CGTECH_USERNAME environment variable to prevent overwriting the
Preferences file. See "Environment variables" for more information.

To reset Preferences file settings:


y Windows—Choose Reset VERICUT Preferences file from the CGTech
programs group.
y UNIX—Delete the "cgtech_user.prefs" from your home directory, or run the
"delprefs" command file located in the ...<computertype>/commands directory of
your VERICUT installation.

86
Sample Preferences file "cgtech_user.prefs":

87
Project File
Typical file extension: .VcProject

A VERICUT Project file is an XML (Extensible Markup Language) text file containing
VERICUT session settings, also known as "user configuration values" or "user values",
including: measurement units, colors, choices, data field values, directory paths and file
names, etc.. These files are relatively small in size, yet can control the entire cutting
process and minimize the effort required to configure the system for processing NC
program files.

Project files are saved via the File menu > Save Project function, and loaded via File
menu > Open. User files can also be specified on the command line when VERICUT is
executed, such as during batch processing to simulate NC programs without user
interaction.

88
Report Template File
Typical file extension: .VcTemplate

A Report Template file is an XML (Extensible Markup Language) text file containing all
of the formatting information required to generate VERICUT reports.

89
Status File
Typical file extension: .txt

An ASCII text file that contains whatever data is sent to the Status window during the
simulation (ref. Info menu > Status). A Status file is created when the
CGTECH_STATUS environment variable is set to a file name before VERICUT is
executed. The file is overwritten when the VERICUT model is reset.
For each NC program record processed, the following status data is written:
y REC—Indicates a NC program record processed.
y REC fields—NC program Record Line Number, NC program Record
y DATA—Specifies most of the status values separated by commas. Fields not
displayed in the Status window are represented by commas.
y DATA fields—Mch Axis Loc- X, Y, Z, A, B, C, U, V, W, Tool Tip Loc- X, Y, Z,
I, J, K, Errors, Warnings, Time, Time%, Dist, - Dist%, Coolant, Feedrate, OP
Feedrate, Spindle, OP Spindle
y TOOLCHANGEREC—The record which caused the last tool change (present
only if the Status window is configured to show this field).
y TOOLDESC—The current tool description (present only if the Status window is
configured to show this field).
y TOOLGEOMETRY—The current tool geometry (present only if the Status
window is configured to show this field).

APT example:
REC,12,GOTO/3,2,1
DATA,,,,,,,,,,,,,,,,3,,,,0,0,0.5355,,,,ON ,10 IPM,,500,CLW ,
TOOLCHANGEREC,CUTTER/1.125,.25,0,0,0,0,2.1

G-Code example:
REC,20,N0130G0X-.2Y-.3Z2.S1200M3
DATA,,,,,,,,,,,,,,,,19,,,4,0,0,1.6979,,,,OFF,2 IPM,,1200,
TOOLCHANGEREC,N0120T4M6

90
Stereolithography Model File
Typical file extension: .stl

A Stereolithography model file, also known as an "STL" or "SLA" file, is an ASCII text
or binary file which describes virtually any surfaced or solid model shape. The STL data
representing the model shape is composed of three-sided facets with associated surface
normals. STL files typically originate from a CAD system and represent an enclosed
model used by an SLA machine, such as developed by 3D Systems.

Load Stereolithography model files into VERICUT via the Project menu > Setup
Models > Define function. For an STL file to be used in VERICUT as a solid model, the
STL data must represent a fully enclosed (watertight) model and have normals that point
consistently outward. (STL files used as surface models do not have to be watertight.) If
normals are inconsistent, gaps exist between facets, or facets overlap, solid model display
results are unpredictable. When cutting is started or the model is analyzed, these
symptoms indicate problems exist in the model file data:

y model is not displayed at all


y model is displayed with holes, gaps, or seams
y portions of the model are missing

Tip: If any of the above symptoms are experienced, use the PolyFix Converter and/or the
Stock Consistency Check feature (ref. File menu > Properties: General tab) to repair
the model before cutting. Similar advice applies for models added to Design components
for use with AUTO-DIFF, except the Design Consistency Check feature is used (ref.
Analysis menu > AUTO-DIFF: Options tab).

91
Sample STL file:

92
Tool Library File
Typical file extension: .tls

An ASCII text file that contains descriptions of cutting tools, shanks and holders, as well
as other tool data used by VERICUT. Specific tool data is stored and retrieved via a tool
"ID".

This file is created and maintained via the Project menu > Tools function. The Tool
Library file used by VERICUT when the Project menu > NC programs function is
configured to do so.

NOTE: If errors occur when attempting to load the file, consult ERRORS and
Problem Solving at http://www.cgtech.com/support/errors_problems/errors.htm, for
assistance.

93
Sample VERICUT Tool Library file:

VERICUT 5.0 Tool Library File generic format and allowable syntax:
CGTECH Tool Library File

Version-5.0

TOOLID "toolid" {

DRIVENPOINT_OFFSET (#,#,#)

94
GAGEPOINT_OFFSET (#,#,#)

TOOLTYPE MILLING|TURNING

USE CUTTER|SHANK|HOLDER "toolid"

DESCRIPTION "description"

STACK YES|NO

COLOR #

ROTATION_ANGLE #

CUTTER {

ORIGIN (#,#,#)

XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

CUTTER_TYPE "APT 7"|"APT 10"|"BALL END"|"BULL NOSE"|"FLAT END"|"DRILL"|

"TRIANGLE INSERT"|"DIAMOND INSERT"|"DRILL TURN"

STANDARD (#,#,#,#,#,#,#,#,#,#) /* All 7 or 10 must be preset */

ASSEMBLY {

BLOCK {

LENGTHS (#,#,#)

ORIGIN (#,#,#)

XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

CYLINDER {

HEIGHT #

95
RADIUS #

TOLERANCE #

ORIGIN (#,#,#)

XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

CONE {

HEIGHT #

BOTTOM_RADIUS #

TOP_RADIUS #

TOLERANCE #

ORIGIN (#,#,#)

XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

SWEEP {

ZLIMITS (#,#)

ARC (#,#,#)

ARC (#,#,#) SHORTEST_DISTANCE|CCW|CW

PTS {

(#,#) /* coordinates are grouped by () */

ORIGIN (#,#,#)

96
XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

SOR {

ARC (#,#,#)

ARC (#,#,#) SHORTEST_DISTANCE|CCW|CW

PTS {

(#,#) /* coordinates are grouped by () */

TOLERANCE #

ORIGIN (#,#,#)

XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

VC_MODEL_FILE {

FILE_NAME "filename"

ORIGIN (#,#,#)

XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

STL_FILE {

FILE_NAME "filename" "Inward"|"Outward"

97
ORIGIN (#,#,#)

XAXIS (#,#,#)

ZAXIS (#,#,#)

COLOR #

SHANK {

<data>

HOLDER {

<data>

98
Tool Manager Report File
Typical file extensions: .htm (HTML version), .txt (test version)

An HTML or text file that contains information about tools in a VERICUT Tool Library
file, such as: the Tool Library name, listing of tools, tool images (HTML version only),
and optimization properties, if defined. Tool Manager Report files are created and viewed
from the Tool Manager window via clicking File menu > Create Report features.

Sample HTML version Tool Manager Report file:

99
Sample text version Tool Manager Report file:

100
User File
Typical file extension: .usr

An ASCII text file that contains VERICUT session settings, also known as "user
configuration values" or "user values", including: measurement units, colors, choices,
data field values, directory paths and file names, etc.. These files are relatively small in
size, yet can control the entire cutting process and minimize the effort required to
configure the system for processing a NC program file.
User files are loaded via File menu > Open. User files can also be specified on the
command line when VERICUT is executed, such as during batch processing to simulate
NC programs without user interaction.

Sample User file:

Within the User file, the left column contains descriptive information about user
variables, the center column lists the user variable names, and the right column lists saved
values for corresponding user variables.
Use the user variable names listed in the center column when referencing via command
line options. For more information, see "Command line options".

101
NOTE: Environment variables can be used to affect VERICUT's use of User
files. For more information, see "Environment variables".

102
VERICUT Linear Sweep File
Typical file extension: .swp

A VERICUT Linear-sweep file, or "Linear-sweep file" for short, is an ASCII text file that
describes an extruded shape. A 2-D profile is defined in the XY plane, then swept
(extruded) along the model's Z axis.
Linear-sweep files are loaded into VERICUT via the Project menu > Setup Models >
Define function, and contain the following data:
y File type record—Specifies the type of VERICUT file, for example "VERICUT-
model".
y Version number record—Software version in which the file is to be used, for
example "version-3.0".
y Model file identifier record—Model file type: "2" identifies a Linear-sweep file.
y Sweep start value—Z value of the linear sweep start.
y Sweep end value—Z value of the linear sweep end.
y Polyline data—The remaining records in the file are the XY point pairs which
define the polyline to extrude. Each X and Y value must be on a separate line with
a space between values. There is no limit on the number of point pairs allowed,
but there must be at least 3 pairs. The polyline can be completely enclosed or
open ended, but can not cross over itself. Open ended polylines are automatically
closed to the start point.

Sample Linear-sweep files:

103
VERICUT Polygon File
Typical file extensions: design- .dsn, fixture- .fix, stock- .stk, any- .ply

A VERICUT Polygon file, or "Polygon file" for short, is an ASCII text file that describes
virtually any shape open surface or enclosed shape. The polygon (faceted) data is
composed of three or four sided polygons with associated surface normals that represent
the true geometric model shape.

Load Polygon model files into VERICUT via the Project menu > Setup Models >
Define function. For a Polygon file to be used in VERICUT as a solid model, the polygon
data must represent a fully enclosed (watertight) model and have normals that point
consistently outward. (Polygon model files used as surface models do not have to be
watertight.) If normals are inconsistent, gaps exist between facets, or facets overlap, solid
model display results are unpredictable. When cutting is started or the model is analyzed,
these symptoms indicate problems exist in the model file data:

y model is not displayed at all


y model is displayed with holes, gaps, or seams
y portions of the model are missing

Tip: If any of the above symptoms are experienced, use the PolyFix Converter and/or the
Stock Consistency Check feature (ref. File menu > Properties, General tab) to repair
the model before cutting. Similar advice applies for models added to Design components
for use with AUTO-DIFF, except the Design Consistency Check feature is used (ref.
Analysis menu > AUTO-DIFF, Options tab).

Polygon file format:

y File type record—Specifies the type of VERICUT file, for example "VERICUT-
model".
y Version number record—Software version in which the file is to be used, for
example "version-3.0".
y Model file identifier record—Model file type: "1" specifies a Polygon file.
y Sweep start value—Z value of the linear sweep start.
y Sweep end value—Z value of the linear sweep end.
y Polygon format record—Describes the surface normal data and vertex data
formats. This record contains three integer numbers separated by blanks: n1 n2 n3
(e.g. "0 0 1") where:

n1 (normal vector type)—Specifies the type of surface normal vector information


present in the polygon file.
0- each polygon has one normal vector
1- each vertex has a normal vector

104
n2 (normal vector direction)—Specifies the surface normal vector direction relative to
the model surface.
0- normal vectors point inward
1- normal vectors point outward
2- normal vector directions are inconsistent (should ONLY be used after both the
"0" and "1" values have been attempted with unfavorable results; requires
significantly more processing time and computer resources)

n3 (Polygon format type)—Specifies the polygon data format.


0- binary data format (recommended- requires less storage space and is processed
faster, however, binary formatted files are computer-specific)
1- ASCII data format
y Polygon data—The remaining records in the file are the polygon data records
which define the model shape. Each model facet (or polygon) is represented by a
series of records describing its number and location of vertices, as well as surface
normal vector direction(s). There is no limit on the amount of data allowed.

Two polygon data formats are supported. The polygon data type must be consistent for
the entire file.

Format 1- 1 normal per polygon:


vertex count (3 or 4)
X Y Z (vertex 1)
X Y Z (vertex 2)
X Y Z (vertex 3)
I J K (normal)

Format 2- 1 normal per vertex:


vertex count (3 or 4)
X Y Z (vertex 1)
X Y Z (vertex 2)
X Y Z (vertex 3)
I J K (normal 1)
I J K (normal 2)
I J K (normal 3)

105
Sample Polygon file:

106
VERICUT Solid File
Typical file extension: .vct

A VERICUT Solid file is a binary file containing "geometry only" data representing a cut
stock model without history data.

The VERICUT Solid enables you to use a previously created cut stock model in a new
VERICUT session as a stock, fixture or design model. You can also use a VERICUT
Solid as a design model for Constant Gouge Check.
A cut stock model can be saved using the File > Save Cut Stock option in the
Configuration menu > Component Tree window.

VERICUT Solid files are loaded into VERICUT using the Project menu > Setup
Models > Define function.

NOTE: VERICUT Solid models are not recognized in FastMill Cut Mode or
when using AUTO-DIFF Surface.

107
VERICUT Solid-of-Revolution File
Typical file extension: .sor

A VERICUT Solid-of-revolution file, or "Solid-of-revolution file" for short, is an ASCII


text file that describes a revolved shape. A 2-D profile is defined in the ZX plane, then
revolved around the model's Z axis.

Solid-of-revolution files are loaded into VERICUT via the Project menu > Setup
Models > Define function, and contain the following data:

y File type record—Specifies the type of VERICUT file, for example "VERICUT-
model".
y Version number record—Software version in which the file is to be used, for
example “version-5.0”.
y Model file identifier record—Model file type: "0" identifies a Solid-of-
revolution file.
y Tolerance of revolution—Chordal tolerance (intol) of the revolved surface,
controls the S.O.R.'s degree of roundness for the model database.
y Polyline data—The remaining records in the file are the XZ point pairs which
define the polyline to revolve. Each X and Z value must be on a separate line with
a space between values. There is no limit on the number of point pairs allowed,
but there must be at least 3 pairs. X values must be greater than or equal to zero.
The polyline can be completely enclosed or open ended, but can not cross over
itself. Open ended polylines are automatically closed to the start point.

108
Sample Solid-of-revolution files:

109
Library Files

Library File Overview


This section provides information about the library files installed with VERICUT
("library" directory in your VERICUT installation). Library files are included in every
installation, and include:

General Purpose Library Files


The following types of General Purpose Library Files are included:
VERICUT default files — Default files opened by VERICUT. The files are
configured to perform a short simulation when Play is pressed. Two sets of files
provide demonstrations for inch (vericut.*) and metric (vericutm.*) environments.
VERICUT initialization files — Initialization files opened by VERICUT via File
menu > New Project. Two sets of files provide initialization for inch (init.*) and
metric (initm.*) environments.
Library Control Files
Library Control Files are example NC machine controls intended to help you
configure VERICUT for simulating G-Code NC Programs that run on popular NC
machining centers.
Library Machine Files
Library Machine Files are example NC machines intended to help you configure
VERICUT for simulating G-Code NC Programs that run on popular NC machining
centers.

110
General Purpose Library Files
The general purpose library files are listed below in alphabetical order.

Library file name: Usage: Notes:


init.VcProject (in), Initialization files for Automatically loaded by
initm.VcProject (mm) VERICUT- clears settings VERICUT via selecting File
from the prior simulation, menu > New Project > Inch
then configures VERICUT (Millimeter).
with default settings for inch
(init.*) or metric (initm.*)
environments.
vericut.VcProject (in), Default files- files Demonstrates how
vericutm.VcProject (mm) configured to perform a short VERICUT identifies many
simulation of a three setup common NC tool path
project, using three different problems.
machines, when Play is
pressed.

111
Library Control Files
This section describes Control files available in the CGTech library ("library" directory in
your VERICUT installation). These files enable you to quickly configure VERICUT to
simulate how features of various NC controls affect the machining process. A Control file
is loaded into VERICUT via the Configuration menu > Control > Open function, or by
opening a Project file configured to use the control.

Available NC controls are listed below in alphabetical order, by control manufacturer and
model. See also the accompanying notes file for details (same base file name with .txt
extension-located in the "library" directory). You can do this in online Help by clicking
on file names that appear as hyperlinks (underlined text).

NOTE: Customized machines and controls can be found in the "samples"


directory in your VERICUT installation. See "Sample-Demo files" in this chapter
for more information.

Control Control model: Control file name:


manufacturer:
Acramatic (by
Cincinnati)
850MC acr850mc.ctl
950MC acr950mc.ctl
2100 acr2100.ctl
CNC PC acrcncpc.ctl
Allen-Bradley
7320 ab_7320.ctl
8200 ab_8200.ctl
8600 ab_8600.ctl
9260 ab_9260m.ctl
Bosch
CC300 bshcc300.ctl

112
Boston Digital
BDC 3200 (inch) bdc3200_in.ctl
BDC 3200 (mm) bdc3200_mm.ctl
Charmilles
200 Wire EDM chr200.ctl
Cincinnati - see
"Acramatic"
Fadal
CNC 88, Format 1 ("Fadal" fad88a.ctl
mode)
CNC 88, Format 2 ("Fanuc" fad88.ctl
mode)
Fanuc
Series 0 fan0m.ctl (mill)
fan0t.ctl (turn)
Series 3 fan3t.ctl (turn)
fan3tt.ctl
Series 5 fan5m.ctl (mill)
Series 6 fan6m.ctl (mill)
fan6t.ctl (turn)
Series 9 fan9t.ctl (turn)

Series 10 fan10m.ctl (mill)


fan10t.ctl (turn)
Series 11 fan11m.ctl (mill)
fan11t.ctl (turn)
Series 12 fan12m.ctl (mill)
fan12t.ctl (turn)
Series 15 fan15im.ctl (model
"I" mill)
fan15it.ctl (model
"I" turn)
fan15m.ctl (mill)
fan_15m_custom_o
ptimizable.ctl

113
fan15t.ctl, (turn)
fan15t_t.ctl (turn-
turret)
fan15t_t_ws.ctl
Series 16 fan16im.ctl (model
"I" mill)
fan16it.ctl (model
"I" turn)
fan16m.ctl (mill)
fan16t.ctl, (turn)
fan16w.ctl
(wireEDM)
Series 18 fan18im.ctl (model
"I" mill)
fan18it.ctl (model
"I" turn)
fan18m.ctl (mill)
fan18t.ctl (turn)
Series 21 fan21im.ctl (model
"I" mill)
fan21it.ctl (model
"I" turn)
fan21m.ctl (mill)
fan21t.ctl (turn)
Series 30 fan30im.ctl (model
"I" mill)
Series 31 fan31im.ctl (model
"I" mill)
Series 32 fan32im.ctl (model
"I" mill)
Series 150 fan150im.ctl
(model "I" mill)
fan150it.ctl (model
"I" turn)
fan150m.ctl (mill)
fan150t.ctl (turn)
Series 160 fan160im.ctl
(model "I" mill)
fan160it.ctl (model
"I" turn)

114
fan160m.ctl (mill)
fan160t.ctl (turn)
Series 180 fan180im.ctl
(model "I" mill)
fan180it.ctl (model
"I" turn)
fan180m.ctl (mill
fan180t.ctl (turn)
Series 210 fan210im.ctl
(model "I" mill)
fan210it.ctl (model
"I" turn)
fan210m.ctl (mill)
fan210t.ctl (turn)
Series 300 fan300im.ctl
(model "I" mill)
Series 310 fan310im.ctl
(model "I" mill)
Series 320 fan320im.ctl
(model "I" mill)
Series 3000 fan3000c.ctl
Fidia
M30 fidm30.ctl
GEMINI (by
Kearney & Trecker)
GEMINI-C kt_c.ctl
GEMINI-D gemini_d.ctl
GEMINI-E gemini_e.ctl
General Electric
(GE)
1050MC CNC ge_1050mc.ctl
2000MC CNC ge_2000mc.ctl

115
Generic (Fanuc-like) +
controls
decimal generic.ctl (in)
genericm.ctl (mm)
leading zeros genlead.ctl (in)
genleadm.ctl (mm)
trailing zeros gentrail.ctl (in)
gentrailm.ctl (mm)
Giddings & Lewis
(G&L) - see
"NumeriPath"
HAAS
CNC hascnc.ctl
MiniMill haas_minimill.ctl
Heidenhain
Mill Plus heimplus.ctl

TNC 407 hei407.ctl


(conversational)
hei407g.ctl (ISO)
TNC 415b hei415b.ctl
(conversational)hei
415bg.ctl (ISO)
TNC 415c hei415c.ctl
(conversational)hei
415cg.ctl (ISO)
TNC 425 hei425.ctl
(conversational)
hei425g.ctl (ISO)
TNC 426 hei426.ctl
(conversational)
hei426g.ctl (ISO)
TNC 430 hei430.ctl
(conversational)
hei430g.ctl (ISO)
TNC530 hei530.ctl

116
Kearney & Trecker -
see "GEMINI"
Lumonics
Laserdyne System 94 laserdyne_94.ctl
Maho - see "Phillips"
Makino
Professional Series 3 makpro3.ctl
Professional Series 5 makpro5.ctl
Mazak
Mazatrol Fusion 640 maz640m.ctl (mill)
maz640mpro.ctl
(mill)
maz640t.ctl (turn)
maz640t_t.ctl
maz640mpro_maza
k_e650h_2000u.ctl
maz640m_mazak_n
exus410a.ctl
maz640m_variaxis.
ctl
mazak_e650h_2000
u_640mpro.ctl
mazak_nexus410a_
maz640m.ctl
Mazatrol M-2 mazm2.ctl
Mazatrol M-3 mazm3.ctl
Mazatrol M-32 mazm32.ctl
Mazatrol T-2 mazt2.ctl
Mazatrol T-3 mazt3.ctl
Mazatrol T-32 mazt32.ctl
Mori Seiki
mori_seiki_mt2000
sz_fan16it.ctl

117
NUM
1020T num1020t.ctl
1040T num1040t.ctl
1060M num1060m.ctl
1060T num1060t.ctl
NumeriPath (by
G&L)
800M nph800m.ctl
8000L nph8000l.ctl
8000M nph8000m.ctl
Okuma - see "OSP"
Olivetti
MC8600 oli8600.ctl
OSAI
osai_10.ctl
OSP (by Okuma)
OSP700L osp700l.ctl
OSP5000L osp5000l.ctl
OSP5000M osp5000m.ctl
OSP7000L osp7000l.ctl
osp7000l_t.ctl
(turret)
OSP7000M osp7000m.ctl
PaR Systems
Cimroc 5000 cimroc_5000.ctl
Phillips
CNC 432 phi432.ctl
CNC 532 phi532.ctl

118
Sinumerik (by
Siemens)
3T, 3TT sin3t.ctl, sin3tt.ctl
810 sin810d.ctl (810D)
840 sin840c.ctl (840C)
sin840d.ctl (840D)
880M sin880m.ctl (880M)
FM-NC sinfmnc.ctl
Sundstrand
MicroSWINC LM swilm.ctl
MicroSWINC M200 swim200.ctl
Thermwood
91000 Super Control thermwood_91000.
ctl
Tosnuc (by Toshiba)
888 tos888.ctl
Yasnac
i80m yasi80m.ctl
MX-3 yasmx3.ctl

119
Library Machine Files
This section describes Machine files available in the CGTech library ("library" directory
in your VERICUT installation) and CGTech sample files ("samples" directory). These
files enable you to quickly configure VERICUT to simulate motions on various NC
machines. Note that while library machines are generally considered ready to use, many
of the sample machines have job-related data that may interfere when configuring for use
with new NC tool paths. A Machine file is loaded into VERICUT via the Configuration
menu > Machine > Open function, or by opening a User file configured to use the
machine.
Available NC machines are listed below in alphabetical order, by manufacturer and
model. All machines reside in the library unless otherwise noted to be in "samples". Click
on the thumbnail to see a larger image. See also the accompanying notes file for details
(same base file name with .txt extension-located in the "library" directory). You can do
this in online Help by clicking on file names that appear as hyperlinks (underlined text).

Machine Machine Thumbnail (click to see Machine file name:


manufacturer: model: larger image):
Aerostar
H2200
aerh2200.mch
5ax horiz. mill

Bohle
BW120S
bohbw120.mch
5ax horiz. mill

Bostomatic
405
bos405.mch
5ax vert. mill

120
5ax vert. mill samples - bos5vm01.mch

Charmilles
Robofil 200 chr200.mch
4ax wire
EDM

Cincinnati
3-spindle 5ax samples - cinci_3spindle_5ax.mch
gantry mill

5ax dual- samples- cin5vm01.mch


tilting head
vert. mill

T30
cint30m.mch (mm),
5ax horiz. mill
cint30_2.mch,
cint30_3.mch (tool change arm)

Deckel Maho -
see "Maho"
Dixi
100
dix100m4.mch
4ax horiz. mill

100
dix100m5.mch
5ax horiz. mill

121
150
dix150m4.mch
4ax horiz. mill

150
dix150m5.mch
5ax horiz. mill

350 TCA50S dix350m.mch


5ax horiz. mill

DPH-80
dixi_dph80.mch
4ax horiz. mill

Droop and
Rein
DR969 vert. 3 dr_dr969.mch
spindle mill

Fadal
VMC 15
fadvmc15.mch
3ax vert. mill

VMC 4020 fad4020.mch


4ax vert. mill

122
VMC 6030 fad6030.mch
3ax vert. mill

Fidia
218
fid218.mch (in),
5ax vert. mill
fid218m.mch (mm)

Forest
Flexiax 510 forfx510.mch
5ax horiz. mill

Generic
machines
generic_2ax_turn.mch
2ax horiz.
lathe

samples-
2ax horiz.
2hl02.mch (shown),
turret lathe
2hl03.mch

g3vm.mch
3ax vert. mill
generic_vmill_3ax.mch
generic_vmill_3ax_3d.mch

g4vmta.mch
4ax vert. mill- Not 3-D
table A

123
samples -
3ax vert. mill
bars_robot.mch
with robot
gripper arm

samples -
3ax horiz.
3ht.mch
mill/turn-table
C

samples -
4ax horiz.
4hl02.mch (steadyrest),
dual turret
4hl03.mch (no steadyrest),
lathe
4hl04.mch (steadyrest)

4ax horiz. samples - mcdturn6.mch (robot arm


dual turret part-grabber)
lathe with
pick-off
spindle
library -
4ax horiz.
generic_vmill_4ax_table_b.mch
mill-table B
samples -
4hmtb.mch (shown)
samples -
4ax horiz.
4ht.mch (in),
mill/turn-table
4htm.mch (mm)
C

4ax vert. mill- Not 3-D generic_vmill_4ax_table_a.mch


table A
5ax horiz. Not 3-D generic_5ax_hmill_heada_tableb.mch
mill-head A,
table B
5ax horiz. Not 3-D generic_5ax_hmill_tablea_tableb.mch
mill-table A
on table B
5ax horiz. Not 3-D generic_5ax_hmill_tableb_tablea.mch
mill-table B

124
on table A
5ax vert. mill- Not 3-D generic_5ax_vmill_heada_headb.mch
head A on
head B
5ax vert. mill- Not 3-D generic_5ax_vmill_tablea_headb.mch
table A, head
B
9ax cutter samples -
grinder 9v_grind.mch

Giddings &
Lewis (G&L)
Not 3-D gl_2ax_turn.mch
5ax vert. samples- gl_5vt01.mch
mill/turn-table
C

G60 4ax gl_g60.mch


horiz. boring
mill

G60 4ax gl_g60_sav.mch


horiz. boring
mill

HAAS
MiniMill
haas_minimill.mch
3ax vert. mill

125
VB-1
hasvb1.mch
5ax vert. mill

Hermle
C30
hermle_c30.mch
5ax mill

C800U
hermle_c800u.mch
5ax mill

Ingersoll
Mastercenter ingmast1.mch
4ax Multi-
head gantry
mill-detailed

Kearney &
Trecker
(K&T)
HB4
kt_hb4.mch
4ax horiz. mill

Model 180 kt_180.mch


4ax horiz. mill

126
Kuraki
KBM11
kurkbm11.mch
5ax horiz.
boring mill

Maho
DMU 80 P mahdmu80.mch
5ax horiz. mill

MH700
mah700m.mch (mm),
3ax vert. mill
mahmh700.mch (in)

Not 3-D mahvrt.mch


DMU 50V dmg_dmu50v.mch
5ax vert. mill

DMU 60 t 5ax dmg_dmu60t.mch


vert. mill

DMU 125 P dmg_dmu125p.mch


5ax vert. mill

DMU 200 P dmg_dmu200p.mch


5ax vert. mill

127
Makino
MC1010
mak1010.mch
5ax horiz. mill

A55
makino_a55.mch
4ax horiz. mill

A66
makino_a66.mch
5ax horiz. mill

A77
makino_a77.mch
4ax horiz. mill

Marwin
Advanced
mrwamc.mch
Manufacturing
Cell
5ax horiz. mill

Matsuura
FX-5
Not 3-D matfx5.mch
4ax vert. mill
MAM 600HF Not 3-D mat600hf.mch
vert. mill
Mazak
H500
mazh500.mch
4ax horiz. mill

128
Super 400H maz400h.mch
4ax horiz. mill

E650H
mazak_e650h_2000u_3_jaw.mch
horiz.
mill/turn

HTC 4000 5ax mazak_htc_4000.mch


horiz. mill

Nexus 410a mazak_nexus410a.mch


vert. mill

QTN250MY Mazak_qtn250my.mch

Variaxis 500 mazak_variaxis500.mch


5ax vert. mill

mazak_variaxis730.mch

Mori Seiki
Partner M-
ms_m400.mch
400C1
5ax vert. mill

129
MT 2000 SZ mori_seiki_mt2000sz_alpha1.mch
multi-axis
turning center

Motch
135 VNC vert. motch_135vnc.mch
turning center

Okuma
LB400 2ax Okuma_LB400.mch
horiz. lathe

LB25 2ax samples -


horiz. lathe okulb25.mch

SNK
FSP-100V 5ax snkfsp01.mch
horiz. mill

SH-200
snksh200.mch
5ax gantry
mill

STC
STC1000
stc1000.mch
5ax horiz. mill

130
Sundstrand
Omnimil
sunom3.mch
OM3
5ax vert. mill

Omnimil
sunom80.mch
OM80
5ax horiz. mill

Toyoda
FH80
tydfh80.mch
5ax horiz. mill

Tsugami
MA3
Not full 3-D tsuma3.mch
4ax horiz.mill
Warner &
Swasey
Titan
ws_titan.mch
4ax horiz.
dual turret
lathe

131
Environment variables
You can set environment variables to help customize the VERICUT user interface, alter
VERICUT performance, and perform other various actions. This section describes
environment variable formats and the available environment variables that can affect the
VERICUT simulation.
Environment variables are typically set via CGTech command files located in the
CGTech "commands" directory, under the directory representing your computer type. For
example, the command files or VERICUT 6.0 installed on the "C:" drive of a Windows
NT computer are located in the C:\CGTech60\winnt\commands directory. Environment
variables can also be set in any other system file used to execute VERICUT.
Formats
Formats used to set environment variables differ, based on the computer's operating
system. Consult the operating system documentation, or refer to the CGTech-installed
command files on your computer for specific examples.
Operating system: Env. var. format: Examples of use:
Windows set set CGTECH_DEFAULT_UNITS=inch
ENV_VAR_NAME
=value set
CGTECH_LIBRARY=C:\CGTech50\library
UNIX ENV_VAR_NAME CGTECH_DEFAULT_UNITS=inch
=value
export CGTECH_DEFAULT_UNITS
export
ENV_VAR_NAME CGTECH_LIBRARY=C:\CGTech50\library
(2 records required export CGTECH_LIBRARY
to set each variable)

"CGTECH" environment variables


Available environment variables that can affect the VERICUT simulation are listed
below in alphabetical order. For simplicity, all examples of use below are in Windows
format. See above for UNIX format examples.

CGTECH_CEILING_IMAGE — Specifies the JPEG file to use as texture for the


ceiling in OpenGL machine views.
Example of use:
set CGTECH_CEILING_IMAGE=C:\path\ceiling.jpg

132
2. CGTECH_DEFAULT_UNITS — Sets the default units for VERICUT. Specify
either INCH or MILLIMETER
Example of use:
set CGTECH_DEFAULT_UNITS =MILLIMETER

CGTECH_DISPLAY — Sets the animation display method for tool motion in the
Workpiece view. The display is updated for animation when you start cutting or
the refine the display ( e.g. press Refine Display ). Changing the animation
display method can affect simulation speed and display quality, but does not
affect model accuracy. Results are different, based on the types of parts you cut
and specified Cutting Tolerance. Options:

REFINE1 — This display method creates the best quality animation image for
all-around use, but may take slightly longer to simulate with than REFINE2
(see below).
REFINE2 — Alternate display method-fastest when a large amount of model
detail is visible. This method is more sensitive to Cutting Tolerance than
REFINE1, and is typically very good when the cut tolerance is small enough.
ULTRA — Another alternate display method-this method can be faster than the
others, but has lower display quality when compared to the default method.

Example of use:
set CGTECH_DISPLAY=REFINE2

3. CGTECH_FLOOR_IMAGE — Specifies the JPEG file to use as texture for the


floor in OpenGL machine views.
Example of use:
set CGTECH_FLOOR_IMAGE=C:\path\floor.jpg

CGTECH_FONT_SIZE — Sets the font size for text appearing in the VERICUT
user interface. Size can be given an absolute point size, or incremental value from
the default value of "12".
Examples of use:
set CGTECH_FONT_SIZE=14 (sets 14 pt. font)
set CGTECH_FONT_SIZE=+2 (also sets 14 pt. font: default 12 +2= 14)

133
CGTECH_INSPECTION_TOLERANCES — Specify a fully qualified
/path/filename of a "custom" inspection tolerance file" containing default
tolerances to be used for Inspection Sequence.
Example of use:
set
CGTECH_INSPECTION_TOLERANCES=C:\mydir\inspect_tolfi
le.txt

6. CGTECH_LIBRARY — Specifies the directory location of the CGTech Library


of machines and controls accessed via choosing the "CGTECH_LIBRARY"
shortcut option on file selection windows. Setting this environment variable can
be useful for sites that use their own library VERICUT machines and controls
instead of that supplied on CD with VERICUT. The full directory path can be
included.
Example of use:
set CGTECH_LIBRARY =C:\mylibrarydir
See also: "Where VERICUT looks for files" in the Introduction section

CGTECH_MATRIX_FORMAT — Enables you to view the Matrix Tables in the


Coordinate System Window, Matrix tab and the Modeling Window, Position tab,
Matrix tab with the I, J, K along the vertical axis and the X, Y, Z along the
horizontal axis rather than the "default" horizontal orientation.
Horizontal Orientation (default):

Example of use:
set CGTECH_MATRIX_FORMAT=VERTICAL

Vertical Orientation:

134
CGTECH_OLD_FSB — Enables you to use the more common Windows File
Selection Box (FSB) rather than the "standard" VERICUT FSB.
Example of use:
set CGTECH_OLD_FSB=YES

CGTECH_STATUS — Creates a Status file, an ASCII text file that contains


whatever data is sent to the Status window during the simulation. The full
directory path can be included with the file name.
Example of use:
set CGTECH_STATUS=C:\mydir\statusfile.txt

CGTECH_TPEDITOR — Causes Edit Toolpath to issue a system command using


the string content of the variable, with the current tool path file as an argument.
Thus you can choose to run an alternate tool path editor, such as any one of the
clever NC code editors available today.
When you press Edit > NC Program > 'c:\path\filename.mcd', or Project
menu > NC Program >(list item) > right mouse click > Edit, or the Edit NC

Program icon , then VERICUT issues the system command:


c:\program files\cooltoolpatheditor\editor.exe
c:\path\filename.mcd
This will only work with tool path editors that can take the tool path file name as an
argument on the command line that runs the editor. Depending on the editor's
command syntax, it may be necessary to point CGTECH_TPEDITOR at a batch or
script file that intercepts the tool path file name and re-formats the command as
necessary.
Example of use:
set CGTECH_TPEDITOR=c:\program
files\cooltoolpatheditor\editor.exe

CGTECH_USERNAME — Specifies the user name to include in the name of the


Preferences file that is automatically saved when you exit VERICUT. This
environment variable is recommended to prevent users that share a machine (or an
account) from overwriting the Preferences file.
Example of use:
set CGTECH_USERNAME=bob (Preferences file saved =>
"cgtech_bob.prefs")

135
CGTECH_VCPROJECT — Specifies the default Project file for VERICUT. The
full directory path can be included.
Example of use:
set
CGTECH_VCPROJECT=C:\mydir\myprojectfile.VcProject

CGTECH_VCUSR — Specifies the default User file for VERICUT. The full
directory path can be included.
Example of use:
set CGTECH_VCUSR=C:\mydir\myuserfile.usr

CGTECH_X_WALL_IMAGE — Specifies the JPEG file to use as texture for the


two walls having normals along plus or minus X in OpenGL machine views.
Example of use:
set CGTECH_X_WALL_IMAGE=C:\path\x_wall.jpg
CGTECH_Y_WALL_IMAGE — Specifies the JPEG file to use as texture for the
two walls having normals along plus or minus Y in OpenGL machine views.
Example of use:
set CGTECH_Y_WALL_IMAGE=C:\path\y_wall.jpg

Adding custom environment variables for shortcuts


You can add your own environment variables to the beginning section of the VERICUT
command file and have them appear in the shortcut list of file selection windows.
VERICUT lists all custom environment variables that begin with "CGTECH_" in the
shortcut list, and have at least one file in the directory that is recognized as a CGTech file
type, for example a file with any of the following extensions: *.ctl, *.ip, *.job, *.mcd,
*.mch, *.olb, *.stl, *.tls, *.tp, or *.usr
Note that the contents of the file are not verified unless loaded by VERICUT. Just the
existence of a file with an extension that qualifies as one of the valid CGTech file types
(see above) is enough to make the shortcut appear in the list.
Example 1—The following environment variable creates a shortcut to a directory
containing VERICUT 6.0 sample files.
set CGTECH_60SAMPLES=C:\CGTech60\samples\vericut
Example 2—The following environment variable creates a shortcut to a directory
containing a user's custom VERICUT files. The directory contains a file named
"dummy.usr".
set CGTECH_MYVERICUTFILES=E:\myvericutfiles

136
Interacting with VERICUT
VERICUT main window
The VERICUT main window is composed of distinct areas, each with different user
interaction. The window header displays the last Project file loaded and the current
session units (inch or millimeter). This window can be resized like most other window,
via dragging the window header, sides or corners.

y To learn more about interacting with VERICUT through the main window
components, click on one the topics below.S
Menu Bar
Tool Bar (dockable)
Graphics Area
Progress bar menu (dockable) consists of all the following features:
Message Area

137
Animation Slider
Busy/OptiPath Lights
Progress Bar
Simulation Controls
Hint: Press "F1" in any VERICUT window to receive help on that window.

138
Menu Bar
The menu located across the top of the VERICUT window provides easy access to
VERICUT functions. Each menu contains groups of related functions. Left-click on any
menu name to expose the list of functions in that menu. If an arrow appears to the right of
a function in a menu, move the mouse over the arrow to expose a sub-menu of additional
functions. Click on the function in the menu you want to use.

139
VERICUT menu descriptions
The menus which provide access to all VERICUT functions are listed below, followed by
a brief description of what the menu functions do. In VERICUT Help, click VERICUT
Menus & Functions, then open the desired menu and select the function for more
information about each function.

y File menu — Functions in this menu open and save the most common files used
in VERICUT, access converter products, control properties, export cut model
data, and generate VERICUT reports.
y Edit menu — Functions in this menu enable you to edit text files, NC programs
and control display colors.
y View menu — Functions in this menu set up the number of views, orientation
(angle and distance) for each view, and store or select commonly used views, and
set up other VERICUT display characteristics.
y Info menu — Functions in this menu access session information, such as the files
currently being used, machining status, machine offsets, log files.
y Project menu — Functions in this menu provide the functions required for "job"
setup including the the display of the Project Tree. Functions include selection of
machines, controls, NC programs, tools, and processing options. Its features also
enable the selection and setup of output files created by VERICUT during
processing and customized reports.
y Configuration menu — Functions in this menu are used to build or configure
NC mahines and controls.
y Analysis menu — Functions in this menu are used to analyze and inspect the
VERICUT model. It provides access to the following features: X-Caliper, AUTO-
DIFF, Comparator, NC Program Review, Inspection and Die Sinking Simulation.
y OptiPath menu — Functions in this menu access OptiPath-the feed rate and
spindle speed optimization software that creates "optimized" tool paths that cut
parts in the least amount of time.

Hint: To find functions in alphabetical order, use the Index.

140
Tool Bar
VERICUT's Toolbar provides quick and easy access to the most commonly-used
functions/features.

To see what is associated with a Toolbar icon, simply position the cursor over the icon
and a tip appears, as shown with the Close Toolbar icon in the illustration above. You can
close/open the Toolbar at any time. Using View menu > Toolbar you can also customize
the Toolbar to suit your needs. The Toolbar window is also one of the dockable windows
enabling you to be able to re-position it if you choose.

To close the Toolbar:

From the Toolbar select Close Toolbar .

To open the Toolbar:


1. Select View menu > Toolbar.
2. Select Display Toolbar.

To add/remove groups in the Toolbar:


1. Select View menu > Toolbar.
2. Clear check from a group to remove, put a check by a group to add.
Tip: You can affect all Toolbar groups at once using the Set All / Clear All
buttons.

141
Graphics area
The graphics area is where solid models of the workpiece, fixtures, etc. are displayed, and
where the simulation takes place. By default, two views are seen: a Workpiece view and
a Machine Cut/Stock view. Using View menu > Layout you can add more views
displaying the workpiece or NC machine (if a machine is defined). All views are
contained within the VERICUT main window.

Right-click in a view to display Shortcuts menu, as shown in the illustration below,


enabling you to modify its attributes, such as: view type, standard modeling views,
background, etc. Use dynamic and static view options on the Tool Bar to rotate, zoom, or
fit the model.

142
Many other VERICUT functions enable user interactions in this area, including: picking
models or surfaces to be measured, determining tool path records responsible for specific
cuts, and more.

143
Message Area
The message area, also known as the "message logger", is located below the graphics
area, and by default displays the most recent message VERICUT has provided.
VERICUT provides error, warning, and informational messages to assist you during a
simulation session.
To review previous messages, click on the message line-the most recent message is listed
last. Click again to close the message logger.

NOTE:
1. All messages can be seen along with other valuable information in the Log
file.
2. See problem descriptions and solutions for VERICUT error/warning
messages in ERRORS and Problem Solving at
http://www.cgtech.com/support/errors_problems/errors.htm.

144
Animation Speed Slider
The Animation Speed Slider, located at the bottom of the VERICUT main window
between the Message Area and the Busy/OptiPath Lights, controls the speed at which
VERICUT animates material removal in workpiece views. Moving the slide bar left
slows animation by adding intermediate tool display positions between motion start and
end points. Moving the slide bar right reduces the number of intermediate tool display
positions to speed animation display.

The animation slider will be displayed in one of two ways:

Animation Speed Slider in full right Animation Speed Slider moved off of full
position right position

Use Min. Motion Dist. and Max. Motion Dist. , on the Project > Processing Options >
Motion window, to define the range for the Animation Speed Slider.

Tip: To group cuts together for even faster animation display, use the Skip Cut
feature located on the Motion window.

145
BUSY-OptiPath lights
The "BUSY" and "OptiPath" lights located at the bottom-right of the VERICUT window
provide constant visibility over when VERICUT is busy performing a task, or optimizing
a tool path file. A bright red color indicates an "on" condition, as seen in the example
below with the "BUSY" light.

146
Progress bar
The progress bar located at the bottom-right corner of the VERICUT window provides
visibility over progress of a CPU-intensive task, such as: comparing models using
AUTO-DIFF, exporting model data, and checking the consistency of the stock model(s).
The progress bar moves towards the right as the task nears completion. To interrupt the

task, press the Stop icon, .

Sample progress bar nearing completion of a task:

147
Simulation (VCR) controls
The simulation controls, also known as VCR buttons, located at the bottom-right corner
of the VERICUT window control interactive tool path simulation. Once VERICUT is
configured, you will use these control to start and stop the simulation, as well as begin
with a new, uncut workpiece. To see what is associated with a Simulation control icon,
simply position the cursor over the icon and a tip appears. Simulation control:

Icon: Name: Function:


Play to End Start or re-start tool path
processing
Single Step Process one tool path record
(“single block”)
Stop Stop processing (after the
(or press Escape current record is processed)
key <Esc>)
Rewind Toolpath Rewind the tool path file to
the beginning (leave the
model as is)
Reset Model Display a new VERICUT
model and rewind the tool
path file

148
Look & Feel
The Look & Feel features change the appearance of VERICUT's user interface. All
windows are affected. The look and feel of VERICUT can be changed any time. (Not all
options are available on all systems.)
Options (click to see examples):

y Metal
y Motif
y Windows
y Windows Classic
y Text Larger — Use to make the text in VERICUT menus, message logger,
windows, etc. larger. Each time you click on "Text Larger", the text gets
incrementally larger to a maximum font size of "14 point".
y Text Smaller — Use to make the text in VERICUT menus, message logger,
windows, etc. smaller. Each time you click on "Text Smaller", the text gets
incrementally smaller to a minimum font size of "6 point ".

To change the user interface look and feel:


1. From the View menu, select Look and Feel.
2. Choose the option that provides the desired appearance.

149
Right Mouse Button Shortcut Menus

VERICUT Graphics Area:


Right-click in the VERICUT Graphics Area to display the following menu:

View Type Workpiece, Machine, Machine/Cut Stock,


Profile
View To Back
View Always In Front
Reverse
Fit
Set Spin Center
Select View List of standard and available custom views
Draw Mode (Machine View Only) Shade, Lines, Hidden, Mixed
Background Style Flat, Shaded, Walls (Machine View Only)
Attach Component List of available components
Accelerated (Open GL)
Set Active Coord. Sys. List of available coordinate systems
Display Axes List of available Axes, Active Coordinate
System, Set Axes, Clear Axes, View Axes
Model Definition
Project Tree

Tool Manager window:


Right-click in the Tool Manager Tool Table to display the following menu:

Modify
Rename
Delete
Cut
Copy
Paste
Add Tool New Mill
Add Tool Component Select Existing ... Turn
Add OptiPath New Probe
Add Driven Point Select existing ...
Add Cutter Compensation
Search Tool
Search OptiPath
Spin Around Tool Axis
Machine Spindle

150
2. Right-click in the Tool Manager Tool Display area to display the following
menu:

Fit
Reverse
Select View XY
Driven Point YX
Gage Point YZ
Axes ZY
ZX
XZ
V-
ISO
H-
ISO

Project Tree:
NOTE: Any item shown in bold a Project Tree pop-up menu can also be reached
directly by double clicking on the the item (branch, component, model, etc.) in the
Project Tree, that you right -clicked on to display the pop-up menu. For example, double-
clicking on the Project branch in the Project Tree displays the Open Project window, just
like clicking on Open in the pop-up menu shown in 1 below.

1. Right-click on the Project branch in the Project Tree window to display the
following menu:

Inch, Millimeter
New

Open

Save

Save As
Unit Inch, Millimeter
Import Setup

Motion
APT Cycles
Expand All Children
Recent List of recently used project files

Close

151
2. Right-click on a Setup branch in the Project Tree window to display the following
menu:

Active

Cut
Copy
Paste
Delete
Rename

Properties
Report Report Template Edit

User-Defined Tag Values


Motion
Settings, Variables, Process
G-Code Options

APT Settings
Define, Active
Coordinate Systems

Section
Inspection
Die Sinking
Expand All Children

3. Right-click on a CNC Machine branch in the Project Tree window to display the
following menu:

CNC Machine...
MDI ...
G-Code Settings ...
Variables...
Process Options...

Machine Settings ...


Expand All Children

152
4. Right-click on a Control branch in the Project Tree window to display the
following menu:

Open
Cut
Copy
Paste
Delete
MDI ...
G-Code Settings ...
Variables...
Process Options...

Right-click on a Machine branch in the Project Tree window to display the following
menu:

Open
Cut
Copy
Paste
Delete
Machine Settings ...
Expand All Children

6. Right-click on an Attach Component in the Project Tree window to display the


following menu:

Component Attributes
Paste
Append Fixture
Expand All Children Stock
Design
Design Point
More List of Components

153
7. Right-click on a Component Branch (Fixture, Stock, Design) in the Project Tree
window to display the following menu:

Component Attributes
Cut
Fixture
Copy
Stock
Paste
Design
Delete
Rename Design Point
Append List of Components
More
Visibility Blank, Workpiece View, Machine View, Both Views
Expand All Children

NOTE: When Visibility is set to "Blank" for a component, the icon


representing the component in the Project Tree will be displayed in gray
instead if a color.

Right-click on a Model in the Project Tree window to display the following menu:

Modify...
Cut
Copy
Paste
Delete
Visible

NOTE: The Visible icon will indicate the visibility status of the model.
indicates "visible", indicates "not visible". Click on Visible to toggle
between the two modes. In the Project Tree, any model in the "not visible"
state will be displayed in gray instead if a color.

9. Right-click on Tooling in the Project Tree window to display the following menu:

Open
Tool Manager...
Cut
Copy
Paste

Delete

154
9. Right-click on an NC Program branch in the Project Tree window to display the
following menu:

Add/Modify NC Programs...
Paste
Delete All
Expand All Children

10. Right-click on an NC Program file in the Project Tree window to display the
following menu:

Active

Add/Modify NC Programs...

Edit...
Cut
Copy
Paste
Delete

11. Right-click on an NC Subroutines branch in the Project Tree window to display


the following menu:

Add/Modify NC Subroutines...
Paste

Delete All
Expand All Children

12. Right-click on an NC Subroutine file in the Project Tree window to display the
following menu:

Edit...
Cut
Copy
Paste
Delete

155
Component Tree:
NOTE: Any item shown in bold a Component Tree pop-up menu can also be reached
directly by double clicking on the the item (component, model) in the Component Tree,
that you right-clicked on to display the pop-up menu. For example, double-clicking on
the Component branch in the Component Tree displays the Modeling window:
Component Attributes tab, just like clicking on Component Attributes in the pop-up
menu shown in 1 below.

1. Right-click on a component in the Component Tree window to display the


following menu:

Component Attributes
Cut
Copy
Paste
Delete
Rename
Insert List of Components
Append List of Components
Visibility Blank, Workpiece View, Machine View, Both
Views

NOTE: When Visibility is set to "Blank" for a component, the icon


representing the component in the Component Tree will be displayed in gray
instead if a color.

2. Right-click on a model in the Component Tree window to display the


following menu:

Modify...
Cut
Copy
Paste
Delete
Visible

NOTE: The Visible icon will indicate the visibility status of the model.
indicates "visible", indicates "not visible". Click on Visible to toggle
between the two modes. In the Project Tree, any model in the "not visible"
state will be displayed in gray instead if a color.

156
NC Program Review window:
Right-click in the NC Program Review window to display the following menu:

Set Start
Set Current
Set End
Display to Box

Cut Line

Non-Cut Line

Current Line
Goto Start
Goto Current
Goto End

Inspection Sequence window:


Right-click in the Inspection Sequence window to display the following menu:

Insert Wall Thickness Row

Insert Floor Thickness Row

Insert Hole Diameter Row

Insert Datum Plane Row

Insert Distance Row

Insert Angle Row

Insert Position Rows

Insert Hole Depth Row

Insert Radius Row

Insert Surface Finish Row

Insert Note Row

Use probe for selected feature

Use probe for all features

Program probe cycles

Modify Marker Location

157
Restore Default Tolerance
Edit Geometric Tolerance

Delete Row

Refresh

NC Program window:
Right-click in the NC Program window to display the following menu:

Add
Replace
Copy
Paste
Origin None, List of Available Coordinate Systems
Delete
Edit

Word/Address window:
Right-click in the Word/Address window to display the following menu:

Add/Modify
Cut
Copy
Paste
Find
Contract All Children
Expand All Children

G-Code Settings window, Subroutines tab:


Right-click in the G-Code Settings window, Subroutines tab to display the
following menu:

Add
Replace
Delete
Edit

Edit — Displays the of the highlighted subroutine file in a text editing


window. Standard text editing features are provided, such as: copy/cut, paste,
search, etc.

158
Personalizing the VERICUT Main Window
VERICUT enables you to personalize your workspace to match the process by which you
use VERICUT's many features, as well as incorporating your own personal preferences.
Through the use of "dockable" dialog windows, you can set up your VERICUT
workspace as simply or as complex as you choose. Each of these windows can be docked
inside the VERICUT main window, or un-docked to be displayed as a stand alone
window like previous versions of VERICUT. By docking or undocking windows, you
can taylor the VERICUT workspace to meet your specific needs.The "Simple VERICUT
Workspace" illustrates the most basic workspace.

Simple VERICUT Workspace:

The "Complex VERICUT Workspace" is shown with nearly all of the available
"dockable" windows docked to the VERICUT main window. While it appears cluttered,
and is not likely an efficient workspace, the intent is to show the flexibility that you have
for setting up your workspace. Your optimum workspace layout will likely fall
somewhere between the two extremes. The main point is that you decide the the most
effective workspace layout based on how you use VERICUT and how you prefer to
interact with its many features.

159
Complex VERICUT Workspace:

160
Dockable Windows
The following summarizes the dialogue windows that can be docked inside VERICUT's
main desktop:

Dockable Location Docking Positions


Window

Toolbar VERICUT main Left, Right , Top, Bottom,


window Standalone
Progress bar VERICUT main Top, Bottom, Standalone
window
NC Program Info menu > NC Left, Right , Top, Bottom,
Program Standalone
Status Info menu > Status Left, Right, Standalone
Project Tree Project menu > Left, Right, Standalone
Project Tree
X-Caliper Analysis menu > X- Left, Right, Standalone
Caliper

161
Docking and Un-docking windows
The procedure for docking/undocking any of the dockable windows is the same. All
dockable windows have a dotted line on the left side of the window as indicated by the
arrow in the Toolbar in the picture below. This dotted line is used for both docking and
undocking these windows. To undock a currently docked window, left click on the dotted
line on the left side of the window, then while keeping the button depressed, drag the
rectangle representing the window (see Figure 1) to the desired location outside the
VERICUT main window. When you release the mouse button, the window moves and is
displayed as a stand alone window.

Figure 1

Figure 2 shows the result of dragging the Toolbar window to a position below the
VERICUT main window.

162
Figure 2

The procedure for docking a stand alone window or moving a currently docked window
to a different docking location is the same. Starting with the stand alone Toolbar window
shown in Figure 2, left click on the dotted line in the Toolbar window, then drag the
rectangle representing the window to one of the docking positions available for the
particular window. In this case we are docking the Toolbar window on the right side of
the VERICUT main window. When the rectangle representing the window is dragged to
a dockable position, the shape of the rectangle will change and the border will be
displayed red as shown in Figure 3.

163
Figure 3

Releasing the left mouse button moves the window to the docked position as shown in
Figure 4.

Figure 4

164
VERICUT Menus and Features

File menu
New Project
Location: File menu > New Project > Inch / Millimeter

Toolbar short cut for creating a New Project file: (Inch) or (Millimeter). Right-
click on the icon to switch between the two modes.

Sets VERICUT to a "new" condition, as if no files have been loaded. Afterwards,


configure VERICUT by adding models, tool paths, descriptions of cutting tools, etc.
To establish the new condition, VERICUT purges all data from memory, then opens the
init.VcProject (inch project) or initm.VcProject (millimeter project) Project file from the
CGTech library. The Project Tree and Component Tree shown below are automatically
defined, ready for you to configure VERICUT by adding models, tool paths, descriptions
of cutting tools, etc.

Project Tree after a new Component Tree after a new


condition: condition:

Tips:
y You can customize how VERICUT establishes the new condition by making
changes to the init.VcProject or initm.VcProject files. Store the changed files in
your working directory, or the CGTech library directory.
y If needed, change the units for the new session as follows:

165
Open (Project)
Location: File menu > Open

Toolbar short cut for opening Project files:

Opens an existing Project file with the current VERICUT session settings.

166
Save Project
Location: File menu > Save Project

Toolbar short cut for saving Project files:


Saves (updates) an existing Project file with the current VERICUT session settings.

167
Save As

VERICUT Users:
VERICUT Location: File menu > Save As

Toolbar short cut for saving Project files:

Mold and Die Users:


Mold and Die Location: Setup page > Save the Setup or Preview and Optimize
page > Save the Setup

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Setup page > Save the Setup or View Simulation page >
Save the Setup

Notebook Feature:

Opens a file selection window enabling you to save Project files, In-Process files, Control
files, Machine files, Tool files or any other VERICUT file. Most features on this window
are standard file selection window features that enable you to navigate through
directories, filter files, and type or select file names. Use the "Filter" to specify the type
of file to be saved. Depending on the filter setting, VERICUT will save the current file
of that type. If "Filter" is set to anything other than .usr, .ip, .ctl, or.mch, the user file will
always be saved.

168
Save All
Location: File menu > Save All

Saves (updates) Project files, Machine Files and Control Files associated with the
current VERICUT session. It provides the combined functionality of File menu > Save
Project, Configuration menu > Control > Save and Configuration menu > Machine >
Save. In the event that a file cannot be saved, a window will open enabling you to Save
As.

169
In Process

Open (In Process file)

VERICUT Users:
VERICUT Location: File menu > In Process > Open

Toolbar short cut for opening IP files:

Mold and Die Users:


Mold and Die Location: Setup page > Open In-Process Session

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Setup page > Open In-Process Session

Notebook Feature:

Opens a window to open (load) an In Process file, or "IP file". IP files contain all the data
necessary to re-establish a VERICUT session, including the current VERICUT model
(with cuts), user interface settings, and a copy of the Log file.
Features on this window are standard file selection window features that enable you to
navigate through directories, filter files, and type or select file names.

170
Save (In Process file)
Location: File menu > In Process > Save

Toolbar short cut for saving IP files:


Saves (updates) an existing In Process file, or "IP file", with the current VERICUT
model, including all machine cut.

171
Save As (In Process file)
VERICUT Users:
VERICUT Location: File menu > In Process > Save As

Toolbar short cut for saving IP files:

Mold and Die Users:


Mold and Die Location: Preview and Optimize page > Save In-Process Session

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: View Simulation page > Save the In-Process Session
Notebook Feature:

Opens a window to save an In Process file, or "IP file". IP files contain all the data
necessary to re-establish a VERICUT session, including the current VERICUT model
(with cuts), user interface settings, and a copy of the Log file.
Most features on this window are standard file selection window features that enable you
to navigate through directories, filter files, and type or select file names.

172
Save Cut Stock
VERICUT Location: Model menu > Save Cut Stock

Save Cut Stock enables you to save the selected Cut Stock model as a VERICUT Solid
file (.vct). This option is only active after a Cut Stock model has been created by
VERICUT. The default file extension is .vct.

This feature provides access to the same functionality as File > Save Cut Stock in the in
the Component Tree window.

173
Save Cut Stock - STL
Still "under construction".

174
CAD Model

Export Cut Stock window


Location: File menu > Save Cut Stock > CAD Model

Opens a window to export the VERICUT model. Export formats include:


Stereolithography (STL) or VERICUT Polygon model files, or IGES data. (See how) A
cut VERICUT model is exported with machine cuts intact. During the export operation a
Model Export Boundaries window may open enabling you to manually close ambiguous
open boundaries that VERICUT was unable to resolve, prior to completing the export.
When the model has been exported, a message informs you how many IGES surfaces (or
model file triangles) were created.

175
Tips on exporting models:
y Make sure that Model Export Cut Mode in the File menu > Properties >
General tab is toggled "On".
y Make sure that Display Holders in Workpiece View in the Project menu >
Processing Options > Motion window is toggled "Off".
y Make sure that Visibility is set such that models of fixture components are not
visible in the Workpiece View. See Model menu > Model Definition >
Component Attributes tab for more information.
y When you cut the model a message similar to "For best AUTO-DIFF, OptiPath
and Model Results, set Cut Tolerance to 0.XXXX, due to small tool features"
will appear in the logger. Use this information as a starting point for setting
Cutting Tolerance and Base Cut Tolerance on values on the File menu >
Properties > Tolerance tab.
y To export a higher quality model reduce the Cutting Tolerance.
y You can section cut models, then export what remains in the sectioned view. This
can be helpful to export portions of complex models on computers with limited
resources.

Settings tab — Features on this tab establish general properties for the model export.
Options tab — Features on this tab are used specify properties related to specific
methods of processing VERICUT model geometry.
Apply — Saves the Export Model window settings.
Output — Processes and exports the VERICUT model according to the Export Model
window settings. During the export operation a Model Export Boundaries window opens
providing control over small surfaces that may cause problems in your CAD system.
When the model has been exported, a message informs you how many IGES surfaces (or
model file triangles) were created.
Close — Closes the Export Model window.

176
Export Cut Stock window, Settings tab
Location: File menu > Export Cut Stock

Features on this tab establish general properties for the model export.

Output File — Enter the \path\file name in the text field of the file to receive exported
model data or click on Browse and use the Export Model File selection window to
specify the file.
File Type — Type of file to export. Options are: VERICUT, STL, IGES, CATIA V5,
ACIS, CATIA V4 and STEP.
File Format — Format in which STL or VERICUT model data is exported. Options are:
ASCII or Binary.
Output Color — Use to specify the color that is stored in the IGES file for the exported
model. (Only active when File Type = IGES )
Output Solid — Use to export a solid model. (Only active when File Type = CATIA
V5, ACIS, CATIA V4,or STEP)
Stock — When multiple Stock components are defined, this option enables you to select
which one to export.
Coordinates — Coordinate system in which model data is exported. Options are: Stock
(stock component origin) or Active System (See Project menu > Coord. System).
Units — Unit measurement system in which model data is exported. Options are: Inch or

177
Millimeter.
Method — Controls the method of processing VERICUT model geometry into the
specified data format. Features and Patches, Features Only and Turned Features
Only are only active when File Type = IGES, CATIA V5, ACIS, CATIA V4,or STEP.
Slices is only active when File Type = IGES
Options:
y Features and Patches — Builds synthetic features from several small
adjacent features that are difficult to resolve in 'Features Only' mode.
Analyzes the cut model using UV grid logic and group machined features by
grid region. Grid Count specifies the number of grid squares in U and V
space, spread over the cut model surface. VERICUT attempts to create one
surface within in each grid, or as few surfaces as possible. This option is
recommended for cut models with smooth or transitioning surfaces, for
example: mold and die cavities and patterns, blended or sculptured surfaces,
etc.
y Features Only — Groups similar machined features into like IGES data
entities. This option is recommended for cut models with distinct differences
between machined features, for example: aerospace structural components,
pocketed parts, parts with strengthening ribs/walls and stepped floors, etc.
y Turned Features Only — Exports the turned, or "revolved" representation of
the cut model. Turned models are exported as an IGES file and contain the 2-
D turned profile and surface of revolution.
y Slices — Exports the cut model such that resulting IGES output is a set of
composite curves representing slice profiles of the cut stock.

178
Export Model window, Options tab
Location:File menu > Export Cut Stock

Features on this tab are used specify properties related to specific methods of processing
VERICUT model geometry. The options displayed will vary depending on the method of
processing (either Hybrid or Slices) selected on the Settings tab.

Process = Features and Patches


Grid Count — Use to specify the number of grid squares in U and V space to be
spread over the cut model surface during the IGES export process. Increasing this
number increases the size of the output file, and increases IGES data accuracy.
Valid values are 0 (the same as off) - 100.
Global Angle — Angle which, if exceeded, divides the machined surface into
multiple IGES surfaces. Enter the angle in degrees. Increasing the angle decreases
output file size and decreases IGES data accuracy. On "Grid" processed models
Global Angle affects the output of all machined surfaces.

NOTE: When you increase the Grid Count (more grid sections), the
Global angle can also typically be increased since fewer features are
considered for each grid.

179
Tolerance — Use to specify the amount that the exported model surface can
deviate from the cut model surface. The smaller the value, the closer the output
model will approximate the cut stock.

NOTE: This tolerance value should be equal to, or greater than, the cut
tolerance.

Group by Color — When toggled "On" (checkmark visible), patches will be


created to only contain data related to a single color.
Detect Scallop Planes — Toggle "On" to activate "scallop plane logic" to process.
Processing is faster when toggled "Off".
Preview and Combine Patches — Toggle "On" to activate The Model Export
"Preview and Combine Patches" feature. After VERICUT completes a preliminary
analysis of the model, the model display changes to show multi-colored patches
(see below), and the Preview and Combine window displays enabling you to:

y preview the model before going through the entire model export process.
This enables you to cancel the current export and update settings before
proceeding.
y merge adjacent patches for smoother output, faster model export, and
smaller model sizes.

VERICUT display for Preview and Combine Patches

180
Filter Features — Use to specify the size of the area to be taken into account
when differentiating between a "feature" and a "surface". Select the appropriate
"feature" tab, (Plane, Cone, Cylinder, Sphere, Torus, Torus Sweep, or Ellipse
Sweep) then use the slider to specify the size of the area. More end if the scale is
approximately equal to .0001 of the part size. Less end of the scale is
approximately equal to .1 of the part size.

Process = Slices
Slice Direction — Use to specify the direction of the slices. Select X, Y, or Z
based on the axes of the cut stock model.
Number of Slices — Use to specify the total number of slices to create.

NOTE: If the specified number is greater than the number of grid planes
internally stored in the cut stock database, the number of slices output will
automatically be reduced to this smaller value.

Local Angle — determines the max angle between 2 adjacent pieces of one slice
when they still can be combined in one segment.
Tolerance — Use to specify the amount that the exported curves can deviate from
the cut model surface. The smaller the value, the closer the output curves will
approximate the cut stock surface.

NOTE: This tolerance value should be equal to, or greater than, the cut
tolerance.

181
Model Export Boundaries window
The features in the Model Export Boundaries window enable you to close difficult or
poorly defined feature trimming edges before exporting the model.

Feature/Boundary Table — Contains a list of features. Each "feature" contains one or


more open edges that VERICUT was not able to close automatically. Click on the "+"
sign to the left of the feature to display a list of edges associated with it.
Construct Mode — These options enable you to manually close open feature edges prior
to exporting the model. To activate Construct Mode, select any option in the list other
than "Off". A red and white "cross-hairs" cursor indicates when Construct Mode is active.
(See how)
Options:
y Off — Turns off Construct Mode. (You can also use the "escape" key on
the keyboard)
y Project Edge — Use to extend an edge along a feature/feature intersection,
one point at a time by projecting the "Begin / End" point of the highlighted
edge to the selected point on the intersection.
y Trim Edge — Use to eliminate overlapping boundary curves by trimming
the "Begin / End" point of the highlighted boundary to the selected
location.

182
NOTE: It is better to trim the boundary short, leaving a small gap that can
then be closed than to have an "overlap" condition in the boundary.
y Add Edge — Use to connect two edges within the same feature. The
"begin/end" point of the highlighted edge is connected to the "end" or
"begin" point on the selected edge.
NOTE: Highlight the edge by selecting it in the Feature/Edge table or by
clicking on the edge in the graphics area with the center mouse button.
y Construct Patch — Use to construct a patch to fill an open area between
features.

Delete Edge — Use to delete the highlighted edge.


Reverse Edge — Use to reverse the direction of the highlighted edge.
Fit Edge — Use to resize and center the graphics window display around the highlighted
edge. Select the edge in the Feature/Edge table or by clicking on the edge with the center
mouse button in the graphics area.
Fit Feature — Use to resize and center the graphics window display around the selected
feature. Select the feature in the Feature/Edge table or by clicking on the feature in the
graphics area.
Clear — Use to clear the graphics display of "persistent boundaries".
Do Not Output Open Boundaries — Toggle "on" to prevent the export of open
boundaries.
Persistent Boundaries — When toggled "on", enables you to display multiple feature
boundaries. Use to display the feature boundaries adjacent to the edge that you are trying
to close. Use Clear, described above, to remove "persistent boundaries" from the
graphics display.
Color Pallet — Select an object from the list then click on the color pallet icon to display
the color pallet. Select the color for the selected object. You can specify colors for the
following objects:

y Begin Point Color — Use to specify the color to display the "begin" point
of an open feature boundary.
y End Point Color — Use to specify the color to display the "end" point of
an open feature boundary.
y Boundary Color — Use to specify the color to display "open" feature
boundaries.
y Projection Color — Use to specify the color to display the projected
feature curve that displays when using Construct Mode options Project,
Trim or Extend are used.
y Selected Color — Use to specify the color to display "selected" open
boundary color (the highlight color of the active boundary).
y Closed Color — Use to specify the color to display "closed" feature
boundaries.

183
y Node Color — Use to specify the color to display "node" points (the point
where two adjacent edge segments connect on a feature boundary).

OK — Creates the export file and closes the Model Export Boundaries window.
Output — Creates the export file and leaves the Model Export Boundaries window
open.
Cancel — Cancels the export of the model.

184
Export Cut Stock, Preview and Combine
window
Use the the features on the Preview and Combine window to:
preview the model before going through the entire model export process. This enables
you to cancel the current export and update settings before proceeding.
merge adjacent patches for smoother output, faster model export, and smaller model
sizes. (See example)

The features available, and how to use them, are described right in the window.

185
Export Cut Stock, "Combine" Example
The following example shows the process of combining a number of smaller patches into
a single patch.

When Preview and Combine Patches is toggled "On", VERICUT completes a


preliminary analysis of the model, then displays the model as multi-colored patches as
shown below.

To combine patches, start by selecting the "initial" patch (in this case patch # 1) using the
left mouse button. The initial patch will display as shown below.

NOTE: Patch boundaries and numbers have been added for illustration purposes
and will not be seen in the VERICUT display.

186
Select the first patch to be merged (in this case patch #2) with the middle mouse button.
Any patch adjacent to the "initial" patch could have been selected for merging. The
display updates as shown.

Continue selecting adjacent patches to merge using the middle mouse button. The picture
below show the display after all 12 of the numbered patches have been selected for
merging.

187
When finished selecting patches to be merged, click on the part with the left mouse
button to combine the selected patches into a single patch as shown in the picture below.

188
Export Cut Stock, Preview and Combine
Techniques
The following techniques are provided to assist you in maximizing the quality of the
models you create using the Export Cut Stock features.

1. Avoid long narrow strips.

The first image shows original patches.

The second image shows a resultant


long narrow patch which should be
avoided.

189
The third image shows an ideal
resultant patch.

Consider neighboring node propagation.

The first image shows original patches.

The second image shows a resultant


patch which will be split do to
neighboring nodes.

190
The third image shows what should be
done to minimize unnecessary splits.

3. Merge small patches.

Use the table to identify small patches


by sorting by the Size column. Once
small patches have been identified
combine small patch with larger patch
or combine a group of small patches to
create one large patch. The image at
the right shows a small patch (in red)
that should be merged with one of the
two larger patches.

4. Merge all small plane anomalies.


All small anomalies within a plane
should be combined with the plane. The
first image shows a plane (in red) with
several small anomalies within the
plane.

191
The second image shows the plane with
the small anomalies combined with the
plane.

5. Consider initial design intent.


When combining patches take into
consideration intended design feature.
The initial design intent of the images
below is a cylinder.
The first image shows the original
patches.

The second image shows the combined


patches considering the initial design
intent.

192
6. Tabulated cylinder representation.

Patches should be combined to represent


a tabulated cylinder. The first image
shows the original patches.

The second image shows what should not


be done.

The third image shows the ideal patch


combination abiding by the tabulated
cylinder rule.

193
7. Use Split and Merge to improve fillets.

The first image shows the patches from


the original collection.

The second image shows the patches after


using split and merge to improve fillet
areas.

8. Use Split and Merge to improve jagged boundaries.

The first image shows the original patch


boundary.

194
The second image shows the patch, after
using split and merge to improve
boundary.

195
Working Directory

VERICUT Users:
VERICUT Location: File menu > Working Directory

Toolbar short cut for setting a working directory:

Mold and Die Users:


Mold and Die Location: Setup page > Work Directory
Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Setup page > Work Directory
Notebook Feature:

Opens a window to set the working directory for opening and saving VERICUT files.
After setting the working directory (see how), VERICUT will look here by default
whenever files are saved or opened. You can also quickly access files in this directory via
the Working Directory entry in the file selection window Shortcut list.
Most features on this window are standard file selection window features that enable you
to navigate through directories, filter files, and type or select file names. In this case, all
that is required is to select a directory.

196
Properties

Properties Window

VERICUT Users:
VERICUT Location: File menu > Properties

Mold and Die Users:


Mold and Die Location: Other Settings page > Session Properties

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Other Settings page > Session Properties

Notebook Feature:

Opens a window to set properties for the verification session, such as: cut mode,
resolution and tolerance values that affect cut model display, accuracy, and motion
simulation.

197
General tab — Features on this tab establish general properties for the VERICUT
simulation session.
Tolerance tab — Features on this tab set tolerances for the overall simulation session.
These values are used by VERICUT to construct the solid database for machining,
simulate circle motions, identify errors related to material removal, and work with conic
solid models.
OK — Saves the window settings and closes the Properties window.
Apply — Saves the current window settings and leaves the Properties window open.
Cancel — Closes the Properties window without saving changes.

198
Properties, General tab
Location: File menu > Properties

Features on this tab establish general properties for the VERICUT simulation session.

Default Machining Type — Sets the machining mode for VERICUT.


Options:
y Mill — A spinning tool removes material when in contact with Stock/Fixture.
y Turn — A Spindle spins the Stock/Fixture assembly and a stationary tool (not
spinning) removes material when in contact with Stock/Fixture.
y Wire EDM — An electrically charged wire removes material when in contact
with Stock/Fixture.
The machining type can be changed during the simulation using a VERICUT-
MODAL record (APT or G-code tool paths) or via the
VC_ModeMilling/VC_ModeTurning NC control macros (G-code tool paths
only).
Stock Consistency Check — When selected, VERICUT checks the consistency of stock
models, including: check for "watertight" solid- repair improperly trimmed surfaces
(overlaps and gaps), and reconstruct insignificant missing surfaces. This option is highly
recommended for stock models creating from importing IGES data, and other model files
where portions of the stock model disappear, or gaps/seams appear in the model when
cutting is started.
Model Export Cut Mode — When toggled "On", causes VERICUT to cut with a more
accurate internal cutter representation for better results when using modules like Model
Export or OptiPath. Only toggle "On" when the additional accuracy is required as it can
have an impact on processing speed.

199
Properties, Tolerance tab
Location: File menu > Properties

Features on this tab set tolerances for the simulation. The tolerance values control the
accuracy of the cut stock model, simulated circular motion and other interpolated
motions, whether or not certain errors get written to the error log, and the accuracy of
cylinders, cones and other revolved models and tool assemblies for collision checking.

Interpolation Tolerance— This value is used to interpolate intermediate positions


during NURBS, circular, and helical motions. This tolerance is also used by the Detect 4-
Axis Rotary Motion APT setting to determine if sequential GOTO locations can be
performed as a single 4-axis motion- ref. Project menu > Processing Options > APT
Settings: Rotary tab.
Minimum Error Volume— This value sets a threshold for the minimum volume of
material that must be removed by a fast feed motion or holder collision in order for an
error to be reported. If the volume removed by an error motion is less than this value then
no error is reported in the log file or logger for the motion, and the error count is not
incremented.
However, any volume of material removed by a fast feed motion or holder is always
shaded in the error color (typically red), regardless of the volume. Thus small volume
errors may be shaded red but will not be reported in the log file or logger if the volume is
less than Minimum Error Volume.
The Minimum Error Volume value is in cubic units (inch or millimeter). Use this setting
to filter very small fast feed and holder collisions from VERICUT's error reports. The
default value "0" causes VERICUT to calculate a small internal value based on stock size
and cut tolerance.

200
Model Tolerance— This value is used when displaying revolved models such as
cylinders, cones, and revolved profiles. It is also used when displaying the revolved
image of a turning stock model created from an IGES profile. Accuracy of cylindrical
tool assemblies displayed in a machine view are also affected by this value.
This value has a small effect on collision checking accuracy for revolved models used to
represent machine components or fixtures.
Cutting Tolerance— This value sets the accuracy of VERICUT's cut stock model. The
Base Cut Tolerance on choices below determine how the value is used to establish the
cut stock accuracy. Increasing the Cutting Tolerance value increases the speed of the
simulation and various other operations, and uses less memory, but reduces the accuracy
of the cut stock model. Decreasing the value improves accuracy of the cut stock model,
but reduces speed and increases the memory required by the cut stock model.
The cutting tolerance affects the accuracy and speed of AUTO-DIFF, Model Export,
and OptiPath. A smaller Cutting Tolerance produces more accurate results but takes
longer to process. VERICUT's ability to detect small holder collisions and fast feed errors
are also affected. The speed of dynamic rotate/pan/zoom operations and the time required
to create the refined image in the workpiece view are also affected.
Base Cut Tolerance on— Controls how VERICUT applies the Cutting Tolerance to set
the accuracy of the cut stock model.

y Tool Size—When selected, VERICUT scans the current tool path files and
analyzes the geometry of all cutters used by the NC programs. The Cutting
Tolerance value is applied as a chordal deviation on curved tool shapes
(diameter, corner radius, etc). The smallest calculated chord length or cutter
profile segment is then used to set the accuracy of VERICUT's cut stock model in
order to reliably create cut features with the tools used by the current NC
programs. This option is recommended when faster simulation speed is important.
This is the default setting.
y Stock Size—When selected, VERICUT applies the Cutting Tolerance value
directly, creating the cut stock model at the specified accuracy. The tool path files
are not scanned to detect the cutters used. The value represents the size of the
smallest cut feature VERICUT can detect.

NOTE: It is very important to understand that the value represents the size of a
cut's volume measured in any direction. Thus, cuts that are larger than the Cutting
Tolerance in at least one direction will be detected by VERICUT.
For example, a .001" axial depth cut by a .25" ball end mill produces a volume with
the following shape:

201
As a general practice, setting Cut Tolerance Based on Stock Size to one-fourth
(1/4) the size of a cut volume's span will detect the cut. Thus in this case, to detect a
.001" deep cut by a .25" ball end-mill, set Cut Tolerance to .007" or smaller.
However, results can vary depending on the shape of the cut volume.
The Stock Size option is recommended when an exact value is desired for
VERICUT's cut stock model accuracy, independent of the tools used.

202
Preferences
Location: File menu > Preferences

Opens a window enabling you to specify the VERICUT project file (.VcProject) that you
want displayed when you start a the next VERICUT session.

Open standard VERICUT project — When toggled "On", the standard VERICUT
project is displayed upon startup. The standard VERICUT project is either
vericut.VcProject, or vericutm.VcProject, in the "library'" directory of your VERICUT
installation depending on the way environment variable, CGTECH_DEFAULT_UNITS,
is set.
Start a new project — When toggled "On", the VERICUT session opens ready to start a
new project.
Open last project — When toggled "On", the new VERICUT session opens with the
same project file that was open when you closed the previous VERICUT session.
Choose project file on startup — When Toggled "On", VERICUT displays the Open
Project window at startup enabling you to select a project file.

OK — Saves the window settings and closes the Preferences window.


Cancel — Closes the Preferences window without saving the window settings.

203
Custom Interface
Location: File menu > Custom Interface

Toolbar short cut for accessing Custom Interface:


Opens a file selection window that enables you to select an existing custom VERICUT
User Interface for use; or for editing an existing, or creating a new custom interface with
VERICUT Customizer.

Folder "tree"— Enables you to specify the location for new custom interface
folder or select an existing custom interface folder. All files related to the notebook
and custom interface are stored in this folder.
Shortcut— Displays the Shortcut option list providing quick access to files in your
Working Directory, or CGTech library and sample files. Use the "Folder Up" icon
to move to the next higher level in the Folder "tree".
Folder— Use this text field to enter a /path/folder name to open an existing custom
interface notebook, or to create a new custom interface folder and open a new
"empty" custom interface notebook. You can also use the Folder "tree" to specify
the path then append the name for the new custom interface folder in the text field,.
OK— Opens an existing custom interface notebook or creates the new custom
interface folder and displays new "empty" custom interface notebook.
Cancel— Ends book selection and returns to VERICUT.

204
Introduction to VERICUT Customizer
The VERICUT Customizer, or "Customizer", is a standard VERICUT feature that
provides the tools to create a custom simplified VERICUT User Interface. VERICUT
Customizer is designed to simplify VERICUT usage for specific jobs or classes of jobs.
Include only the VERICUT functionality that you need in a custom interface and
eliminate the need to search through the wide range of features that are presented in
VERICUT's "full function" standard user interface to find the ones they need to use.
VERICUT Customizer:

y enables you to graphically arrange and label buttons, choice lists, check boxes,
etc. in a way that is most meaningful in your particular work environment.
y enables you to include instructions and pictures within the interface to prompt or
explain to the user how to use VERICUT to accomplish their job.
y enables you to produce a simplified user interface that will make "new" or
"occasional" VERICUT users productive with minimal training.

What does a custom VERICUT interface look like?

205
A custom VERICUT interface consists of two main parts, the "notebook" and the
VERICUT main window.

Notebook -
This is a simplified VERICUT user interface. It has been designed for a particular type or class jobs.
It contains only the functionality essential to the particular job type without the complexity of the
standard "full functionality" VERICUT user interface. A notebook can be created with both
"feature" and "help" pages.
Feature Pages -
Contain features (buttons, text fields, choice lists, etc.) that enable you to pass necessary
information to VERICUT for processing. Each of the features selected for use on the feature
pages can be labeled in the language and/or terminology that is most appropriate for the
intended end user. Feature pages use XML files to store feature information.
Help Pages -
Used to include instructions, explanations and pictures within the custom interface to assist
the user in providing the necessary information to VERICUT. Help pages are HTML files
and GIF or JPEG images to illustrate the instructions.

VERICUT Main Window -


The VERICUT main window in a custom user interface is similar to the standard
VERICUT main window without the main menu bar and a lot less icons. This
makes using VERICUT much easier to use for those who do not need the full range
of functionality provided by the standard VERICUT user interface.

What is involved with creating a custom VERICUT interface?


Creating and deploying a custom interface for use by VERICUT users involves the
following seven steps. Click on each of the steps listed below for more information about
each step.
1. Set up a default user file.
2. Creating the notebook.
3. Determining the size of the notebook.
4. Adding custom interface features.
5. Adding custom interface help.
6. Test the custom interface.
7. Make the custom interface available for use.

206
Setting up the Custom Interface Default
Project File
Each customized interface notepad references a default project file. This project file is
retrieved by VERICUT each time the notebook is opened. It is advisable to preset as
many parameters as possible in the default project file. Doing this will minimize the
number of features that will be required in the customized interface notebook and make it
much simpler to use.
It cannot be stressed too much that the key to creating a concise, easy to use custom
interface is attention to detail in the design of the default project file. While there are
seven steps involved in creating a custom interface, it is estimated that as much time will
be spent on this first step as the other six put together. If you get the default user file
right, the remaining steps to create the custom interface will be much easier and the
resulting notebook will be much simpler to use.
The following topics should be considered when setting up a default user file for use with
a specific notebook:

y Use of colors
y Cut mode (Standard or FastMill)
y Units
y Tolerances
y Conditions for AutoSave
y Layout, orientation and attributes of Views
y Configuration of status window
y Report, log and result file names
y Machine and fixture models
y Toolpath type
y Tool change technique
y Motion, G-Code and APT settings
y Location of stock model within stock component
y Tool and OptiPath library
y Control parameters
y Machine parameters

Many of the parameters associated with the above topics can be set using features
displayed on the feature pages of the notebook, but if they are not going to change, there
is no reason to include them in the notebook. Just set them in the default project file.
After all, the purpose of the custom interface is to simplify the use of VERICUT.

207
In many instances, creating multiple notebooks that reference different default user files
can simplify the use of a custom interface. For example, if you are creating a notebook to
lead a machine operator through processing a toolpath in VERICUT before running it on
the machine, it could be beneficial to create a notebook and corresponding default user
file for each machine/controller combination on the shop floor. That way the operator
does not have to enter machine/controller information every time. Just call up the
appropriate notebook enter the toolpath information, then process.

Notebooks should be created in such a way that the user is can only save the user file
with their input under a different name. Default project files should also have permissions
set as "read only" and stored in "write protected" directories and folders so they do not
accidentally get modified.

Now that you have tailored a project file for the notebook you intend to create, it's time to
create the notebook.

208
Creating the Custom Interface Notebook
Creating a custom interface notebook:
Select File--> Custom Interface in the VERICUT main menu to display the Select
book's folder window shown below.

Folder "tree"— Enables you to specify the location for the custom interface
folder. All files related to the notebook and custom interface are stored in this
folder.
Shortcut— Displays the Shortcut option list providing quick access to files in your
Working Directory, or CGTech library and sample files. Use the "Folder Up" icon
to move to the next higher level in the Folder "tree".
Folder— Use this text field to enter a /path/folder name, or use the Folder "tree"
to specify the path and append the name in the text field, for the new custom
interface folder.
OK— Creates the folder and displays the new custom interface notebook.
Cancel— Ends book selection and returns to VERICUT.

209
The notebook:

Notice that when the notebook is created it contains no pages. Adding pages will be
discussed later. The custom interface notebook header shows the folder that the notebook
is associated with. The main menu bar contains the following options:

File:
Open— Displays the Select book's folder window allowing you to open
another custom interface notebook for editing or create a new notebook.

210
Recent— Displays a list of recently opened files. To open a file in the list,
select the desired file.
Close Book— Closes the VERICUT custom interface and displays the
standard VERICUT interface.
Exit VERICUT— Ends the VERICUT session.

Layout

— Positions the notebook on the left side of the VERICUT main


window.

— Positions the notebook on the right side of the VERICUT main


window.

— Overlays the notebook on top of the VERICUT main window. Left


click on the notebook's header and drag to any position.
Minimize — Reduces the notebook size to only display the custom Interface
header and main menu bar.
One Page — Use to display the custom interface notebook as a single page.
Two Pages — Use to display the custom interface notebook as two pages.

Help:
On VERICUT— Starts VERICUT Help.
About VERICUT— Opens a window that displays information about the
current VERICUT session.

Notebook modes:
User mode:
When a notebook is in "user" mode it can only be used to interact with VERICUT.
It cannot be modified or edited in any way. When a notebook is opened, it is
always in "user"mode, even when it is new and empty. If password protection for
"author" mode is in effect, the following window will be displayed when the F7
key is used to enter "author"mode:
Password — Enter the correct
password in the text field and
select Unlock to allow entry to
"author" mode.
Unlock — Use with password
above, to allow entry to
"author" mode.
Cancel — Use to dismiss the
access window.

211
Author mode:
When a custom interface notebook is in "author" mode, pages and features can be
added or removed, text and labels can be edited and the size of the notebook can be
changed. Use the F7 key on the keyboard to switch between "user" and "author"
modes. When you are in "author" mode, the notebook changes as seen in the
illustration below.

Notice that "(284x554)" has been added to the end of the menu bar. This number
represents the current size of the notebook in pixels. While you are in "author"

212
mode you can change the size of the notebook. Click on one of the corners or edges
and drag to change the notebook size like any other window. The size of the
notebook that is set in "author" mode is what the user will have to work with. The
size of the notebook is fixed for the user. The position of the notebook can be
changed by the user but not the size. See Sizing the Custom Interface Notebook for
more information on determining the appropriate size for the notebook.
Notice also that a row of icons has been added to the sides of the notebook. The
icons on the right are used to add or remove pages and save the notebook. The
icons on the left are used to edit the text on notebook help pages. They remain
grayed out and inactive until help pages are added to the notebook.
Finally, the following options have been added to the File menu:

User File — Enables you to specify the default .usr file that is associated with the custom
interface notebook.
Protect — This item enables the author to prevent the user from entering
"author" mode without entering a password. Selecting Protect displays the
Protection window which enables you to specify whether or not to use
password protection for the notebook while in "user" mode and to specify a
password.
Password — Enter a
password in the text field
that will allow entry to
"author" mode.
Lock — Use to turn on
password protection for
"author" mode.
Unlock — Use to turn off
password protection for
"author" mode.
Cancel — Use to exit the
Protection window without
making changes.

To add password protection for entering "author" mode:


1. Type a password in the text field.
2. Select the Lock button.
3. Save the notebook using the Save all changes icon.
4.
The next time that the notebook is opened, if the user uses the F7 key to enter
"author" mode, they will be prompted to enter the password before being
allowed into "author" mode.
Use the Unlock button while in "author" mode to remove an existing
password protection.

213
Allow Close — This item enables the author to prevent the user from exiting the custom
VERICUT interface and returning to the standard VERICUT interface. This item toggles
"on" and "off".
If Allow Close is toggled "on" (indicated by a checkmark), the Close Book option will
appear in the File menu when in "user" mode allowing the user to exit the custom
VERICUT user interface and return to the standard VERICUT user interface.
If Allow Close is toggled "off" (indicated by no checkmark), the Close Book option
will not appear in the File menu when in "user" mode preventing the user from exiting
the custom VERICUT user interface and returning to the standard VERICUT user
interface.

Adding pages to the notebook:


Before you can add features or help text to the notebook you need to add pages. Add any
combination of feature pages and help pages. Keep in mind that two pages are displayed
at once. It makes a lot of sense to have alternate feature pages and help pages. One
advantage of this user interface style is that it can lead the user through a specific
sequence of steps.

Use the icons illustrated below to add pages to or remove pages from the notebook.

NOTE: If you do not see the icons below on the right side of the notepad, you
are not in "author" mode. Use the F7 key on the keyboard to switch to "author"
mode.

Remove Upper Page


Insert Upper Page
Insert Lower Page
Help Page Append Page
Feature Page
Remove Lower Page
Save all changes

Remove upper page — Use to remove the displayed upper page from the
notebook.
Insert upper page — Use to insert a page into the displayed upper position of the
notebook. Select HTML or Form from the pop-up menu to specify the type of
page to create.

214
HTML — Use to create a help page.

Hint: You can tell a help page by it's white background.

Form — Use to create a feature page.

Hint: You can tell a feature page by it's gray background.

Insert lower page — Use to insert a page into the displayed lower position of the
notebook. Select HTML or Form (described above) from the pop-up menu to
specify the type of page to create.
Append page — Use to add a page to the end of the notebook. Select HTML or
Form (described above) from the pop-up menu to specify the type of page to
create.
Remove lower page — Use to remove the displayed lower page from the
notebook.
Save all changes — Use to save all changes made to the notebook. This includes
notebook size changes, pages added or removed, and page content added or edited.

NOTE: There is no "undo" capability in "author" mode so saving often is


highly recommended.

Once you have added some pages, use the following to move around in the notebook.
Click on one of the "dog-eared" corners in the upper page (or use the Page Up key
on the keyboard) to turn back one page in the notebook.

Click on the one of the "dog-eared" corners in the lower page (or use the Page
Down key on the keyboard) to turn forward one page in the notebook.
Use the Ctrl and Home keys on the keyboard at the same time to move directly to
the first page of the book.

Use the Ctrl and End keys on the keyboard at the same time to move directly to
the last page of the book.

Now that you have created the notebook, it's time to decide on the size of the notebook.

215
Sizing the Custom Interface Notebook
A customized interface notebook retains the size set while in "author" mode and cannot
be changed by user. This is because information on one page does not reposition to the
next page if the size of the notebook is reduced, nor are scroll bars used if a page contains
more information than will fit. To do so would be contrary to the idea of a simplified user
interface.
You need to decide on the size of the notebook, which in turn determines the size of its
pages, before you start adding content. The size of the notebook can be changed later, but
if you make it smaller you may be spending a lot of time cutting and pasting between
pages.
To help determine the appropriate size for the notebook, try to answer the following
questions:

y What is the resolution of my target user's screen?


y How large does the VERICUT main window need to be?
y How much space to the left or right of the VERICUT main window remains for
the notebook? Positioning the notebook on either of the main window is clearly
preferable.
y If the answer to this last one is "Not enough!", is it reasonable to overlay the
notebook on top of the VERICUT main window?

As a starting point, you might try allocating 3/8ths of the screen's width for the notebook.
You can adjust the notebook size by dragging its edges or corners as you would any other
window. The numbers on the right side of the notebook's menu bar will continuously
update as you re-size the notebook. If your target screen resolution is 1280 x 1024, and
you have decided to allocate 3/8ths of the width to the notepad, you could manipulate the
window until you see (480 x 990), leaving some space for the Windows taskbar. If your
target user has a Windows based platform, you do not want to use screen's full height or
the notebook will be partially hidden behind the Windows taskbar.

Use the Save all changes icon ( ) located on the right side of the notebook to save the
notebook with its size and position.

Now that you have established the size of the notebook, and thus the size of its pages,
you can add features to the pages.

216
Creating Custom Interface Feature Pages
Now that you have created and sized the notebook, it is time to add features to the feature
pages. The user interacts with features in the notebook to enter numbers, select files,
make choices from a limited set of options and see results. As the author of a custom user
interface notebook it is your task to arrange a collection of features so the user can
specify all the parameters needed to get his or her job done. The way that you lay out the
features within the notebook, and use help pages, enables you to lead the user through a
logical sequence of actions to accomplish the required task.
If your notebook does not yet contain feature pages, or you need additional ones, use the
procedure described in Adding Pages to the Notebook to add them.

Feature Page Layout:

A "feature" page is easily distinguished from a "help" page by it's gray background.
Features can only be added to "feature" pages. They cannot be added to "help" pages. In
order to add features to the page you must be in "author" mode.
Within a page, features are laid out in two columns. The left column will only be as wide
as the widest feature that it contains. All features placed in the right column will expand

217
to fill the remaining width. Use blank spaces within features in the left column to control
sizing of the two columns. Adding blank spaces to the longest feature in the left column
will increase the width of the left column, thereby decreasing the width of the right
column. Add or remove blank spaces to the longest feature in the left column until the
desired column balance is achieved.
Typically the left column will contain labels explaining the purpose of the corresponding
feature in the right column, although you are not restricted to this convention. The first
feature that you place in a form will always go to the left column.

What Features Are Available?


The following feature types are available for use in any combination on the feature pages
of your notebook.
FEATURE DESCRIPTION
Labels the purpose of adjacent
features.

Text Fields are used to enable the


user to input character information to,
or receive results from VERICUT.
Numeric Fields are used to input one
or more numeric values. Can also be
used to input numeric data requiring
calculations like "3+31/64".
File Selection Boxes are used to input
file names or browse for the file using
the icon.
Choice Lists are used to present a
limited set of options in a drop-down
list

Check Boxes are used for options


requiring only a simple on/off
condition.
Radio Buttons are used as an
alternate method of presenting a
limited set of options. There can only
be one set of radio buttons used on
each feature page. Only one of the
radio buttons will be active at a time.
When one is selected, all others in the
set become deactivated.

218
Buttons are used to trigger actions
like file conversion or display a
secondary window.
MDI Buttons are used to input
machine control functions.

MDI Numeric Fields are used to


input numeric data to machine control
functions.

Adding Features:

While in "author" mode (use F7 key


on your keyboard if necessary if
necessary), move the cursor to an
unoccupied area of the page and click
the right mouse button. You will see a
pop-up menu like the one shown on
the left, enabling you to select one of
the various feature types described
above. As each feature is added to the
page you will notice that initially they
contain question marks "???" for text.
Type over the "???" with the desired
text. You can edit the text of an
existing feature by clicking in it and
making the changes.
Remember that features on the page
are positioned in just two columns.
The first feature is added in the left
column. Initially it appears in the
center of the page. As soon as you
add another feature to the right of it, it
repositions the first one from the
center to the left edge of the page.
Continue adding the desired features
to the page, or until the page is full.
At that point, add another feature
page and continue. Note that you can
insert a feature between two existing
rows by carefully positioning the
cursor between them.

219
You may have noticed that the pop-up menu of feature types has
another choice, Paste, that we have not discussed yet. If you
right-click on one of the features that you have already put on the
page, you will see the pop-up menu shown on the left. Select
either the Cut or Copy options, then right-click on an empty area
of the page. The feature type pop-up menu discussed above will
display. Selecting the Paste enables you to move or copy the
feature. This is also the way that you can move or copy features to
another page if necessary. Delete enables you to remove an
existing feature from the page.

Connecting the Features to VERICUT:


To this point the features that you have added to your notebook may look great but they
are not yet functional. They need to be connected to the parameters and functions of
VERICUT so that they produce the desired result when put to use by the user. These
connections to VERICUT are accomplished by using the Details option that appears
when you right-click on a feature. This is the same pop-up menu that contained the Cut
and Copy options discussed above.
The interaction that follows is dependent on the feature type, although some feature
types require similar interaction.
y Labels and Text Fields
y Numeric Fields
y File Selections
y Choice Lists and Radio Buttons
y Check Boxes
y Buttons
y MDI Buttons and Numeric Fields

Once you have finished adding functional feature pages to the notebook, it's time to add
some help pages.

220
Custom Interface - Labels and Text Fields
While in "author" mode, right-clicking on either a label or a text field on a feature page
and selecting Details, displays essentially the same window. The only difference is that
the one for label features has a set of radio buttons that enable you to adjust its alignment.
The tree that dominates these windows is identical. It is organized to reflect VERICUT's
menu structure. Each "leaf" in the tree represents a text parameter. When selecting
between using a label or a text field, keep in mind that a user can only read a label, but
can edit the content of a text field. Most label features in a notebook will not need to be
associated with a VERICUT parameter. They will simply be used to describe other
features on the feature page.
To connect a feature to a parameter, simply expand the tree till you find the parameter
you are looking for, select it and click OK. You can also use these windows to check on
an existing association, in which case you would use the Cancel button afterwards.
Click on either of the windows below to display a complete list of VERICUT parameters
that are available for label and text field features.

Label Feature Window

Label features can be used to display


the text output of certain VERICUT
parameters. The label feature window
to the left illustrates how a label can
be used for this purpose. The label is
associated with the second line on X-
Caliper's Feature/History tab, which
presents the coordinates of a selected
geometry feature's datum (such as a
sphere's center). When the user
selects a geometry feature in the
VERICUT graphics area, the text of
the label will change to display the
resulting text, just as it would be
displayed in the X-Caliper window.
It is also possible to associate a text
field feature with such a parameter,
but it is probably not a good idea to
do so unless the user will need to
copy and paste the text to another
application.

221
Text Feature Window

The text feature window to the left


illustrates how a text field feature can be
associated with the operating system's print
command for use by VERICUT's
ShadeCopy function.

Return to Connecting the Features to VERICUT.

222
Custom Interface - Label/Text Field
Parameter List

File Shade Copy Print Command


Annotation

Setup Motion Start At


Stop At

G-Code Block Skip


Character

APT Settings Rotation Center


Goto Format

Analysis X-Caliper Feature/History Feature 1


Feature 2
Feature 3
Feature 4
Feature 5
Feature 6
History 1
History 2
History 3

Return to Custom Interface -Labels and Text Fields.

223
Custom Interface - Numeric Fields
While in "author" mode, right-clicking on a numeric field on a feature page and selecting
Details, displays the window illustrated below. The title of the window is the current text
from the numeric field. Note that you can also specify the maximum number of decimal
places used to display the parameter. For an integer, such as the number of cuts between
automatically saved ShadeCopy images, use zero decimal places.
The tree that dominates the window is organized to reflect VERICUT's menu structure.
Each leaf in the tree corresponds to a numeric parameter that appears in one or more of
VERICUTS's standard user interface windows. Each of them can be placed on a feature
page independently, though some will almost always appear in sets. A good example is
the direction of the light that illuminates each view, represented by an (I, J, K) vector.
The three parameters that control the location of a stock model relative to the stock
component's datum are another, but they can be combined with three choice lists to
provide some extra functionality that is not currently available in the standard VERICUT
user interface.
To connect a feature to a parameter, simply expand the tree till you find the parameter
you are looking for, select it and click OK. You can also use these windows to check on
an existing associations, in which case you would use the Cancel button afterwards.
Click on the window below to display a complete list of VERICUT parameters that are
available for numeric field features.

Numeric Field Feature Window

Defining the three dimensions of a


stock block is another good example.
In the numeric field feature window
displayed on the left, a numeric field
feature is associated with the Length
(X) dimension of a stock model
block. When combined on the feature
page with numeric fields associated
with the Width (Y) and Height (Z)
values, the user can quickly and easily
define a stock block

Return to Connecting the Features to VERICUT.

224
Custom Interface - Numeric Field Parameter
List

File Convert IGES Tolerance

Surface Tolerance
Offset
Base Location

VDAFS Tolerance

Binary CL Minimum
Cutter Height

Model Export Grid Count


Global Angle
Tolerance
(Grid)
Plane Size
Number of
Slices
Local Angle
Tolerance
(Slice)

Properties Circle Radial


Tolerance
Interpolation
Tolerance
Minimum
Error Volume
Model
Tolerance
Cutting
Tolerance

AutoSave In Process # of Cuts

225
Shade Copy # of Cuts

Margins Left
Right
Top
Bottom

Render
Width
Height

View Angle

VERICUT Solid # of Cuts

View Attributes Light (IJK)

Section Cuts
Delay

Model Block Length (X)


Width (Y)
Height (Z)

Auto Block Offset

Cone Height (Z)


Base Radius
Top Radius

Cylinder Height (Z)


Radius

IGES File Tolerance


Offset Amount
Base Location

Location X

226
Relative tp
Parent
Y
Z

Setup Motion Start At Line Number

Stop At Num of Cuts


Line Number

Stop At Max
Errors
Stop At Max
Warnings
Fast Feed
Skip Cut
Min. Cutter
Height
Holder
Clearance

G-Code Settings Ignore Data


after Column
Rotary Feed
Motion Tol
Rotary Rapid
Motion Tol

Turning CSS Maximum


RPM

WireEDM Wire Diameter


Work Table XY
Plane
XY Plane to UV
Plane

APT Settings Max Tool Axis


Angle
Tool Axis Reset
Angle

227
Default
CLEARP
GOHOME R
Dist

Machine Default Near


Miss

Analysis AUTO-DIFF Solid Gouge


Tolerance
Excess
Tolerance

Point Gouge
Tolerance
Excess
Tolerance
Gouge Check
Distance
Excess Check
Distance
Default Normal
(IJK)

Profile Gouge
Tolerance
Excess
Tolerance

Constant Gouge Tolerance


Check

Compare by Minimum XYZ


Region
Maximum XYZ

OptiPath Override All


Feedrates %

Return to Custom Interface - Numeric Fields.

228
Custom Interface - File Selection
While in "author" mode, right-clicking on a file selection feature on a feature page and
selecting Details, displays the window illustrated below. The title of the window is the
current text from the feature, in this case the file's path and name.
The tree that dominates the window is organized to reflect VERICUT's menu structure.
Each "leaf" in the tree represents an input or output file.
To connect a file selection feature to a file type, simply expand the tree till you find the
file type you are looking for and select it. To connect a widget to a file type, simply
expand the tree till you find the one you are looking for and select it.
You can also supply a prompt which will be used in the file selection window when the
user clicks on the browse icon ( ) to the right of the feature. If the file type has one or
more commonly used extensions, you can specify them as a filter for this window also. In
this case we have just used "*.olb" to narrow the choices to OptiPath libraries, but for
toolpaths you could use a compound filter, such as "*.tp;*.apt;*.cls". The user can always
override the filter.
When you are satisfied with the properties of the file selection feature, click on the "OK"
button. You can also use these windows to check existing associations, in which case you
would use the Cancel button afterwards.
Click on the window below to display a complete list of VERICUT parameters that are
available for file selection features.
File Selection Feature Window

In the example window on the left, a file selection


feature is being associated with the OptiPath
library.

Return to Connecting the Features to VERICUT.

229
Custom Interface - File Selection Parameter
List

File User File


Working
Directory

Convert IGES Input File


Output File

PolyFix Input File


Output File

Surface Input File


Output File

VDAFS Input File


Output File

Binary CL Input File


Output File
APT Table File

Export Model
File
Edit

ShadeCopy Output File

AutoSave In Process Auto Save


Auto Error

Shade Copy Auto Save


Auto Error

VERICUT Solid Auto Save


Auto Error

230
Info G-Code Report
Control Report

Model Stock Model File


IGES File

Design Model File


IGES File

Cut Stock

Setup Toolpath
G-Code APT Output
File
G-Code Log
File
Tool Library
Control
Machine

OptiPath OptiPath
Library
Optimized File

Return to Custom Interface - File Selection.

231
Custom Interface - Choice Lists and Radio
Buttons
While in "author" mode, right-clicking on either a choice list or radio button on a feature
page and selecting Details, displays essentially the same window. The only difference is
that the one for choice list features has a table of choices at the bottom of the window and
the one for a radio button feature has a single drop-down list. The title of the window is
either the text of the current choice in the choice list or the caption of the radio button.

The tree that dominates these windows is identical. It is organized to reflect VERICUT's
menu structure. Each "leaf" in the tree represents a set of choices for a single parameter.
To connect a feature to a parameter, simply expand the tree till you find the parameter
you are looking for and select it. Select an option from those available in the Choice pull-
down for each Item, then click OK. The interaction is slightly different for choice lists
and radio buttons and described in more detail below. You can also use these windows to
check on an existing association, in which case you would use the Cancel button
afterwards.

Click on either of the windows below to display a complete list of VERICUT parameters
that are available for choice lists and radio button features.

232
For a choice list feature, selecting a
parameter in the tree, causes the Choice
Choice List Feature Window column of the table at the bottom of the
window to be filled with the set of options
that are appropriate for the selected
parameter. Each cell of the Choice column
is itself a choice list containing the set of
options that are appropriate for the
selected parameter.
The text that will appear to the user in the
choice list appears in the Item column of
the table. Double-click on the item to edit
the text. You can also edit the text for each
item in the choice list from the feature
page while in "author" mode.
To associate each item with a particular
option:
1. Click on an item in the Item
column so that it becomes
highlighted.
2. Click on the corresponding row in
the Choice column to expand the
pull-down of available options.
3. Click on the option in the pull-
down to associate it with the item.
4. When you have finished
associating the items with options,
click on the OK button.

You can provide the user with a more limited set of options than is available in the
standard VERICUT user interface by simply including fewer items in the Item column.
The items that you include can be in any order. To change the order of items, use the
small blank buttons on the left edge of the table to drag rows to different positions.

233
Radio Button Feature Window
For radio buttons, selecting a
parameter in the tree, causes the
Choice pull-down at the bottom of
the window to be filled with the set of
options that are appropriate for the
selected parameter. Keep in mind that
there can only be one set of radio
buttons on each feature page so when
picking a parameter for one radio
button, you are actually picking it for
all the others on the page. The same is
true if you change the parameter
associated with a radio button. It will
change for all the other radio buttons
on the page also.
In either case you will need to
associate a particular option for each
individual radio button.
To associate an option with a radio
button, simply click on the Choice
pull-down to expand it and click on
the desired option. Click OK.
The text for radio buttons can only be
edited on the feature page while in
"author" mode.
As with choice lists, you do not need
to include a radio button for all of the
available options. Include fewer radio
buttons on the feature page to
simplify the interaction for the user.

Most of the parameters in the tree correspond to functionality that is available in


VERICUT's standard user interface. The exceptions are the three parameters located
under Model --> Relative Location. These parameters control the location of a stock
block model relative to the stock component's datum and when combined on a feature
page with certain other features provide some extra functionality for automating the
placement of a stock block that is not currently available in the standard VERICUT user
interface.

Return to Connecting the Features to VERICUT.

234
Custom Interface - Choice List/Radio Button
Parameter List

File Convert IGES Output File Type


Output File Format
Normal Direction
Surface Input Mode

PolyFix Input File Type


Output File Type
Output File Format

Surface Input File Type


Output File Type
Output File Format

VDAFS Output File Type


Output File Format
Normal Direction

Binary CL Input File Type

Export Model File Type


File Format
Output Color
Coordinates
Units
Process
Slice Direction

Colors Brightness

Properties Default Units


Display Resolution
Default Machining
Type
Base Cut Tolerance
On

235
Shade Copy Type
Method
Shading By
Orientation
Paper Size
Light Location

View Attributes View Type


Draw Mode
Background

Model Location Relative to X


Parent
Y
Z
Normals
Units
Visibility
Mixed Mode

Setup Toolpath Toolpath Type


Tool Change By

Motion Start At
Stop At
Drill Cycle
Tool Display
Cut Color Method
Control Point

G-Code Settings Programming


Method

Block Skip Apply Switch Value

4-Axis Sync Method

236
Apt Settings Default Toolpath
Units
RAPID Motion
GOHOME Motion
ROTATE
ROTABL
ROTHED
Philosophy
Angle Value
Direction

Machine Floor/Wall Orient


Ignore Collision
between Cutter and
Stock

Analysis AUTO-DIFF Stock Display


Design Display
Comparison
Method
Comparison Type
Normal Direction

OptiPath OptiPath Control

Return to Custom Interface - Choice Lists and Radio Buttons.

237
Custom Interface - Check Boxes
While in "author" mode, right-clicking on a checkbox feature on a feature page and
selecting Details, displays the window illustrated below. The title of the window is the
current text associated with the check box.
The tree that dominates the window is organized to reflect VERICUT's menu structure.
Each "leaf" in the tree represents an on/off parameter available in the standard VERICUT
user interface.
To connect a feature to a parameter, simply expand the tree till you find the on/off
parameter you are looking for, select it and click OK. You can also use these windows to
check on an existing associations, in which case you would use the Cancel button
afterwards.
Click on the window below to display a complete list of VERICUT parameters that are
available for check box features.

Check Box Feature Window


In the example window on the left a check box feature is bein
APT output file is generated corresponding to the processed G

Return to Connecting the Features to VERICUT.

238
Custom Interface - Check Box Parameter
List

File Convert Surface Project Rectangle

Binary CL Output Circles

Export Model Binary


Millimeter
Group By Color
Detect Scallop
Planes

Colors Recycle Cut Color

Properties Millimeter
Stock Consistency
Check
Model Export Cut
Mode

AutoSave In Process Cutter Change


# of Cuts
File End
Auto Error

Shade Copy Print Command


Annotation
Cutter Change
# of Cuts
File End
Auto Error
Color
Portrait
Add output file to
Report
Render
Specify image size

239
Shadows

VERICUT Solid Cutter Change


# of Cuts
File End
Auto Error

View Orient Zoom creates new


View
Standard Rotation
Image

Section Section on mouse


pick

Axes Component
Model
Machine Origin
Workpiece Origin
Coordinate System
Tool Tip Zero
Driven Point Zero
Active Coordinate
System

Info Status SubSystem

Position Record Number


Toolpath Record
Machine Axes
Tool Tip

Tool Record Number


Change Record
Sequence
Geometry
Description
Number
ID

240
Status Errors
Warnings
Time
Time %
OP Time
Distance
Distance %
Coolant

Feed Feedrate
OP Feedrate

Speed Sprindle
OP Spindle

OP Info Volume Removal


Rate
Chip Thickness

Graph Tool Use


Cutting Conditions

Model Model File Outward


Millimeter

Component Disable Auto


Attributes Direction
Reverse Direction

Import Offset Surface


Extend to Rectangle

Delete Material Update While


Simulating

Save Cut Stock Save With Features

Setup Motion Stop At Max Errors


Stop At Max

241
Warnings
No Animation
Check for Spindle
Off
FastMill
Ignore Undercuts
Display Holder in
Workpiece View
Tool/Fixture
Collision Only (no
cutting)
Calculate Min.
Cutter Extension

G-Code Settings Process Cutter


Comp.
Scan Toolpath Files
Ignore Data After
Column
Apply Acceleration
to Cycle Time

Block Skip Immediate


Switch 1
Switch 2
Switch 3
Switch 4
Switch 5
Switch 6
Switch 7
Switch 8
Switch 9

Turning RPM changes with


RAPID and CSS

Process Options Create Apt Output


File

Apt Settings Millimeter


MULTAX
Process Circles

242
Reverse Circles
Detect Chordal
GOTO's
Reset Tool Change
Process Unigraphics
or CATIA Matrix
Ignore
unrecognized Major
words

Rapid Motion Square

GOHOME Motion Retract

Angle Value Absolute

Detect 4-Axis
Rotary Motion

Machine Machine Simulation


On
Transparent Stock
Collision Detect
Overtravel
Detection On

Axis Priority Pos/Neg


Negative

Analys AUTO-DIFF Settings Stock Display


is
Design Display

Options Design Consistency


Check
Keep Design Solid
Disable Report
Report Uncut
Differences
Show Point Vectors
Constant Gouge

243
Check

Compare by Region On
Apply Regions Over
Entire Stock
Improve Cut Stock
Tolerance

Return to Custom Interface - Check Boxes.

244
Custom Interface - Buttons
While in "author" mode, right-clicking on a button feature on a feature page and selecting
Details, displays the window illustrated below. The title of the window is the current text
from the button.
The tree that dominates the window is organized to reflect VERICUT's menu structure.
Each "leaf" in the tree represents an action available in the standard VERICUT user
interface.
To connect a feature to a parameter, expand the tree until you find the parameter you are
looking for, select it and click OK. You can also use these windows to check on an
existing associations, in which case you would use the Cancel button afterwards.
A button can contain an icon in addition to, or instead of, the caption. An icon is derived
from a GIF or JPEG file which you select while in this dialog. An icon's height is limited
to 16 pixels. If you select a larger icon, it will be shrunk to fit within the button's height,
but its aspect ratio is maintained. The GIF or JPEG file will be copied to the book's folder
if necessary, so that the entire book can be handled as a unit. Use the Icon field, at the
bottom of the Button Feature window, to enter or select the image file to use.
Click on the window below to display a complete list of VERICUT parameters that are
available for button features.

Button Feature Window

In the example window on the left a button


feature is being associated with the a
request to browse VERICUT's help files.
When the user presses the button,
VERICUT Help will display.

Return to Connecting the Features to VERICUT.

245
Custom Interface - Button Parameter List

File User File New


Open
Save
Save As

In Process Open
Save
Save As

Working Directory

Convert IGES
PolyFix
Surface
VDAFS
Binary CL

Export Model

Edit Toolpath
File

Colors
Properties

Report Create Text Report


Create HTML
Report
Create PDF Report
Report Template
User-Defined Tags

Print
Shadecopy
Close Book
Exit VERICUT

246
View Layout One View
Left and Right
Top and Bottom
1 Left, 2 Right
1 Top, 2 Bottom
Four Views
Add View
Delete View
Cascade
Tile Horizontally
Tile Vertically
View to Back
Always in Front

Orient Dialog
XY
YZ
ZX
YX
ZY
XZ
H-ISO
V-ISO
Zoom In
Zoom Out
Fit
Fit All
Refine
Last Refine Display
Reverse
Reset

Attributes
Section
Select/Store View
Axes

Info Toolpath

247
Status
Machine Offsets
File Summary
VERICUT Log
Clear Logger

Model Model Definition


Auto Block
Component Tree
Load Stocks
Delete Material
Revolve Profile
Sweep Profile

Setup Toolpath
Motion
G-Code Settings
Variables
Apt Settings
Cycle Definitions
Coordinate Systems
Tool Manager

Control Open
Save
Save As
Words
Word/Address
Mdi
Settings
Advanced Control
Options

Machine Open
Save
Save As
Settings

Analysis X-Caliper

248
AUTO-DIFF Dialog
Apply

Comparator
Toolpath Review
Inspection Sequence
Die Sinking
Simulation

OptiPath OptiPath Control


OptiPath Manager
Compare Toolpath
Files

Help Browse
About

Simulation Reset Model


Rewind Toolpath
Single Step
Play to End

Return to Custom Interface - Buttons

249
Custom Interface - MDI Buttons and Numeric Fields

While in "author" mode, right-clicking on an MDI button feature on a feature page and
selecting Details, displays the window illustrated below. The title of the window is the
current text from the MDI button.

In the "SubSystem" field, enter the


index number of the subsystem (not
the subsystem name) that the MDI
Action command is to be applied to.
In the "MDI Action" field, enter the
command(s) to be executed when the
MDI button is pressed by the user,
MDI Button Feature Window then click OK.
You can also use the window to check
what command(s) are currently
associated with the MDI button, in
which case you would use Cancel
afterwards.
A default MDI button will contain the
icon ( ), in addition to the caption.
But you can provide another icon from
a GIF or JPEG file which you select
while in this dialog. An icon's height is
limited to 16 pixels. If you select a
larger icon, it will be shrunk to fit
within the button's height, but its
aspect ratio is maintained. The GIF or
JPEG file will be copied to the book's
folder if necessary, so that the entire
book can be handled as a unit.

While in "author" mode, right-clicking on an MDI numeric feature on a feature page and
selecting Details, displays the window illustrated below. The title of the window is the
current MDI command combined with the value from the MDI numeric field.

250
In the "SubSystem" field, enter the
index number of the subsystem (not
the subsystem name) that the MDI
Action command is to be applied to.
In the "MDI Action" field, enter the
command to be executed when the
MDI Numeric Feature Window value in the MDI numeric feature
field is changed or when the MDI
icon ( ) is pressed, then click OK.
Use the Decimal Places field to
specify the maximum number of
decimal places to display. For an
integer, use zero decimal places.
Once you have entered the desired
MDI Action command and specified
decimal places, click OK.
You can also use the window to check
what command and decimal place
value is currently associated with the
MDI numeric feature, in which case
you would use Cancel afterwards.
As with an MDI button, you can
change the icon used with an MDI
numeric field by specifying an
appropriate GIF or JPEG file.

Return to Connecting the Features to VERICUT.

251
Example - Automatic Stock Block Placement
The following example shows how you can use a custom user interface to automate the
placement of a stock block at the machine origin. This cannot be accomplished using the
standard VERICUT user interface.

The upper three numeric field features are


connected to the X, Y and Z parameters
respectively, located under Model --> Block
in the numeric field "Details" tree
representing the length, width and height of
a stock block. When the user changes one of
the values, all models in the stock
component are replaced by a single block
with the specified dimensions.
The lower three numeric field features are
connected to the X, Y, and Z parameters
respectively, located under Model -->
Relative Location in the same tree. When
the user changes one of these values, the
origin of the block ( the X min, Y min, Z
min corner) is positioned at the specified
offsets.

The three choice lists in the lower left


corner are connected to the parameters
located under Model --> Relative Location
in the choice list "Details" tree. These
features are unique to a custom interface
and do not correspond to any of the features
in the standard VERICUT user interface.
They can be used to locate any of the
block's corners, mid-edges or mid-faces to
the specified location. As shown in the
sample at the left, the center of the bottom
face of the block is designated as the block's
origin.
If a dimension of the block is changed, the
position of the block remains unchanged.
For example if block width is increased to
3, it would grow by 1/2 a unit in the +Y and
-Y directions, thereby keeping the center of
the bottom face position unchanged.

252
If you decide to use one or more of these choice lists, it is possible to limit the options
available to the user. Each list can contain up to four choices but not all choices need to
be included in the list. For example, the list for the Z axis has options for "Z", "Z Low",
"Z Mean" and "Z High". You may decide that "Z Mean" makes no sense in your
application and could omit that choice from appearing the list.
However, you should never omit the "X", "Y" or "Z" choices from the choice lists. These
are needed to position the block by specifying values directly in one of the numeric entry
fields because none of the predetermined positions is appropriate. For example, if the
block is 1.5 units high and the user enters a Z location of -0.5, the choice list should not
display "Z Low", "Z Mean" or "Z High". Instead it should be able to display just "Z".
You can of course alter the text of the choices, so instead of using "Z Low" and "Z High",
you could display "Z Minimum" and "Z Maximum", or "Bottom Face" and "Top Face" or
any other suitable text.
NOTE: The three parameters for automating the location of a stock block are not
applicable to other types of primitives, such as cylinders, cones, polygon files or IGES
files.

253
Creating Custom Interface Help Pages
Now that you have created and sized the notebook and added some features to the feature
pages, it is time to add some help pages to assist the user in using the custom user
interface to accomplish their job. Use help pages in the notebook to instruct the user on
how to use the features or guide then through a sequence of actions to accomplish the
required task.
A "help" page is easily distinguished from a "feature" page by the white background.
Only text and illustrations can be added to "help" pages. In order to add, remove or
modify text or add, remove or replace illustrations to a help page you must be in "author"
mode (F7 key).
If your notebook does not yet contain any help pages, or you need additional ones, use
the procedure described in Adding Pages to the Notebook to add them.
Help Page Layout:
Each help page is created blank. Click on the help page and begin to type your
instructions. Use the column of icons located on the right side of the notebook (when in
"author" mode) to position, place emphasis on portions of text or add "style" to your help
page. Use the bottom icon in the column to add illustrations to your help page. Each of
the icons is described in more detail below.
The first four icons are used to control the appearance of the text. They can be used in
two ways. As you type you can change the current "mode" by clicking on one of the
icons. Subsequent text will exhibit the change until you click the same icon again to
revert to regular characters. Or you can highlight an existing portion of the text and
update its appearance by clicking on one or more of the icons. A double click will
highlight a word. A triple click will highlight a line. You can also apply multiple style
types to your text as illustrated here using bold, italics and underline on the same text.
Bold
Italics
Underline
Text Color
Align Left
Center
Align Right
Add image
Insert Hyperlink
Bold — Use to make selected text bold.

254
Italics — Use to make the selected text in italics.

Underline — Use to underline the selected text.

Text Color — Displays a color pallet enabling you specify a color for text. Pick one of
the colored squares to proceed. The darker colors show up best on the white background
of a help page.

The next three icons are used to control the position of the text displayed on the page.
Align Left — Use to align the selected text to the left side of the page. This is the default.

Center — Use to center the selected text on the page.

Align Right — Use to align the selected text to the right side of the page.

Add Image — Use to add illustrations to your help page. The images used for
illustrations can be in GIF or JPEG format. When you select an image file it is copied to
the notebook folder so that all elements of the notebook are kept together. Each image
will be centered in the page and will be at its stored size. If you need to adjust the size of
an illustration, do so with an image editing software before using on your help page.

Insert Hyperlink — Use create a hyperlink between the highlighted text and an HTML
file. Highlight the desired text, select the Insert Hyperlink icon, then use the file
selection box that displays to specify the file to create the hyperlink to.

255
Sample Help Page:

Now that you have a complete custom VERICUT interface notebook, it's time to do some
testing.

256
Testing the Custom Interface
While a notebook is in "author" mode, (size displayed adjacent to the menu items and
columns of icons displayed on both sides) any changes to the content of features are not
communicated to VERICUT. To test that all features are connected to the correct
parameters and function as intended, the notebook needs to be in "user" mode. Toggle
between these modes with the F7 key on the keyboard
Unlike many of VERICUT's windows, the notebook window does not use the concept of
an Apply or OK button to invoke sets of changes. When the user changes the content of a
feature on a notebook's feature page, that change is sent to VERICUT immediately. For
many parameters, a change in value does not cause any immediate response. For
example, changing the number of cuts to be processed when the "Play" button is hit has
no effect until the toolpath is processed.
On the other hand, some feature changes will cause an immediate response from
VERICUT. For example, using a file selection feature associated with the user file will
cause VERICUT to retrieve the selected file immediately. Similarly, if you have numeric
fields associated with the dimensions of a block, changing one of the values will cause
VERICUT to immediately apply the change. With experience you will learn which
parameters will prepare for a future response and which ones will result in an immediate
response from VERICUT.
As you test the notebook try to view it as the targeted user will. Is the purpose of each
feature clear? Would some different wording in the labels make more sense, or perhaps
some extra labels? Could an illustration on a help page replace a bunch of words? Do the
views presented by the notebook's default user file display the process effectively or
could they be improved? Above all, is it simpler to use and save time for the user?
If you decide that refinements are needed in the default user file, closing the notebook
while in "author" mode causes VERICUT's standard user interface to be displayed so that
you can make those changes.

When you are satisfied with the notebook's behavior, it is time to make your custom
VERICUT user interface available for use.

257
Making the Custom Interface Available for
Use
Notebook folder and file descriptions:
All of the files that define a notebook are stored in a single folder, the name of the folder
being the name of the notebook. Some or all of the following file types may be present:
y HTML files for the help pages. Their names will be of the form "Pagexxx.html",
where "xxx" is the page number.
y GIF and JPEG files referenced by the HTML pages.
y XML files for the notebook and it's feature pages. Their names will be of the form
"Pagexxx.xml", where "xxx" is the page number.
y "Page000.xml" which contains information pertinent to the whole notepad.
Notably absent from the above list is the default user file for the notebook and any files
referenced by it. It may be beneficial to store the default user file and any associated files
in the notebook folder to simplify data management. That way, if a notebook's folder
location is changed, all of the files associated with it move with it.

Making the notebook available:


Deploying a customized notebook to a target user involves making the folder available.
This can be done by establishing a network mapping to the folder, or by copying the
folder to the user's machine. If the default user file and the files which it needs are not in
the same folder, you may find that the relocated notebook is unable to access the default
user file. If this is the case, on the target machine use the F7 key to briefly get into
"author" mode again, switch to the required user file and re-save the notepad. The user
file that is displayed at the time you save becomes the notebook's default.
You can also launch VERICUT each time with a custom user interface instead the
standard user interface by using the file customizer. bat to start the VERICUT session.
This file can be found in the \cgtech5x\windows\commands\ folder. The customizer .bat
file needs to be edited as follows to specify which custom interface notebook to use at
startup.
In the customizer.bat file locate the "start" command, shown below, at the end of the file.
%start_cmd% "%CGTECH_JRE%\bin\javaw" -Xms16m -Xmx64m -Xss4m -
classpath"%CGTECH_CLASSES%;%CGTECH_CLASSES%\CGTech.jar" VeriBook
%argstr%
Make sure that the next to the last parameters is VeriBook (not Vericut) indicating that
VERICUT should be started with a custom user interface instead of the standard user
interface.
Replace the last parameter "argstr" with the path to the desired custom interface
notebook folder.
Now simply use customizer.bat to start the VERICUT session with the specified
notebook instead of with the standard VERICUT user interface.

258
Using a VERICUT Custom User Interface
The following user interface is applicable to the VERICUT Mold & Die and VERICUT
Grinder products,as well as to any "custom" interface created with VERICUT
Customizer.

The user interface consists of two main parts, the "notebook" and the VERICUT main
window.

The Notebook
The notebook consists of a menu bar and two different types of pages. Click on the
upper page corners to page back in the notebook. Click on the lower page corners
to page forward in the notebook.
Menu Bar -
File:
Open— Displays the Select book's folder window allowing you to open
another custom interface notebook for editing or create a new notebook.
Recent— Displays a list of recently opened files. To open a file in the
list, select the desired file.
Exit VERICUT— Ends the VERICUT session.

259
Layout:

— Positions the notebook on the left side of the VERICUT main


window.

— Positions the notebook on the right side of the VERICUT main


window.

— Overlays the notebook on top of the VERICUT main window.


Left click on the notebook's header and drag to any position.

Help:
On VERICUT— Starts VERICUT Help.
About VERICUT— Opens a window that displays information about
the current VERICUT session.

Help Pages -
Help pages contain instructions, explanations and pictures to assist you in providing the
necessary information to VERICUT. Help pages are easily recognized by the white
background.
Feature Pages -
Feature pages contain features (buttons, text fields, choice lists, etc.) that enable you to pass
necessary information to VERICUT for processing. Each of the features on a "feature" page
is described on the previous "help" page. Feature pages are easily recognized by the gray
background.
Some features display another window enabling you to provide additional
information to VERICUT. Use the F1 key to display more information about
the displayed window.

VERICUT Main Window


The VERICUT main window is composed of six distinct areas, each with different user
interaction. The window header displays the VERICUT version and the current session
units (inch or millimeter). This window can be resized and/or moved like most other
windows, via dragging the window header, sides or corners.

260
To learn more about interacting with VERICUT through the main window components,
click on one the topics below.
Tool Bar
Graphics Area
Message Area
Animation Slider
Busy/OptiPath Lights
Progress Bar
Simulation Controls
Hint: Press "F1" in any VERICUT window to receive help on that window.

261
Introduction to VERICUT Reports
VERICUT Report provides the tools needed modify/create report templates enabling you
to generate "custom" reports.
Generate reports that only include information important to your particular work
environment, in a format that is most meaningful to the users of the report. Eliminate the
need to search through the wide range of information that is included in a more generic
"standard" report.

VERICUT Reports:

y enable you to generate reports using one of the "standard" report templates
supplied. The following "standard" report templates are included and can be
found in the "library" directory of your VERICUT installation:
inspection.VcTemplate - Use this template to create a basic inspection report
that includes the inspection sequence table and graphic showing the location
of the inspection points on the part. This is the default report template that
Inspection Sequence will use if no other template has been specified.

NOTE: Report template inspection.VcTemplate should only be used


for creating reports from the Inspection Sequence window. Using it to
create reports from other VERICUT applications will result in incorrect
data being displayed in the report.

vericut.VcTemplate - This is the default report template that VERICUT will


use if no other template has been specified.
vericut_basic.VcTemplate - Use this report template to create a report
containing overview information about the VERICUT session. Includes a file
summary, and a Tool Summary table and Tool Use graph for each toolpath.
vericut_optipath.VcTemplate - Use this report template to create a report
similar to the "basic" report but also includes OptiPath information.
vericut_shadecopy.VcTemplate - Use this report template to create a report
similar to the "basic" report but also includes shadecopy images specified
with File > AutoSave > Shadecopy tab.
vericut_full.VcTemplate - Use this report template to create a report similar
to the "shadecopy" report but also includes OptiPath information.

NOTE: The above five report templates should only be used for
creating reports using File menu > Create Report > ... in the main
VERICUT window. Using them to create reports from other VERICUT
applications will result in incorrect data being displayed in the report.

262
vericut_tools.VcTemplate - Use this template to create a tool library report.
This is the default report template that Tool Manager will use if no other
template has been specified.

NOTE: Report template vericut_tools.VcTemplate should only be used


for creating reports from the Tool Manager window. Using it to create
reports from other VERICUT applications will result in incorrect data
being displayed in the report.

y enables you to modify a "standard" report template by changing the content,


layout and/or format of the included information and save it as a "custom" report
template.
y enables you to produce "custom" report templates from "scratch". You decide the
format, layout and content that best meet your needs.
y provide the tools to include a wide variety of information from different sources.
Include text, tables or pictures. Extract information from the VERICUT user file,
include information from external files, or "generic tags" that will be updated with
information specific to a particular user file at the time that the report is created..

What is involved with creating a custom VERICUT report?


Creating and deploying a custom report for use by VERICUT users involves the
following steps. Click on each of the steps listed below for more information about each
step.
Set up "styles" to be used for the report template
Define "user defined tags" that will be included in the template
Create the page layout for the report template
Using the report template

263
Create Report
Location: File menu > Create Report, in the main VERICUT window.
File > Create Report, in the Inspection Sequence window.
File > Create Report, in the Tool Manager window.

Opens the Save VERICUT Report window enabling you to specify the /path/file name
for the report file to be created. If "User-Defined" information has not been previously
defined, (either using the User-Defined Tag Values window or during a previous use of
Create Report) VERICUT will then prompt you for any unspecified User-Defined Tag
values, then generate the report using the "current" report template. (See How)

Text — Use this option to create a report in text format.


HTML — Use this option to create a report in HTML format.
PDF — Use this option to create a report in PDF format. (PDF report generation
based in part on iText (www.lowagie.com/iText)).

264
Print View
Location: File menu > Print View

Toolbar shortcut:
Opens a window to print images in VERICUT view ports. Each view port is
automatically fit to the printable area and printed on a separate page. All view ports are
printed. Features on this window are standard print window features that enable you to
access printer settings, specify number of copies, etc. Consult your printer documentation
for more information.

265
Images

Record Movie
Location: File menu > Images > Record Movie

Toolbar short cut for recording images:


Opens a window to record images in a VERICUT Image file or AVI file. (See how)
Images in all view ports are recorded. Images can be recorded interactively in VERICUT,
or via batch processing. After recording is stopped, you can view the file via the File
menu > Images > VERICUT Playback or File menu > Images > AVI Playback function,
depending on the file type.
This window appears differently, depending on the Output Format choice.
VERICUT Image Record window features
AVI Image Record window features

NOTES:
The size of the graphics area directly affects the display size of the recorded Image
file. Make the VERICUT window larger to record larger images.
Recording animations captures all changes in the graphics area. Recorded tool paths
with lots of small motions can generate large Image files sizes. Consider using the
Animation Slider, located at the bottom of the VERICUT main window to reduce
Image file size.
AVI record is not intended for use with cascaded views.
AVI record does not support capture of the Profile view.

266
VERICUT Image Record window
These features are available when recording images in a VERICUT Image file. (See how)

Output Format=VERICUT—Format of the output image file is VERICUT Image file.


Filename—Name of the file to receive recorded images.

Snapshot Events group:

These options control when a snapshot image is recorded. Each selected event causes a
snapshot to be recorded when that event occurs.

Error—Record a snapshot when VERICUT detects an error.


Cutter Change—Record a snapshot when the cutter has been changed.
N Records—Record a snapshot after a specified number of tool path records have been
processed.
Processing Complete—Record a snapshot when tool path processing has been
completed.

267
Animation Control group:

These options determine when animation images are recorded, and how they will be
replayed.

Disabled—Do not record animation images.


Forward—Record animation images to play in the forward direction only.
Forward & Backward—Record animation images to play in forward or backward
direction.

Append Options group:

These options control appending images to an existing Image file.

Append—When active, appends recorded images to the end of an existing Image file.
Append Delay—When appending images, inserts the specified number of seconds of
delay prior to appending new images.

Pauses group:

Insert Stop—Inserts a stop point into the Image file. The stop point is used by the Stop
at Inserted Stop play back feature.
Insert Delay—Inserts the specified seconds of delay.
Record—Starts recording images based on current window settings, VERICUT window
size, shape, and layout. Recording must be stopped before the Image file can be viewed.
Stop—Stops recording. The Image file can be viewed via File menu > Images >
VERICUT Playback.
Snapshot—Records a single snapshot image.
Close—Closes the Image Record window.

268
AVI Image Record window
These features are available when recording images in an AVI file. (See how)

Output Format=AVI—Format of the output image file is an AVI file.


Filename—Name of the file to receive recorded images.

Recording Screen Area group:

These features control the screen area to record.

Start Left / Start Top—Identifies the start point (top-left location) of the screen area to
record.
Width / Height—Width and height (in pixels) of the screen area to record, as measured
from the top-left start point.
Select Region—Uses a rubberbanding box to indicate region to record. Left-click to
define the start point of the region, then move the mouse to trap the area to record. Press
<Esc> to interrupt rubberbanding.
Select All—Records all views.

269
AVI Frame Rates group:

These features set the rate at which to record image frames. Frame rate controls the speed
at which the AVI file plays back.

Playback Rate—Number of frames to record per second. Increasing the recording frame
rate causes the AVI file to play back faster, and decreases the file size.

Pauses group:
These features control the AVI recording process, and insert delay into the AVI file.
Pause / Continue—Pauses (or continues) AVI file recording. VERICUT motions
simulated after pausing are not recorded.
Insert Delay—Inserts the specified seconds of delay.
Record—Starts recording animation images based on current window settings,
VERICUT window size, shape, and layout. Recording must be stopped before the Image
file can be viewed.
Stop—Stops recording. The AVI file can be viewed via File menu > Images > AVI
Playback.
Snapshot—Records a single frame image.
Close—Closes the Image Record window.

270
Playback VERICUT Movie
Location: File menu > Images > Playback VERICUT Movie

Toolbar short cut for playing back VERICUT images:


Opens a "VERICUT Player" window to load and play back an Image file recorded by the
File menu > Images > Record Movie function. (See how) Images are played in a separate
"image player" window enabling simultaneous access to the VERICUT main window
and its functions. The size and view layout of the image player window is as recorded.
However, this window can be moved, or minimized using standard window controls.
Recorded machining status is also seen when the Status window is open while playing.

File menu—Functions in this open new Image files, compare existing Image files, and
provide control over playing back recorded images.
y Open—Open an existing Image file.
y Compare—Opens a window to configure the player to compare two Image files.
Features enable you to play both Image files simultaneously, and identify
differences between them.
y Playback Options—Opens a window for controlling playing back recorded
images. (See Playback Options window features)
y Close—Closes the VERICUT Player window.
Playback (VCR) icons—These icons control playing and rewinding recorded images. To
see what is associated with an icon, position the mouse cursor over the icon and a tip
appears. Playback VCR icons:
Icon: Name: Function:
Play Play images in the forward
direction
Next Snapshot Advance to the next snapshot

Skip to End Advance to file end

Stop Stop playing back images


(or press Escape
key <Esc>)
Play Backwards Play images in the backward
direction
Previous Snapshot Rewind to the previous
snapshot
Skip to Start Rewind to the Image file
beginning

271
Playback Options window features:
Configure group:
Speed—Controls how fast images are played back. Actual speed varies, depending on
computer hardware. Stop the play back to access this feature.
Snapshot Delay—Number of seconds to pause after displaying a snapshot.

Control group:
These options provide additional stop control by event, or the ability to play in a
continuous loop (without stopping). Options:
y Stop at Error—Stop replay at an error detected by VERICUT.
y Stop at File End—Stop replay when the end of a toolpath file end has been
reached.
y Stop at Cutter Change—Stop replay when the cutter has been changed.
y Stop at Every N Events—Stop replay after a specified number of events (frames)
have been recorded.
y Stop at Inserted Stop—Stop replay on a stop inserted by pressing "Insert Stop"
on the File menu > Images > Record Movie window.
y Loop—Play in a continuous loop until interactively stopped via pressing

Stop , or pressing the Escape key <Esc>.

272
Playback AVI Movie
Location: File menu > Images > Playback AVI Movie

Toolbar short cut for playing back VERICUT images:


Opens an "AVI Player" window to play back an AVI file recorded by the File menu >
Images > Record Movie function. (See how) Assuming your system has an AVI player
installed, the AVI images are played in a separate "image player" window enabling
simultaneous access to the VERICUT main window and its functions. The size and view
layout of the image player window is as recorded.

273
View Capture window
Location: File menu > Images > View Capture and File menu > AutoSave > View
Capture tab : Properties

Toolbar short cut for accessing View Capture:


Opens a window to capture VERICUT images and format them for printing or importing
into desktop publishing applications. View Capture can also output printer-formatted files
that you can move to other computers or printing devices. Images can be captured and
output interactively or automatically (via AutoSave), or via batch processing. When
configuring this window for future use or batch processing, press OK (instead of
Output) to save the window configuration without outputting a View Capture image file.
Hint: Avoid having to re-configure this window by creating a master Project file
containing the modified View Capture values.

Attributes tab — Features on this tab are used to configure the attributes for formatting
captured VERICUT images.
Postscript Settings tab — Features on this tab provide information about centering and
annotating PostScript format images on the printed page.
Render tab — Features on this tab enable you to specify the output size of "rendered"
images.
OK — Saves the View Capture window settings and closes it without outputting an
image file.

274
Output — Outputs the current VERICUT image to the specified file. File format is
determined by the View Capture window configuration.
NOTE: Output is not applicable when setting up File menu > AutoSave > View
Capture tab : Properties.
Cancel — Closes the View Capture window without saving setting changes or outputting
an image file.

275
View Capture window, Attributes tab
Location: File menu > Images > View Capture

Toolbar short cut for accessing View Capture:


Features on this tab are used to configure the attributes for formatting captured
VERICUT images.

Type — Type of format in which to capture VERICUT images. Printer-ready and


electronic formats are available. Options:

y PostScript — Postscript format.


y EPSF — Encapsulated PostScript File.
y TIFF — Tag Image Format File.
y JPEG — JPEG compressed format. (JPEG image support based in part on the
work of the Independent JPEG Group.)

Method — Method of coloring the captured image. Options:

y Standard — black and white only


y Grayscale — black and white with shading
y RGB Color — Red-Green-Blue values for each pixel
y Palette Color — Red-Green-Blue color tables
y CMYK Color — Cyan-Magenta-Yellow-Black color tables

276
Shading By — Method of shading black and white images. Options:

y Intensity — Shade by light intensity only, for example: the brightest yellow color
is the same shade of gray as the brightest blue color.
y Color — Shade by color differences and light intensity.

Orientation — Controls image orientation on the printed page: Landscape or Portrait.


Output File — Use to specify the name of the file to receive image data when the
Output button is pressed. Enter the \path\file name in the text field or click on Browse
and use the Save File selection window to specify the file.

NOTE: When images are output via File menu > AutoSave, the file names
specified on the AutoSave, View Capture tab are used instead.

Add output file to report — When toggled "On", and Output is pressed, the output
JPEG images are available for use in "standard" VERICUT reports.

NOTE: Add output file to report is not available when setting up File menu >
AutoSave > View Capture tab : Properties.

Render — Use to toggle the Render feature on and off. When Render is toggled "on"
and the Output button is pressed, the active view will be rendered and a JPEG file will
be output with the name specified in the Output File field. (see how) Pressing the "Stop"
button during rendering will stop the process.
By default, the width and height of the active view is used for the size of the rendered
image. Use Specify image size on the Render tab to specify a different width and/or
height for the rendered image.

y Currently, JPEG is the only supported output.


y Method, Shading By and Orientation are not applicable to Render.
y AUTO-DIFF models, Travel Axis, design components/models and Temp Stock
components are not supported by the Render feature .

NOTE: Generating a "rendered" image can take considerably longer than


generating a standard View Capture image.

277
Standard View Capture image Rendered image

278
View Capture window, Postscript Settings tab
Location: File menu > Images > View Capture

Toolbar short cut for accessing View Capture:


Features on this tab provide information about centering and annotating PostScript format
images on the printed page.

Center / Margins options—Controls image placement on the printed page. Options:

y Center—Center image in the middle of the page.


y Margins—Place image according to specified margin dimensions (see below).

Left / Right / Top / Bottom—Margin dimensions, as measured from the corresponding


edges of the paper.
Paper Size—Size of paper to print.
Annotation—When active, includes annotated text with the image. Annotation includes
the current date, tool path file name, tool path record number being processed, and user
specified text.

Tip: If you want to add a note that uses special characters add an "escape" backslash
character ("\") before each special character. Example:

To enter this annotated text => Part Number (1234) ((due date
12/01/00))
Type this in the Annotation field => Part Number \(1234\) \(\(due
date 12\/01\/00\)\)

279
View Capture window, Render tab
Location: File menu > Images > View Capture

Toolbar short cut for accessing View Capture:

Features on this tab enable you to specify the output size, whether or not to use shadows,
and light source location for "rendered" images.

Specify image size — Toggle "On" to use the Width and Height values specified below
for creating an image using Render. By default, the width and height of the active view is
used for the size of the rendered image.
Width — Use to specify the width for a rendered image.
Height — Use to specify a height for a rendered image.
Shadows — Toggles Shadows On/Off.
Light Location — Use to specify one nine fixed light locations. Choose from: Top Left,
Top, Top Right, Left, Center, Right, Bottom Left, Bottom, and Bottom Right.
View Angle — This field enables you too define the view angle. Valid range is from 1 to
80 degrees.

280
AutoSave
Location: File menu > AutoSave

Toolbar short cut for accessing AutoSave:


Opens a window to configure VERICUT to automatically save In Process files, View
Capture image files, (such as JPEG, PS, EPSF, or TIFF files) or VERICUT Solid (.vct)
files. Saving is based on user specified events or when VERICUT detects errors during
tool path processing. Auto-saving is especially useful to save data during batch
processing.

In Process tab—Features on this tab control automatic saving of In Process files.


View Capture tab—Features on this tab control automatic saving of ShadeCopy image
files.

281
VERICUT Solid tab—Features on this tab control automatic saving of VERICUT Solid
files.
OK — Saves all tab settings and closes the AutoSave window.
Cancel — Closes the AutoSave window without saving settings.

282
In Process tab
Location: File menu > AutoSave window
Project menu > Output window

VERICUT toolbar short cut:

Features on this tab control automatic saving of In Process files, or "IP files".

Auto Save options — These options control when VERICUT automatically saves IP
files. Click on the box to the left of the event to toggle On/Off. Each selected event
causes a file to be saved when that event occurs. Options:
y Cutter Change — Save an IP file when the cutter has been changed.
y # of Cuts — Save an IP file after a specified number of cuts. Enter the number of
cuts in the # of Cuts text field.
y File End — Save file at the end of tool path processing. Choose either End of
each File (end of each toolpath file) or End (end of the NC program) from the
pulldown list.

283
In Process File — Use to specifiy the base name for IP files saved. Enter the \path\file
name in the text field or click on Browse and use the selection window to specify the file.
Unique file names are maintained by appending the tool path number and line number of
the record causing the event to the end of the base file name. Naming convention for
auto-saving files is: <IPfilename>n1_n2.ip where "<IPfilename>" is the name
specified in the In Process File field, "n1"=sequential tool path number, and
"n2"=number of the record causing the auto-save event.
The following examples assume the AutoSave (or Output) window configuration shown
below.

Example 1: One tool path processed, tool change on record #10 => test1_10.ip
Example 2: Two tool paths processed, tool change on record #10 in both tool paths =>
test1_10.ip (from tool change in tool path #1), test2_10.ip (from tool change in tool path
#2)
Example 3: Two tool paths processed, tool path one tool change on record #10, tool path
two tool change on record #5 => test1_10.ip (from tool change in tool path #1), test2_5.ip
(from tool change in tool path #2)

284
Auto Error On — When active, VERICUT automatically saves an IP file when an error
is detected.
In Process File — Specifies the base name for IP files saved due to errors. Similar to In
Process File for the Auto Save options (see above), unique file names are maintained by
appending the line number of the record causing the error to the end of the specified IP
file name.

285
View Capture tab
Location: File menu > AutoSave
Project menu > Output

VERICUT toolbar short cut:

Features on this tab control automatic saving of View Capture image files (JPEG, PS,
EPSF, or TIFF).

Print Command — When toggled "Off", sends graphical data to the specified
ShadeCopy File. When toggled "On", executes the print command that sends raw
graphical image data to the printer.
By default, the "prshade" command executes the "prshade" command file containing
operating system commands typically used to print images on your computer. If printing
fails, correct the entry in the Print Command field, or use an ASCII text editor (NOT a
word processor) to edit the "prshade" command file to have the proper print command for
your computer/printer.

286
Properties — Opens the View Capture window to access settings for file formatting and
printing.

Auto Save options — These options control when VERICUT automatically saves
ShadeCopy files. Click on the box to the left of the event to toggle On/Off. Each selected
event causes a file to be saved when that event occurs. Options:
y Cutter Change — Save a ShadeCopy file when the cutter has been changed.
y # of Cuts — Save a ShadeCopy file after a specified number of cuts. Enter the
number of cuts in the # of Cuts text field.
y File End — Save a ShadeCopy file at the end of tool path processing. Choose
either End of each File (end of each toolpath file) or End (end of the NC
program) from the pulldown list.
y ShadeCopy File — Use to specify the base name for ShadeCopy image files
saved as a result of Auto Save options described above, when the Print
Command checkbox is toggled "Off". Enter the \path\file name in the text field
or click on Browse and use the selection window to specify the file. The naming
convention used for saved files is as described for IP files-see In Process tab for
details.

Auto Error options — These options control when VERICUT automatically saves
ShadeCopy filesdue to errors.
y Auto Error On—When toggled "On", VERICUT automatically saves a
ShadeCopy image file when an error is detected.
y ShadeCopy File — Use to specify the base name for ShadeCopy image files
automatically saved as a result of errors detected when AutoError On is toggled
"On", and the Print Command checkbox is toggled "Off". Enter the \path\file
name in the text field or click on Browse and use the Save File selection window
to specify the file. The naming convention used for saved files is as described for
IP files-see In Process tab for details.

287
VERICUT Solid tab
Location: File menu > AutoSave
Project menu > Output

VERICUT toolbar short cut:

Features on this tab control automatic saving of VERICUT Solid (vct.) files.

Auto Save — These options control when VERICUT automatically saves VERICUT
Solid files. Click on the box to the left of the event to toggle On/Off. Each selected event
causes a file to be saved when that event occurs. Options:
y Cutter Change — Save a VERICUT Solid file when the cutter has been changed.
y # of Cuts — Save a VERICUT Solid file after a specified number of cuts. Enter
the number of cuts in the # of Cuts text field.
y File End — Save a VERICUT Solid file at the end of tool path processing.
Choose either End of each File (end of each toolpath file) or End (end of the NC
program) from the pulldown list.

288
VERICUT Solid File — Use to specifiy the base name for VERICUT Solid files saved
due to Auto Save options. Enter the \path\file name in the text field or click on Browse
and use the selection window to specify the file.

AutoError — Use these options to specfy whether or not VERICUT automatically saves
VERICUT Solid files when an error is detected.
y On — Click on the box to the left to toggle On/Off. When active, VERICUT
automatically saves a VERICUT Solid file when an error is detected.
VERICUT Solid File — Use to specifiy the base name for VERICUT Solid files saved
when AutoError is active. Enter the \path\file name in the text field or click on Browse
and use the selection window to specify the file.

NOTE: The naming convention used for saved VERICUT Solid files is the same as
described for IP files-see In Process tab for details.

289
Recent Files
Provides a list of recently opened Project files or User files. To open a file in the list,
select the desired file.
List contents are stored in the VERICUT Preference file.

290
Exit
Location: File menu > Exit
Exits (quits) the VERICUT program. Any files that were opened during the VERICUT
session, such as the Log file, Image file, etc. are automatically closed. You can also exit
VERICUT by clicking "X" at the top right corner of the VERICUT main window.
Session information is not automatically saved by VERICUT upon exiting. It is the
responsibility of the user to decide if session information should be saved before exiting.

291
Edit menu

Text File
Location: Edit menu > Text File

Opens a text editor window-just load any ASCII text file and start editing. The following
is a general description of the features available for searching and editing text and tool
path files throughout VERICUT. The features available in a particular window may vary
depending on the purpose of the window that they appear in.
Menu Bar:
The menu bar located at the top of the window provides easy access to major functions.
Each menu contains groups of related functions. Left-click on any menu name to display
the list of functions in that menu. Click on the function in the menu you want to use. The
name of the current file is also displayed in this area.

File:
Open — Open a file.
Save — Save the current file.
Save As — Save the current file under a different name.
Print — Print the file.
Exit — Close the window.

Edit:
Cut — Cuts the highlighted text in the file listing and puts it in the paste buffer.
Copy — Copies the highlighted text in the file listing to the paste buffer.
Paste — Puts the contents of the paste buffer at the location of the cursor in the
file listing.
Restore — Restores the highlighted changes to the original state.

Icon Bar:

The items in the Icon Bar enable you to search for, and/or replace, specific items in the
file listing, print the file, or exit the window. Moving the cursor over the icon will display
name of the option. Each feature (from left to right) is described below.

Open File — Opens a file selection window enabling you to select another file.

Save File — Save the current file.

292
Line Number or Search Text — Use this text field to enter a line number, or a
string of text, to search for.
Goto Line Number — Moves the cursor in the file listing to the line
number specified in the Line Number or Search Text field.

Search Forward — Searches forward in the file listing for the text string
specified in the Line Number or Search Text field.
Search Backward — Searches backward in the file listing for the text
string specified in the Line Number or Search Text field.
Replacement Text — Use this text field to enter a "replacement text" string.

Replace One — Replace one occurrence of text string in the Line Number
or Search Text field (or the highlighted text in the file listing) with the text string
in the Replacement Text field.

Replace All — Replace all occurrences of the text string in the Line
Number or Search Text field with the text string in the Replacement Text field.

Undo Highlighted Changes — Restores the highlighted changes to the


original state.
Print — Print the file.

Close Window — Closes the window.

293
NC Program (Edit)
VERICUT Users:
VERICUT Location: Edit menu > NC Program

Toolbar short cut for accessing the NC program editor:


Selecting Edit menu > NC Program displays a list of all toolpaths and subroutines in
the project file. Choosing one of the tool paths/subroutines opens a text editor window
with the selected tool path/subroutine file loaded and ready for editing.

Mold and Die Users:


Mold and Die Location: Analyze, View Files, Print page > Edit the Tool Path File

Notebook Feature:
Opens a text editor window with the "current" tool path file loaded and ready for editing.

Cutter Grinder Users:


Cutter Grinder Location: Analyze, View Files, Print page > Edit Grinding Program

Notebook Feature:
Opens a text editor window with the "current" grinder program file loaded and ready for
editing.

Standard text editing features are provided, such as: copy/cut, paste, search, etc. For more
information on using the editing features, see Text File under Edit menu.
Warning: Editing the tool path file can cause undesirable results, especially when edits
are made to portions of the tool path which have already been processed by VERICUT.
These edits can cause the tool path record number pointer to be out of sync with the
edited tool path file. In these cases it is recommended to rewind the tool path file after
editing, and restart the simulation with the last unedited record prior to the first
addition/deletion.

294
Colors
Color window
VERICUT Users:
VERICUT Location: Edit menu > Colors

Toolbar short cut for accessing the Color window:

Mold and Die Users:


Mold and Die Location: Other Settings page > Colors

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Other Settings page > Colors

Notebook Feature:

Opens a window to define the colors seen in VERICUT. Colors are changeable at any
time. The affect of changing colors is immediate.

295
Assign tab — Features on this tab are used to assign Error, Reset Cut and Background
colors.
Cut Colors tab — Features on this tab assign colors to machine cuts made in the
workpiece.
Define tab — Features on this tab define colors seen in VERICUT, and control light
brightness.

OK — Saves tab settings and closes the VERICUT Color window.


Apply — Saves tab settings and leaves the VERICUT Color window open.
Cancel — Closes the VERICUT Color window without saving tab settings.

296
Color window, Assign tab
VERICUT Location: Edit menu > Colors

Toolbar short cut for accessing the Color window:


Features on this tab are used to assign Error, Reset Cut and Background colors.

Error — Color for highlighting unsafe machining conditions (default: "Red"). The "error
color" will help you identify the following potentially dangerous situations:

y Material removed while cutting too fast (known as a "fast feed" error)
y Cuts in clamps, fixtures, bolts, and other hardware holding the workpiece
y Material removed by non-cutting portions of the tool, such as: tool holders,
extensions, etc.
y Gouges in a design model (via AUTO-DIFF)
y
Reset Cut — Color applied to all cuts in the workpiece when a Reset Cut Color
operation is performed (see below). By default this color is set the same color as the stock
model to give the appearance of uncut stock, however, any defined color can be selected.

297
Floor, Ceiling, Wall — Colors of the floor, ceiling and walls displayed in a machine
view when Background is set toWalls in the View menu > Attributes window. A sample
machine is shown below with the floor, ceiling and walls in the background. The tile
affect on the floor is created by alternating the Floor and Ceiling colors.

Shaded Background — Use to specify the color that will be displayed when the view
Background attribute is set to Shaded.
Reset Cut Color — When selected, the color of all cuts in the workpiece are changed to
the single color specified by Reset Cut (see above).

298
Color window, Cut Colors tab
VERICUT Location: Edit menu > Colors

Toolbar short cut for accessing the Color window:

Features on this tab assign colors to the machine cuts made in the workpiece. The items
displayed on this tab will vary depending on the Color Method selected.

Color Method — Method of determining colors used to shade machined cuts. Options
are:

Cut Color Table — Cut color is determined by the Cut Sequence/Color list
defined in the Cut Color Table.

Cut Seq. / Color list — List of colors used for material cut with a safe
cutting feed rate (less than the Fast Feed threshold). The cut color list
associates colors with cut sequences in the NC program file. A new cut
sequence is assumed when a tool with a different shape is loaded for cutting.
All portions of the cutting tool shape are considered for differences. When
the number of cut sequences exceeds the number of cut colors defined in the

299
table, Recycle Cut Color determines the cut color for the remaining tools
(see below).
Double-click on the cut sequence number in the table to edit it. Double-click
on a color in the table and select from the pull-down color list to change a
color. Add or remove colors from the pull-down list using the Shade Colors
list feature on the Color window, Define tab.
Add, Delete — Adds (or deletes) cut colors in the list.
Recycle Cut Color — When selected, recycles colors in the cut color list
when the tool path contains more tools than cut colors defined. For example,
assume that 4 cut colors are defined. When tool 5 is encountered VERICUT
recycles cut color 1, tool 6 uses cut color 2, and so on. When this option
cleared, the last defined cut color is used for cut sequences that follow the
last defined cut sequence color. Using the example above, tool 4, 5 and 6
would receive the cut color defined for cut sequence 4.

Tool Color — Cut color is determined by the tool color property stored in a
VERICUT Tool Library.

Feed Range Color — Cut color is determined by the feed rate programmed in the
NC program file.

Feed Range / Color list — List of colors used for material cut within a
specified feed rate range. The cut color list associates colors with feed rates
in the NC program file. Using the sample table shown above, cuts using a

300
feed rate between 0 and 25 will be displayed Aquamarine. Cuts using a feed
rate between 25 and 49 will be displayed Light Steel, and so on.
Double-click on the Feed Range number in the table to edit it. Double-click
on a color in the table and select from the pull-down color list to change a
color. Add or remove colors from the pull-down list using the Shade Colors
list feature on the Color window, Define tab.
Add, Delete — Adds (or deletes) cut colors in the list.

TP File Color — Cut color is determined by the Cut Sequence/Color list defined in
the Cut Color Table method described above except that the Cut Sequence changes
as the NC program file changes instead of when the tool changes. If a Project file
only uses one NC program file, then all cuts will be the same color.

301
Color window, Define tab
VERICUT Location: Edit menu > Colors

Toolbar short cut for accessing the Color window:


Features on this tab define colors seen in VERICUT, and control light brightness.

Shade Color list — List of colors that can be used to shade solid objects seen in
VERICUT, such as: models, cutting tools, and machined cuts (maximum 128 colors).
The number of shade colors also affects shade quality. The color band at the bottom of
the window displays the shade variations of the selected color in the list, as impacted by
the total number of defined colors. Once defined, assign the colors to solid objects using
the features on the Assign tab and the Cut Colors tab.
Add, Delete — Adds (or deletes) colors in the list.
Red-Green-Blue slidebars — Control the amount of red, green, and blue color
components mixed to define a color. The exact value is shown in the field to the right of
each slidebar (0=none to 255=maximum).
Color list — Opens a window of pre-mixed colors selectable for background,
foreground, and shade colors.
Brightness — Controls the amount of light for shading solid objects. Options are: High,
Normal and Low.

302
Flat Colors group:
Background — Select this option to change the color of the graphics area background
when View menu > Attributes: Background is set to "Flat". You can also change the
background to display a shaded color, or machine views can display ceiling, floor, and
walls.
Foreground — Select this option to change the color of items drawn on top of the
VERICUT display, for example: coordinate system axes, lines indicating the bounding
region of selected models/components, etc.
The Background and Foreground colors should be different, or foreground-colored
items may "blend in" with the background.

303
View menu

Layout
Location: View menu > Layout

The options in the Layout menu control how many views of the VERICUT model are
seen, and how they are arranged. All views are contained within the VERICUT main
window. The size and orientation of the model in each view is individually controlled.
View port size and layout are saved in the user file.

One view is considered by VERICUT to be the "active view". A view is made active by
clicking in it, and is designated by a colored window header. Many VERICUT functions
are effective only in the active view, including most viewing functions.

Standard—Sets views of the VERICUT model to one of the standard view layout
choices. By default standard view layouts are tiled, but you can change this using other
functions in the Layout menu, or via standard window management features, such as
dragging, resizing, etc.

Add View—Adds a view. You can add as many views as desired. What is seen in a view
(workpiece, machine, etc.) is determined by the view attributes- ref. View menu >
Attributes.

Shortcut: You can quickly change the attributes or orientation of a view by right-
clicking in the view, and selecting from the displayed menu.

Delete View—Deletes a view. You can also delete a view via clicking "X" at the top
right corner of the view window.
Cascade—Cascades views in an overlapping arrangement. Note that cascaded view
layouts are not saved by VERICUT.
Tile Horizontally—Tiles views in a horizontal arrangement.
Tile Vertically—Tiles views in a vertical arrangement. Examples follow.

304
Cascaded-

Tiled horizontally-

Tiled vertically-

View to Back—Moves the "active" view to the back. This function can also be accessed
using the right mouse button in the active view.
View to Front—Moves the selected view to the front. Selecting "View to Front" displays
a list of all available views allowing you to select the desired view to be moved to the
front even if it is obscured by other views in the graphics area.
Always in Front—Makes the active view remain "always in front" until it is specifically
moved to the back or until another view is specified as "always in front". This function
can also be accessed using the right mouse button in the active view.

305
View Orient window
Location: View menu > Orient

Toolbar shortcuts:

Opens a window to orient the view, including: rotate, zoom, pan, reverse, etc. You can
view machining from any angle or distance, and change the view at any time during the
simulation. Views of the workpiece, NC machine, or cutting tools seen in the Tool
Manager are oriented in the same manner, as described by the sections that follow. In
general, click in a view to make it active, then change view orientation as required. View
rotations are described with respect to the "view coordinate system".

306
Dynamic viewing options—These options use mouse actions to dynamically orient the
object in view. Mouse actions are different, depending on the active option-see the table
below for details. Dynamic viewing options are also available on the VERICUT Toolbar.
Dynamic viewing options:

Icon: Name: Action:


Dynamic X Rotation Horizontal rotation- drag mouse up/down
in direction to rotate
Dynamic Y Rotation Vertical rotation- drag mouse left/right in
direction to rotate
Dynamic Z Rotation Screen plane rotation- drag mouse left to
rotate CCLW, right for to rotate CLW
Dynamic XY Rotation Horizontal/vertical combined rotation-
drag mouse up/down/left/right in direction
to rotate
Dynamic Pan Pan/translate- drag mouse in the direction
pan
Dynamic Zoom Zoom/magnify- drag mouse up to zoom
in, down to zoom out

Shortcut: The following keys provide instant access from the keyboard to
dynamic viewing options (press and hold keys while dragging): Dynamic
Zoom—<Ctrl>, Dynamic Pan—<Shift>, Dynamic XY—<Ctrl> + <Shift>.
Mouse actions are the same as above. You can also use the "Up" or "Down"
arrows on your keyboard to zoom in or out.

Standard drawing view buttons- XY, YX, YZ, ZY, ZX, XZ, V-ISO, H-ISO—Orients
the object in the selected standard drawing view and automatically fits the object in the
view.
Rotation features:
Angles—Absolute rotation about the view coordinate system X Y Z axes, respectively.
The three values are separated by spaces.
Increment—Degrees of incremental rotation to apply when a rotation button is pressed
(see below).
Rotation buttons (X+/X-, Y+/Y-, Z+/Z-)—axis and direction in which to apply
incremental rotation specified by the Increment value.
Spin Center—Specify a point to be used as the center of rotation during dynamic
rotations. Click in the Spin Center field so that it becomes active, then either enter XYZ
values (separated by spaces) in the field and click on the Apply button or click on a
position in the view to specify the Spin Center point. The values are applied to the
"active" view. If a workpiece view is the active view, the coordinates are relative to the
origin of the workpiece coordinate system. If the "active" view is a machine view, the
coordinates are relative to the origin of the machine coordinate system.

307
Press to display the Spin Center marker and activate the point for the active view.
To de-activate Spin Center point, press the button again. You can specify a different
rotation point for each view. When you close the View Orient window, the Spin Center
markers will no longer be displayed but the activated Spin Centers will remain active.
When you use one of the dynamic rotation features described above in a view with an
active Spin Center, the Spin Center point will be used as the center of rotation instead of
the view coordinate system origin.

Shortcut: You can quickly change the spin center location by right-clicking in the
view, select Spin Center from the displayed menu, then select the desired position
in the graphics area.

Orient on Feature—Resets the view, normal to the feature selected in the graphics area.
The modified view is centered on the position of the selection vector.
Zoom creates new View—When toggled on, creates a new view for the zoomed area
instead of modifying the current view. Also changes the icon in the toolbar to the Zoom
(create new view mode) icon.

Shortcut: You can quickly toggle between the two Zoom modes (standard or

create new view) by right-clicking on the Zoom to Box icon , or , in the


toolbar.

Static viewing buttons—These buttons use various mouse actions to zoom, fit, and
reverse the object in view. See the table below for details. Static viewing options are also
available on the VERICUT Toolbar.

Static viewing buttons:


Button name: Toolbar Icon: Action:
Zoom (standard mode) Left-click and move mouse
(Zoom to Box) to trap area to zoom (press
<Esc> to interrupt
rubberbanding)
Zoom ( with Zoom creates Similar to Zoom (standard
new View toggled On) (right click on Zoom to mode) described above
Box) except a new view is created
to display the zoomed area.
Zoom In / Zoom Out Zooms in/out approx. 20%
each time clicked

308
Fit Fits object in active view
(left click)
Fit All Fits objects in all views
(right click)
Refine Refines the display to
(Refine Display) improve image quality
Reverse Reverses viewing direction,
as if you stood behind the
object (see also: "reverse"
VERICUT command record)
none Restores the last refined
(Last Refine Display) display

Shortcut: You can quickly reverse or orient the model in one of the defined views
by right-clicking in the view and selecting from the displayed menu.

Reset — Resets the view to the last orientation accepted by pressing Apply, or as it was
when the Orient window was opened.

309
View Attributes window
Location: View menu > Attributes
Opens a window to control the attributes of a view, such as: what is seen in a view, light
source, shading, etc. In general, click in a view to make it active, then change attributes
as required. Each view has its own view attributes.

View Type—Controls what is seen in a view. Options are:


y Workpiece—Displays the stock workpiece and machining that occurs on it. This
view supports full inspection capabilities on the machined part, including X-
Caliper measurements and AUTO-DIFF model comparisons.
y Machine—Displays a 3-D NC machine, when defined. The uncut stock can be
seen, however, material removal does not occur in this view type.
y Machine/Cut Stock—Same as above, except material removal does occur. (Does
not support machined part inspection-use a Workpiece view type for this
activity.)

310
y Profile—Displays a 2-D profile view of a turned workpiece in a G-code tool path
simulation, as if it were spinning and sectioned along the turning axis. The profile
is created when cutting begins.
y
NOTE: Ensure a Spindle component is defined in the machine and turned on by
codes in the G-code tool path file.

Draw Mode—Controls how machine components are displayed. Toolbar short cuts for

Draw Shaded , and Draw Lines , draw mode:

Options:
y Shade—Shaded solids
y Lines—Wireframe
y Hidden—Wireframe with back-facing lines hidden
y Mixed—shade, lines or hidden, as defined by the component's Mixed Mode
attribute (Ref. Project menu > Model Setup > Define: Component Attributes tab)

Light—I J K vector direction in which the light source points. The three values are
separated by spaces, as described in the view coordinate system. A second light source
shines on the opposite side of the model.
Background—Controls the background seen in a view. Colors for backgrounds are
defined via the Edit menu > Colors function. Options:
y Flat—Monochromatic.
y Shaded—Light-to-dark shading.
y Walls—Walls, floor, and ceiling-machine views only.

Sample backgrounds: Upper—Shaded, Lower left—Walls, Lower right—Flat

311
Shortcut: You can quickly change the view type and background by right-
clicking in the view, and selecting from the displayed menu.

Attach Comp.—Attaches the view point and line of sight for a view to the selected
component. By default, a Workpiece view is attached to a Stock component, thus the
workpiece remains stationary while the tool moves about it. Similarly, by default in a
Machine view the view is attached to the machine's Base component, thus the machine
base appears stationary while its axes move. Whatever component is selected as the
attach component becomes stationary in the simulation, while all other objects are
simulated as moving relative to that component.

Shortcut: You can quickly change the component the view is attached to by
right-clicking in the view, and selecting from the displayed menu.

Translucent—

Toolbar short cut:


Controls when the stock model is displayed as translucent (can be seen through).
Translucent can only be applied to an active workpiece view. Once the attribute is set,
more than one workpiece view can be displayed "translucent". It is only valid with a
"refined display".
All VERICUT functions can be used with a translucent view. However, when the model
is rotated, sectioned, or zoomed, the resulting view is a solid. Use Refine Display to re-
display the translucent view. Almost any model feature can be seen using combinations
of Translucency, Reverse, Section, and Zoom.

NOTE: Translucent cutters may intermittently disappear while cutting a


translucent model. Display the tool as a solid to eliminate this "flashing" affect.

y Off— Translucency is off and the workpiece is displayed as a solid (can not be
seen through).
y Normal— Causes material in front of a machined surface to become translucent.
When a machined surface is not present behind material, the material is displayed
in solid.
y Extended— Similar to Normal , except when a machined surface is not present
behind material, the material is still displayed with translucency.

312
Translucent "Off" Translucent "Normal" Translucent
"Extended"

Shortcut: You can quickly change Translucent settings by using the toolbar short

cut: Use the left mouse button on the icon to toggle Translucent "on" or
"off". When the Translucent icon is toggled "on", use the right mouse button to
quickly toggle between Translucent "Normal" and Translucent "Extended" modes.
The change is immediately applied to the "active" workpiece view.
Accelerated (OpenGL)— Toggles Hardware Graphics Acceleration On/Off.
Accelerated (OpenGL) is only applicable to Machine and Machine/Cut Stock
views.
You can also right-click in a Machine or Machine/Cut Stock view and use
Accelerated (OpenGL) in the displayed menu to toggle Hardware Graphics
Acceleration On/Off
Perspective View— This feature is only available when Accelerated (OpenGL) is
toggled "On". When Perspective View is toggled "On", a perspective view is
displayed in Machine and Machine/Cut Stock views.
Field of View Angle— This feature is only available when Accelerated
(OpenGL) and Perspective View are both toggled "On". It enables you to control
the Field of View Angle of the perspective view. Move the slider to the left to
decrease the view angle and to the right to increase it.
Clipping Plane—This feature is only available when Accelerated (OpenGL) and
Perspective View are both toggled "On". It enables you to control the position of
the "clipping plane" in the perspective view. Move the slider to the left to move the
"clipping plane" closer to the plane of the screen. Move it to the right to move the
"clipping plane" further into the view (away from the plane of screen). All objects
between the "clipping plane" and the plane of the screen are blanked from the
display. For example, this feature could be used to blank parts of the machine (like
doors) to better view the part on the machine.
Cut Stock Display— This feature enables you to control the way that the Cut
Stock is displayed (and therefore the processing speed). Moving the slider to the
left will display a "sharper" image of the Cut Stock but will result in longer
processing times. Moving the slider to the right results in a Cut Stock display with
a less sharp image, but processing time will be faster.

313
Section window
VERICUT Users:
VERICUT Location: View menu > Section

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Views and View Layouts page > Display Section

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Change Views and View Layouts page > Display Section
Notebook Feature:

Opens the Section window enabling you to define section planes through a VERICUT
model in a workpiece view. You can define as many section planes as desired, in any
orientation. (See how) Section plane orientation and distance are described with respect

314
to the active coordinate system. Restore the original model by clicking anywhere off the
part in the workpiece view, or click Restore on the Section window. You can continue
cutting on the sectioned model, or restore the original (unsectioned) model. Machine cuts
are applied to the entire model regardless of how it is displayed after sectioning..
Section on mouse pick—Immediately sections the model through the point selected with
mouse. The section plane orientation is controlled by the characteristics of the plane
highlighted in the Section planes table.
Section planes table:
Table of defined section planes.
On—Toggles on and off to activate/deactivate defined section planes in the table. Only
the active planes will be used to determine the portion of the model that will be displayed
after the section planes are applied.

NOTE: The on/off state of this toggle is only used in conjunction with the Section
button below. It has no effect on which plane/direction vector is displayed in the active
workpiece view. The plane /direction vector that is displayed in the active workpiece
view is determined by the plane that is highlighted in the section planes table.

Pl Type—Specifies section plane orientation. Standard options include six orientations


that are perpendicular to axes of the active coordinate system (POS X, POS Y, POS X,
NEG X, NEG Y and NEG Z). POS and NEG define the direction of the normal vector
of the section plane with respect to the coordinate system axis. The normal vector points
away from the portion of the part that will be displayed when it is sectioned. Using the
Custom option, you can define a section plane at any orientation by entering the I, J, and
K components of the desired normal vector in the Normal I J K fields (see below).
Normal I, Normal J, Normal K—Specifies the I J K coefficients of a vector
perpendicular to the desired section plane. These values are automatically set when Pl
Type is set to one of the six standard options and cannot be changed. When Pl Type is
set to Custom, the values can be changed to define the direction vector of the desired
section plane. Values entered do not have to define a unit vector (vector length=1). Any
combination of values can be entered to define the normal vector.
Distance—Distance along the normal vector (see above), measured from the active
coordinate system origin to the desired location of the section plane. Key in a value or
pick a point on the model with the mouse. A positive value is measured along the
specified normal vector, a negative is measured in the reverse direction.
Start / End—When selected, defines the starting and ending planes for automatic
sectioning. (See "Automatic sectioning features" below).
The following actions can be accomplished by either selecting the associated button in
the Section window or selecting it from the pulldown that results from using the right
mouse button while the cursor is in the section planes table.
Add - Use to add additional section planes to the table.
Delete - Use to delete the highlighted section plane from the table.
Reverse - Use to reverse the direction vector of the highlighted plane to display the
opposite side of the model after sectioning..

315
Automatic sectioning features:
This group of features displays a series of animated sectioned views, beginning with the
plane identified as the "Start" plane (Start selected), and ending with the "End" plane
(End selected). The start plane direction vector must point away from the end plane and
the end plane vector must point away from the start plane for proper automatic
sectioning to take place. Automatic section cuts are equally spaced.
Cuts—The number of equally spaced section planes that will automatically be
applied between the start and end section planes.
Delay—Seconds of delay to pause between each automatic section cut display.
Auto Section—Begins the automatic sectioning sequence. To interrupt an

automatic sectioning, press Stop, or click in the VERICUT main window and
press the Escape <Esc> key.
Section—Applies the active section plane(s) in the Section planes table to the model. The
resulting "sectioned" model is displayed in all workpiece views.
Restore—Restores the solid model from the sectioned display. The sectioned model is
for display purposes only. When cutting has been performed with a sectioned view
displayed, the results are the same as if the entire model was displayed..
Close—Closes the Section window.

316
Select/Store View window
VERICUT Users:
VERICUT Location: View menu > Select/Store

Mold and Die Users:


Mold and Die Location: Change Views and View Layouts page > Custom Views

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Change Views and View Layouts page > Custom Views
Notebook Feature:

Opens the Select/Store View window enabling you to store, modify and apply custom
views. (See how) Defined views are shown in the "View List". Each custom view is
stored with the View Type and orientation of the view that was active at the time it was
stored. There is no limit to the number of views you can store.

317
VERICUT Shortcut: You can quickly reverse the orientation, or change the view
to one of the standard or stored custom views by right-clicking on the view in the
VERICUT graphics window, then selecting the desired view name using Select
View option in the displayed menu. This shortcut is not available for Mold and
Die.

View List—List of defined views.

VERICUT Shortcut: You can quickly Add, Delete, or Activate views in the View
List by right-clicking on a view and selecting desired action from the displayed
menu. This shortcut is not available for Mold and Die.

Activate—Applies the View Type and orientation of the stored view highlighted in the
View List to the active view in the VERICUT graphics window.
Modify—Modifies the View Type and orientation of the highlighted view in the View
List to match those of the active view in the VERICUT graphics window.
Reset—Resets the active view in the VERICUT graphics area to the View Type and
orientation that it had when the Select/Store View window was opened.
Add—Adds a new view, after the highlighted view, to the View List. The new view will
have the same View Type and orientation as the active view in the VERICUT graphics
window. Double click on the view name to rename the view. Hit <enter> when you are
through editing.
Delete—Deletes the highlighted view from the View List.
Delete All—Deletes all views from the View List.

318
View Axes window
Location: View menu > View Axes

Opens a window to control when various axes and coordinate systems are displayed.
Axes are created by VERICUT and are stored in the Preferences file. Coordinate Systems
(CSYS) are user defined and are stored in the "setup". Once displayed, axes and
coordinate system symbols remain displayed until toggled "Off" in the View Axes
window. Solid lines indicate that an axis is parallel or pointing out of the screen. Dashed
lines indicate that an axis is pointing into the screen.

Shortcut: You can also change axes displayed by right-clicking in the view, and
selecting from the Display Axes list in the menu that displays.

319
AXES

Use the Color Pallet icons , to specify a "global" display color for each type
of axes described below.
Component — When selected, displays XcYcZc axes that representing the
coordinate system of a component. Each component has its own local coordinate
system.
Model — When selected, displays XmYmZm axes that represent the coordinate
system of a model. Each model has its own local coordinate system.
Machine Origin — When selected, displays XmcYmcZmc axes that represent the
coordinate system in which an NC machine is defined.
Workpiece Origin — When selected, displays XwpYwpZwp axes that represent
the coordinate system to which Stock, Fixture, and Design components are
connected.

- In a simulation where a machine IS NOT defined, such as when processing


APT-CLS tool path files, the workpiece coordinate origin is the origin of
the non-moving "Base" component to which Stock, Fixture, and Design
components are connected. In previous VERICUT versions, this was
known as the "World coordinate system" (XwYwZw axes).
- In a simulation where a machine IS defined, such as when processing G-
code tool path files, the workpiece coordinate origin is the origin the
machine component responsible for carrying the Stock, Fixture, and
Design components.

Tool Tip Zero — When toggled "On", displays the XToolTipYToolTipZToolTip


axes that represent where the tool tip ( the VERICUT control point) of the "active"
tool would be located, relative to the "active" stock, if all linear axes were
positioned at zero. The display is based on the actual Machine/Control
configuration and therefore may be displayed as a right hand axis, a left hand axis
or possibly even a non-orthogonal axis. If no tool has been loaded, VERICUT
assumes a zero length tool.
The following should be considered when using this feature:
Tool Tip Zero is only applicable when processing G-Code Data.
The Tool Tip Zero display is based on the "active" tool. If the machine being used
has more than one tool component, the correct tool component must be set as
active before valid results can be achieved.
The Tool Tip Zero display is based on the "active" stock. If more than one stock
component on the machine, the correct stock component must be set as active
before valid results can be achieved.
The Tool Tip Zero display shows where the tool tip is and therefore may not be
particularly useful when programming a 5-axis machine in "gage-length"
mode.

320
Driven Point Zero — When toggled "On", displays the "driven point" ( identified

by the symbol) and the XDrivenPointYDrivenPointZDrivenPoint axes.


The "driven point" is only displayed in the Machine View. The initial "driven
point" position is determined based on the following:

If there are no rotary/turret components attached to the "active" tool component,


the initial driven point is the origin of the "active" tool component.
If there is 1 rotary/turret component attached to the "active" tool component, the
initial driven point is the origin of the rotary/turret component.
If there are 2 rotary/turret components attached to the "active" tool component,
the initial driven point is the intersection of the two rotary axes.
If there are more than 2 rotary/turret components attached to the "active" tool
component, the initial driven point is the origin of the highest level
rotary/turret component.

The following offsets are then applied to the initial "driven point" (adjusted as
needed for RTCP):
Gage Offset
Tool Nose Compensation Offset
Tool Length Compensation Offset
Turret Offset
Gage Pivot Offset
Pivot Offset (RTCP)
3D Tool Length Comp Offset (Fanuc)

The Driven Point Zero axes represent where the driven point of the "active" tool
would be located, relative to the "active" stock, if all linear axes were positioned at
zero. The display is based on the actual Machine/Control configuration and
therefore may be displayed as a right hand axis, a left hand axis or possibly even a
non-orthogonal axis. The Driven Point Zero axes are displayed in Workpiece,
Machine and Machine/Cut Stock views.

The following should be considered when using this feature:


y Driven Point Zero is only applicable when processing G-Code Data.
y The Driven Point Zero display is based on the "active" tool. If the machine
being used has more than one tool component, the correct tool component
must be set as active before valid results can be achieved.
y The Driven Point Zero display is based on the "active" stock. If more than one
stock component on the machine, the correct stock component must be set as
active before valid results can be achieved.

321
y Some machine configurations do not conform to initial "driven point" rules
described above and therefore will not produce useful results. An example of
this would be Maho-Phillips machines using a two position head. The initial
driven point could not be calculated correctly resulting in invalid results.
y Dual turret machines typically will not have the active tool defined for both
turrets, therefore the initial driven point can not be calculated correctly
resulting in invalid results.
y Some machine/controller combinations, like the one in the sample file
bos5vm01.VcProject, may not produce the results that you might expect, but
based on the above definitions, the displayed results are accurate.

Set Axes — When selected, all "axes" are toggled "On" and will be displayed.
Clear Axes — When selected, all "axes" are toggled "Off" and will not be
displayed.

NOTES:
1. Axes display status is stored in the Preferences file. Axes that are displayed
when exit a VERICUT session are displayed the next time you run
VERICUT.
2. Axes are drawn in the Foreground color by default. Use the Color Pallet icon

, for each axes type to change the display color of the individual axes.

COORDINATE SYSTEMS (CSYS)


Display Active Coord. Sys. — When toggled "On", the active coordinate system
will be displayed.
Coordinate System Table — The Coordinate System Table displays all coordinate
systems defined for the "current setup". Each CSYS in the table has a checkbox
that toggles "On" and "Off" , indicating whether it is displayed or not. By default,
CSYS are drawn in the Foreground color. The color of the CSYS can be changed
using the Color Pallet button, described below. The background color of each
Coordinate System Name field indicates the color that the CSYS will be
displayed.
Set CSYS — When selected, all "coordinate systems" are toggled "On" and will be
displayed.

Color Pallet button — Use to define the display color for a


"coordinate system". To specify a color for a particular CSYS, click on the
Coordinate System Name field, in the Coordinate System Table, so that it
becomes highlighted. The background color of the Coordinate System Name field
indicates the current color of the CSYS. Click on the Color Pallet button and select
the desired color from the color pallet that displays.
Clear CSYS — When selected, all "coordiunate systems" are toggled "Off" and
will not be displayed.

322
NOTES:
1. Coordinate System display status is stored in the "setup".
2. Axes are drawn in the Foreground color by default. Use the Color Pallet
button , in the Coordinate Systems section of the View Axes
window to change the display color of individual coordinate systems.

See also "VERICUT axes and coordinate systems" in the Using VERICUT section.

323
View Toolbar window
Location: View menu > Toolbar

Opens a window to control when the Toolbar is displayed and the icons it contains.
Toolbar icons provide provide quick and easy access to the most commonly-used
VERICUT functions/features. The Toolbar can be closed, opened, or customized at any
time. (See how)

Display Toolbar—When selected, displays Toolbar groups on the VERICUT main


window.
Set All, Clear All—Turns on (or off) display of all Toolbar icons. Corresponding options
are all selected (or cleared).

Toolbar groups:

Icons: Toolbar Functions (click for more info)


name:
Close Close Toolbar
Open Project
File
Save Project
New Project (See NOTE 1 )
Open In Process File
Save In Process File
Working Directory
Edit NC Program

324
Custom Interface
Motion
Simulation
G-code Settings
Settings
APT Settings
No Machine Simulation
AutoSave
Save Machine
Configuration
Save Control
Machine Settings
Component Tree
Word Format
Word Address
Control Settings
Control Advanced Options
Zoom to Box / Zoom creates new
Static View
View (See NOTE 2 )
Zoom In
Zoom Out
Fit / Fit All
Refine Display (See NOTE 3 )
Last Refine Display (See NOTE 4 )
Reverse
OptiPath
Cut Options
Standard/FastMill Cut Modes
Delete Detached Stock
MDI
Dynamic X/Y/Z/XY Rotation
Dynamic
Dynamic Pan
View
Dynamic Zoom
Open Machine
Project
Open Control
Setup Models
NC Program
Tools
Output
Coordinate Systems
Project Tree
AUTO-DIFF
Analysis
X-Caliper
Toolpath Review
Die Sinking Simulation
Comparator
Workpiece View
Display
Machine/Cut Stock View
Draw Shaded
Draw Lines

325
Section
Translucent
Color
View NC Program
Info
Status
Graphs
VERICUT Log
Clear Log File and Logger
Image Record
Images
Image Playback / AVI Playback
(See NOTE 5 )
View Capture
Print View

NOTES:
1. Right-click on the New Project icon to toggle between (Inch) and
(Millimeter) mode.

2. Right-click on the icon to toggle between (Zoom to Box) and (Zoom


creates new View) modes.
3. Refine Display — When selected, refines the display to be a high-quality image.
Refining the display can useful to see model details after model manipulation,
such as zooming, rotating, panning, etc. This action occurs automatically any time
cutting is started.
4. Last Refine Display — When selected, returns a workpiece view to the last
refined display image. This action is useful to quickly start cutting after
manipulating the workpiece for viewing: zooming, rotating, panning, etc.
5. Image Playback/AVI Playback — The active icon is set automatically based on
the active image record output format (ref. File menu > Images > Record Movie).
6. Clear Logfile and Logger — Clears both the VERICUT Log File and the Logger
(Message Logger).

For information about the other VERICUT functions accessed by Toolbar icons, click on
the links above or refer to the function names in the VERICUT Menus and Features
section of VERICUT Help.

326
Resolution
Location: View menu > Resolution

Controls the quality of cut model display. Increasing resolution displays a more accurate
representation of the cut model, and requires more computer resources and processing
time to display and manipulate the model. A coarse display resolution is automatically
used when dynamically manipulating the model, such as rotation, zooming, etc. When the
dynamic action is finished, the display is upgraded to the previous resolution.
Options:
Manual — A display resolution which allows most models to be manipulated with
acceptable performance and display quality.
Auto — Automatically sets display resolution based on viewing distance from the
model. Resolution automatically increases when you zoom closer to see details on
the model, and decreases as you zoom out.

327
Look & Feel "Metal" example

328
Look & Feel "Motif" example

329
Look & Feel "Windows" example

330
Look & Feel "Windows Classic" example

331
Look & Feel "Text Larger" example
The following example shows the Text Larger feature at maximum size (14 point font).
Notice the text in the menu bar, the View Toolbar window and the message logger

332
Look & Feel "Text Smaller" example
The following example shows the Text Smaller feature at minimum size (6 point font).
Notice the text in the menu bar, the View Toolbar window and the message logger.

333
Dynamic Controls
Location: View menu > Dynamic Controls

View menu > Dynamic Controls options enable you to use the same mouse actions
while in VERICUT, that are required to perform dynamic pan, zoom or rotate in each of
the supported CAD systems. This parameter is saved in the Preferences file.

CATIA — Use CATIA's mouse action conventions for dynamic pan, zoom and rotate.
Pro/E — Use Pro Engineer's mouse action conventions for dynamic pan, zoom and
rotate.
Unigraphics — Use Unigraphics' mouse action conventions for dynamic pan, zoom and
rotate.
VERICUT — Use VERICUT's standard mouse action conventions for dynamic pan,
zoom and rotate.
Wildfire — Use Pro Engineer Wildfire's mouse action conventions for dynamic pan,
zoom and rotate.

The following table summarizes how each dynamic feature was implemented for each
CAD system.

CATIA Pro/Engineer Unigraphics VERICUT Wildfire


Pan Middle Hold Ctrl key, Hold Shift Hold Shift Hold down
mouse Right mouse key, Middle key, any SHIFT, the
button, drag button, drag mouse mouse button, middle
button, drag drag mouse
(or, Middle button, and
& Right drag the
mouse mouse.
button, drag)
Zoom Hold Hold Ctrl key, Hold Ctrl Hold Ctrl Hold down
Middle Left mouse key, Middle key, any CTRL, the
mouse button, drag: mouse mouse middle mouse
button, click Down or Left for button, drag button, drag: button, and
Left or larger (or Left & Up for larger drag the
Right Up or Right for Middle Down for mouse
mouse smaller mouse smaller vertically.
button, button, drag
drag:
Up for
larger
Down for

334
smaller
Rotate Hold Hold Ctrl key, Middle Hold Shift & Hold down
Middle Middle mouse Mouse Ctrl keys, the middle
mouse button, drag button, drag any mouse mouse button
button, hold button, drag and drag the
left or Right mouse.
mouse
button, drag

To change the dynamic controls behavior:


1. From the View menu, select Dynamic Controls.
2. Choose the CAD System that you want VERICUT to emulate.

335
Info menu

NC Program (Info)

VERICUT Users:
VERICUT Location: Info menu > NC Program

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Analyze, View Files, Print page > Display Tool Path Text

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Analyze, View Files, Print page > Display Grinding
Program Text
Notebook Feature:

336
Opens a window containing the tool path file being simulated. In this window, you can
scroll through the entire file to see all the records, search for text forward and backward,
print, and more (see features). An arrow pointer indicates the current tool path record
being processed. The window is updated when a new tool path file is processed, such as
when a list of tool paths are simulated. (Ref. Project menu > NC Programs).
The NC Program window is also one of the dockable windows enabling you to dock it
inside the VERICUT main window if you choose.
Tip:
You can edit the tool path file using the Edit menu > NC Program function in
VERICUT, or Analysis and Viewing page > Edit the Tool Path File in Mold
and Die.

337
Status

VERICUT Users:
VERICUT Location: Info menu > Status

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Preview and Optimize page > View Optimization Info
While Cutting

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: View Simulation page > View Info While Grinding
Notebook Feature:

Opens a window that provides status information about the simulation, and what would
be occurring on the NC machine. Status information includes: tool path record being
processed, machine and tool tip locations, information about the cutting tool, machining
conditions, errors and warnings detected by VERICUT. The Status window can be left
open for monitoring, minimized, closed and opened at any time. Information displayed is
configurable, and is updated after each tool path record is processed. You can re-
configure the window at any time.
The Status window is also one of the dockable windows enabling you to dock it inside
the VERICUT main window if you choose.

338
Configure — Displays the Status window in configuration mode enabling you to
specify status features that you want displayed in the Status window. Click on the icon to
enter configuration mode. Click the icon again to return to the normal display mode.

Close Window — Closes the Status window.


Tips:
y Status is recorded by the File menu > Images > Record function, and can be seen
in the Status window when playing back the Image file.
y You can send status information to a text Status file. To accomplish this, set the
CGTECH_STATUS environment variable to the name of the file before or when
VERICUT is executed.

339
Status window, configuration mode
The Status window, in configuration mode, enables you to select the items you want
displayed in Status window. Click in the box to the left of each feature you want included
in the Status window display. When toggled "On", a checkmark is displayed. Click on the
checkmark to toggle "Off " the feature.

The following features are available for display in the Status window:

SubSystem — When a machine with more than one subsystem is in use, this
option controls which subsystem status to show.
Program — The name of the current NC program.

340
Program Rec.# — The line number of the current NC program record.
Program Record — Current NC Program record being processed. Both the record
text and sequential line number in the file are shown.
Change Rec.# — The line number of the last tool change record.
Change Record — The last tool change record processed. Both the record text and
sequential line number in the file are shown.
Machine Axes — Locations of machine axes resulting from processing G-Code
NC Program data.
Local Axes — The display will be similar to the Machine Axes (only showing the
axis that exists for that subsystem). The contents of the "Local Axes" fields will
represent the current X, Y, Z, A, B, C, U, V, W, A2, B2, C2 axis within the local
coordinates. Typically, this will correspond to the values entered in the MCD file
(except when specifying machine coordinates, or incremental values).
Tool Tip — Current X Y Z tool tip location and I J K tool axis orientation with
respect to the active tool path coordinate system.
Tool Sequence — Sequential number of the last tool change event.
Tool Number — Tool number in use (if specified). Examples follow.

Tool path type: Sample tool chg Status window


record: "Number":
G-code data T10M6 10
APT CUTTER/... none
APT PPRINT/VERIC none
UT-TC...
APT LOADTL/1 1
UG CLS LOAD/TOOL,4,. 4
..

Tool ID — ID of a tool retrieved from a VERICUT Tool Library file, if any. A


blank field indicates the current tool did not come from a tool library.
"OVERRIDE" indicates that the current tool has been specified via the Override
feature. If the ID differs from the Number field value described above, the tool
was specified via a tool list.
Tool Geometry — Cutter shape geometry. The method used to define the cutter
shape is shown in square brackets "[ ]" followed by the description. "PROFILE"
indicates an profile type of cutter definition.
Tool Description — Description of a tool retrieved from a VERICUT Tool Library
file. A blank field indicates a description for this tool was not defined in the library,
or the tool did not come from a tool library.
Errors — Quantity of errors detected by VERICUT. A blank field indicates no
errors detected. Consult the Log file for details about the errors.

341
Warnings — Similar to Errors above, except applies to warnings detected.
Time — Time anticipated to machine the part (as simulated by VERICUT). To
calculate anticipated machining time, VERICUT records time for tool motions
based on specified cutting feed rates and rapid rates.
Time % — Percentage of time in feed rate mode. This value can be helpful when
judging tool path efficiency. For example, a high value suggests an efficient tool
path, since a value less than 100 percent means that the tool is moving at rapid feed
and is probably not removing material.
Distance — Tool movement distance in inches or millimeters, depending in the
VERICUT session configuration.
Distance % — Percentage of tool movement distance in feed rate mode. Similar to
the Time versus Time% relationship described above, this value can also be
helpful when judging tool path efficiency.
Feedrate — Current programmed feed rate. A blank field indicates no records that
control feed rate that have been processed.
Spindle — Current programmed spindle speed. A blank field indicates no records
that control spindle speed that have been processed.
Coolant — Current programmed coolant condition. A blank field indicates no
records that control coolant that have been processed.
Motion Type — Rapid / Linear / CW / CCW / Thread / Nurbs / Poly
Abs/Inc — Absolute / Incremental
Motion Plane — XY / YZ / ZX
Units — Inch / Metric
Spindle Mode — CSS / RPM
Compensation — On / Off
Cycle — Off / Drill / Face / Deep / Tap /Bore / Mill / Thru / Bore Orient / Bore
Drag
Interpolation — None / Polar / Cylindrical
OptiPath Time — Time anticipated to machine the part with an optimized tool
path file. This field is only updated when the current tool path if being optimized
by OptiPath. To estimate machining time saved by OptiPath, compare this value
against the Time field value.

NOTE: OP Time does NOT consider feedrates output as a result of


Acceleration/Deceleration optimization adjustments.

OptiPath Feed — Optimized feed rate, as calculated by OptiPath.

342
OptiPath Spindle — Optimized spindle speed, as calculated by OptiPath.

The following features are in effect when OptiPath Mode is set to On, Prompt
While Cutting or Learn From NC Program. They report maximum volume
removal rate and chip thickness for each cut calculated by OptiPath for the
programmed feedrate.
Volume Removal — Volume Removal Rate is calculated for any Optimization
Method and for any tool valid for OptiPath.
Chip Thickness — Chip Thickness is calculated only if the Optimization Method
for the current tool is either Chip Thickness, or Chip Thickness and Volume
Removal. Chip Thickness is not calculated when OptiPath optimizes by any other
method. When OptiPath Mode is set to Learn From NC Program, Chip
Thickness is calculated only for tools, which have a convex profile.

343
Graphs window
VERICUT Location: Info menu > Graphs

VERICUT toolbar short cut:

The Graphs window enables you to display a Tool Use graph showing information
related to tool use and/or the Cutting Conditions graph showing selected cutting
conditions.

Common Features:

Time Interval — Use to specify the time interval represented by the Tool Use graph
display. Use the Time Interval text field to specify the time interval represented by the
Tool Use graph.

/2 — Use to reduce the displayed time interval by a factor of 1/2.

X2 — Use to increase the displayed time interval by a factor of 2.

344
Configure — Displays the Graphs window in configuration mode enabling you to
specify graph display characteristics and features. Click on the icon to enter configuration
mode. Click the icon again to return to the normal display mode.

Close Window — Closes the Graphs window.

Tool Use Graph:

When toggled "On", the Tool Use graph is displayed which shows the machining time
spent by each simulated tool. Each tool that cuts the part is shown in the graph with its
cut color. Tool changes are indicated by a spike in the graph line. Positioning the mouse
cursor on or above a graph line displays data about that tool. A 4-axis turned part has 2
graph lines; one for each turret. Machines with additional heads/sub-systems will have a
graph line displayed for each. A gap in a graph line indicates idle time spent waiting for a
turret/sub-system to synchronize. Positioning the mouse cursor above a gap in a the graph
displays the amount of idle time.

Tool Use graph features:

Sample Tool Use graphs:

Tool Use graph from a milling NC Program:

345
Tool Use graph from 4-axis merged turning NC Program:

Cutting Conditions Graph:

When toggled "On", the Cutting Conditions graph is displayed which shows changes in
the selected cutting condition features. The picture below shows the Cutting Conditions
graph display for 4-axis merged turning NC Program, with the Feed Per Minute and
Spindle Speed features toggled "On".

346
Cutting Condition graph features:
Select any of the following "cutting condition" features to be displayed in the
Cutting Conditions graph. Each feature can be toggled On/Off at any time and the
graph will be immediately updated.

Depth — Depth of cut.


Width — Width of cut.
Volume Removal Rate — Volume removal rate based on programmed
values.
Chip Thickness — Chip thickness based on programmed values.
Feed Per Minute — Feed per minute based on programmed values.
Feed Per Tooth — Feed per tooth based on programmed values.
Feed Per Revolution — Feed per revolution based on programmed values.
Spindle Speed — Spindle speed.
Surface Speed — Surface speed.
Contact Area — The area of the tool that is in contact with the material.
OP Volume Removal Rate — Optimized volume removal rate, as
calculated by OptiPath.
OP Chip Thickness — Optimized chip thickness, as calculated by OptiPath.
OP Feed Per Minute — Optimized feed per minute, as calculated by
OptiPath.
Op Feed Per Tooth — Optimized feed per tooth, as calculated by OptiPath.
OP Feed Per Revolution — Optimized feed per revolution, as calculated by
OptiPath.
Show Tool Change — Use to show tool changes in the Cutting Conditions
graph. Tool changes are represented by a vertical line, in the cut color, at the
point of the tool change.

347
Graphs window, configuration mode
The Graphs window, in configuration mode, enables you to specify graph display
characteristics and features to be graphed. Many of the features are identical to the ones
in the Graphs window and are described there.

Tool Use — When toggled "On" (check mark displayed), displays the Tool Use
graph which shows the machining time spent by each simulated tool. Each tool that
cuts the part is shown in the graph with its cut color. Click in the box to the left of
Tool Use to toggle the graph On/Off.
Cutting Conditions — When toggled "On" (check mark displayed), displays the
Cutting Conditions graph which shows changes in the selected cutting condition
features. Click in the box to the left of Cutting Conditions to toggle the graph
On/Off. Select any of "cutting condition" features to be displayed in the Cutting
Conditions graph from the list below the graph area.
Color Pallets — Use the color pallet associated with each cutting condition feature

348
to specify the color that is to represent the feature in the graph. Click on the icon to
display the color pallet for your color selection.
Min/Max values — Use the Min/Max values associated with each cutting
condition feature to specify the lower/upper limits of the range of values
representing the vertical component of the graph (see the picture below).
Show Tool Change — Use to show tool changes in the Cutting Conditions graph.
Tool changes are represented by a vertical line, in the cut color, at the point of the
tool change (see the picture below).
Set All — Select all available features to be displayed in the Cutting Conditions
graph.
Clear All — Clear all selected features.

Sample Cutting Conditions graph:

349
Machine Offsets
VERICUT Location: Info menu > Machine Offsets

Opens a window that displays the values that are set for each machine offset and whether
the particular machine offset is currently active. If you "Single Step" through the
toolpath, the displayed values update at the end of each motion. When you are using
"Play to End", the displayed values are updated each time you "Stop" processing or
when processing stops at the end of the toolpath. The Machine Offsets window is
intended for debugging purposes only. The window displays current values set for each
offset and whether the offset is currently active. You cannot modify the values directly in
the Machine Offsets window. The values must be edited in the table or macro in which
they were originally set.

The offsets are grouped into 4 categories: Work& Shift, Tool, Other, and Total
Offsets, as shown in the Category column in the window above. Each Category can
consist of a number of different machine offsets and are displayed in the Offsets column.
The remaining columns indicate the offset values that are set/applied for each machine
axis. Each particular offset will only displayed if it contains non-zero values. If all offsets
within a Category are zero, then the Category will not be displayed. The exception to this
rule is the Total Offsets Category which will always be displayed.

350
This window also contains a series of flags associated with offsets and transformations.
SubSystem — All values displayed in the Machine Offsets window are specific to a
particular subsystem. If the machine configuration has more than one subsystem, use this
feature to select the desired subsystem.

Offset Categories:
Work and Shift:
These offsets are in a separate category because the DynamicWorkOffsets feature applies
to these offsets.
Base Work Offset — See SetBaseWorkOffset, CancelWorkOffsets,
EnableWorkShiftOffsets, DisableWorkShiftOffsets, CancelAllWorkOffsets,
BaseWorkOffsetValues

NOTE: This offset is automatically applied during reset.


Work Offset — See WorkCoord, AdditionalWorkCoord, SetBaseWorkOffset,
CancelWorkOffsets, EnableWorkShiftOffsets, DisableWorkShiftOffsets,
CancelWorkOffsets, CancelAllWorkOffsets.

NOTE: This can also be set from the Configuration menu > Control
Settings: Offsets tab.

Secondary Work Offset — See SecondaryWorkCoord and


SecondaryRefWorkCoord.
Shift 1 — See ChangeWorkCoord, AbsoluteShift, IncrementalShift,
EnableWorkShiftOffsets, DisableWorkShiftOffsets, CancelShiftOffsets,
CancelAllWorkOffsets, SiemensShiftOffsetA, SiemensL137COffset,
SiemensL137CoffsetCancel.
Shift 2 — See AbsoluteShiftNum, OkumaCopyStart, OkumaCopyEnd,
OkumaShiftRotate, OkumaCancelShiftRotate, SiemensShiftOffsetB.
Shift 3 — See NumLengthCompX, NumLengthCompY, NumLengthCompZ.
Total — The combined total of all of the above offsets.
Adjusted Total — The resulting total after the corresponding rotations have been
applied.
Tool:
In many cases, an offset will be applied to the machine based on the tool offset and the
orientation of the tool. The tool offset can actually be composed of several pieces; some
of which are mutually exclusive.
Gage Offset — This value is typically calculated from the tls file. It is the "Gage
Offset" minus the "Ctrl Pt". The value from the tls file can be overriden with an
entry in the Gage Offset Table. This value is typically set with a tool change. Its
value can also be updated with a call to ToolOffsetUpdate.

351
Tool Length Offset — This value is typically only used if the Programming
Method is set to Tool Length Compensation. This value can, however, be used in
all 3 Programming Methods. The value will be set based on the corresponding
entry in the Tool Length Compensation table. If no entry exists, and the
Programming Method is set to Tool Length Compensation, this value will be set to
the Z value of the Input Program Zero + the Z value of the Gage Offset. See also:
ToolLengthComp... macros (ToolLengthCompUpdate, ToolLengthCompPos,
ToolLengthCompNeg, ToolLengthCompOff, ToolLengthCompValue,
ToolLengthCompToolnum) and SiemensPlaneSelectionArg.
Tool Nose Comp — See ToolNoseComp... macros (ToolNoseCompApply,
ToolNoseCompCancel, ToolNoseCompToolNum, ToolNoseCompValue).
Turret Offset — The turret offset is defined to be the XYZ distance from the
active tool to the center of its corresponding Turret. This offset can be turned on
and off. When turned on, this offset will be set with calls to TurretActivateTool or
TurretToolChange. It can also be reset to zero if the current gage offset is set to
zero and the apply turret offset flag is set accordingly. This flag is set with
ApplyTurretOffset.
GagePivotOffset — This offset is used as an alternative approach to RTCP
(Dynamic Tool Offsets). RTCP has been based on the concept of the spindle face
being the driven point when there is no tool in the spindle. When a tool is loaded,
and then rotated, both the gage offset and the pivot offset needs to be adjusted.
When driving the center of the pivot, and then adjusting for the gage and pivot
offset, the calculation is different. This offset is used for this latter approach. Its
functionality is currently limited. The capability is turned on with
ApplyGagePivotOffset, and its value is updated whenever the tool offsets are
updated. This capability is mutually exclusive with RTCP.
Current RTCP Pivot Offset — The pivot offset can set be set in the RTCP Pivot
Offset Table. If the corresponding entry does not exist, it will be auto-calculated
based on the active tool component and the position of the corresponding parent
rotary components. The application of this offset can be turned on or off using
ApplyPivotOffset. When applied, it will be adjusted based on the orientation of the
tool. It assumes that in its initial state, no offsets are to be applied. The initial state
is set at start of processing, and can be updated with a call to SetPivotOffset.
Applied Total — This is the sum of the Tool offsets, which are currently being
applied.

NOTE: Not all of the offsets listed will be applied. For example: Gage
Offset values might be specified, but may not be applied because the
Programming Method is set to Gage Length.

Adjusted Total — This value takes the applied total, possibly adjusts it based on
the orientation of the tool, and then applies it to the corresponding axis. See various
discussions on RTCP and XToolOffsetCompName, YToolOffsetCompName,
ZToolOffsetCompName.

352
Other:
Dynamic 3D Tool Offset — See Tool3dOffset.
3D Tool Length Comp — The Tool Length Offset as describe above, is an offset,
which applies only to Z. There is special handling of this value within the software,
and has therefore not been grouped with the Tool offsets. This offset can be applied
to any axis. See FanucToolLengthComp and ToolLengthCompOff.
Input Program Zero — This offset is typically set in the Input Program Zero
(Special Z) table. The values are automatically activated during initialization, and
can be updated with calls to UpdateIPZ and AutoUpdateIPZ. When the
programming method is set to Tool Length Compensation, the Z value of the IPZ
will not be applied. In this programming method, the Z value might later be used in
the calculation of the Tool Length Offset.
Input Machine Zero — This offset is set in the Machine Zero table and is
automatically activated during initialization. Typically, this offset is not used.
Miscellaneous — Other offsets that might be applied – intentionally not defined.
Total — Sum of the above offsets.
Total Offsets:
Sum of all offsets being applied.

NOTE: This does not include rotation planes.

Active Translations/Rotations:
The following become highlighted when the particular translation/rotation is active.
RTCP Pivot Offset is shown in its "active" state in the sample Machine Offsets window
shown at the start of this topic.
Gage Offset — If the Programming Method is set to Tool Tip, the Gage Offset will
be applied.
RTCP Pivot Offset — This flag is set if in RTCP mode and the pivot offset is
applied. See RtcpOn, RtcpOff, RotaryControlPointOnOff, ApplyPivotOffset. This
flag is also set if in a special Fanuc Tool Length Comp Mode and the apply pivot
offset flag is set to 2. See FanucToolLengthCompAxisOn, ToolLengthCompOff.
3D Rotation Planes — This flag is set if Rotation Planes are currently being
applied. See RotationPlane, RotationPlane2, RotationPlaneCancel,
RotationPlaneCancel2, FidiaRotate, FidiaRotate2, FidiaRotateCancel,
FidiaRotateCancel2, NumPlane, VirtualYAxis
Turret Offset — This flag is set with ApplyTurretOffset.
2D Rotations — 2D rotations are defined within the active plane (XY, YZ or ZX).
The 2D rotation flag is set with calls to: RotateXYZ, RotateCancel, RotateOrigin,
RotateMacro
Mirroring — If mirroring about any axis is set, this mirror flag will be set.
Mirroring is activated with calls to the Mirror... macros: (MirrorX, MirrorY,
MirrorZ, MirrorA, MirrorB, MirrorC, MirrorA2, MirrorB2, MirrorC2,

353
MirrorXValue, MirrorYValue, MirrorZValue, MirrorAValue, MirrorBValue,
MirrorCValue, MirrorA2Value, MirrorB2Value, MirrorC2Value, MirrorCancel,
MirrorXCancel, MirrorYCancel, MirrorZCancel, MirrorACancel, MirrorBCancel,
MirrorCCancel, MirrorA2Cancel, MirrorB2Cancel, MirrorC2Cancel).
Gage Pivot Offset — This feature is turned on with the ApplyGagePivotOffset
macro.
RPCP — This feature can be set using the Configuration menu > Control Settings:
Rotary tab. It can also be set with the following macros: RpcpOn, RpcpOff,
RotaryControlPointOnOff

354
File Summary

VERICUT Users:
VERICUT Location: Info menu > File Summary

Mold and Die Users:


Mold and Die Location: Analyze, View Files, Print page > Show Files Used

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Analyze, View Files, Print page > Show Files Used

Notebook Feature:

Opens a window reporting a summary of environment variables and files currently in use
by VERICUT. All standard text viewing features are supported, such as: search
forward/backward, go to line number, print, etc.

A "Copy all files" option provides a quick and easy way to store a copy of the files
in a new directory. This action is useful when preparing a set of files to send to CGTech,
or other destination.

355
Sample File Summary window:

356
G-Code Report
Location: Info menu > G-Code Report

Creates a G-Code Report file containing information about how the current NC control
configuration will interpret a G-code tool path file. Reported information includes:
machine codes present in the tool path and macros (actions) they will call, variables used
(if any), cutting tools used, subroutines defined and referenced, and more.

357
Control Report
Location: Info menu > Control Report

Creates a Control Report file containing information about how the current NC control
configuration will interpret machine codes. Reported information includes all the G-
codes the control is configured to handle and macros (actions) they will call, subroutines,
and other supported control features.

358
VERICUT Log

VERICUT Users:
VERICUT Location: Info menu > VERICUT Log

Toolbar short cut :

Cutter Grinder Users:


Cutter Grinder Location: Analyze, View Files, Print page > View Log File

Notebook Feature:

Opens a window containing the VERICUT Log file. This file contains session
information, such as error, warning and informational messages about the verification
session. In this window, you can view, print, change then name, or reset Log file
contents.

359
Clear Log File and Logger
Location: Info menu > Clear Log File and Logger

Toolbar short cut :

This feature enables you to clear both the Message area, also known as the "message
logger", and the Log file.

360
Project Setup menu

Current Setup
Location: Project menu > Current Setup

Selecting Current Setup displays a pull-right menu showing a list of available Setups. A
check mark is displayed next to the current setup (See Setup 3 in the picture below).
Picking a setup on the list makes it the current one. Inactive setups are displayed in red
text (See Setup 2 in the picture below).

361
Add New Setup
Location: Project menu > Add New Setup

Add New Setup appends a new setup after the current setup. All settings from the current
setup are copied to the new setup. Once the new setup is added, it becomes the current
setup.

362
Delete Current Setup
Location: Project menu > Delete Current Setup

Delete Current Setup deletes the current setup and makes the next setup in the list the
current setup (Example 1). If the setup at the end of the list is deleted, then the previous
setup becomes the current setup (Example 2). There must always be at least one setup in
a project. Therefore the last remaining setup cannot be deleted.

Example 1:

Before using Delete


Current Setup, Setup: 2 is
the "current" setup.

After using Delete Current


Setup, Setup:2 is deleted
and Setup:3 (the next in the
list) becomes the "current
setup.

363
Example 2:

Before using Delete


Current Setup, Setup: 4
(the last in the list) is the
"current" setup.

After using Delete Current


Setup, Setup:4 is deleted
and Setup:3 (the previous in
the list) becomes the
"current setup.

364
Import Setup
Location: Project menu > Import Setup

Copies a setup from either a pre-V6.0 user file or from a V6.0 project file and appends it
after the current setup.

Project File selection window — Use the Project file selection window to specify the
project file that the setup is to be imported from.
Setup List — After selecting the project file, a list of setups contained in the project file.
Select one or more setups to be imported. Use the Shift and Ctrl keys on the keyboard to
select multiple setups.
Import — Use to import the highlighted setups into the "current" project file.
Close — Closes the Import Setup window without importing any setups.

365
CNC Machine
Location: Project menu > CNC Machine

CNC Machine opens a dialogue for selecting the Machine and Control file to use for the
current setup.

Machine
Machine files contain data that describes NC machine construction, kinematics, and other
properties.

Enter the \path\file name in the text field of the Machine file to to be used or click on the
Browse button and use the file selection window that displays to specify the machine file.

You can also click on the arrow button at the end of the Machine text field to display
a list of all the Machine files contained in the "library" directory of your VERICUT
installation and select the desired Machine file from the list.

Control
Control files contain data that describes how the NC control processes machine code
data.

Enter the \path\file name in the text field of the Control file to to be used or click on the
Browse button and use the file selection window that displays to specify the control file.
You can also click on the arrow button at the end of the Control text field to display a
list of all the Control files contained in the "library" directory of your VERICUT
installation and select the desired Control file from the list.

366
Setup Models

Modeling window

VERICUT Users:
VERICUT Location: Project menu > Setup Models > Define
VERICUT Location: Configuration menu > Define

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Analysis and Viewing page > Specify a Design Model

Notebook Feature:

Opens a window to define or import the models that represent the solid objects used in
the simulation. VERICUT uses "components" to describe the function of various solid
objects, while models provide 3-D size and shape for material removal and collision
checking. To learn more, see "About modeling in VERICUT".

367
Active Component — Component active for editing. The active component is
automatically set when you select items from the graphics area or Component Tree
window. However, you can select a different component via picking it from the option
list.
Component Type — The active component's type is shown in an uneditable field for
reference purposes. To change the component type, use the Component Tree window
Edit menu.
Selected — Identifies what is selected for editing: a Model or the Component. This
option is automatically set when you select items from the graphics area or Component
Tree window. However, you can change what is selected for editing via clicking the other
option.
Model tab — Features on this tab add and modify models attached to components to
provide 3-D shape. The models can be simple parametric shapes, or refer to external
model files.

368
Position tab — Features on this tab move a component or model.
Component Attributes tab — Features on this tab define the attributes of a component.
Import tab — Features on this tab import IGES model files for use as stock, fixture,
design, or machine component models.
OK — Applies the changes and closes the Modeling window.
Apply — Applies the changes and leaves the Modeling window open.
Cancel — Closes the Modeling window without applying changes.

Tips:
y Right-click shortcut menu: Features used to manipulate components are
displayed in a shortcut menu when a component is selected and the right mouse
button is clicked in the Component Tree window. Similarly, features used to
manipulate models are displayed when a model is selected and the right mouse
button is clicked.
y Delete components or models by selection the object in the graphics area, then use
the <Delete> key on your keyboard
y You can move objects in the Component Tree window via dragging them from
one parent component to another, or copy them via holding down the <Ctrl> key
and dragging.
y Click repeatedly on a model in the graphics area to toggle selection between the
model and its component. Refer to the Component Tree window to review what is
selected.
y Using the center mouse button of a three button mouse, click repeatedly on a
model in the graphics area to toggle selection between different models along the
line of sight from the pick point. Use this technique to select models hidden from
view by an object in the foreground

369
Modeling window, Model tab
Location: Project menu > Setup Models > Define
Location: Configuration menu > Define

Toolbar short cut:

Features on this tab are used to add and modify models attached to components to
provide 3-D shape. (See how) The models can be simple parametric shapes, or refer to
external model files.

Type — Type of model being defined. The active choice configures the model
description area below this option with the values needed to define the selected model.
The table below lists the available model types and corresponding descriptions.

370
Model type: Appears in the Component Description
Tree:
Block Length (X), Width (Y),
Height (Z), Color, Auto
Block, Offset
Block specific features:
Length (X), Width (Y), Height (Z) — Dimensions of the block.
Auto Block—When defining a Block type model, this feature automatically
defines and locates a stock block based on tool positions in the current tool path
file(s). Rapid and APT-CLS “FROM” tool positions are ignored during this
calculation. The block size and location guarantee that the tool path will cut the
block.
Offset — Offset applied to a block created using Auto Block (see above). The
offset is applied in all dimensions.

Cone Height (Z), Base Radius,


Top Radius, Color
Cone specific features:
Height (Z), Base Radius, Top Radius — Dimensions of the cone (height, radius
at the base of the cone and the radius at the top of the cone).

Cylinder Height (Z), Radius, Color


Cylinder specific features:
Height (Z), Radius —Dimensions of the cylinder.

Model File Model File, Sketcher,


Normals*, Units, Color

371
Model File specific features:
Model File — Enter the /path/filename of the model file or use the Browse button
to display a file selection window and use it to select the model file.
Sketcher — Displays the Profile Sketcher window enabling you to edit or create a
"Sweep solid (.swp)" or "Revolve (.sor)" model file. This feature is only available
when the selected file is a Revolve or Sweep file type. To create a new Revolve or
Sweep model file, clear the Model File text field and press Sketcher, select the
profile type (Revolve or Sweep) from the window that displays, then OK to
display the Profile Sketcher window. Cancel dismisses the Profile Type window.
Normals — This feature applies to STL file models only and indicates the
direction in which surface normals defined in the STL data point, relative to the
model. Select Inward, Outward, or Computed (let VERICUT determine the
direction of the surface normals).
Units —Units (Inch or Millimeter) of the model file.

Common Features
Color — Color of the model. Available colors are the Shade Colors defined on the
Edit menu > Colors: Define tab. Models connected to the component have the
option to "Inherit" or override the component's defined color.
Add — Adds the model defined by the current window values to the active
component.
Visible — Toggles "on" or "off" to indicate whether or not the model file should be
displayed in the graphics area.
Preserve Stock Transition — Use to create the coordinate systems required for
transitioning the cut stock from one setup position to another. Preserve Stock
Transition is only active when a stock component model is selected.
When Preserve Stock Transition is pressed, two coordinate systems named "setup
sequence:setup name" are created and added, where setup sequence is a number
representing the nth setup in the project, and setup name is the text name of the
setup. One CSYS is added to the current setup, attached to the Stock Component
parent of the selected model. It is created with Use for Cut Stock Transition
toggled "On", designating it as a coordinate system used for transitioning the cut
stock from one setup position to another. The other CSYS is added to the first setup
in the project, and is located at the origin of the stock component who's name
matches current setup stock component. The following illustrates how to use
Preserve Stock Transition:
Configure Setup #1.
Simulate.
Configure Setup #2.
Move cut stock into position using cut features and assembly modeling to
position the cut stock

372
Press Preserve Stock Transition.
Simulate.
Configure Setup #3.
Move cut stock into position.
Press Preserve Stock Transition.
Simulate.
and so on ...

373
Modeling window, Position tab
Location: Project menu > Setup Models > Define
Location: Configuration menu > Define

Toolbar short cut:

Features on this tab move an object: component or model.

Translate tab — Features on this tab translate the selected object via indicating "from"
and "to" points to move the object.
Rotate tab — Features on this tab rotate the selected object about a rotation center point.
Assemble tab — Features on this tab move the object by assembling (mating or aligning)
it with other objects.
Matrix tab — Features on this tab move the selected object via a twelve parameter
transformation matrix.
CSYS tab — Features on this tab enable you to move a selected component/model from
one coordinate system to another.

374
Mirror tab — Features on this tab enable you to mirror a model about a specified axis
(plane).
Location features
The Location features are common to all of the above tabs and show the selected object's
position and angle, and can be used to move the object or verify its current location.
Values are shown relative to the parent component or machine origin, whichever is
selected: Relative Location or Machine Location, respectively.
Location Relative to Parent — When selected, indicates object location is shown
relative to the parent component origin. Examples follow.
Positioning a component—component is moved relative to the parent component
origin.
Positioning a model—model is moved relative to the component origin.
Location Relative to Machine Csys — When selected, indicates object location is
shown relative to the machine origin.
Position — Specifies the absolute XYZ position of the object, separated by spaces.
Angles — Specifies the absolute XYZ rotation of the object, separated by spaces.
Undo — Returns the object to its previous location, or as it was when the Modeling
window was opened.

375
Modeling window, Position tab, Translate tab
Features on this tab translate the selected object via indicating "from" and "to" points to
move the object. Movement occurs each time you press the Move button. (See how) If
the applied movement is incorrect, press Undo (on the Position tab) to return the object to
its previous location.

Translate tab features


From / To — Specifies the locations to move the object from and to, relative to the
machine origin. XYZ values can be entered (separated by spaces), or selected by clicking
in the field then clicking on a model. As you move the mouse over the VERICUT model,
a crosshair and vector show you the pending pick-point location. Graphical selection
supports picking corner points and midpoints of uncut model geometry, or virtually any
point on machined features.

Move — Moves the selected object by the incremental distance, as calculated from the
"From" point to the "To" point location.

376
Modeling window, Position tab, Rotate tab
Features on this tab rotate the selected object about a rotation center point. Movement
occurs each time you press one of the rotation direction buttons: X+/X-, Y+/Y-, Z+/Z-.
(See how) If the applied movement is incorrect, press Undo to return the object to its
previous location.

Rotate tab features


Center of Rotation—Specifies XYZ point location about which to rotate the object.
XYZ values can be entered (separated by spaces), or selected by clicking in the field then

clicking a position on a model. To see the center of rotation, press . To remove


the center of rotation symbol press the button again, or close the window.
Increment—Specifies incremental degrees of rotation to apply when one of the rotation
direction buttons are pressed.
Rotation direction buttons—(X+/X-, Y+/Y-, Z+/Z-) When pressed, applies the
incremental rotation specified in the Increment field. Rotation occurs about the Center
of Rotation, relative to the machine origin.

377
Modeling window, Position tab, Assemble tab
Features on this tab move the selected object by assembling (mating or aligning) it with
other objects. Objects are assembled by mating or aligning one to three planar surfaces
with surfaces on other models. (See how) If a non-planar surface is selected, VERICUT
constructs a tangent plane at the pick point. The relationship of surfaces being mated or
aligned is known as a "constraint".

Follow these general steps to define a constraint for assembly:


1. Choose the constraint type.
2. Select a surface on the object to move.
3. Select the surface to move the object relative to.
4. Press Apply.

Assemble tab features

Constraint Type—Specifies how to constrain selected surfaces during object movement.


After selecting two surfaces to define a constraint, VERICUT moves the object and
highlights the satisfied constraint with a checkmark. Options:

Mate—Moves the object so the selected surface opposes the surface selected on the
second object (surface normals oppose each other).
Align—Moves the object so the selected surface is aligned with the surface selected
on the second object (surface normals point in the same direction).

378
Consider the starting condition below for the examples that follow.

Mated surfaces- the left side of the magenta model is mated with the right side of
the yellow model.

379
Aligned surfaces- the left side of the magenta model is aligned with the left side
of the yellow model.

Offset—Distance and direction in which to offset constrained surfaces, applied normal to


the surface.
Reset—Resets constraints to receive new data.
Undo—Returns the object to its previous location, or as it was when the window was
opened.

380
Modeling window, Position tab, Matrix tab
Features on this tab move the selected object via a twelve parameter transformation
matrix. (See how) If the applied movement is incorrect, press Undo (on the Position tab)
to return the object to its previous location.

Matrix tab features


Matrix table — The transformation matrix table is similar to the matrix used in
programming APT tool paths. Its twelve parameters reveal the geometrical attributes of
the local (transformed) coordinate system (CSYS) in terms of the machine origin.

The format of the matrix table is as follows:

I J K D
X I1 J1 K1 D1
Y I2 J2 K2 D2
Z I3 J3 K3 D3

Each row represent an axis of the local CSYS. The first three columns represent the
vector associated with each axis: I1, J1, K1 as the positive X-axis vector; I2, J2,K2 as the
positive Y-axis vector; and I3, J3, K3 as the positive Z-axis vector. The fourth column
values D1, D2, D3 represent the coorinates of the the origin point of the local CSYS.

NOTE: If you prefer to see the the Matrix Table displayed with the I, J, K along
the vertical axis and the X, Y, Z along the horizontal axis, set the environment
variable, CGTECH_MATRIX_FORMAT=VERTICAL.

381
Update — Updates the object location to reflect the matrix table transformation. After
updating, press OK or Apply to move the object.
Apply Inverse On Update — When selected, inverts the matrix so that its twelve
parameters reveal the geometrical attributes of the machine origin in terms of the local
(transformed) coordinate system.

382
Modeling window, Position tab, Csys tab
Features on this tab enable you to translate the selected object from one coordinate
system (Csys) to another. Select the "From" Csys and the "To" Csys to move the object.
Movement occurs each time you press the Move button. (See how) If the applied
movement is incorrect, press Undo (on the Position tab) to return the object to its
previous location.

Csys tab features


From / To — Specifies the coordinate system to move the object from, and to. Select the
appropriate Csys from each of the pull-down lists.

Move — Moves the selected object from the "From" Csys to the "To" Csys orientation.

383
Modeling window, Position tab, Mirror tab
Features on this tab enable you to mirror a model about a specified axis (plane).

Mirror tab features

Mirror Off — The Mirrror attribute is turned off.

Mirror in X (about the YZ plane) — The Mirror attribute is set to Mirror in X, or about
the YZ plane.

Mirror Off Mirrored in X (about the YZ plane)

384
Mirror in Y (about the ZX plane) — The Mirror attribute is set to Mirror in Y, or about
the ZX plane.

Mirror Off

Mirrored in Y (about the ZX plane)

Mirror in Z (about the XY plane) — The Mirror attribute is set to Mirror in Z, or about
the XYplane.

Mirror Off

Mirrored in Z (about the XY plane)

385
NOTES:

The following model types can be mirrored:


VERICUT polygon files (polygon, sweep solid or solid of revolution (SOR)
STL files
VRML files
The model is mirrored in its local coordinate system (not the active coordinate
system)
The mirror attribute is part of the model structure and is saved with the model data
when saved to the project file or machine file.
When VERICUT reads a Project file or machine file, the models that have the mirror
attribute set will be mirrored when loaded.

386
Modeling window, Component Attributes tab
Location: Project menu > Setup Models > Define
Location: Configuration menu > Define

Toolbar short cut:

Features on this tab define the attributes of a component. (See how) VERICUT handles
components and their solid models differently depending on the component's type and
attributes. Most attributes apply to components used in building NC machines.

Color — Color of the component. Available colors are determined by the colors defined
on the Edit menu > Colors: Define tab.

Visibility — Controls the views in which the component is visible. Options:


y Blanked — Component is blanked from all views and cannot be seen.
y Workpiece View — Component is seen in the workpiece view.
y Machine View — Component is seen in the machine view.

387
y Both — Component is seen in both the workpiece and machine views.
See also: VERICUT command records that control displaying/loading/removing
models
Machine group:
Motion Axis — Specifies the axis of motion for a linear, rotary or turret type component,
relative to the component coordinate system. Use a "moving tool philosophy" to specify
the motion axis and direction, even though the component may actually move on the
machine instead of the tool.
Linear motion component: the motion axis is the axis in which linear motion
occurs.
Rotary and turret components: the motion axis is the axis about which rotation
occurs. The positive rotation direction is counterclockwise when viewed from
the positive end of the motion axis towards the component origin.
Tool and spindle components: the motion axis is the aligned with the tool axis,
typically "Z".
Disable Auto Direction — When toggled "On" (checked), disables VERICUT’s sense of
the "moving tool philosophy" for that particular component.
When Disable Auto Direction is toggled "Off" (not checked), VERICUT checks to
determine whether or not the component is "part side". A component is considered "part
side", when one of it's child components is a Stock component. If the component is "part
side", VERICUT automatically reverses the direction of motion.
This feature is intended for use in situations where a component starts connected to one
machine component , then later gets disconnected and reconnected to a different machine
component (for example, moving a "stock" component from one "fixture" component to a
different "fixture" component). If moving the component changes the "part side/not part
side" relationship of the components, Disable Auto Direction should be toggled "On"
(checked) causing the component motion direction to remain constant regardless of
where the component is connected.
If the relationship between two components is sometimes "part side", and sometimes "not
part side", then the Disable Auto Direction should be used, and the component motion
direction set explicitly with Reverse Direction feature (described below).
In the example below, the machine is configured like:
Base
Y
X
A
Fixture1
U
A2
Fixture2
Sometimes the Stock is connected to Fixture1, and sometimes it is connected to Fixture 2.
Components A, U, and A2 should have Disable Auto Direction toggled "On", and
Reverse Direction should be used to control the component's motion direction.
Reverse Direction — When toggled "On" (checked), reverses the component motion
direction.

388
Mixed Mode — Controls how the component is displayed when displayed in Mixed
draw mode.
Connect To — Component to which the active component is connected. The component
being connected to is known as the "connect component". Components must be
connected in the same way as they are in the real world. Improper connections cause
incorrect NC machine movement and simulation, especially when rotary components are
involved.
Rapid Rate — Feed rate for motion-type components moving in rapid positioning mode
(e.g. G0). For linear motion components the value entered is units/minute where "units"
reflect the units of the tool path file. For rotary motion components the value entered is
degrees/minute.
SubSystem — Subsystem which commands a linear or rotary motion type component to
move. Any alpha-numeric sub-system name can be entered (may include spaces). Enter
"*" (without the quotes) for motion axes included in all machine subsystems. Subsystems
are used in machines with multiple motion components that are commanded to move via
the same G-code word, for example "X". By default, a machine uses one subsystem for
all motion components, assuming they are commanded to move via unique G-code
words.
When multiple motion components are driven by the same G-code word, such as can
occur in 4-axis lathes or mills with multiple independently controlled heads, define
different subsystems to control which component moves when the motion command is
processed. Then, configure the control so that other codes in the tool path activate the
appropriate subsystem for movement. A full set of tables are available to support each
machine subsystem. See "Sample-demo files" , in the V60 Online Help Library for
examples of machines that use multiple subsystems.
Tool Index — Index number of a Tool component. When defining machines with
multiple tool load positions, such as a multi-spindle mill or a turret lathe machine with
tools loaded in the turret, define additional Tool components with different index
numbers. Values entered are integer numbers. Use the "ActiveTool" macros to activate
each Tool component for tool changes. For example, call "ActiveTool2" to activate the
Tool component with Tool Index=2, and so on.
Toolchain Parameters — Displays the Toolchain Parameters window enabling you to
specify toolchain component characteristics. Toolchain Parameters is only active when
the Active Component is Tool Chain.
Accel/Decel group:
Acceleration / Deceleration — Velocity at which the NC machine component can
accelerate (or decelerate). Values entered are units per second per second, where units
could be inches or millimeters for linear axes, depending on the machine units, or degrees
for rotary axes.
Max Feed Velocity — Maximum speed axes can travel while in feed mode. The value
entered is in units per minute, where units could be inches or millimeters for linear axes,
depending on the machine units, or degrees for rotary axes.
Max Velocity for Direction Change — Maximum feed rate for motions that cause an
axis to decelerate to zero velocity, such as occurs when turning at a corner.

389
Toolchain Parameters window
Location: Project menu > Setup Models > Define: Component Attributes tab

The features on this window define toolchain characteristics. See Toolchain Operation for
more information.

Number of Pockets — Use to define the number of tools in the toolchain. The
VERICUT will automatically create this number of equally spaced tool components
along the toolchain's perimeter geometry. The toolchain perimeter is defined by the first
sweep model file attached to the toolchain component. This file is normally not displayed
except for debugging purposes. Other models may be used to define the associated
toolchain machine structure.

These tool components are named Pocket1, Pocket2, ..., PocketN. They are created each
time the machine definition file is loaded, are not saved, and may not be edited. The
position of Pocket1 is defined by the start point of the first boundary geometry segment
(line or arc). Pocket1 is also defined as the "select" or "exchange" position. The perimeter
geometry is scaled about Pocket1 to achieve the pocket-to-pocket spacing entered in the
GUI. Normally this adjustment should be small.

390
Pocket order — Use define the direction for pocket numbering. Select Clockwise or
CounterClockwise from the pull-down list.
Pocket-to-pocket time — Defines the time (in seconds) required to move the toolchain
one position.
Tool exchange time — Use to define the time (in seconds) required to move the selected
tool into the machine's spindle and return the unloaded tool to the toolchain.
Pocket-to-pocket distance — Defines the distance between adjacent tool centers along
the toolchain's perimeter.
Replace tool in its original pocket — Use to specify where the tool being unloaded
from the spindle is to be placed in the toolchain. When toggled "On", the unloaded tool is
returned to its original pocket position. Otherwise, the tool being unloaded is placed in
the pocket emptied by the tool being loaded.
Display pockets in component tree — Use to specify whether or not the toolchain's
associated tool components are displayed in the component tree. When toggled "On",
tool components will be displayed in the component tree. The default is not to display the
tools components since large toolchains can contain a hundred or more tools.
Tool-to-tool collision checking — Use to specify collision checking when a tool is
placed in the toolchain during a tool exchange. When toggled "On", the tool being
unloaded and returned to the toolchain is checked for collisions with the tools in adjacent
pocket positions.
Tool length checking — When toggled "On", tool lengths are checked against the
Maximum tool length value when they are initially put in the toolchain. If the tool
length exceeds the Maximum tool length value, an error is output.
Maximum tool length — Use to specify the maximum tool length value used for Tool
length checking.

391
Modeling window, Import tab
Location: Project menu > Setup Models > Define
Location: Configuration menu > Define

Toolbar short cut:

Features on this tab import IGES model files for use as stock, fixture, design, or machine
component models. (See how) The component type determines how the converted IGES
model will be used in VERICUT. An option is also available to create a solid model from
an IGES surface. The surface can be used as is, or offset before converting it into a solid.
During import, VERICUT converts the IGES model data into a VERICUT Polygon file
(.ply extension) and automatically refers the converted file. This window functions
similar to the IGES Converter window-ref. File menu > Convert > IGES.

IGES File — Name of the file containing the IGES data to import. Either enter the
/path/filename in the IGES File text field , or click on the Browse button and use the file
selection window that displays to select the file.

392
Tolerance — Specifies the amount of chordal deviation allowed in 3-D space from the
IGES surface when creating the converted surface. The converted surface is
approximated using "facets", or triangles.

Offset Surface group:

Offset Surface — When active, creates a solid model from an open IGES surface.
Offset Amount — Distance and direction in which to offset the design surface, as
applied normal to the input surface. For example: ".100" applies an offset of .100 to the
surface in the Z+ direction. A value like "-.100" applies the offset in the Z- direction,
effectively "shrinking" the model.
Base Location — Specifies the Z value of the plane to become the base of the solid
model. The surface is projected along the Z-axis to this plane.
Extend to Rectangle — When active, expands surface edges to create a rectangular base.
The size of the rectangular base is determined by the X-Y bounding region of the surface
data.
Add — Adds the VERICUT polygon model defined to the active component.

393
Load Stocks
Location: Project menu > Setup Models > Load Stocks

After cutting, selecting this option causes VERICUT to load new stock models for Stock
components having models defined, but a cut stock model does not exist. This capability
is used when simulating a series of parts being machined through multiple machining
stages. This type of manufacturing is often refered to as "staged machining".

In general, the following actions take place in staged machining:

1. Simulate the first stage cutting operation. (Creates a "Cut Stock" workpiece that
appears as in the Component Tree window)
2. Move (e.g. cut and paste) the cut stock to a different Stock component defined to
represent the next cutting stage.
3. Select Load Stocks to load a new uncut stock model in the first cutting stage.
4. Continue cutting-typically cutting the first and second stages, but may cut all
stages even though workpieces have not yet been placed in subsequent cutting
stages.
5. Repeat actions as required to cut a workpiece through all cutting stages required
to complete the final part configuration.

394
Delete Detached Stock
VERICUT Users:
VERICUT Location: Project menu > Setup Models > Delete Detached Stock

Toolbar short cut:

Cutter Grinder Users:


Cutter Grinder Location: View Simulation page > Delete or Keep Material
Notebook Feature:

Opens a window enabling you to delete or keep pieces of material. (See how) This
feature is typically used to delete pieces of excess stock that have been cut free from the
workpiece. However, pieces of other models can also be deleted.

Items are selected for Delete/Keep in the Workpiece View. Any number of items can be
selected. Selected items are immediately highlighted with the Error color. Once you click
Delete (or Keep) the items are removed from all views. However, the selected items are
not actually deleted until you click OK.

NOTE: Once model pieces are deleted, model pieces can not be restored.

Update While Simulating — When toggled "On", VERICUT checks during the
simulation for detached material based on the stock's relationship to all sibling and parent
fixture models. If the detached stock does not intersect, or is not tangent to, a parent or
sibling fixture model, then the piece is considered "unattached" and is automatically
deleted. This logic applies to both milling and turning operations.

395
For turning mode, VERICUT checks at the end of each block. For milling mode,
VERICUT checks at each tool change, at the end of each file, whenever VERICUT is
stopped (except for"single step"), at Clamp/Unclamp events, and whenever the
CheckForLooseMaterial macro is called. (See example)
Tab Removal — Use this feature to remove tabs left on the machined part (used for
holding the part during the machining process) from a VERICUT cut model. VERICUT
will project the cutter used to cut the selected machined surface, through the bottom of
the part, removing the tab area. More than one position on the machined surface may
need to be selected to remove the entire tab area.

Before Using Tab Removal After Using Tab Removal

OK — Use this feature to permanently delete the items selected for Delete/Keep, or
activate Update while Simulating and close the Delete Material window.
Delete — After selecting the items to be deleted (they will be highlighted), click Delete
to remove selected items from all views. Click OK, described above, to permanently
delete the items.
You can also use Delete to delete the un-displayed portion of a sectioned view. Without
selecting any items, click on Delete. You will be prompted with the message "The cut
stock is sectioned. Delete the sectioned (invisible) material?" Yes/No". A "Yes" response
permanently deletes all un-displayed (invisible) sectioned material. A "No" response
does not. Using the Keep in this manner will produce the same results.
Keep — After selecting the items to keep (they will be highlighted), click Keep to
remove all un-selected items (not highlighted) from all views. Click OK, described
above, to permanently delete the items.
Unselect — Use this feature any time while selecting items for Delete/Keep to un-select
all selected items (they will no longer be highlighted). This feature becomes inactive
once you click on Delete/Keep.
Cancel — Use to un-select all items, cancel any Delete/Keep action, and close the Delete
Material window.

396
Delete Detached Stock - Update While
Simulating Example

Update While Simulating Toggled "Off":

Notice that when Update While Simulating is toggled "Off", the pieces of excess stock
that have been cut free from the workpiece remain displayed, as shown in the pictures
below.

397
Update While Simulating Toggled "On":

Notice that when Update While Simulating is toggled "On", most of the pieces of excess
stock that have been cut free from the workpiece have been automatically deleted, as
shown in the picture belows. The reason that they were not all automatically deleted is
because of slight differences in the holding fixtures. In setups 2 and 3, the remaining
excess stock pieces are at least partially in contact with the fixture so they were not
automatically deleted.

398
Create Model File
VERICUT Location: Project menu > Setup Models > Create Model File > Revolve /
Sweep

Opens the Profile Sketcher window enabling you to define a profile to be used to create a
solid model either by rotating the profile about the Z-axis (Revolve), or by sweeping the
profile along the Z-axis (Sweep).

Revolve — Click this option to open the Profile Sketcher window in "solid of revolution"
mode.
Sweep — Click this option to open the Profile Sketcher window in "sweep solid" mode.

399
Profile Sketcher Features
Locations:
Project menu > Setup Models > Create Model File > Revolve
Project menu > Setup Models > Create Model File > Sweep

Project menu > Setup Models > Define > Model tab: Type=Model File >
Sketcher > Revolve
Project menu > Setup Models > Define > Model tab: Type=Model File >
Sketcher > Sweep

Configuration menu > Define > Model tab: Type=Model File > Sketcher >
Revolve
Configuration menu > Define > Model tab: Type=Model File > Sketcher >
Sweep

Project menu > Tools > Add(Modify) Cutter >Tool


Component tab:
Project menu > Tools > Add(Modify) Insert (Revolve Profile)
>Tool Component tab:
Project menu > Tools > Add(Modify) Holder
>Tool Component tab:

Project menu > Tools > Add(Modify) Holder


>Tool Component tab: (Sweep Profile)

The Profile Sketcher provides an easy graphical means of describing a profile of in 2-D
drawing space. Profiles are sketched by connecting a series of lines and arc segments.
You can select points, enter point/arc data into the Profile entity list, or pick then edit
entity values in the list. You can also import the 2-D geometry from a DXF file. The
profile displayed in the sketcher window is constantly updated regardless of how you
supply profile entity data, making it easy to see what you've defined.
The Profile Sketcher can be opened in either "Revolve" mode, where an "open" 2D
profile is rotated about the Z-axis to create a solid model or cutter/holder,

400
or in "Sweep" mode, where a "closed" 2-D profile is "swept" a specified distance along
the Z-axis to create a solid model or a cutter insert/holder.

The Profile Sketcher is accessible from Project menu > Setup Models > Create Model
File > Revolve/Sweep and from Project menu > Setup Models > Define: Model tab to
create profiles that can be rotated about an axis, or swept along an axis to create solid
models. It is also accessible and Tool Manager to Add(Modify) cutters, inserts and
holders.

401
The options available in the Profile sketcher will vary slightly depending on whether it
was accessed from one of the Model menu windows or from Tool Manager. Most of the
features are common regardless of where the window was accessed from and have
identical functionality. Those features that are specific to a particular function are located
at the bottom of the window are described in the Special Features section below.

Common Features
Entity list — Lists the point/arc entities that define the profile. The list is created
by graphical selection, or by pressing Add to add entities to the list. Existing data
can be edited directly in the Entity list..
Add / Delete — Adds (or deletes) a single entity to/from the Entity list. Once
added, the entity type (Point or Arc) can be changed, or data values edited.
Delete All — Deletes all entities in the Entity list.
ImportDXF — Opens the DXF Geometry window enabling you import two
dimensional tool geometry from files which comply with a de facto CAD system
standard, the Data eXchange Format (DXF) to add (or modify) individual cutter (or
holder) components in existing tool records.
Fillet Size — Use this text field to specify the size of the fillet to be created. Use
with Create Fillet described below.
Create Fillet — Use to create a fillet at the selected point. Use Fillet Size
described above, to specify the size of the fillet.
Shortcut: Add, Delete, Delete All, Import DXF, Create Fillet, and Undo
(described below) are also available by right-clicking in the Sketcher
window.
Sketcher window — Displays the current defined tool profile (blue line), based on
the entity list. The profile in the window is constantly updated to reflect current list
data. The following symbols may be seen in the sketcher window:

—Tool origin. The tool origin is assumed by VERICUT to be the


control point, or driven point, on the tool. Typically, tool profiles are
sketched relative to the tool origin to provide proper cutting by the tool.
However, the tool origin can be relocated at any time via dragging the
origin point. Tool origin display is controlled by the Origin feature
on the sketcher Toolbar (see below).
(blue dot) Entity point — This symbol indicates a point on the profile
or an arc center point. You can change the profile shape by dragging
entity points to different locations. The corresponding entity in the list is
automatically updated.
(green dot) Selected entity point — This symbol indicates the entity
selected for editing. The corresponding entity in the list is also highlighted
for editing.

402
NOTE: Selecting a line segment in the Sketcher window selects both
end points for editing. Drag the line segment to the desired location and
both end points are automatically updated in the Sketcher window as
well as in the Profile Entity List.

(red dot) Target selection point — This symbol follows the mouse
and is the target for graphical selection. Values displayed with the
Sketcher axes below the sketcher window reflect the target selection
point location.
Sketcher axes — Axes that depict the coordinate system in which the tool profile
is being constructed. Values displayed with the axes reflect the target selection
point location, relative to the tool origin.
Sketcher Toolbar — The icons on this Toolbar zoom in/out, fit, and pan the tool
profile in the sketcher window. See the table below for details. Sketcher icons:
Shortcut: The following keys provide instant access from the keyboard to
dynamic viewing options (press and hold keys while dragging): Dynamic
Zoom—<Ctrl>, Dynamic Pan—<Shift>.
Arc / Pt — Controls the profile entity type being defined via graphical selection.
Arc Direction — Controls the direction of an Arc being defined via graphical
selection.
Grid Size — When selected, displays a grid in the sketcher window. When a grid
is displayed, target and selected points snap to the nearest grid line intersection.
Grid spacing is specified in the data field located right of the GridSize label, and
can be changed at any time. Clear the checkbox to remove the grid and select or
drag points anywhere in the 2-D drawing space.
Sketcher Message area — Located below the sketcher window, this uneditable
text field displays error and informational messages to assist you with defining tool
profiles. If actions in the Tool Manager and/or sketcher window are not as
expected, check the VERICUT main window message area for additional relevant
messages.

Icon: Name: Action:


Pan Pan/translate- drag mouse in the direction
pan
Zoom In / Zoom Out Zooms in/out approximately 20% each
time they are clicked
Fit Fits the tool in the sketcher window
Origin When selected, displays the tool origin
point
Undo Select to "undo" the previous action(s).

403
Special Features
The following are only available in the Sweep Profile window:
Zmin / Zmax —Used to specify the starting and ending location along the Z-axis
when creating a "swept" solid model.

The following are available in the Tool Manager, Add (Modify) cutter window:
Flute Length —Used to specify the length of the cutter having flutes, or teeth, that
can remove material.
Offset (Z) —Used to specify the offset applied to the cutter. The offset is applied
in the Z direction (along the tool axis).
Color —Used to specify the color of the tool component as seen in a machine
view.

The following are available in the Tool Manager, Add (Modify) Insert and the Tool
Manager, Add (Modify) Holder windows:
Thickness —Used to specify the thickness of the insert or holder (sweep profile
only).
Color —Used to specify the color of the tool component as seen in a machine
view.

NOTE: For additional information on these Tool Manager features, see the
specific tool component in the Tool Add/Modify window.

404
DXF Geometry window
Locations: Profile Sketcher window > Import DXF
Tool Manager window > File > Import > DXF Tool

Opens the DXF Geometry window enabling you to import two dimensional geometry
from files which comply with a de facto CAD system standard, the Data eXchange
Format (DXF).
The Profile Sketcher window is accessible Project menu > Setup Models > Create Model
File > Revolve/Sweep and from Project menu > Setup Models > Define: Model tab to
create profiles that can be rotated about an axis, or swept along an axis to create solid
models. It is also accessible and Tool Manager to Add(Modify) cutters, inserts and
holders.

The options available in the DXF Geometry window will vary slightly depending on
whether it was accessed from one of the Model menu windows,

or from Tool Manager.

405
Many of the features are common regardless of where the window was accessed from and
have identical functionality, Those features that are specific to either of the Model menu
windows or Tool Manager windows are noted in the feature descriptions below.

Importing DXF Profile Data:


DXF File — Use to specify the DXF file containing the tool data. Enter the /path/file
name in the text field or click on Browse and use the Select DXF File window to specify
the file.
Mill/Turn — (Tool Manager only) Select Mill or Turn to specify the "type" of tool data
being imported.
Inch/Millimeter — (Tool Manager only) Select Inch or Millimeter to specify the
"units" of the tool data being imported.
Component Table —
After specifying the DXF file, a record is created in the Component Table for each layer
contained in the file. You can re-order the records in the table by clicking on the button in
the first column of the record and dragging it to the desired position.

y DXF Layer — This column displays the name, or number, identifier of the layer.
y Profile — (Create Model File only) This column is used to identify the profile
that is to be used.
y Cutter — (Tool Manager only) This column is used to identify the "cutter"
geometry data to be imported. Click on the box in the appropriate layer row to
activate it (checkmark is visible).
y Holder — (Tool Manager only) This column is used to identify "holder"
geometry data to be imported. Click on the box in the appropriate layer row(s) to
activate it (checkmark is visible).

NOTE: When the DXF Geometry window is accessed from the Tool
Manager, only layers that have been indicated as "cutter" or "holder" will be
imported. If the DXF window was accessed using Add > DXF Tool in the
Tool Manager, only one "cutter" component can be imported, but multiple
"holder" components can be imported for each tool record.

Import — Imports the geometry data into the appropriate Profile Sketcher window, or in
the case of Add > DXF Tool in the Tool Manager, into the appropriate tool record/tool
component.
Cancel — Use to close the DXF Tool Geometry window.

406
DXF File Requirements:
Only the ENTITIES section of a DXF file is scanned by VERICUT. The BLOCKS
section is ignored, so BLOCK references within the ENTITIES section will not be
expanded. REPEAT entities are also ignored. The only geometric entity types processed
are LINE, ARC, CIRCLE, POLYLINE, LWPOLYLINE, TRACE, SOLID, 3DLINE and
3DFACE .
For Creating Solid Models
Import "open" 2D profiles to be rotated about the Z-axis to create "revolved" solid
models. Putting the start and end points of the profile off of the Z-axis will result in a
solid model that is open in the center like the one shown in the "Revolved Solid Model"
picture below. To create the model with a solid center, make sure that the start and end
points of the profile are on the Z-axis.

Open Profile Revolved Solid Model

Import "closed" 2-D profiles to be "swept" a specified distance along the Z-axis to create
a solid model or a cutter insert/holder.

Closed Profile Swept Solid model

407
For Creating Cutters, Inserts and Holders
VERICUT expects only one tool per DXF file. Each component (cutter or holder) of the
tool should be on its own named or numbered layer. There can be no more than one cutter
component, but multiple holder components are permitted. The DXF file may contain
other layers which are unrelated to the definition of the tool's geometry. Within each
component layer, LINEs, ARCs, CIRCLEs, POLYLINEs, LWPOLYLINEs, TRACEs,
SOLIDs, 3DLINEs and 3DFACEs can be used to define the profile of the tool.
For a milling tool, the Y coordinate of the DXF data corresponds to the tool's axis of
rotation, known as the Z axis in VERICUT's Tool Manager. The X coordinate of the
DXF data corresponds to the Tool Manager's X axis. An exception to this is a DXF file
recognized by its use of layer names as being generated by TDM Systems', Tool Data
Management (TDM) system. In such a file, the X axis is the tool's axis of rotation, with
the tool tip on the right, and the Y coordinate is the radial distance from the rotation axis.

DXF Data In VERICUT

DXF Data from TDM

For a turning tool, the X coordinate of the DXF data corresponds to the lathe's axis of
rotation, known as the Z axis in VERICUT's Tool Manager. The Y coordinate of the
DXF data corresponds to the Tool Manager's X axis.

408
DXF Data In VERICUT

Cutter on Layer 1
Holder on Layer2

Back to Tool Manager window


Back to Profile Sketcher window

409
NC Programs

NC Program window
VERICUT Users:
VERICUT Location: Project menu > NC Programs

Toolbar short cut:

Mold and Die Users:


Mold and Die Location: Setup page > Select Tool Path Files and Tools

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Setup page > Select Grinding Programs

Notebook Feature:

Opens a window to specify the NC program file(s) to simulate, and controls how
VERICUT receives descriptions of cutting tools. In general, VERICUT can obtain
descriptions of cutting tools by processing parametric cutter description records found in
the NC program file, or can be configured to retrieve them from a VERICUT Tool
Library file.

410
NC Program Type — Type of NC program file for VERICUT to simulate. By default,
VERICUT simulates G-Code or "machine code data" NC programs destined for a 3-axis
mill machine with a "Fanuc-like" control. Using this option, you can quickly configure
VERICUT to simulate NC programs from all popular CAM systems. Options:

y G-Code Data — G-Code NC program file. With this choice, VERICUT uses a
Machine file, Control file, and G-Code settings (ref. Project menu > Processing
Options > G-Code > Settings) to interpret codes present in the file.
y VERICUT APT — Generic ASCII APT NC program file from virtually any
source, including ACL format.
y UG CLS — Unigraphics CLS NC program file.
y CATIA APT — CATIA APT source NC program file. This file must be
processed from CATIA using the CATUTIL function and typically has a
".APTSOURCE" extension.
y CV APT — ComputerVision APT NC program file.
y CADRA APT — CADRA APT NC program file.
y APT (RevPost) — ASCII APT NC program file created from reverse post-
processing G-Code data Refer to "Reverse post-process G-Codes to APT" in the
Configuring For Toolpath Simulation sectionof Using VERICUT for more
information.
y Pro/MFG APT — Pro/Manufacturing APT NC program file.
y NCL APT — NCL APT NC program file.
In addition to the NC program types above, VERICUT's converters enable you to
simulate NC programs from various CAM systems. See the following sections
for more information:
- File menu > Convert > Binary CL
- Reverse post-process G-Codes to APT

Tool Change By — Controls how VERICUT receives descriptions of cutting tools.

y Cutter Desc. — Process parametric cutter descriptions in the NC program file.


Examples: CUTTER and VERICUT-TC comment records.
y VERICUT TC — Process by PPRINT/VERICUT-TC cutter statements in the
toolpath file.
y Tool Number — Process NC program records that reference tool or pocket
numbers and retrieve associated tools from a Tool Library file. Examples: TnM6
(G-Code NC programs), LOADTL or LOAD TOOL, and TURRET. When using
Tool Change by Tool Number, The tool number is matched with the pocket
number (ex: tool #5 in pocket #5).
y List — Refer to a list of tool change event-to-tool ID references that retrieve
associated tools from a Tool Library file. The list is accessed via the Use Tool
List feature, as described later in this section.

411
y File Name — Use a tool from a Tool Library file as specified for each NC
program file in the list.
y Tool Name — This option is only applicable when NC Program Type is set to
UG CLS. Tool Name refers to the tool identifier in the TOOL PATH/ statement
in the UG CLS file.

Use Selected Files — When used in conjunction with the Use checkboxes in the
Toolpath list, enabling you to select only specific toolpath files from the list for
VERICUT processing. If this option is not checked on, all toolpaths in the list will be
processed in the order that they appear in the list.
Initial Tool — When active, VERICUT loads an initial tool from a Tool Library file.
This action occurs automatically when the Project file is loaded, the NC program is
rewound, or the model is reset. Choose the ID of desired tool using the option list next to
this feature. This feature is useful when simulating NC programs for machines that have a
tool loaded at the time tool processing is started, therefore do not have information about
the first tool.
You can also use this feature to preload multiple tools in a milling machine (e.g. tool
change carousel), via selecting Initial Tool, but leaving the corresponding field blank. If
you specify a tool number, then that tool is forced in to all tool component positions.

NOTES:
This feature should not be used if you are using multiple toolpaths.
This action also occurs when a "Turret" type component is present, such as
commonly used with turret lathe setups.

Tool Override — When active, overrides the current cutter description with a specified
tool from a Tool Library file. This action occurs immediately. Choose the ID of desired
tool using the option list next to this feature. VERICUT uses the override tool until you
select a different tool ID or clear the Tool Override checkbox. When cleared, the tool
that would have been in use becomes the active tool.
NC Progam list — Also known as the "toolpath list", displays all of the NC program
files available in the project file. The NC Program list consists of some, or all, of the
following columns of information depending on the way that the NC Program Type and
Tool Change By options are set.

List Order buttons — NC programs are processed by VERICUT in listed order.


List order is changed via left-dragging the List Order button in the first column of
each toolpath entry in the list. Only NC programs that have not been simulated by
VERICUT can be reordered. Reset the model to reorder NC programs that have
been already been simulated.
Use — This column is only displayed when the Use Selected Files option,
described above, is toggled "On". Use the checkboxes in this column to select
certain files in the toolpath list for VERICUT processing. By default all toolpaths
are selected (checked) for processing.

412
NC Program — displays the path and file name of each toolpath currently
available for VERICUT processing.
Tip: Double clicking on the toolpath file name displays the NC Program
Editor window with the toolpath ready for editing.
NC Program Origin — Use to specify the coordinate system that corresponds to
each toolpath. Change the CSYS by clicking on current value in the Toolpath
Origin column then select the desired CSYS from the pull-down list of available
coordinate systems. The option None makes the toolpath origin relative to the
Workpiece Origin for CL Data, and relative to the Machine Origin for G-Code
data.
To change multiple Toolpath Origins at the same time, select the desired toolpaths
using one of the following methods:

Select multiple files in sequence—Click first file name in the sequence, then
press and hold the <Shift> key while clicking the last file name. You can also
click on the first file name in the sequence, while still holding down the
mouse button, drag the cursor to the last file name in the sequence.
Select additional files—Press and hold the <Control> key while selecting
each additional file.
With either method, selecting a file name a second time while holding down
the <Control> key unselects the file.

Then Right-click in the list area and select Origin from the shortcut menu. Select
the desired CSYS from the pull-down list to update the Toolpath Origin for all
highlighted toolpaths.
Curve Fit — This column is only visible when Toolpath Type is set to G-Code
Data. Use the check boxes in this column to select specific toolpaths for Curve
Fitting. When you check one or more toolpaths for Curve Fit processing, the Curve
Fit button, described below, becomes active enabling you to access the NC
Program Curve Fitting Control window to set curve fit parameters and start the
curve fit process.
Tool ID — This column is only visible when Tool Change By is set to File Name.
It specifies the ID of a tool from the current Tool Library file to use with each NC
program file.
Tip: Right-click in the list area to access a shortcut menu for adding, replacing,
changing the toolpath origin, deleting, or editing the highlighted toolpath in the list.
The Add, Delete and Replace options are the same as the buttons described below.
Copy / Paste enable you to copy the highlighted NC program and paste it at the
end of NC Program List. The Origin option is the same as the NC Program
Origin option described above. The Edit option displays the NC Program Editor
window with the highlighted toolpath ready for editing. If Use Selected Files is
toggled "On", Unselect All appears in the menu to enable you to uncheck all boxes
in the Use column with a single pick.
Add — Opens a file selection window enabling you to add one or more NC program files
to the list.

413
Replace — Displays a file selection window enabling you to select a toolpath file to
replace the selected (highlighted) toolpath file in the list. If there is only one toolpath in
the list, you do not need to select (highlight) it. Just click on Replace to display the file
selection window and pick the replacement file. VERICUT will replace the existing
toolpath file with the new one. You can also double click on a toolpath file name in the
list to display the "file selection box". To select multiple NC program files for
replacement, use any combination of the techniques below.

- Select multiple files in sequence—Click first file name in the sequence, then
press and hold the <Shift> key while clicking the last file name-all files in
between those selected are also selected.
- Select additional files—Press and hold the <Control> key while selecting each
additional file. Selecting twice de-selects the file.

Delete — Deletes the selected NC program file from the list. To select multiple NC
program files for deletion, use any combination of the techniques described above under
Replace.
Clear — Clears the list of all NC program files.
Curve Fit — Displays the Toolpath Curve Fitting Control window that enables you to set
parameters for use during curve fitting. (See window features)
Use Tool List — When Tool Change By=List, this feature opens a window to create
and maintain a list of references that link tool change events to tools stored in a Tool
Library file. You can use this list to supply tools from the library for sequential tool
changes, or to replace tools specified for use in the NC program file. (See window
features)

414
NC Program Curve Fitting Control window
The curve fitting option is targeted at 3-axis G-Code NC programs containing long
sequences of relatively short cutting motions. VERICUT detects sequences of planar
motion and fits arcs (or NURBS) whenever the motion can conform to a specified
tolerance. Arcs are only replaced along the machine's major axes (XY, YZ and XZ). The
resulting NC program files may be smaller, produce an improved surface finish, and
process faster in VERICUT than the original NC program file. (See how)
Curve fitting makes a single pass through the G-Code NC program(s) and writes new NC
program file(s) containing the modified motions. The original NC program files are not
changed. Curve fitting may be selectively applied to NC programs by checking the curve
fit box in the NC Program list.

The "Curve Fit" button brings up the NC Program Curve Fitting Control window
enabling parameters to be set and the curve fitting process to be executed.

415
Arc Fitting — Select this feature to fit arcs during Curve Fit processing. Selecting this
feature also activates the Arc Fit Parameters options described below.

NURBS Fitting — Select this feature to fit NURBS during Curve Fit processing.
Selecting this feature also activates the NURBS Fit Parameters described below. NURBS
Curve Fitting is supported for the Fanuc G6.2 (Generic control), the Siemens (BSPLINE
format), and the Toshiba G6 machine controls.

Output NC Program — Specifies the name of the new G-Code NC program file
containing the results of the curve fitting process. The Output NC Program file name
must be different from that of the original NC program file name. Curve Fitting will not
permit the original NC program file to be overwritten. When curve fitting multiple NC
program files, a modified NC program file is output for each NC program file processed.
Each output file has an ascending sequence number appended to the end of the base file
name. For example: assume Output NC Program ="path.mcd" is entered (without the
quotes). Curve Fit processing of 2 NC programs outputs the following files:
path001.mcd => modified NC program from NC program 1
path002.mcd => modified NC program from NC program 2
If a dot "." is the last character of the output NC program file name, then three digits are
appended to the file name as the extension. Continuing with the above example: assume
Output NC Program ="path." is entered. Curve Fit processing of the same 2 NC
programs outputs the following files:

part.001 => modified NC program from NC program 1


part.002 => modified NC program from NC program 2

If an asterisk "*" is used in the output NC program file name, the original NC program
file name is used as the output file name in place of the asterisk. If characters follow the
asterisk, the input NC program file name extension is replaced with the characters
following the asterisk. Examples follow.

Original NC program file: Output NC Program file Output file name:


name:
dir1/filename.mcd dir2/filename.mcd
dir2/*
dir1/filename.mcd dir2/filename.filter
dir2/*.filter
dir1/filename.mcd dir2/filenamecf
dir2/*cf
dir1/filename.mcd dir2/filenamecf.mcd
dir2/*cf.mcd
filename.mcd filename.cf
*.cf

416
Only a single asterisk is acted on in the optimized NC program file name, with one
exception: asterisk dot asterisk ("*.*"). This case behaves exactly like the single asterisk
file name described above. This is NOT a regular expression replacement, therefore any
characters before the asterisk are ignored and lost. When there is more than one asterisk,
only the first one is replaced. Examples follow.

Original NC program file: Optimized NC Program Output file name:


file name:
dir1/filename.mcd dir2/filename.mcd
dir2/*.*
dir1/filename.mcd dir2/filename.mcd
dir2/cf*
dir1/filename.mcd dir2/filename.ext
dir2/cf*.ext
dir1/filename.mcd dir2/filenamecf.*
dir2/*cf.*

Arc Plane Selection — Check boxes for major planes where arc fitting is requested.

Arc Fit Parameters:


The following options are only active when Arc Fitting has been selected above.

Fit Tolerance — Maximum deviation allowed for the fitted arc from the NC
program points being fitted. All points replaced by a circular motion must be
within this distance from the arc. In addition, the midpoint of all motion segments
being replaced must be within this distance from the arc.
Planar Tolerance — Maximum deviation from the plane formed by the motions
being tested. Points within this tolerance are adjusted to the plane defined by the
sequence.
Minimum number of arc points — Lower limit on the number of points required
to define an arc.
Smallest Arc Radius — Lower limit on radius of arcs created. Smaller arcs will
remain a sequence of points.
Largest Arc Radius — Upper limit on radius of arcs created. Larger arcs will
remain a sequence of points.

NURBS Fit Parameters:


The following options are only active when NURBS Fitting has been selected
above.

NURBS Tolerance — Maximum amount that the NURBS interpolated curve can
deviate from the from the linear cut segments being replaced.

417
Minimum number of NURBS points — Minimum number of linear cut segments
required before a NURBS curve fit is attempted.
NURBS Order (3or4) — Use to specify the "order of the NURBS. Select 3 or 4
depending on the what "order of NURBS" is supported by the machine controller.

Accel/Decel — This feature applies Accel/Decel settings from the NC machine


configuration to adjust optimized feed rates. VERICUT looks ahead in the NC program
file and slows the machine prior to direction changes, as well as changes feed rates based
on the machine axes ability to accelerate and decelerate. For more information on the
individual options, see Accel/Decel options on the OptiPath window.

Remove Colinear Points — When toggled "On", this feature eliminates colinear points
during Curve Fit processing.

G-Code Output Options — Displays the General and OptiPath & Curve Fit tabs of the
Control Settings window.

NOTES:
1. If you happen leave the 12 tab Configuration menu > Control Settings
window open and it gets hidden behind other windows then use G-Code
Output Options you may see all 12 tabs instead of just 2 tabs. This is because
it is the same window, displayed differently depending on where it is called
from.
2. When you use F1 Help on the 2 tab G-Code Output Options window, the
documentation for the 12 tab Configuration menu > Control Settings window
will display. The information for the General and OptiPath & Curve fit tabs is
the same for both cases.

OK — Updates the settings saved with the job and dismisses the NC Program Curve
Fitting Control window.

Process — Updates the parameters and processes the files selected for curve fitting.
Processing multiple NC programs may require running the Curve Fit process more than
once if the NC programs require different Curve Fit tolerances. For example, one pass
might be used for roughing NC programs and use a larger tolerance. A second pass would
then be used for finish NC programs using a smaller tolerance.

NOTE: When using Curve Fit, you must take into account the tolerances used by
the CAM system to create the original NC program(s). Using large Curve Fit
tolerances may cause the tool to deviate an unacceptable amount from the intended
surface.

418
Upon completion of processing, the curve fit results are displayed in the following
message:
Number of arcs created = xxx .
Number of moves replaced = yyy.
Blocks read = nnn
Blocks output = zzz
Do you wish to use the new file(s) as the active NC program file(s)?

A Yes answer will replace the list of NC programs for the current job with the modified
NC program files produced by Curve Fit. A No answer will not replace the NC programs
in the list.

Cancel — Dismisses the NC program Curve Fitting Control window without executing
Curve Fitting or saving Curve Fit parameters.

Curve Fitting with a Tool List


When Tool Change By is set to List, the Use Tool List button is becomes active. The
Tool Change List window will contain a Curve Fit column of check boxes. One or more
of these boxes must be checked for the appropriate curve fitting to be processed. If the
Curve Fit column is hidden, adjust the width of the visible columns.
Arc Quadrant Output
Some machines require that circular blocks do not cross quadrant boundaries. To output
this type of circular blocks, the macro CircleCurveFitQuadrants should be used as a Start
of Processing Event macro. The default allows blocks to cross quadrant boundaries.

419
Tool Change List window
Opened via pressing Use Tool List on the Project menu > NC Programs window, the
features on this window maintain a list of references that link tool change events to tools
stored in a Tool Library file. You can use this list to specify tools to use with sequential
tool changes, or to replace tools specified for use in the tool path file.

List Tool Change By — Specifies the tool change event used to build the tool list from.
Select an option, then press Build Tool List to have VERICUT automatically create the
tool change event list. Options are:

y Cutter Desc. — Changes tools when parametric cutter description records in the
tool path file are encountered, for example: CUTTER and VERICUT-TC
comment records.
y VERICUT TC — Changes tools when VERICUT-TC statements in the toolpath
file are encountered.
y Pocket Num. — Changes tools when tool path records that reference tool or
pocket numbers are encountered, for example: TnM6 (G-code tool paths),
LOADTL or LOAD TOOL, and TURRET.
y Prog. Stop — Changes when "program stop" codes are encountered, for example:
M0 (G-code tool paths) and STOP.
y Pocket Num per File — Similar to Pocket Num., except creates additional
entries in the list for duplicate tool numbers that appear in different tool path files.

Tool Change Event/Tool ID list — List of tool change events expected to occur during
the simulation as indicated by the active List Tool Change By option (see above), and
IDs of the tools to use for each. Event text must match the tool change record text exactly
as it appears in the NC program file. Type or left-click and choose the tool ID from an

420
option list. Right-click to add and delete tool list entries. For the Cutter Desc. and Prog.
Stop options, the list represents the sequential order of tool changes found in the tool path
file(s), and tools to use for each. A Pocket Num. list is a cross-reference index between
tool or pocket numbers referenced in the tool path file(s) to tool IDs in a VERICUT Tool
Library. A Pocket Num per File list is similar to Pocket Num., except creates additional
entries in the list for duplicate tool numbers that appear in different tool path files.

The Tool Change List consists of the following columns of information.

Event — displays the tool change event.


Cutter ID — the ID of the tool.
Holder ID — the ID of the holder associated with the tool.
Optipath Settings — the OptiPath settings associated with the tool.
File # — the file in the Toolpath List that the tool is associated with.
Curve Fit — this column is only visible when Toolpath Type in the Toolpath
window is set to G-Code Data and one or more of the NC programs in the NC
Programs list has Curve Fit toggled on.
Initial Pocket — this column is related to the use of tool chains. It enables you to
specify the pocket that the tool will be initially located.
When using Tool Change by List, the default initial pocket numbers are assigned as
follows. The first called tool is assigned to pocket 1, regardless of the tool number.
The second called tool is assigned to pocket 2, and so on. You can then change the
pocket number for each tool as necessary. When you do a Reset, the tool will
display in the assigned pocket. This feature is useful when using large tools that
could interfere with each other if located in adjacent pockets. Change the pocket
location to ensure that all the tool changes are collision-free. Another use would be
to optimize the tool change time for very short operations by minimizing the tool
selection time.

Add —Adds a new tool change event to the tool change event list. Event data can be
entered, or in the case of tool component IDs and OptiPath settings-can be selected from
option lists.
Delete —Deletes the selected tool change event from the tool change event list.
Clear —Clears all tool change events from the list.

NOTE: Always reset VERICUT (press on the VERICUT main window)


after making changes.

Prompt for OptiPath Settings while building the tool list—When active, causes
VERICUT to prompt for OptiPath settings during interactive tool path optimization. At
each tool change event an Optimization Settings window opens. Configure this window

421
as desired to optimize the cutting sequence, or choose "Do not optimize this tool". An
OptiPath Library file is created as you go containing the optimization settings defined for
each optimized tool.
For more information about optimizing tool paths, see "About optimizing tool paths".
Skip Duplicate Cutter Descriptions—When active, causes VERICUT to skip duplicate
cutter descriptions when building the tool change event list. This feature is useful for
suppressing redundant tool changes often output by CAM systems for different cutting
operations by the same cutter.
Build Tool List—Builds a tool list by scanning the files in the tool path list and looking
for the tool change events specified by the List Tool Change By feature (see above).
When multiple tool path files are listed, a comprehensive tool change events list is
created with all tool change activity from all listed tool paths. Sample output is shown in
the following image.

422
Tools

Tool Manager window

VERICUT Users:
VERICUT Location: Project menu > Tools

Toolbar shortcut to access the Tool Manager:

Mold and Die Users:


Mold and Die Location: Setup page > Work Directory

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Setup page > Create Wheels

Notebook Feature:

423
Opens a window to create and maintain VERICUT Tool Library files containing
descriptions of cutting tools, or tool assemblies. Library tools are used by VERICUT
when the Project menu > Toolpath function is configured to do so. In general, double-
click on a tool component to modify, or key in supporting values into the associated data
fields. Right-click to access shortcut menus for defining and modifying tools. Tools can
be defined interactively in VERICUT, or outside of VERICUT by running the Tool
Manager "toolman" command file.

The Tool Manager main window is composed of 4 distinct areas, each with different user
interaction. The window header displays the current tool library file. This window can be
resized like most other window, via dragging the window header, sides or corners.
To learn more about interacting with the Tool Manager main window components, click
on one the topics below.

y Menu Bar
y Tool Table
y Tool Display
y Message Area

Tips:
y Right-click shortcut menus: Features used to manipulate tools are displayed in a
shortcut menu when a tool is selected and the right mouse button is clicked in the
Tool Manager window. Similarly, features used to manipulate tool components
are displayed when they are selected and the right mouse button is clicked.
Finally, features used to manipulate the tool graphics is displayed when the right
mouse button is clicked in the Tool Display area.
y You can move objects in the Tool Manager window via dragging them from one
parent tool to another, or copy them via holding down the <Ctrl> key and
dragging.

424
Tool Manager window, Menu Bar
The menu bar, located across the top of the Tool Manager window, provides easy access
to Tool Manager functions. Each menu item contain groups of related functions. Left-
click on any menu name to display the list of functions available for that menu item. If an
arrow appears to the right of a function in a menu, move the mouse over the arrow to
display a sub-menu of additional functions. Click on the function, in the menu, that you
want to use. An expanded function list, for the Add menu is shown below.

File menu—Features in this menu are used to create new, open, or save Tool Libraries,
generate Tool Manager Report files, and close the Tool Manager window.

y New / Open / Save / Save As — Creates new, opens existing, or saves Tool
Library files.
y Save Selected Tool — Use to save the selected tool to a specified tool library
file. Selecting Save Selected Tool displays a file selection window enabling you
to specify a /path/filename for the tool library file.
y Import —
y DXF Tool — Opens the DXF Tool Geometry window enabling you to import
two dimensional tool geometry from files which comply with a de facto CAD
system standard, the Data eXchange Format (DXF).
y Export Selected Tool — Use to export highlighted tool in the specified format
(STL or VRML) Displays a file selection window enabling you to specify a
/path/filename for the file.
y Create from APT NC Program — Causes the Tool Manager to scan the tool
path files for cutter statements (including CUTTER, PPRINT-VERICUT TC, etc),
and create a tool library file named <user filename>.tls. The APT tool path tools
replace the current tool library contents. Tools are numbered sequentially,
beginning at 1.
y Import OptiPath Library — Opens the Open OptiPath library file window,
enabling you to import an existing OptiPath Library file.

425
y Create Report — Use to create and view a tool manager report (See How).
Choose one of the following formats:
y Text — Create an inspection sequence report in text format.
y HTML — Create an inspection sequence report in HTML format.
y PDF — Create an inspection sequence report in PDF format.
y Report Template — Displays the Report Template window enabling you to
select and/or modify an existing tool manager report template or create a new one.
y User-Defined Tag Values — Opens the User-Defined Tags window enabling
you to assign/edit user-defined tag values used by the current tool manager report
template.
y Close — Closes the Tool Manager window.

Edit menu — Features in this menu are used to edit tools in the library and their
cutter/holder components. (Functions also available via right-clicking on a tool
component.)

y Modify — Opens the Tool Add/Modify window enabling you to modify the
selected tool component (cutter, insert, probe tip, holder). The features displayed
on the window will vary depending on the selected tool component. This option is
not available when a tool is highlighted.
y Rename — Enables you to rename the highlighted tool/tool component.
y Delete — Deletes the selected tool/tool component.
y Cut / Copy / Paste — Enables you to cut, copy or paste the selected tool/tool
component within the same tool library file.
y Search Tool — Displays the Search Tool window.
y Search OptiPath — Displays the Search OptiPath Record window.
y Stack — Use to automatically stack tool components on top of each other.

View menu — Features in this menu provide control over viewing tools in the display
area, such as: view orientation, lighting, and symbols used to indicate driven point, gage
point, etc.

y Orient — Opens the View Orient window enabling you to orient the view of a
tool. Features include: rotate, zoom, pan, reverse, etc.
y Attributes — Opens the View Attributes window, enabling you to display/not
display Driven Point, Gage Point, and Axes symbols, as well as define a light
source direction vector for the Tool Display graphics window.
y Show All — Expands all tools in the ID list displaying the tool components
associated with each tool.
y Hide Tool Components — Closes all tools in the ID list displaying only the tools
in the list but none of the tool components.

426
Add menu — The features in this menu are used to add a new tool, or to add cutter,
insert or holder tool components to the selected tool. The features available will vary
depending on what is selected in the Tool table. These features are also available via
right-clicking on a tool and selecting from the shortcut menu.

y Milling Tool Wizard — Displays the Milling Tool Wizard window to assist you
in defining Milling tools.
y Tool —
y New — Adds a new tool to the library. Select the tool type (Mill, Turn, or
Probe) , then key in a unique ID to start the new tool definition.
y Select Existing — Displays the Search Tool window.
y Tool Component — Displays the Tool Add/Modify window enabling you to add
tool components to the highlighted tool.
y OptiPath —
y New — Displays the OptiPath window enabling you to define a new OptiPath
record for the highlighted tool.
y Select Existing — Displays the Search OptiPath record window.
y Driven Point — Use to add one or more a Driven Point records to the highlighted
tool.
y Cutter Compensation — Use to add one or more cutter compensation records to
the highlighted tool.

427
Milling Tool Wizard
The Milling Tool Wizard enables you to quickly and easily define tool assemblies for
your tool library.

y ID (tool) — Use to key in a unique ID for the new milling tool.


y Description — Use to add a description for the milling tool / tool assembly.
y Append cutter shape to description — When toggled "on", adds the cutter
shape description for the cutter defined below to the above description.
y ID (holder) — Use the text field to enter an ID for the "holder" component.

428
Holder Type
y None — Use to specify no "holder" component in the tool assembly.
y New — Displays a window enabling you to add an"extension" component to
the tool assembly. See Tool Add/Modify window: Component tab in Holder
mode for details.
y Search Holder — Displays the Search Tool window enabling you to search
for existing holders.
y ID (extension) — Use the text field to enter an ID for the "extension" component.
Extension Type
y None — Use to specify no "extension" component in the tool assembly.
y New — Displays a window enabling you to add an"extension" component to
the tool assembly. See Tool Add/Modify window: Component tab in Holder
mode for details.
y Search Holder — Displays the Search Tool window enabling you to search
for existing extensions/holders.
y ID (cutter) — Use the text field to enter an ID for the cutter component.
Cutter Type
y None — Use to specify "no" cutter component in the tool assembly.
y New Revolved Cutter — Displays a window enabling you to add a revolved
cutter component to the tool assembly. See Tool Add/Modify window:
Component tab in Revolved Cutter mode for details.
y New Insert Cutter — Displays a window enabling you to add a mill insert
cutter component to the tool assembly. See Tool Add/Modify window:
Component tab in Mill Insert Cutter mode for details.
y Search Revolved Cutter — Displays the Search Tool window enabling you
to search for existing revolved cutters.
y Search Insert Cutter — Displays the Search Tool window enabling you to
search for existing mill insert cutters.
y L2 — Use the text field to enter the exposed length of the "extension"
component. This distance is used to position the "holder" component along the
tool's Z-axis.
y L1 — Use the text field to enter the exposed length of the "cutter" component.
This distance is used to position the "extension/holder" component along the
tool's Z-axis.
y Stack — When toggled "on", automatically stacks tool components on top of
each other.
y Gage Point — Use the text field to enter the gage point.
y Calculate highest point on Z — When toggled "on", VERICUT calculates the
highest point on the Z-axis of the tool and uses it for the Gage Point.

429
y Driven Point — Use to specify the cutter's driven point.
y New — Creates the new tool record and leaves the Milling Tool Wizard window
open to create the next milling tool.
y Close — Use to close the Milling Tool Wizard window.

430
Tool Manager window, Tool Table
Table of tools defined in the Tool Library file. Tools listed in the table are arranged by
ID, but can be sorted by any attribute via clicking on the table header. You can also
search for tools in the library using the Search feature. Double-click the tool ID or click
the + / - symbols to expand or collapse branches of a tool assembly to see its cutter/holder
components. Stretch the window or use the scroll bars to see all the table data.

Tool Table Data:


y ID — Alpha-numeric text that identifies the tool in the Tool Library. IDs typically
correspond to tool or pocket numbers referenced by the the tool change record
that will call the tool from the library. For example, ID " 1" would normally be
used for a tool called by a G-code data block "T1M6", or an APT tool change
record "LOADTL/1". However, you can use a tool list to cross-reference tools
having IDs in a library that are different from those in the tool change record. See
Project menu > NC Programs for details.

The following symbols are used in the Tool ID tree:

Tool

Tool Components:
Insert Cutter
Revolved Cutter
Probe Tip
Holder

431
OptiPath Record
Driven Point Record
Cutter Compensation
Record

Hint: Use IDs and descriptions that make it easy for others to find tools they need.

y Description — Describes the tool or tool assembly. Any alpha-numeric text can
be entered in this field. Special characters are not recommended.
y Units — Controls the unit measurement system (Inch or Millimeter) in which to
describe the tool. If the tool units are different from the session units when loaded,
then tool description values are converted appropriately.
y Gage Point — Specifies the location of the tool assembly gage point. By default,
the gage point is located at the tool origin. Values entered move the gage point
relative to the tool origin, or you can select a gage point by clicking in the Gage
Point field then clicking on the tool in the Tool Display. As you move the mouse
over the tool, a point and normal vector show you the pending pick-point location.
y
When processing G-code tool paths, VERICUT uses the gage point in the
following two ways:

y Controls how the tool loads in the NC machine—When a tool is loaded for
cutting, the gage point is located at the NC machine's Tool component
origin.
y Sets the adjustment needed to drive the tool in "Tool Tip" and "Tool
Length Compensation" programming methods—These programming
methods enable an NC programmer to assume the positions in the tool
path are controlling the tool, instead of NC machine axis positions.
VERICUT uses the gage point to determine where the driven point is
(a.k.a. "control point") relative to the gage point.
y

Missing or incorrect gage point values causes a tool to load incorrectly on a 3-D
machine, or causes improper cutting.

432
Sample gage points for milling and turning tools:

433
The "Gage Point" view attribute displays a hollow target symbol at the gage
point location (ref. Tool Manager: View menu > Attributes).

NOTE: Gage Offset table values can be used to override Tool Manager-
defined Gage Offset values for setting the adjustment to calculate the driven
control point (condition #2 above). However, they do not affect how the tool
is loaded in the NC machine (condition #1 above).

When the Gage Offset table is used to adjust tool motions, the NC control must be
configured to call the ToolOffsetAptAdj macro when a tool change occurs, or when
the tool control point changes, to adjust the motions seen in Workpiece views. The
ToolOffsetAptAdj macro allows the machine simulation to be driven with multiple
tool control points, when a single tool control point was defined in the Tool
Manager.
If this macro is not called on or after the tool change command, or when the tool
control point changes, then Workpiece views may not reflect the adjustment to the
Tool Manager-defined Gage Offset.

y Orientation — Specifies the orientation of the tool assembly when loaded for
cutting. Three values are entered (separated by spaces) to define the X, Y, Z
rotation angles, respectively. Angle values are in degrees, relative to the tool
origin. Rotation occurs about the tool's gage point.
NOTE: This feature is only applicable when NC Program Type is G-Code
Data.
y Teeth — Automatically indicates the number of teeth of the tool referenced by
the Optipath record selected from the OP Description pull-down list.
NOTE: You have the ability to manually edit the number of teeth (either by
typing in a value or selecting a value from the pull-down list) but be aware
that if the number of teeth entered does not match the number of teeth
specified in the OptiPath record, the tool will not be optimized.
y Comments — This field enables you to add comments related to the tool. The
comment text is stored with the tool ID.

Driven Point record — Specifies an offset for the tool control point, or "driven point".
Material is removed based on motion commands and the tool shape relative to the control
point. For milling tools, a positive value moves the control point in the positive tool axis
direction (closer to the spindle), while a negative value moves the control point in the
opposite direction. For turning tools, XYZ values (separated by spaces) are entered
relative to the spindle axis (Z), and cross-slide axis (X).

434
Sample Driven Point values for a milling tool (left) and turning tool (right):

When defined, the "Driven Point" view attribute displays as a hollow target symbol
at the control point location. (Ref. Tool Manager: View menu > Attributes)

Cutter Compensation record — Specifies the cutter compensation value for a particular
tool.

Shortcuts:
1. Double click a tool component in the Tool Table to display the Tool
Add/Modify window to enable modification of the tool.
2. Right-click in the Tool Table to display the following menu:

Modify
Rename
Delete
Cut
Copy
Paste

435
Add Tool New Mill
Add Tool Component Select Existing ... Turn
Add OptiPath New Probe
Add Driven Point Select existing ...
Add Cutter Compensation
Search Tool
Search OptiPath
Stack

436
Tool Manager window, Tool Display
Tool Display area — Displays the tool selected in the Tool Table. Colors distinguish
holders from cutter components. Target symbols indicate the tool's driven point and gage
point. Use the View Orient functions to visually manipulate the tool in the display area.

Shortcuts:
1. Double click a tool component in the Tool Display area display the Tool
Add/Modify window to enable modification of the tool.
2. Right-click in the Tool display area to display the following menu:

Fit
Reverse
Select View XY
Driven Point YX
Gage Point YZ
Axes ZY
ZX
XZ
V-
ISO
H-
ISO

437
Tool Manager window, Message Area

The message area, also known as the "message logger", is located at the bottom of the
Tool Manager window, and by default displays the most recent message VERICUT has
provided. VERICUT provides error, warning, and informational messages to assist you
while working in the Tool Manager.
To review previous messages, click on the message line-the most recent message is listed
last. Click again to close the message logger.

438
Tool Manager - Tool Add/Modify window
Location: Project menu > Tools: Add menu > Tool > New > Mill ( or Turn, or
Probe), or
Add menu > Tool Component
Edit menu > Modify

Opened via adding or modifying tool/tool components, this window is used to describe
tool component shape, color, location, and other attributes. Features displayed on the
Components tab of this window will vary, depending on the tool/tool component type
that you selected to add/modify. The Tool Component tab for a Revolved Cutter
component type is shown below.

439
Tool Component tab — Features on this tab are used to define the shape of a tool
component in a tool assembly. Features displayed on the Tool Component tab vary,
depending on the tool/tool component type that you selected to add/modify. Select one
of the following tool component types for specific information.

y Revolved Cutter
y Mill Insert Cutter
y Turn Insert Cutter
y Probe Tip
y Holder

Assembly tab — Features on this tab are used translate or rotate a component in a tool
assembly, or to move the selected component by assembling (mating or aligning) it with
other objects in the tool assembly.

Add — Use to apply the specified data to the new tool component.
Modify — Use to apply the modified data to an existing tool component.
Close — Close the Tool Add/Modify window without applying the data.

440
Tool Component tab - Revolved Cutter
Opened via adding or modifying a Revolved Cutter tool component, this window is used
to describe the shape of a selected "Cutter" component in a mill tool assembly. Options
are available to define the cutter via parametric shapes, profile sketcher, or reference a
cutter in another tool assembly.

Tool shape icons — Selecting an icon configures the bottom half of the window to
define the selected cutter shape. Options:

Icons: Name: Description:


Diameter (D)
Flat Bottom End
Height (H)
Mill

Diameter (D)
Ball Nose End
Height (H)
Mill

Bull Nose End Diameter (D),


Mill Corner Radius
(R), Height (H)

441
Drill Diameter (D),
Drill Point Angle
(A), Height (H)

7 Parameter D, R, E, F, A, B,
H

10 Parameter D, R1, E1, F1,


A, B, H, R2, E2,
F2

Profile Opens the Profile Sketcher in "SOR" mode.

Reference Displays the Reference features enabling you to


reference a mill cutter in another tool assembly.

The following options are common to all Tool Add/Modify mill cutter windows
except Reference:
Flute Length — Length of the cutter having flutes, or teeth, that can remove
material. This value is measured from the bottom-most portion of the cutter. Zero
assumes the entire cutter length has flutes, or teeth that can cut material. An error
similar to "SHANK removed material..." is reported when the non-cutting portion
of the cutter removes material. Material removed is shaded using the red Error
color.

442
Shank Diameter — Diameter of the tool shank.
Color — Color of the tool component as seen in a machine view. The cuts made by
the cutter are also shaded with this color when the Cut Color Method is set to "Tool
Library". Available colors are the Shade Colors defined on the Edit menu >
Colors: Define tab. Components in a tool assembly have the option to "Inherit" or
override the Tool component's defined color.

Spindle Direction — Use to specify the appropriate spindle rotation direction for
the tool. Choose either CW (clockwise) or CCW (counterclockwise).

NOTE: For revolved milling cutters, CW/CCW is defined looking down


(negative Z) the tool axis.

443
Tips for defining milling cutters:
y Diameter is measured from the intersection points of the cutter side with the
bottom flat or angle.
y D is automatically calculated when D=0, and the corner radius (R) and side angle
(B) are specified. (Good tip for defining tapered endmills.)
y E and F are automatically calculated when diameter and corner radius are
specified.
y Examples of milling cutter shapes that can be defined via the 7 Parameter
option:

444
Tool Component tab - Mill Insert Cutter
Opened via adding or modifying a milling Insert Cutter tool component, this window is
used to describe the insert shape, position and orientation for the "Cutter" component in a
mill tool assembly. Options are available to define the cutter insert via ISO standard
shapes, profile sketcher, or reference a cutter insert in another tool assembly.

Tool Component tab —


Tool shape icons — Selecting an icon configures the bottom half of the window to
define the selected cutter shape. Options:

Icons: Name: Description:


General Insert Displays the General Insert
features enabling you to define ISO
standard insert shapes.
Profile (sweep) Opens the Profile Sketcher in
"sweep" mode.

Reference Opens the Reference window


enabling you to reference an insert
in another tool assembly.
Model File Displays the Model File features
enabling you to specify a model
file to be used as an insert.

NOTE: For inserted milling cutters, tool spinning direction is determined by the insert
thickness direction.

445
Tool Component tab - Turn Insert Cutter
Opened via adding or modifying a turning Insert Cutter tool component, this window is
used to describe the insert shape, position and orientation for the "Cutter" component in a
turning tool assembly. Options are available to define the cutter insert via ISO standard
shapes, profile sketcher, or reference a cutter insert in another tool assembly.

Tool shape icons — Selecting an icon configures the bottom half of the window to
define the selected cutter shape. Options:

Icons: Name: Description:


General Insert Displays the General Insert features
enabling you to define ISO
standard insert shapes.
Groove Insert Displays the Groove Insert
features enabling you to define ISO
standard groove insert shapes.
Thread Insert Displays the Thread Insert features
enabling you to define ISO
standard thread insert shapes.
Profile (sweep) Opens the Profile Sketcher in
"sweep" mode.

Reference Displays the Reference features


enabling you to reference an insert
in another tool assembly.
Model File Displays the Model File features
enabling you to specify a model file
to be used as an insert.

446
Tool Component tab - Probe Tip
Opened via adding or modifying a probe tip tool component, this window is used to
describe the shape, position and orientation of a probe tip component in a probe tool
assembly.

Probe Tip — Features on this tab enable you to describe the shape of a probe tip
component.
Sphere Diameter — Diameter of the sphere at the end of
the probe tip.
Stem Diameter — Diameter of the probe tip stem.
Probe Length — Length of the probe tip.
Maximum RPM — The maximum speed that a probe
tool can spin before a spindle On/Off error is output. The
default value is 0.
Color—Color of the tool component as seen in a machine
view. The cuts made by the cutter are also shaded with
this color when the Cut Color Method is set to "Tool
Library". Available colors are the Shade Colors defined
on the Edit menu > Colors: Define tab. Components in a
tool assembly have the option to "Inherit" or override the
Tool component's defined color.

447
Tool Component tab - Holder
Opened via adding or modifying a Holder tool component, this window is used to
describe the shape of a selected "Holder" component in a tool assembly. Options are
available to define the holder via parametric shapes, profile sketcher, or reference a
holder in another tool assembly. More than one holder can be used in a tool assembly. An
error similar to "HOLDER removed material..." is reported when the non-cutting portion
of the cutter removes material. Material removed is shaded using the red Error color.
Tool Component tab — Features on this tab are used to define the shape of a "holder"
component in a tool assembly.
Holder icons — Selecting an icon configures the bottom half of the window with
the parameters required to define the holder shape. Options:
Icons: Name: Description:
Length (L)
Block
Width (W)
Height (H)

Radius (R)
Cylinder
Height (H)
Tolerance

Bottom Radius
Cone
(R1)
Top Radius (R2)
Height (H)
Tolerance

448
Profile - SOR Opens the Profile Sketcher in "SOR" mode.

Profile - Sweep Opens the Profile Sketcher in "Sweep" mode.

Reference Displays the Reference features enabling you


to reference a holder in another tool assembly.

Model File Displays the Model File features enabling you


to select a model file to define the holder.

The following option is common to all Tool Add/Modify Holder windows:

Do Not Spin with Spindle — When toggled "On", indicates that the holder
component does not spin.
The following option is common to all Tool Add/Modify Holder windows
except Reference:
Color — Color of the tool component as seen in a machine view. Available colors
are the Shade Colors defined on the Edit menu > Colors: Define tab. Components
in a tool assembly have the option to "Inherit" or override the Tool component's
defined color.

449
Common Features

Reference feature
Tool Add/Modify, Reference feature enables you to "reference" a tool component in
another tool library file for use in the current tool library file.

Reference features:
Reference File — Enter the /path/filename of the tool library file containing the
tool component to be referenced in the text field or use the Pick button to display
the Reference Id Pick List window and use it to select the tool library file.
Reference ID — Enter tool ID of the tool component to be referenced in the text
field or use the Pick button to display the Reference Id Pick List window and use it
to select the tool component to be referenced.
Pick — Displays the Reference Id Pick List window enabling you to select the tool
component to be referenced from the from the list. The first time that Pick is
selected during a VERICUT session, a standard file selection window is displayed
so that you can select a tool library file. After the tool library file has been selected,
the Reference ID Pick List window is displayed so that you can select the tool
component.
On subsequent selections of the Pick button during a session, the Reference Id Pick
List window is displayed with the previously selected tool library file. Enter the
/path/filename in the Tool Library text field or use the Browse button to display a
file selection window and use it to change the tool library file

450
Sample Reference ID Pick List window:

451
General Insert features
General Insert features enables you to define "ISO standard", as well as "custom" tool
insert shapes. The parameters and diagram will vary depending on the Insert Type
selected from the list. Only the parameters required to describe a particular insert type
will be displayed.

Insert Type: Parameter Description:


A - 85 degree L - Length
parallelogram W - Width
Thickness
R - Corner Radius
A - Lead Angle
Color

B - 82 degree L - Length
parallelogram W - Width
Thickness
R - Corner Radius
A - Lead Angle
Color

452
C - 80 degree D - Inscribed
diamond Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

C - 100 degree D - Inscribed


diamond Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

D - 55 degree D - Inscribed
diamond Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

453
E - 75 degree D - Inscribed
diamond Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

H - Hexagon D - Inscribed
Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

K - 55 degree L - Length
parallelogram W - Width
Thickness
R - Corner Radius
A - Lead Angle
Color

454
L - Rectangle L - Length
W - Width
Thickness
R - Corner Radius
A - Lead Angle
Color

M - 86 degree D - Inscribed
diamond Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

O - Octagon D - Inscribed
Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

455
P - Pentagon D - Inscribed
Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

R - Round D - Inscribed
Diameter
Thickness
Color

S - Square L - Length
Thickness
R - Corner Radius
A - Lead Angle
Color

456
T - Triangle D - Inscribed
Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

V - 35 degree D - Inscribed
diamond Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

W - 80 degree D - Inscribed
trigon Diameter
Thickness
R - Corner Radius
A - Lead Angle
Color

457
Custom D - Inscribed
diamond Diameter
Thickness
R - Corner Radius
A - Lead Angle
T - Tip Angle
Color

Custom L - Length
parallelogram W - Width
Thickness
R - Corner Radius
A - Lead Angle
Color

Color - Color of the tool component as seen in a machine view. The cuts made by
the cutter are also shaded with this color when the Cut Color Method is set to "Tool
Library". Available colors are the Shade Colors defined on the Edit menu > Colors:
Define tab. Components in a tool assembly have the option to "Inherit" or override
the Tool component's defined color.

Location Aids — This feature is only available for mill Inserts. It enables you to easily
position the insert with respect to the tool diameter.
W (Diameter) - Use this text field to specify the diameter of the tool.

Locate by nominal diameter - Positions the center of the insert corner


radius on the tool diameter.

Locate by outside diameter - Positions the outside edge of the insert on


the tool diameter.

458
Groove Insert features
Groove Insert features enables you to define "ISO standard" groove insert shapes. The
parameters and diagram will vary depending on the Insert Type selected from the list.
Only the parameters required to describe a particular insert type will be displayed.
Groove Insert features are only available for defining turning cutters.

Insert Type: Parameter Description:


Square, double W - Width
end L - Length
Thickness
R - Corner Radius
C
D
Color

Radius, double W - Width


end L - Length
Thickness
R - Corner Radius
D
Color

459
40 degree V, W - Width
double end L - Length
Thickness
R - Corner Radius
C
D
Color

45 degree W - Width
chamfer, double L - Length
end Thickness
R - Corner Radius
C
D
Color

Square, single end W - Width


L - Length
Thickness
R - Corner Radius
C
D
Color

460
Chamfer, single W - Width
end L - Length
Thickness
R - Corner Radius
C
D
A - Chamfer Angle
Color

Round, single end L - Length


Thickness
R - Corner Radius
C
Color

Radius, single end L - Length


Thickness
R - Corner Radius
C
Color

Color - Color of the tool component as seen in a machine view. The cuts made by
the cutter are also shaded with this color when the Cut Color Method is set to "Tool
Library". Available colors are the Shade Colors defined on the Edit menu >
Colors: Define tab. Components in a tool assembly have the option to "Inherit" or
override the Tool component's defined color.

461
Thread Insert features
Thread Insert features enables you to define "ISO standard" thread insert shapes. The
parameters and diagram will vary depending on the Insert Type selected from the list.
Only the parameters required to describe a particular insert type will be displayed. Thread
Insert features are only available for defining turning cutters.

Insert Type: Parameter Description:


55 degree, triangle D - Inscribed
Diameter
Thickness
R - Corner
Radius
E
Color

60 degree, triangle D - Inscribed


Diameter
Thickness
R - Corner
Radius
E
Color

462
30 degree, trapeze D - Inscribed
triangle Diameter
Thickness
R - Corner
Radius
E
F - Flat
Color

ACME, triangle D - Inscribed


Diameter
Thickness
R - Corner
Radius
E
F - Flat
Color

Buttress, triangle, D - Inscribed


right hand Diameter
Thickness
R - Corner
Radius
E
F - Flat
Color

463
Buttress, triangle, D - Inscribed
left hand Diameter
Thickness
R - Corner
Radius
E
F - Flat
Color

60 degree, double W - Width


end, asymmetric L - Length
Thickness
R - Corner
Radius
E
Color

60 degree, double W - Width


end, symmetric L - Length
Thickness
R - Corner
Radius
E
Color

464
ACME, double end W - Width
L - Length
Thickness
R - Corner
Radius
E
F - Flat
Color

Buttress, double end W - Width


L - Length
Thickness
R - Corner
Radius
E
F - Flat
Color

Color - Color of the tool component as seen in a machine view. The cuts made by
the cutter are also shaded with this color when the Cut Color Method is set to "Tool
Library". Available colors are the Shade Colors defined on the Edit menu >
Colors: Define tab. Components in a tool assembly have the option to "Inherit" or
override the Tool component's defined color.

465
Model File features
Model File — Enter the /path/filename of the model file or use the Browse button to
display a file selection window and use it to select the model file.
Sketcher — Displays the Profile Sketcher window enabling you to edit or create a
"swept solid (.swp)" or "solid of revolution (.sor)" model file. This feature is only
available the selected file is a SOR or SWEEP file type. To create a new SOR or SWEEP
model file, clear the Model File text field and press Sketcher.
Normals — This feature applies to STL file models only and indicates the direction in
which surface normals defined in the STL data point, relative to the model. Select
Inward, Outward, or Computed (let VERICUT determine the direction of the surface
normals).
Color — Color of the tool component as seen in a machine view. Available colors are the
Shade Colors defined on the Edit menu > Colors: Define tab. Components in a tool
assembly have the option to "Inherit" or override the Tool component's defined color.

466
View Attributes window

The following features enable you to control view attributes related to the Tool Manager,
Tool Display area.

y Driven Point — Use to display/not display the driven point symbol .

y Gage Point — Use to display/not display the gage point symbol .


y Axes — Use to display/not display the axes representing the tool origin.
y Light (IJK) — I J K vector direction in which the light source points. The three
values are separated by spaces.

467
Assembly tab
Location: Project menu > Tools: Add menu > Add Tool Component, or Project
menu > Tools: Edit menu > Modify

Features on this tab are used translate or rotate a component in a tool assembly, or to
move the selected component by assembling (mating or aligning) it with other objects in
the tool assembly.

Translate group:
Features in this group translate the selected object via indicating "from" and "to" points to
move the object.Movement occurs each time you press the Move button. If the applied
movement is incorrect, press Undo to return the object to its previous location.

468
Features on this tab function the same as Translate features for modeling. (See how)

y From / To— Specifies the locations to move the object from and to, relative to
the tool origin. XYZ values can be entered (separated by spaces), or selected by
clicking in the field then clicking on a tool component shape. As you move the
mouse over the tool, a crosshair and vector show you the pending pick-point
location.
y Move— Moves the selected object by the incremental distance, as calculated
from the "From" point to the "To" point location.

Rotate group:
Features on this tab rotate the selected object about a rotation center point. Movement
occurs each time you press one of the rotation direction buttons: X+/X-, Y+/Y-, Z+/Z-. If
the applied rotation is incorrect, press Undo to return the object to its previous location.
Features on this tab function the same as Rotate features for modeling. (See how)

y Center of Rotation—Specifies XYZ point location about which to rotate the


object. XYZ values can be entered (separated by spaces), or selected by clicking

in the field then clicking on a model. To see the center of rotation, press .
To remove the center of rotation symbol press the button again, or close the
window.
y Increment—Specifies incremental degrees of rotation to apply when one of the
rotation direction buttons are pressed.
y Rotation buttons—(X+/X-, Y+/Y-, Z+/Z-) Applies the incremental degrees of
rotation specified in the Increment field. Rotation occurs about the Center of
Rotation relative to the tool origin.

Assemble group:
Similar to assembling models, objects are assembled by mating or aligning one to three
planar surfaces with surfaces on other tool components. (See how) If a non-planar surface
is selected, VERICUT constructs a tangent plane at the pick point. The relationship of
surfaces being mated or aligned is known as a "constraint". Follow these general steps to
define a constraint for assembly:
Choose the constraint type.
Select a surface on the object to move.
Select the surface to move the object relative to.
Press Apply.

469
Constraint Type—Specifies how to constrain selected surfaces during object movement.
After selecting two surfaces to define a constraint, VERICUT moves the object and
highlights the satisfied constraint with a checkmark. Options:

y Mate—Moves the object so the selected surface opposes the surface selected on
the second object (surface normals oppose each other).
y Align—Moves the object so the selected surface is aligned with the surface
selected on the second object (surface normals point in the same direction).
y Offset—Distance and direction in which to offset constrained surfaces, applied
normal to the surface.
y
Absolute group:

y Position—Specifies the absolute XYZ position of the object relative to the tool
origin. Values in this field are separated by spaces.
y Angles—Specifies the absolute XYZ rotation of the object relative to the tool
origin. Values in this field are separated by spaces.

Reset—Resets constraints to receive new data.


Undo—Returns the object to its previous location, or as it was when the window was
opened.

470
Search Tool
Location: Project menu > Tools: Add menu > Tool > Find Existing or
Edit menu > Search Tool

Search Tool enables you to search existing tool libraries for tools with the specific
attributes.

Libraries group:
y Files — Use to search one or more tool library files for tools meeting the
specified search criteria.
y Directories — Use to search one or more directories of tool library files for tools
meeting the specified search criteria.

471
y Browse — Displays a selection window to assist you in selecting the
files/directories to be searched.

Tool group:

y ID — Search for the specified tool ID.


y Description — Search for a specified string of text within the tool's Description
field.
y Comments — Search for a specified string of text within the tool's Comment
field.
y Units — Select Any, Inch or Millimeter from the pull-down list.
y Component Type — Use to search for tools that include a specific tool
component type. Select Any, Revolved Cutter, Insert Cutter, Probe Tip, or
Holder from the pull-down list.
y Teeth — Use to search for tools containing cutters with a specific number (or
within range of) of teeth.

Revolved Cutter group:

y Diameter — Use to search for revolved cutters with a specific diameter (or
within a diameter range).
y Flute Length — Use to search for revolved cutters with a specific flute length (or
within a flute length range).
y Height — Use to search for revolved cutters with a specific heights (or within a
height range).
y Corner Radius — Use to search for revolved cutters with a specific corner radius
(or corner radii within a range).

Insert Cutter group:

y Insert Style — Use to search for a specific insert style (General, Groove, or
Thread). Select one of the following insert styles from the pull-down list"

Tips:
1. Hold the cursor over any insert style below to see a description .
2. Click on the any isert style below to see a picture of the insert.

472
Any GENERAL INSERT A GROOVE INSERT S2 THREAD INSERT T55
GENERAL INSERT B GROOVE INSERT R2 THREAD INSERT T60
GENERAL INSERT C GROOVE INSERT V2 THREAD INSERT TT
GENERAL INSERT GROOVE INSERT C2 THREAD INSERT TA
C100
GENERAL INSERT D GROOVE INSERT S1 THREAD INSERT TBR
GENERAL INSERT E GROOVE INSERT C1 THREAD INSERT TBL
GENERAL INSERT H GROOVE INSERT O1 THREAD INSERT A60
GENERAL INSERT K GROOVE INSERT R1 THREAD INSERT S60
GENERAL INSERT L THREAD INSERT DA
GENERAL INSERT M THREAD INSERT DB
GENERAL INSERT O
GENERAL INSERT P
GENERAL INSERT R
GENERAL INSERT S
GENERAL INSERT T
GENERAL INSERT V
GENERAL INSERT W
GENERAL INSERT
CD
GENERAL INSERT CP

y Insert Size — Use to search for insert cutters with a specific insert size (or within
a range of insert sizes).
y Thickness — Use to search for insert cutters with a specific thickness (or within a
thickness range).
y Corner Radius — Use to search for insert cutters with a specific corner radius
(or corner radii within a range).

Probe Tip group:

y Sphere Diameter — Use to search for probe tips with a specific sphere diameter
(or within a diameter range).
y Stem Diameter — Use to search for probe tips with a specific stem diameter (or
within a diameter range).
y Probe Length — Use to search for probe tips with a specific length (or within a
lenght range).

473
Holder group:
y ID — Use to search for a holder with a secific ID.

Search — Start the search of the specified tool library (libraries) based on the attributes
specified above.

Tool List:
Displays the a list of tools found during the search. The Tool List display and interaction
is the same as the Tool Table in the Tool Manager, with the one exception that the tool
library file name is also displayed here.

Duplicate — Duplicates the selected tool in the current tool library.


Reference — Creates a reference to the selected tool in the current tool library.
Close — Closes the Search Tool window.

474
OptiPath window
VERICUT Users:
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)
Mold and Die Users:
Mold and Die Location: Other Settings page > Add/Modify Speed and Feed Settings

Notebook Feature:
Opens a window enabling you to create and maintain OptiPath records that describe how
to optimize feed rates and/or spindle speeds for various tools and cutting conditions. The
OptiPath data is used by VERICUT during tool path optimization. The OptiPath window
shows the optimization values for the selected tool.

475
OptiPath record data:

y Description — Use to enter a description for the OptiPath record.


y Material — Stock material to be cut. Enter a new material name, or click on the
arrow to select from a list of materials defined in the library. Any combination of
alpha or numeric characters can be used.
y Machine—NC machine that will be used to cut the workpiece. Enter a new
machine name, or click on the arrow to select from a list of machines defined in
the library. Any combination of alpha or numeric characters can be used.

Unit Power—Power required to remove one cubic unit of material per minute. The
power specification differs, depending on the units set for the OptiPath record (ref.
Settings tab below).
Accel/Decel—When active and a G-code tool path is being optimized, this feature
applies Accel/Decel settings from the NC machine configuration to adjust optimized feed
rates. VERICUT looks ahead in the tool path file and slows the machine prior to direction
changes, as well as changes feed rates based on the machine axes ability to accelerate and
decelerate. Options:

y Off—Does not adjust optimized feed rates for acceleration/deceleration.


y Exact Stop—Assumes all axes must stop and be positioned exactly at the
programmed location before the next block is processed. This option is
recommended when sharp corners are required between motion blocks.
y Continuous—Allows small errors in positioning in order to maintain a more
constant velocity during corners or direction changes.

NOTES:
The block preceding an un-optimized block is not processed through Accel/Decel
logic.
Accel/Decel settings apply to all linear and circular motions, including those in
air.

OptiPath Cutter Shape Graphic — The cutter shape automatically displays for the tool
in the Tool Library that the OptiPath record is associated with. VERICUT refers to the
cutter shape to calculate material removal volume and other machining related data via
features on the OptiPath Manager Feed/Speed tab.
Feed/Speed tab — Features on this tab are used to describe and test various cutting
conditions to optimize, as well as control how optimization will be performed for the
selected tool.

476
Settings tab — Features on this tab specify important settings for the optimization
process, such as: the OptiPath record units, when to add (interpolate) more cuts,
resolution, minimum/maximum optimized feed rates, how to optimize circle and NURBS
motions, and more.
Hard Material tab — The features on this tab enable you to adjust the optimized feed
rate for ‘hostile’ cutting conditions (non-climb, thin radial width, and side-loaded cuts)
when cutting hard materials.
Spindle tab — The features on this tab limit RPM fluctuations and specify feed per tooth
load maintained during Surface Speed optimization.
Plunge tab — The features on this tab control the optimized feed rate for motions along
the tool axis that plunge into or retract from material.
Entry/Exit tab — The features on this tab control the optimized feed rate for entering
and exiting material.
Angle tab — The features on this tab adjust the optimized feed rate for 3-axis linear cuts
ramping in material.
Depth Table tab — The features on this tab controls how optimized feed rates are
calculated for cutting at various depths during Optimize by Tables optimization.
Width Table tab — The features on this tab adjust the optimized feed rate for cuts that
are less than full cutter width during Optimize by Tables optimization.

Add —Adds the Optipath data and optimization parameters to the newly created
OptiPath record.
Modify —Applies the modified Optipath data and optimization parameters to an existing
OptiPath record.
Close—Closes the OptiPath Manager window.

477
OptiPath window, Feed/Speed tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

as well as control how optimization will be performed for the selected tool. As methods
are selected, some of the features become locked (unavailable for editing). However, they
respond to show you the relationships between feed per tooth, RPM, cutter shape, and
feed rate through various cutting conditions. In general, this is a three step process:
Configure the features in the Cutting Condition group to represent a known
successful cutting condition which is typical for the tool.
Select the desired optimization method(s).
Again use the Cutting Condition group to test how optimization will be performed.
After configuring the features on this tab, be sure to review the other tabs in the OptiPath
window for proper optimization values.

Cutting Condition group:


These group of features used to describe and test various machining conditions to
optimize. You can enter or adjust the sliders to set the desired values. As values change,
the cutter graphic is updated to reflect the current cutting condition. The unit of measure
for the values are determined by the units selected on the Settings tab.

NOTE: If the sliders don't go far enough to reach the desired value or the value
in the corresponding data field turns red, then another optimization setting is
limiting input. If all settings on the Feed/Speed tab look okay, then check
values on the Settings tab, such as Maximum/Minimum Cut feed rates.

Axial Depth / Radial Width — Depth and width of cut.


Feed per Minute — Feed rate calculated from feed per tooth, spindle speed, and number
of cutting teeth on the cutter.
Feed per Tooth — Thickness of material or "chip load" removed by each tooth on the
cutter.

Optimization Method group:


This group of features are used to control how optimization will be performed for the
selected tool. Note that all methods optimize air cuts (tool motions not in contact with
material). However, the Air Cut Feed Rate method optimizes only the cuts entirely in
air.

478
Tip: When Chip Thickness and Volume Removal methods are combined (both
selected), VERICUT calculates optimized feed rates for each, then uses the feed
rate having the smaller value. This has the affect of protecting you against
excessive chip thickness or volume conditions that can occur using only one of
these optimization methods.

Chip Thickness — When selected, optimizes cutting by flat, ball, and bull nose endmills
based on maintaining a specified chip thickness. This method increases the feed rate
when width of cut is less than 50% cutter diameter, or when depth of cut is less than the
tool corner radius. Good for optimizing high speed machining and for semi-finishing and
finishing operations using carbide cutting tools where the danger of "chip thinning"
exists. It is especially effective for mold and die applications machining hard materials.
Use the slidebar or enter the chip thickness in the data field. If unknown, unselect all
optimization methods and use the Cutting Condition sliders to calculate it.
Volume Removal — When selected, optimizes based on a constant volume of material
to be removed. This option is good for optimizing tools that encounter widely varying
cutting conditions, such as hogging or roughing operations that cut at different cut depths
and widths. Use the slidebar or enter the volume removal rate (cubic units) in the data
field. If unknown, unselect all optimization methods and use the Cutting Condition
sliders to calculate it.
Spindle Speed — When selected, outputs spindle speed values that support optimized
feed rates. This value is also considered for Cutting Condition calculations (see above).
Use the slidebar or enter the spindle speed (revolutions per minute) in the data field.
Surface Speed — When selected, optimizes feed rates and spindle speeds based on
constant surface speed (CSS). Good for optimizing finish machining by ball or bull-nosed
endmills and high speed machining, this option varies spindle speeds to maintain a
constant surface speed at the maximum tool contact diameter. Feed rates are adjusted to
maintain a constant feed per tooth ("chip load") in material. Use the slidebar or enter the
CSS value in feet/minute (FM) for inch tool paths, meters/minute (MM) for metric tool
paths. If unknown, unselect all optimization methods and use the Cutting Condition
sliders to calculate it. Use features on the Spindle tab to limit RPM fluctuations and
specify the feed per tooth load to be maintained.

NOTE: CSS optimization is for use on high speed NC machines capable of


varying spindle speed quickly without harming spindle motor hardware.

Spindle Power — Power required to remove material. The value entered differs
depending on the active units for the OptiPath record:
Inch units => horsepower required to remove 1 cubic inch of material
Metric units => kilowatts required to remove 1 cubic centimeter of material per
second

479
Air Cut Feed Rate — This option is useful for reducing time of proven tool paths,
without affecting cutting feed rates and resulting surface finishes. When the checkbox is
cleared, this feature controls the feed rate used by all other optimization methods to
optimize air cuts.
Default option — when selected, the air cut feed rate is determined as follows:

G-code tool path = Max Feed Velocity of the machine's X-axis.


APT tool path = Fast Feed value.

To specify an air cut feed rate value, clear the Default checkbox and enter a value in the
data field. The feed rate entered should reflect the maximum speed at which machine
axes can move simultaneously in feed mode (e.g. G01).
Optimize by Tables — When selected, optimizes based on specified feed rates for
various cut depths, widths, and angles. This option is good for optimizing tools used in
hogging or roughing operations where more control over cutting feed rates for various cut
depths, widths, or angles is desired. Use the features on the Depth Table, Width Table,
and Angle tabs to configure settings for this method.
Fill — Automatically fills table data fields with values calculated using the Cutting
Condition sliders. The following values are supplied:

Depth Table => defines five equally spaced cut depths based on cutter height and a
cutting feed rate for each, based on volume of material removed. Also supplies the
calculated volume removal rate for the value for Max. Volume Removal Rate.
Width Table => calculates a percentage of calculated feed rate for each % Width
value based on volume of material removed.

480
OptiPath window, Settings tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

Features on this tab specify important settings for the optimization process, such as: the
OptiPath record units, when to add (interpolate) more cuts, resolution,
minimum/maximum optimized feed rates, how to optimize circle and NURBS motions,
and more.

After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

Modify Existing Cuts Only — When selected, this option calculates the most efficient
feed rate for each motion. VERICUT uses the Resolution value (see below) to divide
each motion into samples and calculates an optimum feed rate for each sample. The feed
rate calculated for the sample with the most severe cutting conditions is retained as the
optimized feed rate for that motion. This option is recommended when disk space is
limited for storing optimized tool path data, or when tool positions are relatively close
together. A tool path optimized with this choice has more efficient feed rates and the
same or slightly more records than the original.

Sample optimization results using the Modify Existing Cuts Only option:

481
Add More Cuts — Similar to Modify Existing Cuts Only except motions are divided
up when cutting conditions warrant feed rate changes. A tool path optimized with this
choice has very efficient feed rates, but many more records than the original. The
Minimum Feedrate Change value (see below) controls the quantity of feed rates output
to the optimized tool path file. This option is recommended when disk space is ample, or
when optimizing widely varying cutting conditions, such as: intermittent cutting, deep
versus shallow cuts, etc.

Sample optimization results using the Add More Cuts option:

Inch / Millimeter options — Controls the unit measurement system in which


optimization data is entered. If the OptiPath record units are different from the session
units, the record values are converted appropriately when loaded.
Resolution — Controls the frequency or "sampling distance" used to analyze each tool
path motion. Each feed rate controlled motion is partitioned into samples based on this
distance. The samples are then analyzed during feed rate calculation. Options:

y Distance — Uses the sampling distance in the corresponding data field. Distance
is measured along the tool motion. Using a resolution equal to 1/2 to 1/4 of the
tool diameter is recommended.
y Auto — Automatically calculates the resolution distance based on the size of the
cutting tool relative to the displayed model. This choice is recommended when
little or no knowledge of cutting methods or feed rates is available.
Example of Resolution applied when optimizing tool path motions:

482
Minimum Feedrate Change — Specifies the minimum change from the current
optimized feed rate that will cause a new optimized feed rate to be output. This feature
controls the quantity of feed rates output to the optimized tool path file. A small value
causes more optimized feed rates to be output than when a larger value is entered.

y Default option — When selected, sets the default Minimum Feedrate Change =
1 IPM or 25 MMPM, whichever applies.

Clean-up Feedrate — Feed rate used when the tool is adjacent to, but not removing
material. This condition is commonly referred to as a "spring pass".

y Default option — When selected, sets the default clean-up feed rate as follows:
- G-code tool path = 50% of the Max Feed Velocity of the machine's X-axis.
- APT tool path = 50% of the Fast Feed value.

Tip: Set the Clean-up Feedrate to be less than the Air Cut Feedrate, since actual
cutting leaves small amounts of material from tool deflection.

Circle Feedrate — Controls when and how feed rates are optimized for circular motions
(e.g. G02-3). Circle feed rate optimization produces a single optimized feed rate for the
entire circular motion regardless of the active Modify Existing Cuts Only or Add More
Cuts option. Options:

y Programmed — Uses the original programmed feed rate.


y Fixed — Uses the feed rate in the corresponding data field.
y Optimize — Calculates an optimized feed rate based on the maximum material
removed throughout the circular motion.

483
y Break-up — OptiPath will attempt to break up circles only if both this option and
the Add More Cuts option has been selected.

For APT, only one output format is supported:

CIRCLE/ xc, yc, zc, i, j, k, rad - defines circle center, plane and radius
GOTO/x,y,z,ijk - defines the ending point of the motion

Circle feed rates are not optimized under the conditions listed below. These circles
receive the original programmed feed rate.

- helical (spiral) circle motions


- circle motion where the tool axis is not perpendicular to the circle axis
- G-code data circle motion programmed in inverse time feed rate mode (e.g.
G93)

Radius Control — When toggled On, OptiPath adjusts the feedrate for circular motions.
During circle motions, OptiPath determines the maximum contact point away from the
tool center line and adjusts the feed rate so the desired feed rate is achieved at that point.
Radius Control is only available when Circle Feedrate is set to Optimize or Break-up.

NOTE: If the effective cutting radius, R, is bigger than the circle radius, r,
OptiPath adjusts (lowers) the feedrate by the factor r/R which is < 1. If R is less
than r (r/R > 1), no adjustment is done (OptiPath will not increase the feedrate
calculated based on the tool center).

NURBS Feedrate — Controls when and how to optimize NURBS motion feed rates
(e.g. G06, G06.2). The active Modify Existing Cuts Only or Add More Cuts option
does not affect feed rates calculated by this feature. Options:

y Programmed — Uses the original programmed feed rate.


y One Feedrate — Calculates the most efficient feed rate for NURBS motions. The
feed rate calculated for the most severe cutting condition used as the optimized
feed rate.
y Multi Feedrate — Calculates multiple feed rates for NURBS motions when
cutting conditions warrant feed rate changes.
y
Feedrate Wear Reduction — Reduces the calculated feed rate based on the amount of
material that has been removed. The value entered is the percentage of reduction to be
applied after each cubic unit of material removed. Zero indicates no adjustment for wear.

484
Example: assume "Feedrate Wear Reduction=.2". The calculated feed rate is reduced
.2% after each cubic unit of material has been removed. After five cubic units removed
the calculated feed rate is reduced 1% (.2% x 5).

Limits:
Minimum Cut Feedrate — Specifies the minimum optimized feed rates that can be
output when removing material.
y Default option — When selected, sets the default minimum feed rate = 1 IPM or
25 MMPM.
Maximum Cut Feedrate — Specifies the maximum optimized feed rates that can be
output when removing material.
y Default option — When selected, sets the default maximum feed rate as follows:
- G-code tool path = 45% of the Max Feed Velocity of the machine's X-axis.
- APT tool path = 45% of the Fast Feed value.
Maximum Cut Depth — Specifies the maximum cut depth that can be output when
removing material.
y Default option — When selected, sets the default maximum cut depth = 5 (inch)
or 150 (metric).
Maximum Volume Removal Rate — Specifies the maximum volume removal rate that
can be output when removing material.
y Default option — When selected, sets the default maximum volume removal rate
= 100 (inch) or 1500000 (metric)
Maximum Chip Thickness — Specifies the maximum chip thickness that can be output
when removing material.
y Default option — When selected, sets the default maximum chip thickness = .02
(inch) or .05 (metric).
Maximum Surface Speed — Specifies the maximum surface speed rate that can be
output when removing material.
y Default option — When selected, sets the default maximum surface speed = 1000
(inch) or 300(metric).

485
OptiPath window, Hard Material tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

Features on this tab enable you to specify feedrate adjustment factors for special cutting
conditions encountered during the optimization process.

Feedrates may need to be adjusted (typically slower than what OptiPath would normally
calculate) based on the following 'hostile' conditions when cutting hard materials:

Non-Climb or "Conventional" cutting


Non-Climb cutting, or "Conventional" cutting occurs when the cutter tooth enters
material close to parallel to the direction of motion. See the following diagram:

The cutting condition worsens as the tooth entry angle decreases. When the tooth entry
angle is near zero the cutting edge contacts material parallel to the direction of motion
and requires excessive force to push the edge into material. The tooth finally enters
material when pressure between the cutter and material increases and the tooth rotates
past the tangent contact.

486
The picture below shows the worst condition.

Thin radial width, typically only one tooth is engaged in material


When the width of material becomes so small that only one tooth of the cutter is engaged,
the tool is no longer well supported and an otherwise reasonable feed rate becomes too
aggressive. As the spindle spins the tool transitions between a tooth engaged and cutting,
and no tooth engaged, causing the tooth to "bang" into material each time it enters. This
"banging" causes premature cutting edge breakdown and reduces tool life.
Determining the number of teeth engaged depends on the number of teeth in the cutter,
the material contact axial depth, the width and location of the contact, and the flute helix
angle.

Side-loaded cutting, material is exclusively on the "climb" side of the cutter


When the tool is cutting with all material on the right of the tool center (for a clockwise
rotating spindle), the cutting pressure forces the tool to deflect in the opposite direction.
The deflection seriously affects cutting performance, increases cutting forces, and causes
premature edge breakdown.

These hostile conditions generally occur when cutting hard or difficult to machine

487
materials such as tool steel, stainless steel, and high temperature alloys. Since there is no
good scientific or empirical information to apply to these hostile conditions, the
following features enable you to adjust the feed rates under each of these Hard Material
conditions.

Adjust Feedrate for Non-Climb Cut —


Adjust Feedrate for Thin Radial Width Cut —
Adjust Feedrate for Side-Loaded Cut —

Each feature consists of a checkbox to toggle the feature On/Off, and a numeric field
enabling you to enter a factor to be applied to the calculated feed rate for each of these
conditions. The number represents a percentage of the calculated feed rate.

When a feature is toggled "On", the factor is applied to the calculated feedrate each time
that the particular condition is detected.

Since these cutting conditions are not mutually exclusive, any combination (or all) of the
features can be toggled "On" at the same time and any, or all, of the factors may be
applied to the same calculated feed rate as appropriate for the cutting conditions.

After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

488
OptiPath window, Spindle tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

The features on this tab limit RPM fluctuations and specify feed per tooth load
maintained during Surface Speed optimization.

After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

Minimum RPM Change—Specifies the minimum change from the current optimized
spindle speed required to output a new spindle speed. This feature controls the quantity of
spindle speed changes output to the optimized tool path file. Small Minimum RPM
Change values cause more spindle speed changes to be output than larger values. Tip:
Start with a value such that only 3-4 changes can occur across the RPM range.

y Default option—When selected, sets the default minimum RPM change = 1000.

Minimum RPM—Specifies the minimum spindle speed that can be output during
optimization.

y Default option—When selected, sets the default minimum RPM as follows:


- G-code tool path = machine spindle minimum set by SpindleSpeedMin macro, if
not set then 100 RPM.
- APT tool path = 100 RPM.

Maximum RPM—Specifies the maximum spindle speed that can be output during
optimization.

y Default option—When selected, sets the default maximum RPM as follows:


- G-code tool path = machine spindle maximum set by SpindleSpeedMax macro,
if not set then 20000 RPM.
- APT tool path = 20000 RPM.

489
OptiPath window, Plunge tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

The features on this tab control the optimized feed rate for motions along the tool axis
that plunge into or retract from material.

After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

Plunge Feedrate—Controls when and how feed rates are calculated for plunging along
the tool axis into material. Options:

y Off—Disable plunge feed rate control.


y Feed/Minute—Uses the feed rate entered in the corresponding data field.
y % of Prog.—Adjusts programmed feed rates based on the percentage entered in
the corresponding data field. 100% uses the programmed feed rate as is, 50% cuts
the feed rate in half, etc.

NOTE: Plunge Feedrate overrides Angle table feed rate for 90 degree cutting
angle (plunge motion), or the Entry Feedrate for entry on plunge motions.

Clearance Distance—Specifies the distance from material to instate the feed rate for
plunging.
Retract Feedrate—Controls when and how the feed rates are calculated for retracting
along the tool axis away from material.

Options:
y Off—Disable retract feed rate control.
y Feed/Minute—Uses the feed rate entered in the corresponding data field.
y % of Prog.—Adjusts the programmed feed rate based on the percentage entered
in the corresponding data field. 100% uses the programmed feed rate as is, 50%
cuts feed rate in half, etc.

NOTE: Retract Feedrate overrides Angle table feedrate for -90 degree cutting
angle (retract motion).

490
OptiPath window, Entry/Exit tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

The features on this tab control the optimized feed rate for entering and exiting material.
The feed rate takes affect at a specified distance from material contact and remains in
affect until the tool has cut a specified distance into material, or the entry motion ends.
After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

Entry Feedrate — Controls when and how feed rates are calculated for entering
material. Options:

y Off — Turns off Entry (or Exit) Feedrate calculation and application
during optimization.
y Feed/Minute — Uses the feed rate entered in the corresponding data field.
y % of Prog. — Adjusts the programmed feed rate based on the percentage
entered in the corresponding data field. 100% uses the programmed feed
rate as is, 50% cuts feed rate in half, etc.
y % of Calc. — Similar to % of Prog., except adjusts the calculated feed
rate.

Affect of Entry Feedrate applied on a motion entering material:

491
NOTES:
When entry motions are optimized with the Modify Existing Cuts Only option, calculated
entry feed rates are considered among other cutting conditions to determine the
appropriate feed rate for motions which enter material.

Plunge Feedrate overrides entry controlled feed rate for entry on plunge motion.
Clearance Distance — Specifies the distance from material to instate the feed rate for
entering.
Cut Distance — Specifies the distance to cut into material using the Entry Feedrate,
after which normal feed rate optimization resumes.
Exit Feedrate — Controls when and how the feed rates are calculated for exiting
material. Options are same as described above for Entry Feedrate.
Clearance Distance — Specifies the distance after breaking free from material to
continue using the feed rate for exiting, after which the Air Cut Feedrate resumes.
Cut Distance — Specifies the distance away from breaking out of material to use the
Exit Feedrate.

492
OptiPath window, Angle tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

The features on this tab adjust the optimized feed rate for 3-axis linear cuts ramping in
material. While these features are normally used to reduce the feed rate for ramping
downward, they can also be used to affect feed rates for upward ramping motions.

After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

Adjust Feedrate for Entry Angle — When active, adjusts feed rates for ramping
motions based on the table configuration.

Angle table — Table of cut angles and corresponding % feed rate adjustments to apply
when the tool ramps into material. Values can be entered or supplied via dragging the
control points on the graph. Add after, or delete table entries via right-clicking on them
and choosing the appropriate option (or use the Add / Delete buttons below the table).
Cuts at angles less than the minimum listed in the table receive the adjustment specified
for the minimum angle. Similarly, when the maximum specified cut angle is exceeded,
the adjustment specified for the maximum angle is used.

y Angle column — Lists up to five cut angles (in descending order) that describe
the range of expected cut angles to adjust. Values can be from -90 to 90, where
"0" represents horizontal milling, "90" represents plunge motion along the tool
axis, and "-90" represents retract motion.
y % Feedrate column — Lists % feed rate adjustments to apply to calculated feed
rates when ramping in material at the corresponding angle. 100% uses the
calculated feed rate as is, 50% cuts feed rate in half, etc.

493
Sample Angle table:

NOTES:
Angle adjusted feedrate for 90 degree cutting angle is overridden by Plunge Feedrate if
active.
Planar milling motions (0 degree angle) are not adjusted.

494
OptiPath window, Depth Table tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

The features on this tab controls how optimized feed rates are calculated for cutting at
various depths during Optimize by Tables optimization. The calculated feed rate can be
used as calculated, or adjusted using the Angle and/or Width tables, as well as features on
other tabs in this window.

After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

Feedrate value type option list — Controls the how to interpret the feed rates in the
Depth table.

Options:
y Feed/Minute — Calculates optimized feed rates based on absolute feed rates
specified for various cut depths. Specify feed in units specified on the Settings
tab.
y % of Prog. — Calculates optimized feed rates based on percentages of
programmed feed rates specified for various cut depths. "100" uses the
programmed feed rate as is, "50" cuts the feed rate in half, etc.
y Feed/Tooth — Calculates optimized feed rates based on feed per tooth, or chip
load specified for various cut depths. Specify feed per tooth in units used by the
tool path file (IPR or MMPR).

Depth table — Table of cut depths and corresponding feed rates to apply when cutting at
a specified depth. Values can be entered or supplied via dragging the control points on
the graph. Add after, or delete table entries via right-clicking on them and choosing the
appropriate option (or use the Add / Delete buttons below the table). Cuts at depths less
than the minimum listed depth in the table receive the feed rate specified for the
minimum depth. Similarly, when the maximum specified cut depth is exceeded, the feed
rate specified for the maximum depth is used and an error identifying the condition is
written to the Log file.

y Depth column — Lists up to five cut depths (in descending order) that describe
the range of cutting by the tool.

495
y Feedrate column — Lists feed rates to apply when the tool is cutting at the
corresponding depths. Feed rate values are interpreted differently based on the
active feed rate value type option (see "Feedrate value type option list" above).

Sample Depth table:

Tip: Un-select all optimization methods and use the Cutting Condition sliders to
determine appropriate feeds and speeds for a known successful cutting condition,
then select Optimize by Tables and press Fill to automatically enter Depth Table
values.

Feedrate Control Options — Controls when and how volume removal rate is
considered in feed rate calculations during optimization by tables.

Options:
y Off — Disable volume removal rate considerations.
y Const. Volume Below Min. Depth — Specifies a constant volume of material is
to be removed when the depth of cut is less than the lowest Depth table entry.
The volume removal rate is expressed in cubic units, where “units” refers to the
units specified on the Settings tab. If unknown, un-select all optimization methods
and use the Cutting Condition sliders to calculate it.

496
The example below shows the affect of Constant Volume Below Minimum Depth
on feed rate calculations for a ball-nose endmill when the lowest Depth Table entry
is equal to the radius of the tool.

y Max. Volume Removal Rate—Specifies the maximum volume removal for the
tool. Optimized feed rates are bounded such that the rate at which material is
removed never exceeds this value. The volume removal rate is expressed in cubic
units, where "units" refers to the units specified on the Settings tab. If unknown,
un-select all optimization methods and use the Cutting Condition sliders to
calculate it.

497
OptiPath window, Width Table tab
Location: Project menu > Tools: Add menu > OptiPath > New, or
Edit menu > Modify (when an OptiPath tool component is highlighted)

The features on this tab adjust the optimized feed rate for cuts that are less than full cutter
width during Optimize by Tables optimization. When the tool is cutting with less than
full diameter the feed rate can typically be higher than for a full width cut, also know as a
"slot cut".
After configuring the features on this tab, be sure to review the other tabs in the OptiPath
Manager window for proper optimization values.

On — When selected, adjusts feed rates for cuts of varying width based on the Width
table configuration.

Width table — Table of cut widths and corresponding % feed rate adjustments to apply
when removing material with the specified cutter width. Values can be entered or
supplied via dragging the control points on the graph. Add after, or delete table entries
via right-clicking on them and choosing the appropriate option (or use the Add / Delete
buttons below the table). Cuts at widths less than the minimum listed in the table receive
the adjustment specified for the minimum width. Similarly, when the maximum specified
cut width is exceeded, the adjustment specified for the maximum width is used and an
error identifying the condition is written to the Log file.

y % Width column—Lists up to five cut widths (in increasing order) that describe
the range of expected cut widths to adjust.
y % Feedrate column—Lists % feed rate adjustments to apply to calculated feed
rates when removing material with the corresponding cut width. 100% uses the
calculated feed rate as is, 50% cuts feed rate in half, etc.

498
Sample Width table:

499
Search OptiPath Record window
Location: Project menu > Tools: Add menu > Tool > Select Existing or
Edit menu > Search Tool

Search OptiPath Record enables you to search existing tool/OptiPath libraries for records
with specific attributes.

Libraries:
y Files — Use to search one or more tool library files for tools meeting the
specified search criteria.
y Directories — Use to search one or more directories of tool library files for tools
meeting the specified search criteria.
y Browse — Displays a selection window to assist you in selecting the
files/directories to be searched.

Search Attributes:
y Description — Search for existing OptiPath records containing a specified string
of text within the record's Description field.
y Material — Search for existing OptiPath records containing a specific material
type.
y Machine — Search for existing OptiPath records containing a specific machine
type.

500
Search — Start the search of the specified ibrary (libraries) based on the attributes
specified above.

OptiPath Record List:


Displays the a list of Optipath records found during the search. The Tool List display and
interaction is the same as the Tool Table in the Tool Manager, with the one exception that
the tool library file name is also displayed here.

Duplicate — Duplicates the selected OptiPath record in the current tool library.
Reference — Creates a reference to the selected OptiPath record in the current tool
library.
Close — Closes the Search OptiPath Record window.

501
Processing Options

Activate
Location: Project menu > Processing Options > Activate

Activate enables you to set the state of the current setup to active / inactive. An active
state is indicated by a check mark.

502
Motion

VERICUT Users:
VERICUT Location: Project menu > Processing Options > Motion

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Advanced Options page > Simulation Settings

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Advanced Options page > Simulation Settings

Notebook Feature:

Opens a window used to control the simulation of tool path and machine motions.

503
Start At/Stop At group:
Start At — Specifies the line, or tool path record at which cutting simulation starts.
VERICUT fast forwards from the beginning of the NC program to the specified
line/record while internally processing intermediate tool path records to store values for
the current feed rate, spindle speed, coolant, tool description, and tool location. Options
are:
y Beginning — Start processing at the beginning of the first file.
y Line Number — Start processing at the specified line number of selected
toolpath file.
NOTE: A list of all NC programs and job subroutine files defined for
the current job will display enabling you to select the toolpath file.
y Line Number (Directly) — Start processing at the specified line number
without internally processing intermediate tool path records. This line number
only applies to the first toolpath (or the first active toolpath if Use Selected
Files, in the Project >NC Program window, is being used to select only
specific toolpath files from the list for VERICUT processing).

504
y Text — Start processing on the line that contains the specified text.
y Tool ID — Start processing when the specified tool is loaded.

Stop At — Provides options for stopping tool path processing. When applicable, enter
supporting "stop at" text or values in the field next to this feature. Text entered is not case
sensitive.

y End — Stop processing at the end of the last toolpath file.


y Num of Cuts — Stop processing after the specified number of cuts.
y Line Number — Stop processing at the specified line number of the selected
toolpath file.

NOTE: A list of all toolpath and job subroutine files defined for the current
job will display enabling you to select the toolpath file.

Text — Stop processing on the line that contains the specified text.

Tool Change — Stop processing when a toolchange occurs.

Program Stop — Stop processing when a "program stop" record is encountered


in the tool path. Examples of such records include: M0 (G-code tool paths) or
STOP.

Optional Stop — Stop processing when a "optional stop" record is encountered


in the tool path. Examples of such records include: M1 (G-code tool paths) or
OPSTOP.

End of each File — Stop processing at the end of each toolpath file.

End of each Setup — Stop processing at the end of each setup.

Stop At Max Errors / Stop At Max Warnings — Number of errors (or warnings)
which, if detected, stops tool path processing. Toggle "On" and specify the Max
Error/Max Warning value.

Motion group:
Fast Feed — Feed rate threshold at which material removal is unsafe (likely to cause tool
breakage, machine malfunction, or part damage). For example, if the maximum feedrate
allowed is 180, Fast Feed should be set to 181 or greater. Material removed under these
conditions is shaded in the Error color (typically red) and causes a "Fast feed rate" error.

505
No Animation — Enables you to reduce processing time. When toggled "On", the
graphics display is not updated until either processing is complete or you Stop the
processing. At that time the cut model is displayed in it "final" state or the state that it
was in when processing was stopped.

Skip Cut — Quantity of animated tool motions to skip before updating the display. Enter
"0" to display each tool motion. Skipping cuts increases animation speed since the
display is not constantly updated. The cut model is unaffected.

Tool Spindle Always On — When toggled On, VERICUT will assume that the spindle
is always on and will not check for spindle status (on/off) or output error messages
related to cutting with the spindle off.

Drill Cycle — Controls when and how to simulate canned tool axis cycles (e.g. G8n,
"CYCLE"). While VERICUT simulates most popular cycle motions, there are also
capabilities to add more and change how existing cycles are interpreted- see "About

506
configuring for cycle simulation" in the Using VERICUT section for more information.

Options:
y Ignore — Ignores cycle motions- the tool moves to each cycle position without
performing cycle motions.
y Bottom Only — Simulates cycle motions for a hole with one full depth motion-
pecking or chip-breaking motions are not simulated.
y Full Motion — Simulates all cycle motions, including pecking or chip-breaking
motions.

NOTE: When "Bottom Only" or "Ignore" options are used, certain motions (and
checks) are ignored. This means that there will be no RAPID checks, no material
removal, no limit checks, no collision checks, no redraws, etc. Because of it's
importance, checks related to "RAPID to the R-plane" motions are included when
"Bottom Only" is selected, but not when "Ignore" is selected.

Need help troubleshooting cycle motion errors? See ERRORS and Problem Solving at
http://www.cgtech.com/support/errors_problems/errors.htm, for assistance with
diagnosing error messages and conditions.

Check Spindle Direction — When toggled On, VERICUT check for spindle direction
against the "valid" direction of the tool.

For turning tools, "valid" direction is based on the turning tool orientation. Spindle
direction, (CW or CCW), is determined looking down the Z-axis of the spindle. It is
assumed that revolving stock material should come onto the insert in the direction of
positiveY-axis of the tool component. If spindle direction is wrong, or spindle speed is
not defined, an error is reported to VERICUT logger. Only one error per spindle is
reported for each operation turning the spindle On or Off.

The error is reported only if turning tool removes material from stock. For air moves, no
errors are reported. Also, if an insert removes material in a motion that crosses the
spindle Z-axis, no error is reported (in this case, one part of the insert is always on the
correct side, while the other part is on the wrong side, therefore there is no preferable
spindle direction).

For milling tools, the direction of the tool spindle (either spindle component or tool
component attribute) is checked with the "valid" direction of the tool in the spindle. Tool
spindle direction (CW/CCW) is defined looking down (negative Z) the tool axis. For
revolved milling cutters, "valid" direction is based on the setting of Spindle Direction
(clockwise or counterclockwise) in the tool definition. For inserted milling cutters,
"valid" direction is based on the insert thickness direction.

507
If the direction of the spindle does not match the direction of the tool, then an error is
reported whenever the tool removes material. The tool removes material in the error color
(similar to the behavior for turning spindle direction error). The check is done and the
error reported only when the tool removes material. Motion that does not remove material
does not report an error.
The check is done for G-Code only.

Min. Motion Dist. / Max. Motion Dist. — Enables you to specify a minimum and
maximum value, defining the range of the Animation Speed slider. The animation speed
is interpolated between these two values.

Check Cutting Limits — Toggle On, to have VERICUT do the cutting limit checks
during simulation. Cutting limit values are set in the OptiPath window, Settings tab.

FastMill — Toggle "On" to process the toolpath in FastMill mode. You can also use the
FastMill icon , in the Toolbar to turn on FastMill mode.

NOTES:
FastMill:
y does "fixed axis" material removal in any tool orientation.
y does not do "undercuts". FastMill automatically switches to standard
material removal when required.
y can be turned On/Off at any time.
y can be used with/without tool animation. Toggle No Animation, described
above, "On" for fastest processing.
y is compatible with OptiPath, AUTO-DIFF, Model Export, as well as X-
Caliper and any other feature that uses the cut model database.
FastMill is not effective when:
y the tool axis changes frequently.
y the cutter "undercuts", such as when using a dovetail or wheel cutter.
y cutter height is less than the cut depth resulting in an undercut condition.
y
Ignore Undercuts — Works in conjunction with FastMill, described above. When
toggled "On" (default), VERICUT does not check each motion for "undercut" conditions
allowing for faster processing in those cases where you are sure that there are no
"undercut" conditions in the toolpath. Toggle "Off" when you want VERICUT to check
for "undercut" conditions as it processes each motion.

NOTE: This feature is only active when FastMill is toggled "On".

508
Tool group:
Tool Display — Controls when and how the tool is displayed. Options are: Off (do not
display the tool), Solid, or Translucent. Material removal is not affected by this choice.

Min. Cutter Height — Default height used when the current tool description does not
specify height, or when specified height is less than this value. Affects milling cutters
only.

Control Point — Controls how milling tools are driven. By default, VERICUT drives
the tool tip. Material is removed based on tool path motion commands and the tool shape,
relative to the control point. Options:

y Tool Tip — Point located at the bottom-center of the cutter.


y Corner Radius — Point located a distance equal to the cutter corner radius up
from the tool tip. With ball nose endmills, this point is commonly referred to as
the "ball center".

NOTES:
If Corner Radius is used with non-ballnosed endmills, the offset is calculated
along the tool axis, from the tool tip to the center of the first arc encountered
in the tool profile.

509
To specify a milling tool control point other the tool tip of corner radius, define
tools via the Tool Manager and specify a control point offset via the tool's
Properties.
This feature is not applicable to turning tools. Instead, define tools via the Tool
Manager and specify a control point offset via tool Properties.

Display Holders in Workpiece View — When toggled "On", instructs VERICUT to


display defined tool holders and detect collisions they may have. Holders are non-modal
and are applied only to the active cutter. An error similar to "HOLDER removed
material..." is reported when a tool holder removes material. Material removed is shaded
using the red Error color.

Calculate Min. Cutter Extension — When active, calculates the minimum height
required to avoid shank/holder collisions. Minimum cutter extension calculations begin
with the defined cutter height. If potential holder collisions are detected during the
simulation, VERICUT extends the cutter to avoid the collision and adds this amount to

510
the calculated height. Note that when these calculations are being performed, tool holder
collisions are not reported since VERICUT extends the cutter to avoid the collision. If
desired, you can include additional clearance in the calculation via specifying Holder
Clearance (see below). The final calculated height for each tool is displayed in the Log
file Tool Summary section under the "Min" column heading.

Holder Clearance — Specifies clearance to add when calculating minimum cutter


extension (see above). The clearance value is also included in the Log file minimum
height values.

NOTE: This feature is only active when Calculate Min. Cutter Extension is
toggled "On".

Back to Mold and Die

511
G-Code

G-Code Settings window


VERICUT Users:
VERICUT Location: Project menu > Processing Options > G-Code > Settings

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Advanced Options page > Job Settings

Notebook Feature:

Cutter Grinder Users:

Cutter Grinder Location: Advanced Options page > Job Settings

Notebook Feature:

Opens a window to configure settings to support processing G-code tool path files.

512
Settings tab — Features on this tab provide important settings for G-code simulation,
such as: the G-code programming method, when cutter compensation (CDC) codes are
processed, tool path scanning, and tolerances used for simulating rotary motions.
Tables tab — Features on this tab are used to specify work offsets and machine locations
specific to the current tool path file(s) and to store tool-related offset and compensation
register data.
Subroutines tab — The features on this tab are used to specify names of external files
containing subroutines that can be accessed by VERICUT.
Block Skip tab — Features on this tab control which levels of block skipping are
recognized, and specify the block skip character.
Sync tab — The features on this tab enable you to select which Sync Sub-sytsem is to be
used. This setting is only applicable if Sync Method on the Control Settings window,
Sync tab is set to something other then None. This feature is intended as as a debugging
tool enabling you to easily select a which sync program they want to run rather then
running them together at the same time.
WireEDM tab — Features on this tab configure VERICUT for wire EDM simulations.
OK — Applies the changes and closes the G-Code Settings window.
Apply — Applies the changes and leaves the G-Code Settings window open.
Cancel — Closes the G-Code Settings window without applying changes.

513
G-Code Settings window, Settings tab
VERICUT Location: Project menu > Processing Options > G-Code > Settings

VERICUT toolbar short cut:

Features on the Settings tab provide important settings for G-Code simulation, such as:
the G-Code programming method, when cutter compensation (CDC) codes are processed,
tool path scanning, and tolerances used for simulating rotary motions.

Programming Method — Describes the relationship between cutting tools and what is
being driven by tool path file motion commands. (Take care NOT to describe the
relationship between cutting tools and the driven point controlled by a CAM system.)

Options:
y Tool Tip — XYZ values represent tool tip positions (center of the tool tip) at all
times.

NOTE: Tool length compensation codes (G43ZnHn/G49) do not appear in tool


tip programmed tool paths. If these codes are present, use the Tool Length
Compensation programming method.

514
y Gage Length — XYZ values represent gage point positions. The gage point is
typically the spindle face, where the centerline of the tool intersects the machine
gage line. Gage length values must be supplied using Gage Offset in the Tool
Manager, or via entries in a Gage Offset table.
y Tool Length Compensation — With comp. active (e.g. G43ZnHn) XYZ values
represent tool tip positions relative to program zero. With comp. cancelled XYZ
values represent machine gage point positions relative to machine zero. Use an
Input Program Zero table to describe where the part zero is. VERICUT
automatically calculates "H" offset values, or enter values in a Tool Length
Compensation table. For proper tool loading on a 3-D machine supply gage offset
values as described above for Gage Length programming method.

Process Cutter Comp. — When active, applies cutter compensation, or "CDC" offsets
to the programmed tool path. Enter CDC offset values in a Cutter compensation table, as
described under "Cutter compensation table" in the Reference chapter. Clear this
checkbox to ignore CDC-related codes in the tool path file. Output Precision specifies
the accuracy for calculating CDC offset tool positions.

NOTE: Tool paths can not be optimized when CDC offsets are being simulated.

Scan NC Program Files — When active, performs a "scan pass" on NC program files to
identify jump destinations for looping-branching logic. Tool paths with this type of logic
must be scanned for proper simulation in VERICUT.
Ignore Data after Column — Specifies the G-Code data column number to begin
ignoring remaining data in the block. Use this feature when unmarked comments are
permitted in designated columns of the G-Code data. Enter the number of the last valid
G-Code data column in the field next to this feature.

515
Apply Acceleration to Cycle Time — When toggled "On", uses the Accel/Decel
parameter, as set in the OptiPath Manager window, when calculating the cycle Time
displayed in the Status window.
Initialize Machine/Control between NC Programs — Enables you to specify whether
or not to reset the control's states, variables, etc. between NC program files during
processing. When toggled "On" (the default), VERICUT resets these values between NC
program files. This condition is consistent with prior releases. Toggle "Off " to retain
these values between NC program files.
Rotary Feed Motion Tol—Tolerance used to calculate intermediate tool positions
resulting from processing rotary motion when Output Intermediate Points is active (ref.
Configuration menu > Settings (Control) : Rotary tab). Decreasing this value
increases the quantity of intermediate points calculated, and decreases simulation speed.
Rotary Rapid Motion Tol — Similar to Rotary Feed Motion Tol, except applies to
rapid rotary motions.

516
G-Code Settings window, Tables tab
VERICUT Location: Project menu > Processing Options > G-Code > Settings

VERICUT toolbar short cut:

Features on the Tables tab are used to specify "Job Tables" to store work offsets and
machine locations specific to the current tool path file(s) and "Tool Tables" to store tool-
related offset and compensation data.

NOTE: The values set in a "Job Table" are used override "standard" values that
were set in a Machine Table for the current NC program file(s).

Tables list — A list of tables that are currently defined. The Machine Settings tables list
will contain only "machine" tables. The G-Code Settings tables list will contain both
"job" tables and "tool" tables.
Add/Modify — Use to access the Add/Modify Tables window enabling you to add
additional tables or modify existing tables. To Add a table , simply click on Add/Modify.
To modify an existing table, select the table to be modified from the Tables list and click
on Add/Modify. (You can also "double-click" on the table in the Tables list.)
Delete — Deletes the selected table entry from the Tables list. If it is the last entry for a
particular table, then the table is also deleted.

517
Job Table and Tool Table values are stored in the Project file.
The following Job Tables can be added or modified with the G-Code Settings window,
Tables tab:
y Base Work Offset
y Initial Machine Location
y Machine Zero (obsolete, formerly Input Machine Zero)
y Machine Reference Location
y Tool Change Location
y Tool Change Retraction
y Work Offsets
y Program Zero
y Input Program Zero (Special Z ) (formerly Input Program Zero)
y RTCP Pivot Offset
y RPCP Pivot Offset
y Part Transformation

The following Job Tables can be added or modified with the G-Code Settings window,
Tables tab:
y Cutter Compensation
y Gage Offset
y Probe Offset
y Tool Length Compensation
y Tool Nose Compensation
y Turret Rotations

518
Add/Modify Tables window
The following discussion applies to both the Add/Modify Machine Table window,
accessed from the Machine Settings window: Tables tab and to the Add/Modify G-Code
Table window, accessed from the G-Code Settings window: Tables tab.

Table Name — Use to identify the table to be added, or modified, if it already exists.
The Table Name list in the Add/Modify Machine Table window will only contain
"machine" tables. The Table Name list in the Add/Modify G-Code Table window will
contain both "job" tables and "tool" tables.
SubSystem ID — Use to specify ID of the machine subsystem for which the table is
being defined.
Register — The Register number that will be used by VERICUT to access corresponding
table data. For "tool" tables, this number typically corresponds to a tool or offset register
number. For "job" and "machine" tables, the Register number may correspond to an
offset register number, or an integer value, as required by a particular table.
SubRegister — Use of this feature enables you to access multiple sub-values for the
same tool from tool related tables. For example, groove tools often have multiple
"driven" points, which then correspond to multiple gage offsets, and possibly multiple
Cutter Comp values, Tool Nose Comp values, and Tool Length Comp values.
SubRegister is only active when the selected "Table Name" identifies a "tool" related

519
table.
Select From/To and Enter Values:
These features are only active for the following tables:
y Input Program Zero
y Input Machine Zero
y Base Work Offset
y Work Offsets
y RTCP Pivot Offset
y RPCP Pivot Offset
For the above tables, VERICUT provides two ways to enter table values.

Select From/To/Offset — Enables you to specify table values based on a "relational"


offset between a "from" point and a "to" point. The "from" and "to" points are designated
by specifying a particular component or CSYS. VERICUT will use the origin of the
component/CSYS as the point. You can also specify an offset from the specified
component/CSYS origin point. Once this relationship has been established, you can
change the machine configuration or the location of the CSYS origin and the table values
will updated automatically during the initial Single Step or during Play to End.
For example: After Input Program Zero has been defined to be the offset from the Tool
Component to the "Program Zero" CSYS, you can change the machine configuration, or
change the location of "Program Zero" CSYS, and the Input Program Zero offset values
will be updated automatically during the initial Single Step or during Play to End.

NOTE: The offsets are calculated based on where the corresponding origin points
are located when all linear axes are driven to machine zero (zero with no offsets in
place).

When Select From/To is toggled "on", the From/To Feature/Name lists and the Offset
text fields become activated. Use the From/To Feature lists to specify whether the point
is associated with a Component or a CSYS (coordinate system). Use the From/To
Name lists to specify a specific component or coordinate system.

NOTE: Only the coordinate systems that have been defined with reference to a
machine component (i.e., visible in a Machine or Machine/Cut Stock view when
Coordinate System axis is toggled "on") will appear in the CSYS/Names lists. See
the discussion for Project menu > Coordinate Systems for more information on
VERICUT Coordinate Systems.

Use the Offset text fields to enter a 3 values, separated by spaces, representing the X, Y,
and Z offset from the specified origin point. You can also click on the "select" button,

then pick a point in the graphics display area. You can pick the point in either a

520
workpiece or machine view. VERICUT will calculate the Offset value between the
selected point and the designated Feature/Name origin point. Offset is only active when
Feature is set to Component.

Calculate when Used — When toggled "On", VERICUT will calculate the table values,
based on the current positions of the rotary axes, at the time that the table values are used.

The following general guidelines should be followed regarding the use of "relational"
offsets.
1. If the offsets are based on the original rotary axes orientations, or if the
offsets are independent of the rotary axes orientations , Calculate when
Used need not be toggled "On".
2. If the offset is dependent on a specific rotary orientation, and you are sure
that the rotary axes will be re-positioned before the "relational" offset is
applied, Calculate when Used should be toggled "On" so that the correct
offset is calculated based on the current rotary axes positions.
NOTE: If the offset is associated with a specific rotary orientation, and
you are NOT sure that the rotary axes will be re-positioned before the
"relational" offset is applied, then the offset must be specified in a
manner which is independent of the rotary orientation. For example: If
the offset "TO" value is a certain point on the stock when the stock is
rotated to A90, you can MDI an A90, have the offset based on the A
component, and then click on the corresponding point of the stock. This
now defines the offset in a manner which is independent of the rotation
on A.

Enter Offset (or select 2 points) — When toggled "On", the Values
(XYZABCUVWABC) text field is activated enabling you to enter one to twelve numeric
values as required by the specific table. Multiple value entries require spaces between the
values.

You can also click on the "select" button, then pick two points in the graphics
display area. You can pick the points in either a workpiece or machine view. VERICUT
will calculate the Offset value between the selected points.
For all other tables, Select From/To and Enter Offset (or select 2 points) are both
inactive. Enter the values in the Values (XYZABCUVWABC) text field as described for
Enter Offset (or select 2 points) above.

521
In the sample window shown above, the current table is the Work Offsets table. The
current table entry is register "54", and contains the values "-14.95 -8 -17.27". The table
is applicable to subsystem "1" of the machine.

522
G-Code Settings window, Subroutines tab
VERICUT Location: Project menu > Processing Options > G-Code > Settings

VERICUT toolbar short cut:

The features on the Subroutines tab are used to specify names of external files containing
subroutines that can be accessed by VERICUT. (See how)

File Names list — List of external files containing subs accessible to VERICUT.

Tip: Right-click in the File Names list area to display a pop-up window with the
following features:

Add — Opens the Job Subroutine Files selection box enabling you to add
external subroutine files to the File Names list.

Replace — Opens the Job Subroutine Files selection box enabling you to
replace the highlighted subroutine file in the File Names list with another.

Delete — Deletes the highlighted subroutine file from the File Names list.

523
Edit — Displays the of the highlighted subroutine file in a text editing
window. Standard text editing features are provided, such as: copy/cut, paste,
search, etc. For more information on using the editing features see Edit menu
> Text File.

Add — Opens the Job Subroutine Files selection box enabling you to add external
subroutine files to the File Names list. (Same as Add in the pop-up window described
above)

Replace — Opens the Job Subroutine Files selection box enabling you to replace the
highlighted subroutine file in the File Names list with another. (Same as Replace in the
pop-up window described above)

Delete — Deletes the highlighted subroutine file from the File Names list. (Same as
Delete in the pop-up window described above)

Delete All — Deletes all subroutines files from the File Names list.

524
G-Code Settings window, Block Skip tab
VERICUT Location: Project menu > Processing Options > G-Code > Settings

VERICUT toolbar short cut:


Features on the Block Skip tab control which levels of block skipping are recognized, and
specify the block skip character. (See how)

Block Skip Character—Character which causes the block to be skipped. This character
must be the first character in the data block for skipping to occur.
Apply Switch Value—Controls when block skip switch values are referenced by
VERICUT. Options:

y Immediately—Reference switch settings when VERICUT is reset, upon loading


a new Project file, and any time tool path processing is started.
y At Reset—Reference switch settings only when VERICUT is reset, or upon
loading a new Project file.

Switch 1-9—When active, processing is skipped for blocks beginning with the
designated block skip switch. For example, "Switch 2" corresponds to blocks beginning
with "2/", "Switch 3" corresponds to blocks with "3/", and so on.

525
G-Code Settings window, Sync tab
VERICUT Location: Project menu > Processing Options > G-Code > Settings

VERICUT toolbar short cut:

The features on this tab enable you to select which Sync Sub-sytsem is to be used. This
setting is only applicable if Sync Method on the Control Settings window, Sync tab is set
to something other then None. This feature is intended as as a debugging tool enabling
you to easily select a which sync program you want to run rather then running them all at
the same time.

526
G-Code Settings window, WireEDM tab
VERICUT Location: Project menu > Processing Options > G-Code > Settings

VERICUT toolbar short cut:

Features on the WireEDM tab configure VERICUT for wire EDM simulations. (See
how)

Wire Diameter — Specifies the effective cutting diameter of the wire.


Work Table to XY Plane — Distance from the top of the work table (machine Z zero)
to the XY reference plane, as measured along the machine Z-axis. This value is usually
zero, but can be a positive or negative value. The XY reference plane is the Z-axis height
at which the tool path file X and Y values are driven.
XY Plane to UV Plane — Distance from the XY reference plane to the UV reference
plane, as measured along the machine Z-axis. This value must be a positive value. This
setting is only used when the tool path file contains U and V-axis values to control the
wire angle. The UV reference plane is the Z-axis height at which the tool path file U and
V values are driven.

527
Variables

G-Code Variables window


Location: Project menu > Processing Options > G-Code > Variables

Features on the G-Code Variables window, are used to initialize, maintain, and monitor
variables. Variables are assumed to have zero for a default value. However, you can
initialize variables with any numeric or text value. (See how) When this window is open
during processing, it gives immediate feedback when variables are set or changed by the
tool path file. Variables are saved to the .usr file if an initial value or a description is
entered, or if the variable is included in the Tracking Variables list.

528
Tracking Variables:
The Tracking Variables portion of the Variables window, enables you to easily track
variables of special interest without having to scroll through all variables in the Variables
List (see how). The following information is displayed for all variables selected for
tracking:

Name — Name of the variable being tracked.


SubSystem — Indicates the subsystem (if any) that the variable being tracked is
associated with.
NOTE: SubSystem in this case pertains to the subsystems defined in the
Variables window variable tree, NOT the subsystems defined by the
machine.
Subroutine — Subroutine (if any) that the variable being tracked is associated
with.
Description — Description of the variable being tracked.
Type — Type of variable (Number, Text or Array)
Current Value — The current value of the variable.
Initial Value — The initial value of the variable.

— Use to add the highlighted variable in the Variables List to the Tracking
Variables list.

— Use to remove the highlighted variable from the Tracking Variables list.

Variables List:
The Variables List, located in the lower portion of the Variables window, displays all
variables initialized and encountered during tool path processing.
Name — The Name column displays a tree structure showing a list of all variables,
and how each variable relates to the overall structure of the NC program
(subsystem, toolpath, subroutines, etc.). Tree is constantly updated as the toolpath
is processed.
Description — Description of the variable. This field enables you to enter a
description for the NC Variable. This feature allows you to document variables for
later use, as well as simplifying the tracking of states. Instead of just seeing 4001, a
more meaningful "Motion Type"description can be added. Descriptions that end
with an " * " has been automatically generated by VERICUT. Automatically
generated descriptions can result from any of the following:
y Setting a variable on the Events window.
y Setting a variable on the Word/Address window.
y Calling one of the Autoset… macros.
y Calling the SetDynamicVars macro.

529
Type — Type of variable (Number, Text or Array); also indicates the type of data
that can be assigned to the variable.
Current Value — The current value of the variable.
Initial Value — The initial value of the variable.

NOTE: It is possible to create a variable with no defined values. This is


done by adding a variable with either a description, or by adding the variable
to the tracking variable list. This is significant because VERICUT treats
variables differently depending on whether the variable exists (defined within
VERICUT) versus whether the variable has an undefined value.

y If you try to access a non-existing variable (a variable that does not


show up in variables window), VERICUT outputs an error message
saying; "un-initialized variable, defaulting to zero".
y When you call a G65 subroutine, variables 1-33 get initialized to
"undefined" or "vacant" except those, which are set on the call to the
subroutine. If you try to access an "undefined" variable, then
VERICUT does not output an error message, or default to zero.

See Notes about un-initalized variables for additional information.

Add — Opens the Variable Add window enabling you specify the characteristics
of a new variable and add it to the variable list.
Delete — Deletes the highlighted variable from the variable list.
Delete All — Deletes all variables in the variable list.
Close — Close the Variables window.

530
Add Variable window
The features on this tab enable you to specify the characteristics of a new variable and
add it to the variable list.

Name — Name of the variable.


SubSystem — Use this feature to specify the subsystem that the variable is associated
with.

NOTE: SubSystem in this case pertains to the subsystems defined in the


Variables window variable tree, NOT the subsystems defined by the machine.

Description — Use this field to add descriptive information about the variable
Type — Select the Type of variable from the pull-down list.; also indicates the type of
data that can be assigned to the variable. Options:
y Number — the variable is real number. For example, value ="0010" => the
numeric value "10" is used.
y Text — the variable is a text string. For example, value ="0010" => the text string
"0010" is used.
y Array — The variable is an array. When Array is selected as the variable type,
an Array Dimension field and an array table are added to the Add Variable
window.
Array Dimension — Use to specify the dimensions of the array that the
variable represents, for example "3, 4", for a 3x4 array.
Array Table — Use the array table to initialize specific array values if
desired. VERICUT automatically adjusts the size if the array based on the
dimension set with Array Dimension and all values are defaulted to 0.

531
Notes on using Array variables:
Non-numeric variables must be defined in the Words window to enable proper
parsing.
In the Variables window, Type must be set to Array, and Array Dimension
must also be defined.
In the MCD file, the syntax must be of the form: name[2,1]=5 where the
square brackets are left and right precedence, and indexes are separated by a
commas. Each index can also be defined as an expression. For example:
name[#7+1,1]=3.
Array variables are also supported in the Word Address window as a variable to
be set. Non-numeric variables can not be used with override values.

OK — Adds the variable to the Variables List in the G-Code Variable window and
dismisses the Add Variable window.
Apply — Adds the variable to the Variables List in the G-Code Variable window and
leaves the Add Variable window open enabling you to specify additional variables.
Cancel —Dismisses the Add Variable window without adding the variable to the
Variables List in the G-Code Variable window.

532
Process Options

Process Options window


Location: Project menu > Processing Options > G-Code > Process Options

Opens a window to configure settings to support processing G-code NC program files.

G-Code Output Files tab — Features on this tab provide important settings for G-code
simulation, such as: the G-code programming method, when cutter compensation (CDC)
codes are processed, tool path scanning, and tolerances used for simulating rotary
motions.
Messages tab — Features on this tab are used to specify work offsets and machine
locations specific to the current tool path file(s).

533
Debug tab — Features on this tab are used to store tool-related offset and compensation
register data.
User Defined (CTRL) tab — Features on this tab are used to initialize, maintain, and
monitor variables referenced by, but not set by the tool path file.
OK — Applies the changes and closes the Process Options window.
Apply — Applies the changes and leaves the Process Options window open.
Cancel — Closes the Process Options window without applying changes.

534
Process Options window, G-Code Output
Files tab
Location: Project menu > Processing Options > G-Code > Process Options

Opens a window to control conversion, or "reverse post-processing" of G-Code tool


paths, and specify the names of files resulting from this process. (See how)

APT Output File — Name of the file to receive ASCII APT tool path records resulting
when Create APT Output File is active (see below). If blank, the file is not created.
G-Code Log File — Name of the G-Code Log file to receive error, warning and
informational messages about G-Code processing. If blank, the file is not created.
Create APT Output File — When active, converts the G-Code NC Program data into
ASCII APT NC Program records. Converted data is stored in the specified APT Output
file (see above).

535
View APT Output File — Opens a window containing the APT Output file with ASCII
APT tool path records created when Create APT Output File is active (see above).
For information about APT NC Program records and formats, see "Supported APT-CLS
records".
View G-Code Log File — Opens a window containing the G-Code Log file. This file
contains information, such as error, warning and informational messages about G-Code
processing. In this window, you can view, edit, or reset the G-Code Log file contents.

536
Process Options window, Messages tab
Location: Project menu > Processing Options > G-Code > Process Options

Opens a window to set the destination and format of messages output during a
simulation. (See how)

Send Error Messages — Destination of messages about errors-potentially severe


problems that will most likely produce incorrect results on the machine tool.
Send Warning Messages — Destination of messages about possible problems.
Scrutinize warnings to decide if they will actually impact the machining process.
Send Info Messages — Destination of messages providing information about files used,
the time and date that the process started, etc.
Send Debug Messages — Destination of debug messages providing additional
information related to internal calculations, conditions, and variable values. The types of
debug messages which appear are controlled via Process Options window: Debug tab.
Send Control Setting Messages — Destination of messages showing the control settings
that were in effect when the tool path file was processed.
Send Input Messages — Destination of messages showing the input tool path file
records processed.

537
Send Output Messages — Destination of messages showing the converted tool path
records resulting from reverse-postprocessing. When Create APT Output File is active
on the Process Options window: G-Code Output Files tab, output messages are sent to the
APT Output File specified on the same window. By default, these records are in ASCII
APT format. However, using the Machine Developer's Kit, other output file formats are
obtainable.
Output Filenames Format — Controls how names of files used by VERICUT are
shown. Options are: Filename Only or Full Path Names (includes full directory path).
Output Block Sequence Numbers — Controls when block sequence numbers are
included with APT output records resulting from conversion. The sequence numbers
appear in columns 73-80, and are useful for general reference or debugging purposes.
Options are: Yes (output block sequence numbers) or No (don't output block sequence
numbers)
Output "Word is not defined" Errors — When set to Yes, outputs the "Word is not
defined" error message when G-code words are encountered that the control is not set up
to process. To prevent these errors from appearing, ensure this feature is set to No.

Messages can be sent to the destinations listed below:


y to APT Output
y to G-Code Log (not available for Send Output Messages)
y to Logger (not available for Send Output Messages)
y to APT Output and G-Code Log
y to APT Output and Logger
y to G-Code Log and Logger (not available for Send Output Messages)
y to APT Output, G-Code Log and Logger
y to Nowhere (not available for Send Error Messages, Send Warning Messages or
Send Output Messages)

NOTE: Not all destination choices are available for all message types.

538
Process Options window, Debug tab
Location: Project menu > Processing Options > G-Code > Process Options

Opens a window enabling you to select what debug messages to send to output. (See
how) Debug messages can provide additional information that may be helpful debugging
development of files used to simulate G-code NC programs and simulate machine tool
motions. Set each Debug Message to either Yes (send to output) or No (don't send to
output). The output destination for debug messages is controlled by "Send Debug
Messages" on the Process Options window: Messages tab.

Debug Offsets — When selected, outputs debug messages about offset value changes,
including: coordinate system offsets/shifts, compensation values in use, etc.
Debug Delta Information — When selected, outputs debug messages about rotating the
tool position.
Debug Rate Calculations — When selected, outputs debug messages about rate
calculations related to tool movement.
Debug Loop Logic — When selected, outputs debug messages about values calculated
by looping or branching logic.

539
Debug Macro Arguments — When selected, outputs the macro name, the word, the text
string value, and the numeric value for the macro being called.
Debug Intersect Points — When selected, outputs debug messages related to intersect
points calculated by CDC calculations.
Debug Cutter Compensation — When selected, outputs debug messages about CDC
tool offset positions.
Debug Cycle Values — When selected, outputs debug messages related to processing
canned tool axis cycles.
Debug Substitution — When to selected, outputs debug messages related to string
substitutions (ref. Configuration menu > Adv. Options: Substitute tab).
Debug Variables — When selected, outputs debug messages about changes to variable
values. See also: Project menu > Processing Options > G-Code > Variables window.
Debug Turning — When selected, outputs debug messages associated with turning, for
example the distance from the turning axis to the tool control point and calculations
related to the use of constant surface speed.
Debug Wire EDM — When selected, outputs debug messages associated with wire
EDM machining.
Debug Optipath — When this is turned on, a descriptive message will be printed
whenever machine simulation determines a block is non-optimizable.

540
Process Options window, User Defined tab
Location: Project menu > Processing Options > G-Code > Process Options

Opens a window to configure user defined control settings supplied via a custom CME
file. This window will appear differently, depending on the CME file in use. CME files
are created using the Machine Developer's Kit, and specified for use in VERICUT via
Dev Kit CME tab of the Advanced Control Options window.

NOTE: Developer's Kit-defined settings can also appear on the User Defined
(CTRL) tab of the Control Settings window, as determined by the developer.

541
APT Settings

APT Settings window


Location: Project menu > Process Options > APT Settings

VERICUT toolbar short cut:

Opens a window to configure settings to support processing APT-CLS tool path files.

542
Motion tab — Features on this tab provide important settings for APT-CLS tool path
simulation, such as: how circle and rapid motions are simulated, default tool path units,
and more.
Rotary tab — Features on this tab provide control over rotary motions simulated for
APT-CLS tool paths.
Turning tab — Features on this tab provide control over lathe turning motions simulated
for APT-CLS tool paths.
Cycles tab — Features on this tab enable you to change how VERICUT simulates APT
or CLS tool path canned cycles, also known as "fixed tool axis cycles".
OK — Saves the settings and closes the APT Settings window.
CANCEL — Closes the APT Settings window without saving setting changes.

543
APT Settings window, Motion tab
Location: Project menu > Process Options > APT Settings

VERICUT toolbar short cut:

Features on this tab provide important settings for APT-CLS tool path simulation, such
as: how circle and rapid motions are simulated, default tool path units, and more.

Default Toolpath Units — Default unit measurement system for tool path files that do
not contain a "UNITS" record. If the tool path file units differ from the session units,
values in the tool path are converted appropriately while being processed.
MULTAX — When selected, interprets six parameter GOTO records as
GOTO/x,y,z,i,j,k where i,j,k is tool axis orientation (superseded by MULTAX/OFF).
Clearing this checkbox interprets these records as GOTO/x1,y1,z1,x2,y2,z2 - two point
locations (superseded by MULTAX/ON).

544
Max Tool Axis Angle — Maximum angle (in degrees) along a multi-axis motion to
display intermediate tool positions. A value of "0" (default) does not display intermediate
positions on multi-axis motions. The cut model is unaffected by this feature.
Tool Axis Reset Angle — Minimum angle (in degrees) which is considered a positioning
move. Multi-axis motions having angles equal to or greater than the reset angle do not
remove material. Instead, the tool display is turned off through the multi-axis motion,
then turned on after the multi-axis destination is reached. Cutting resumes at the new tool
position.
Process Circles — When selected, processes CIRCLE records to simulate the arc
motion. Clear this checkbox to ignore "CIRCLE" records, such as necessary when
CIRCLE records are accompanied by their representative chordal GOTO points.

NOTE: Simulating circle motions increases performance dramatically over


processing chordal GOTO points.

Reverse Circles — When selected, reverses CIRCLE record motions. Clear this
checkbox to simulate circle motions in the direction programmed. (Circle IJK values
determine circle direction.)
Detect Chordal GOTOs — When this option and Process Circles are selected, the
chordal GOTO points which follow CIRCLE records motions are processed to simulate
an arc, or circle motion. Clear this checkbox to process the GOTOs as linear tool
positions.
Reset Tool Change — When selected, resets the tool display following a tool change.
This action turns off the tool display until after the tool is changed and the following
motion is processed. The new tool appears at the end of the motion following the tool
change. This option is recommended when simulating tool paths for NC machines that
automatically retract the tool during a tool change. Clear this checkbox to have
VERICUT change the tool at its current location when a tool change command is
encountered.
Process Unigraphics or CATIA Matrix — When selected, processes these tool path
matrix records to transform the tool path to its base coordinate system: CATIA0 or
MSYS. Clear this checkbox to ignore tool path matrix records. This feature is useful to
automatically orient tool paths to models imported from the same CAD/CAM system.
Ignore unrecognized Major words — When toggled on, VERICUT ignores
unrecognized APT major words and no warning messages are output to the VERICUT
main window message area, or in the Log file.
Default CLEARP — Distance to retract along the tool axis when a RETRCT record is
encountered prior to establishing the retract plane. The default CLEARP condition is
"off" until a CLEARP record defining a clearance plane is encountered.
RAPID Motion — Controls how to simulate rapid positioning motions. Options:
y Linear — Move in a straight line.
y Square — Move with "squared off" motion, where Z motions are processed
independently from X and Y.

545
GOHOME Motion — Controls how the tool is returned to the home position when a
GOHOME record is processed. Options:
y FROM — Move in a straight line to the home position.
y Retract — Move with squared off motion, where the tool is first retracted the
distance specified by the GOHOME R Dist value, then moved to the home
position.
GOHOME R Dist — When simulating GOHOME record motions via the "Retract"
option (see above), this value specifies the distance to retract before going to the home
position.

546
APT Settings window, Rotary tab
Location: Project menu > Process Options > APT Settings

VERICUT toolbar short cut:

Features on this tab provide control over rotary motions simulated for APT-CLS tool
paths. Note that while machines often rotate the workpiece, in a VERICUT Workpiece
view the workpiece is fixed and the tool is seen rotating about the workpiece. Both rotary
cut paths are identical.

"ROTATE/BAXIS,ATANGL,90" as seen on a machine with a "B" rotary table, and


simulated by VERICUT in a Workpiece view:

547
ROTATE, ROTABL, ROTHED — These features control when and how to
simulate motion caused by the corresponding ROTATE, ROTABL, or ROTHED
records, respectively. "BAXIS" is the default rotation axis when not specified. The
rotary pivot point is defined by the Rotation Center. When absolute or incremental
rotation is not specified, the Angle Value determines how to apply the rotary value.
Options:
y Ignore — Ignores the rotary command. (Default)
y Rotate — Rotates while cutting. Tool path motions that follow are
expected to have the rotation applied.
y Rotate/Apply — Similar to Rotate, except also applies the rotated
coordinate system to subsequent tool path motions. Tool path motions that
follow are NOT expected to have the rotation applied.
y Position — Rotates without cutting, also known as "positioning". The tool
disappears from its initial position, then appears at the rotated position.
Tool path motions that follow are expected to have the rotation applied.
y Position/Apply — Similar to Position, except also applies the rotated
coordinate system to subsequent tool path motions. Tool path motions that
follow are NOT expected to have the rotation applied.

Rotation Center — Center of rotation for rotary motions simulated via the ROTATE,
ROTABL, or ROTHED features (see above).

Philosophy — Describes what is being commanded to rotate for rotary motions


simulated via the ROTATE, ROTABL, or ROTHED features (see above): Table
(default), or Tool. Changing the rotation philosophy has the affect of reversing rotation
direction. Note that ROTHED angle values are always assumed to use a rotating Table
philosophy.

548
Angle Value — Controls how angle values are applied for rotary motions simulated via
the ROTATE, ROTABL, or ROTHED features (see above) when the commands do not
specify "ATANGL" or "INCR". Options:

y Relative — Incremental angle values.


y Absolute — Absolute angle locations. (Default)

Note that ROTHED angle values are always assumed to be Absolute.

Direction — Direction of rotation for simulating for rotary motions simulated via the
ROTATE, ROTABL, or ROTHED features (see above). Options:

y Shortest — Direction which travels the shortest distance. (Default)


y CW — Always clockwise.
y CCW — Always counterclockwise.
y Linear — Refers to angles on a linear axis "wrapped" around the rotary
component. Rotary values specify absolute locations along the linear-rotary axis,
while the sign (+ / -) controls which end of the linear axis is used.

Detect 4-Axis Rotary Motion — When selected, simulates an arc cut for multi-axis
motions that fit within an arc path. Clear this checkbox to simulate each multi-axis
motion independently- recommended when simulating 5-axis contouring-type motions.
The Interpolation Tolerance value is used to determine which motions are simulated in
the 4-axis cut.

549
APT Settings window, Turning tab
Location: Project menu > Process Options > APT Settings

VERICUT toolbar short cut:

Features on this tab provide control over lathe turning motions simulated for APT-CLS
tool paths.

GOTO Format — Specifies how turning GOTO record values are to be displayed in a
Workpiece view. In this view, VERICUT simulates turning motion in the ZX plane,
where Z is the spindle-axis, and X is the cross-slide-axis. This feature acts like a post-
processor for turning tool position data.

Example 1- Assume you have a turning tool path programmed in GOTO/x,y


format. By default, GOTO Format "#zval, #xval" displays the first GOTO
value as Z-axis motion, and the second value as X-axis motion.

550
Example 2- Assume you have a turning tool path that was reversed post-processed
from G-code data such that GOTO records are in GOTO/x,0,z format (center
value is "zero"). For VERICUT to process this correctly, set GOTO Format=
#xval, #yval, #zval.

551
APT Settings window, Cycles tab
Location: Project menu > Process Options > APT Settings

VERICUT toolbar short cut:

Features on this tab enable you to change how VERICUT simulates the APT or CLS
CYCLE records to simulate tool path canned cycles, also known as "fixed tool axis
cycles". The Drill Cycle feature controls when and how these records are simulated.

Cycle Set—Controls which cycle definition set(s) are considered by VERICUT when
processing APT tool paths. If you add a new cycle set, for a different flavor of APT or a
different post-processor, you can give it any name you wish and it will appear in this list.
"ALL" considers all cycle sets defined for use.

552
Cycle Definitions—Opens a window to maintain cycle and modals definitions used to
interpret "CYCLE" records. This feature is especially useful if simulated cycle motions
are not displayed as expected. When VERICUT can not find definitions to interpret a
CYCLE record, an error similar to "Invalid CYCLE record" error is issued. In these
cases, cycle definitions must be modified to interpret the cycle data.
For more information about configuring VERICUT to interpret cycle commands, see
"About configuring for cycle simulation" in the Using VERICUT section.

553
Supported APT-CLS tool path records
APT tool path records typically contain a major vocabulary word followed by a slash
("/"), then a combination of data and/or minor vocabulary words. APT records can be
preceded by leading spaces or tabs. Spaces can appear anywhere in the record. APT
record data typically ends prior to column 72. However, a "$" at the end of a record
continues onto the following line.
The APT tool path records processed by VERICUT are listed below in alphabetical order.
See the appropriate section for details. Records not listed are typically ignored by
VERICUT.
y ARC record
y CATIA0 record
y CHGTOOL record
y CIRCLE record
y CLEARP record
y CLRPLN record
y CLRSRF record
y CNTRL record
y CONT record
y COOLNT record
y CSYS record
y CUTCOM record
y CUTTER record
y CYCLE record
y CYLNDR record
y FEDRAT record
y FROM record
y GODLTA record
y GOFWD record
y GOHOME record
y GOTO record
y HEAD record
y INDIRV record
y KNOT record
y LOAD/TOOL record
y LOAD/WIRE record
y LOADTL record
y MODE record
y MOVARC record

554
y MSYS record
y MULTAX record
y NURBS record
y PPRINT record (general purpose)
y PPRINT/ATP CBOX record
y PPRINT/TOOL AXIS record
y PPRINT/VERICUT record (or PPRINTVERICUT)
y RAPID record
y RETRCT record
y ROTABL record
y ROTATE record
y ROTHED record
y SET/MODE record
y SPINDL record
y SPNDL record
y STOP record
y SURFACE record
y TLAXIS record
y TRANS record
y TURRET record
y UNITS record
y UNLOAD/WIRE record
y VECTOR record

ARC record
Causes circular motion. The format of this record is similar to CIRCLE record, except
specifies the arc end point via an additional set of X, Y, Z values.
Go to top

CATIA0 record
Specifies a CATIA-style twelve parameter tool path transformation matrix. VERICUT
processes this record when Process Matrix, on the APT Settings window: Motion tab, is
active.
Example:
$$*CATIA0

$$*AXS2

$$ .00000 .00000 1.00000 -6.59040

$$ .99360 .11299 .00000 -16.50458

555
$$ -.11299 .99360 .00000 -3.32025
Go to top

CHGTOOL record
Specifies the tool number to be changed into the spindle, same as LOADTL record. This
record is not processed by default, however, you can use Tool Change By, in the NC
Program window, to process this record and retrieve cutting tool descriptions from a
VERICUT tool library.
Format:
CHGTOOL/n[,anytext]
Go to top

CIRCLE record
Causes circular motion. The GOTO point preceding the CIRCLE record defines the start
of the circular motion. The GOTO following the CIRCLE defines the circular motion
end. Helical motion is generated when the end point measured along the tool axis differs
from the start point. This record is processed when Process Circles ,on the APT Settings
window: Motion tab, is active.
Formats:
y CIRCLE/x,y,z,i,j,k,r[,n,n,n,n] - where "x,y,z" defines the circle center point,
"i,j,k" is the axis orientation. "r" is the circle radius, but is not used since the
radius is computed from the start, end and center points. The vector defines the
positive Z-axis of counter-clockwise motion following the right-hand rule. In the
11 parameter format, VERICUT only uses the first 7 parameters.
Examples:
CIRCLE/1,2,3,0,0,1,5 - CCW circle motion about point 1,2,3, radius of 5
CIRCLE/1,2,3,0,0,-1,5 - as above, except CW arc motion
Go to top

CLEARP record
Defines a clearance plane used by subsequent RETRCT records. See also: Default
CLEARP on the APT Settings window: Motion tab.
Formats:
y CLEARP/OFF
y CLEARP/value
y CLEARP/XYPLAN(YZPLAN or ZXPLAN),value - establish a clearance plane
parallel to the part coordinate XY, YZ, or ZX plane, respectively at "value"
distance from the part coordinate system origin. Only one plane may be active at
one time. If no plane option is specified, XYPLAN is assumed.
y CLEARP/PERPTO,value - establishes a clearance plane perpendicular to the tool
axis at "value" distance from the part coordinate system origin. Clearance plane

556
distance is measured in the direction of the tool axis. Changing the tool axis
vector changes the clearance plane.
Go to top

CLRPLN record
Defines a clearance plane, same as CLEARP record.
Go to top

CLRSRF record
Defines a clearance plane, same as CLEARP record.
Go to top

CNTRL record
Defines a control point for use with a NURBS record.
Formats:
y CNTRL/x,y,z[,i,j,k][,WEIGHT,w] - where "x,y,x" are the control points (or poles)
for tool postiion, optional "i,j,k" values control the tool axis, and optional "w"
specifies the weights.
Go to top

CONT record
GOTO continuation record, similar to GOTO record.
Formats:
y CONT/x,y,z
x,y,z
:
y CONT/x,y,z,i,j,k
x,y,z,i,j,k
:
Go to top

COOLNT record
Controls coolant usage. Text following the slash is displayed in the Status window as the
current coolant condition.
Formats:
y COOLNT/anytext
y COOLNT/ON[,anytext]
y COOLNT/OFF
Go to top

557
CSYS record
Specifies a ProManufacturing-style twelve parameter tool path transformation matrix.
VERICUT processes this record when conditions are suitable. A more detailed
explanation follows. The "$$->FEATNO" record resets back to the identity matrix, and
"$$->END" ends TRANS/ROTATE/CSYS actions.
Example:
$$-> CSYS / 1.0000000000, 0.0000000000, 0.0000000000, 0.0000000000, $

0.0000000000, 1.0000000000, 0.0000000000, 0.0000000000, $

0.0000000000, 0.0000000000, 1.0000000000, 0.0000000000


ProManufacturing APT has combinations of options that determine how ROTATE,
TRANS, and CSYS are applied. For VERICUT to determine how to apply these
transformations, all records are processed concurrently. The table below describes cases
where ROTATE, TRANS, and CSYS are processed. VERICUT ignores these records for
cases that are not described in the table.

"ROTATE" record "TRANS" record "$$->TRANS" Action


present present present
No No No Ignore CSYS and
TRANS
No No Yes Apply TRANS
No Yes No Apply CSYS
Yes No Yes Add TRANS to
CSYS, then apply
CSYS
Yes Yes No Apply CSYS
Go to top

CUTCOM record
CUTCOM record supports cutter compensation for ProManufacturing CL data. If
VERICUT encounters:
$$-> CUTCOM_GEOMETRY_TYPE / OUTPUT_ON_PROFILE
Then sees a CUTCOM/LEFT, or CUTCOM/RIGHT, it reads ahead to the
CUTCOM/OFF. The profile is then offset to the left or right by the cutter radius and
VERICUT re-reads the APT, making adjustments as required. The algorithm used is not
intended to match any particular postprocessor or controller.

If OptiPath is being used, the OUTPUT_ON_PROFILE gets replaced by


OUTPUT_ON_CENTER in the generated file, and the subsequent GOTOs refer to the

558
cutter centerline.
Go to top

CUTTER record
Describes the shape of the cutting tool.
This record is processed by default, however, you can use Tool Change By, in the NC
Program window, to ignore these and process other records in the tool path file to retrieve
cutting tool descriptions from a VERICUT tool library.
Formats:

y CUTTER/d,r,e,f,a,b,h
y CUTTER/d,r,h
y CUTTER/d,r (requires Min. Cutter Height > 0)
y CUTTER/d (requires Min. Cutter Height > 0)
y CUTTER/XCUT(SHANK or HOLDER),...profile description

The table below and figures that follow describe how the values "d" through "h" are
interpreted, based on if the cutter is used for milling or turning.

Value Milling Cutter Turning Cutter


d diameter nose diameter
r corner radius not used
e dist. from tool centerline to not used
corner radius center
f dist. from tool tip to corner not used
radius center
a base angle tool angle- degrees from
spindle axis
b side angle side angle- degrees from tool
centerline to its side
h height height- measured from tool
tip along its centerline

559
Generic 7 Parameter Mill Cutter Definition: CUTTER/d,r,e,f,a,b,h

Generic 4 Parameter Turn Cutter Definition: CUTTER/d,0,0,0,a,b,h (or


CUTTER/d,,,,a,b,h)

Go to top

CYCLE record
Describes a canned tool axis cycle motion (e.g. drilling, reaming, boring, etc.) that is to
be repeated at subsequent motion locations. The Drill Cycle feature, in the Motion
window, controls when and how these records are simulated.
Formats:
y CYCLE/<parameters> - where "<parameters>" provide information about how
the canned motion is to be applied.
If canned cycle motions are not displayed as expected ensure that Drill Cycle is
not set to Ignore. If cycle simulation is still not correct, use Cycle Def on the
APT Settings window: Cycles tab to configure how VERICUT interprets

560
canned cycle commands.
Go to top

CYLNDR record
Causes circular motion, same as CIRCLE record.
Go to top

END record
Ends the tool path transformation matrix caused by a combination of CSYS, ROTATE
and TRANS records. VERICUT processes this record when conditions are suitable. See
"CSYS record" for details.
Go to top

FEATNO record
Resets the tool path transformation matrix caused by a combination of CSYS, ROTATE
and TRANS records back to the identity matrix. VERICUT processes this record when
conditions are suitable. See "CSYS record" for details.
Go to top

FEDRAT record
This record sets the feed rate, or speed at which the tool moves. Text following the slash
is displayed in the Status window as the current feedrate condition.
By default, a zero feedrate is used until a FEDRAT record is processed. The active feed
rate value is used until another FEDRAT record is encountered. A RAPID motion
overrides the active FEDRAT for that motion only.
Formats:
y FEDRAT/value[,IPM] also: IPR, MMPM, MMPR - where “value” represents
feedrate in the current mode. The feedrate value, and mode if specified, are
displayed in the Status window Feedrate field.
Go to top

FROM record
This record establishes where the tool is starting from. There is typically one record of
this type per tool path file and it usually precedes any other motion record in the file. If a
FROM record is not encountered, then the first GOTO point location is assumed as the
from position.
Formats:
y FROM/x,y,z[,i,j,k] - where "x,y,z" is the starting point and "i,j,k" represents the
starting tool axis vector. If no ijk information is found, then a tool axis of 0,0,1 is
assumed.

561
Go to top

GODLTA record
Designates incremental cutter movement relative to the current cutter location.
Formats:
y GODLTA/x,y,z - specifies the incremental distance along each axis to move the
tool from its current location. For example, if the tool is currently at 4,5,6 in xyz
when GODLTA/1,2,3 is processed, the tool moves to x=5 (4+1), y=7 (5+2), and
z=9 (6+3).
y GODLTA/value - moves the cutter along the tool axis the specified amount.
If there is a transformation active, such as by a previous rotary motion command or a
stock transformation, then the GODLTA values are transformed accordingly.
Go to top

GOFWD record
Designates forward cutter movement relative to the current cutter location. VERICUT
considers this record only when processing motion generated by GOFWD used with
CIRCLE or CYLNDR records. Numerous formats are recognized, many of which also
consider the INDIRV record to determine the "forward" motion direction.
Go to top

GOHOME record
Specifies that the cutter return to the home position. The home position is assumed to be
the location specified by the last FROM record processed. If a FROM record has not been
processed, then 0,0,0 is used.
Formats:
y GOHOME - move all axes to the home position. The GOHOME Motion feature,
on the APT Settings window: Motion tab, controls if the cutter is moved in a
straight line, or is retracted prior to going home.
y GOHOME/XAXIS(YAXIS or ZAXIS) - treated as GOTO statements with the
specified AXIS element set to the FROM value for that axis. The other two
elements are set to the current tool path position values.
Go to top

GOTO record
Designates a position where the tool is moved to.
Formats:
y GOTO/x,y,z[,i,j,k] - where "x,y,z" represent the ending location of the tool
motion and optional "i,j,k" values control the tool axis in multi-axis movements.
"0,0,1" tool axis orientation is assumed. "GOTO/" text is optional after the first
GOTO motion, for example:

562
GOTO/x,y,z[,i,j,k]
x,y,z[,i,j,k]
:
Go to top

HEAD record
Found in tool paths for mill-turn and 4-axis lathe machines, the "HEAD" record specifies
which machining head is in use.
Formats:
y HEAD/1- head 1 active
y HEAD/2- head 2 active
y HEAD/BOTH- head 1 active
y HEAD/OFF- head 1 active
When head 2 is active the tool is changed via a "LOADTL" or "TURRET" record,
VERICUT prepends the tool ID specified by the LOADTL/TURRET record with the
characters "2_" to retrieve tools defined for use by head 2.
Example 1:
HEAD/1
TURRET/1
Looks for ID "1" in the Tool Library (interpreted as tool 1 for use by head
1).
Example 2:
HEAD/2
TURRET/1
Looks for ID "2_1" in the Tool Library (interpreted as tool 1 for use by
head 2).
Go to top

INDIRV record
Vector coefficients describing the "forward" motion direction. VERICUT considers this
record only when processing motion generated by a GOFWD record used with CIRCLE
or CYLNDR records.
Format:
y INDIRV/i,j,k
Go to top

KNOT record
Defines a knot parameter for use with a NURBS record.
Format:
y KNOT/t1,...,t(n-p+2) - where "t1" - "t(n-p+2)" are the knot parameters.

563
Go to top

LOAD/TOOL record
Specifies the tool number to be changed into the spindle, same as LOADTL record. This
record is not processed by default, however, you can use Tool Change By, in the NC
Program window, to process this record and retrieve cutting tool descriptions from a
VERICUT tool library.
Format:
y LOAD/TOOL,n[,anytext]
See also HEAD record for information about how the Pro/MFG APT "HEAD" record
affects how this record is used to retrieve tool from a VERICUT tool library.
Go to top

LOAD/WIRE record
For wire EDM machining- causes the wire to be loaded-sets cutting mode in VERICUT
for wire EDM machining. See also UNLOAD/WIRE record.
Go to top

LOADTL record
Specifies the tool number, or pocket number of the tool to be changed into the spindle.
Optionally, this record may also specify tool length or other aspects about the tool,
however, VERICUT ignores all parameters following the tool number.
This record is not processed by default, however, you can use Tool Change By, in the
NC Program window, to process this record and retrieve cutting tool descriptions from a
VERICUT tool library.
Format:
y LOADTL/n[,anytext] - where "n" is the index number of the tool (number or
alpha-numeric). Leading zeros in the tool ID are also ignored, for example
"LOADTL/01" is interpreted as "LOADTL/1". Any text following the "/" or
number data after tool ID is ignored, for example "LOADTL/2,LENGTH,6.500"
is interpreted as "LOADTL/2".
See also HEAD record for information about how the Pro/MFG APT "HEAD" record
affects how this record is used to retrieve tools from a VERICUT tool library.
Go to top

MODE record
Identifies the machining to be performed: mill or turn.
Formats:
y MODE/MILL(TURN)
Go to top

564
MOVARC record
Causes circular motion, same as CIRCLE record.
Go to top

MSYS record
Specifies a Unigraphics-style nine parameter tool path transformation matrix. VERICUT
processes this record when Process Matrix, on the APT Settings window: Motion tab, is
active.
Go to top

MULTAX record
Determines if subsequent GOTO motions are multi-axis motions. The multi-axis
condition is modal. When multi-axis mode is on it remains on until another MULTAX
record turns it off.
Formats:
y MULTAX/ON
y MULTAX/OFF
Go to top

NURBS record
Defines a NURBS B-spline motion command. NURBS motion commands also utilize the
CNTRL record and KNOT record as part of the B-spline definition.
Format:
y NURBS/[p]- where "p" indicates the B-spline order. The "NURBS" record
typcally spans multiple lines and includes a number of other record types, such as
"KNOT", "CNTRL", etc.
Example:
NURBS/
KNOT/1.0000000
CNTRL/61.2424,93.2577,-31.6260
:
CNTRL/59.8775,93.2224,-31.6263
Go to top

PPRINT record (general purpose)


Comment record that typically has no affect on tool motion. "PPRINT" resides in
columns 1-6. Text following "PPRINT" is typically ignored by VERICUT, however,
some PPRINT records can perform VERICUT actions. See also "Controlling VERICUT
with comment records".

565
Go to top

PPRINT/ATP CBOX record


Defines a stock block via min/max corner points. This record is processed by VERICUT
when a stock model is loaded and the model is not yet cut. A new stock block is defined
and fit into all displayed views.
Format:
y PPRINT/ATP CBOX xmin,ymin,zmin,xmax,ymax,zmax
Example:
PPRINT/ATP CBOX -1,-2,-1,5,7,2 -defines a 6 x 9 x 3 block positioned X=
-1, Y= -2, Z= -1
Go to top

PPRINT TOOL AXIS record


Specifies a new tool axis orientation to be applied to subsequent tool positions. The
specified tool axis is modal and remains in effect until another tool axis orientation is
specified.
Example:
PPRINT TOOL AXIS= XAX=-1.0000 YAX=.0000 ZAX=.0000
Go to top

PPRINT/VERICUT record
(or PPRINTVERICUT) Sets a VERICUT user value, or performs a VERICUT command
or action. PPRINT/VERICUT text must be between columns 1-72. PPRINT data can
span multiple PPRINT records via ending each PPRINT to be continued in a dollar sign.
The next line must be a PPRINT/VERICUT record with the same keyword as the
previous line. Words in PPRINT data can not be split by the dollar sign. Examples are
provided in the sections that follow.
See also "Controlling VERICUT with comment records".
Go to top

RAPID record
Overrides the current feed rate and causes a machine tool to move as fast as possible.
When the RAPID record is processed by VERICUT, the motion following the RAPID
moves the tool using the Fast Feed setting in the Motion window.
For example, assume the file below is processed while Fast Feed=100.
RAPID
GOTO/1,2,3
FEDRAT/20
GOTO/2,3,4

566
RAPID
GOTO/3,4,5
GOTO/4,5,6
The motions are simulated by VERICUT as follows:
y feed rate from the current tool location to 1,2,3: 100
y feed rate from 1,2,3 to 2,3,4: 20
y feed rate from 2,3,4 to 3,4,5: 100
y feed rate from 3,4,5 to 4,5,6: 20
In both examples below, motion from 1,2,3 to 4,5,6 uses a feed rate of "20":
Example 1:
FROM/1,2,3
RAPID
FEDRAT/20
GOTO/4,5,6
In example 1, a FEDRAT record immediately follows the RAPID record before a motion
is encountered. Under this condition, the FEDRAT value overrides a RAPID record.
Example 2:
RAPID
FROM/1,2,3
FEDRAT/20
GOTO/4,5,6
In example 2, a FROM record is not considered to be a motion record. Therefore, the
RAPID record has no affect.
Go to top

RETRCT record
Retracts the cutter along the tool axis to a specified clearance plane, or by a specified
amount.
Formats:
y RETRCT- retract the tool along the tool axis until it reaches the clearance plane
defined by the previous CLEARP or CLRSRF record
y RETRCT/value- retract along the tool axis the specified amount
y RETRCT/ON- retract to the Z level prior to a cycle record.
Example:
GOTO/1,2,3
RETRCT/ON
CYCLE/DRILL,1.0,3,IPM,.1 $$ Retracts to Z=3 between cycle positions.
Go to top

567
ROTABL record
Specifies a table rotation. Unless otherwise specified, rotation about the Y-axis is
assumed. This record is processed when the ROTABL setting, on the APT Settings
window: Rotary tab, is active. Otherwise, ROTABL is ignored.
Formats:
y ROTABL/AAXIS(BAXIS or CAXIS),value
y ROTABL/AAXIS(BAXIS or CAXIS),ATANGL,value
y ROTABL/AAXIS(BAXIS or CAXIS),INCR,value
y ROTABL/ATANGL,value
y ROTABL/INCR,value
Go to top

ROTATE record
Similar to the ROTABL record, this record specifies a table rotation. ROTATE is
handled differently, depending on the active setting of NC Program Type, in the NC
Program window.
1. Non-ProManufacturing tool path types - when the ROTATE setting, on the APT
Settings window: Rotary tab, is active the rotary action is simulated by
VERICUT. Otherwise, ROTATE is ignored.
2. Pro/MFG APT tool path types- ROTATE is considered along with TRAN and
CSYS when determining if the tool path is to be transformed. See "CSYS record"
for details. The "$$->FEATNO" record resets back to the identity matrix, and
"$$->END" ends TRANS/ROTATE/CSYS actions.
Formats:
y ROTATE/AAXIS(BAXIS or CAXIS),value
y ROTATE/AAXIS(BAXIS or CAXIS),ATANGL,value
y ROTATE/AAXIS(BAXIS or CAXIS),INCR,value
y ROTATE/ATANGL,value
y ROTATE/INCR,value
Go to top

ROTHED record
Specifies a head rotation. This record is processed when the ROTHED setting, on the
APT Settings window: Rotary tab, is active. Otherwise, ROTHED is ignored.
Formats:
y ROTHED/ATANGL,value
y ROTHED/value
Go to top

568
SET/MODE record
This record specifies the machining to be performed: mill or turn.
Formats:
y SET/MODE,MILL
y SET/MODE,TURN
Go to top

SPINDL record
Specifies spindle rotation speed (RPM); direction and gear ranges may also be specified.
Text following the slash is displayed in the Status window as the current spindle
condition.
Formats:
y SPINDL
y SPINDL/rpm[,anytext]
y SPINDL/[anytext,]rpm
Go to top

SPNDL record
Specifies spindle rotation speed (RPM), same as SPINDL record.
Go to top

STOP record
Stops the NC machine at its current location. This record commonly indicates an operator
function follows, such as: changing the tool, changing the part-fixture setup, etc.
Go to top

SURFACE record
Causes circular motion, same as CIRCLE record.
Go to top

TLAXIS record
Specifies a new tool axis orientation. The new orientation is modal and is applied to
following GOTO points that do not have I,J,K values. VERICUT processes this record
when NC Program Type, in the NC Program window, is set to CATIA APT.
Example:
TLAXIS/ .000000, 1.000000, .000000
Go to top

569
TRANS record
Specifies a three parameter tool path translation. VERICUT processes this record when
NC Program Type, in the NC Program window, is set to Pro/MFG APT and conditions
are suitable. The presence of ROTATE and TRANS records affect when VERICUT
processes a TRANS record. See "CSYS record" for details.
Format:
TRANS / dx, dy, dz
where "dx, dy, dz" are the distances in X, Y, and Z to translate the tool positions that
follow. The "$$->FEATNO" record resets back to the identity matrix, and "$$->END"
ends TRANS/ROTATE/CSYS actions.
Go to top

TURRET record
Similar to LOADTL record, this record often appears in tool paths for turning operations
to specify the tool number to be changed into location for cutting. This record is not
processed by default, however, you can use Tool Change By, in the NC Program
window, to process this record and retrieve cutting tool descriptions from a VERICUT
tool library.
The number following "TURRET" is often a composite of two numbers: a tool number
and offset number. However, VERICUT simply interprets the entire number as a tool
number. For example, while "TURRET/0101" may indicate tool 01 is used with offset
01), VERICUT interprets this to mean tool 0101 (or 101) is to be used from the
VERICUT tool library.
Formats:
y TURRET/n[,anytext]
y TURRET/FACE,n[,anytext]
See also HEAD record for information about how the Pro/MFG APT "HEAD" record
affects how this record is used to retrieve tools from a VERICUT tool library.
Go to top

UNITS record
Sets the unit measurement system of the data in the tool path file: inches or millimeters.
Formats:
y UNITS/INCHES
y UNITS/MM
Go to top

UNLOAD/WIRE record
For wire EDM machining- causes the wire to be unloaded-sets noncutting mode in
VERICUT for wire EDM machining. See also LOAD/WIRE record.
Go to top

570
VECTOR record
Designates a position where the tool is moved to, same as GOTO record.
Go to top

571
Output window
Location: Project menu > Output

VERICUT toolbar short cut:

Opens the Vericut Output files window to setup, create, or view VERICUT's many output
files.

In Process tab — Features on this tab control automatic saving of In Process files, or "IP
files".
View Capture tab — Features on this tab control automatic saving of View Capture
image files (JPEG, PS, EPSF, or TIFF files).

572
VERICUT Solid tab — Features on this tab control automatic saving of VERICUT
Solid (vct.) files.
Logs tab — Features on this tab enable you to specify and view VERICUT Log files,
Control Report files and OptiPath modified (optimized) NC Program files. It also
provides access to the OptiPath Control window.
G-Code Files tab — Use the features on this tab to specify and view the G-Code Log file
and the APT Output file.
Movie tab — Use the features on this tab to specify an output file, record, and view
VERICUT Image files or AVI files.

OK — Saves all tab settings and closes the VERICUT Output Files window.
Apply — Saves all tab settings and leaves the VERICUT Output Files window open.
Cancel — Closes the VERICUT Output Files window without saving settings.

573
Logs tab
Location: Project menu > Output

VERICUT toolbar short cut:

Features on this tab enable you to specify and view VERICUT Log files, Control Report
files and OptiPath modified (optimized) NC Program files. It also provides access to the
OptiPath Control window.

Log File
Use to specifiy the name of the VERICUT Log file. Enter the \path\file name in the text
field or click on Browse and use the selection window to specify the file.
View — Opens a window containing the VERICUT Log file. This file contains session
information, such as error, warning and informational messages about the verification
session. Standard text editing features are provided, such as: copy/cut, paste, search, etc.
For more information on using the editing features, see Text File under Edit menu.

574
Report
Use to specifiy the name of the Control Report file. Enter the \path\file name in the text
field or click on Browse and use the selection window to specify the file.
View — Opens a window containing a Control Report file containing information about
how the current NC control configuration will interpret machine codes. Reported
information includes all the G-Codes the control is configured to handle and macros
(actions) they will call, subroutines, and other supported control features. Standard text
editing features are provided, such as: copy/cut, paste, search, etc. For more information
on using the editing features, see Text File under Edit menu.

OptiPath
Use to specifiy the name of the Optimized file. Enter the \path\file name in the text field
or click on Browse and use the selection window to specify the file.
Settings — Displays the OptiPath Control window.
View — Opens a window containing the optimized NC Program file. Standard text
editing features are provided, such as: copy/cut, paste, search, etc. For more information
on using the editing features, see Text File under Edit menu.

575
G-Code Files tab
Location: Project menu > Output

VERICUT toolbar short cut:

Use the features on this tab to specify, and view, Control Reports, APT Output Files and
the G-Code Log Files.

Control Report
Enter the /directory path/filename of the Control Report file in the text field or use the
Browse button to specify it. This file contains information about how the current NC
control configuration will interpret various codes.
View — Opens a window containing the Control Report file. In this window, you can
view, edit, or reset the Control Report file contents. Standard text editing features are
provided, such as: copy/cut, paste, search, etc. For more information on using the editing
features, see Text File under Edit menu.

576
APT Output File
Enter the /directory path/filename of the APT Output file in the text field or use the
Browse button to specify it. This file contains information, such as error, warning and
informational messages about G-Code processing.
View — Opens a window containing the APT Output file with ASCII APT tool path
records created when Create APT Output File is active (ref. Process Options window:
G-Code Output Files tab). Standard text editing features are provided, such as: copy/cut,
paste, search, etc. For more information on using the editing features, see Text File under
the Edit menu.

G-Code Log File


Enter the /directory path/filename of the G-Code Log file in the text field or use the
Browse button to specify it. This file contains information, such as error, warning and
informational messages about G-Code processing.
View — Opens a window containing the G-Code Log file. In this window, you can view,
edit, or reset the G-Code Log file contents. Standard text editing features are provided,
such as: copy/cut, paste, search, etc. For more information on using the editing features,
see Text File under Edit menu.

577
Movie tab
Location: Project menu > Output

VERICUT toolbar short cut:

Use the features on this tab to specify an output file, record, and view VERICUT Image
files or AVI files.

Movie
Use to specifiy the name of the Image/AVI output file. Enter the \path\file name in the
text field or click on Browse and use the selection window to specify the file.
Settings — Displays the Image Record window.
View — Opens a "VERICUT Player" window (or "AVI Player" window) to load and
play back an Image file (or AVI file). The type of "player" window that opens depends on
the Output Format setting in the Record Movie window.

578
Report

Report Template
Location: Project menu > Report > Report Template >Edit in the main VERICUT
window.
File > Report Template in the Inspection Sequence window.
File > Report Template in the Tool Manager window.

Opens the Report Template window enabling you to define a new, or modify an
existing, report template (See How) .

The Menu Bar


File
New — Displays an empty Report Template window enabling you to create
a new report template file.
Open — Displays a file selection window enabling you to open an existing
report template file. The "current" report template file is stored in the
Preferences file.
Save — Opens a window enabling you to save the current report template
file.
Save As — Opens a window enabling you to save the current report template
file under a different name or path.
Recent Files — Provides a list of recently opened Report Template files. To
open a file in the list, select the desired file. List contents are stored in the
Preferences file.
Close — Closes the Report Template window without saving the report
template file.
Edit
Add — Enables you to add records to a new or existing report template file.
Edit — Enables you edit the content of the highlighted record. This feature is
only available for the Page Layout tab.
Delete — Enables you to delete the highlighted record from the report
template file.

579
The Tabs
Page Layout tab — Features on this tab enable you to specify or modify the content and
page layout of a report template.
Styles tab — Features on this tab enable you to specify display characteristics (font, font
size, color, etc.) to be used for the report template.
User-Defined Tags tab — Features on this tab enable you to specify "generic" records
included in a report template that will be updated with information specific to a particular
user file at the time the report is created. The user file specific information can be
associated with the User-Defined Tag using the User-Defined Tag Values window. If all
User-Defined Tag values are not defined prior to creating a report, you will be prompted
for any missing information at the time the report is created.
Page Setup tab — Features on this tab enable you to specify or modify page format
characteristics such as margins, orientation and paper size. The features on this tab are
intended to be use with PDF format reports, although it may also be useful for HTML
format reports with certain web browsers.

580
Report Template window, Page Layout tab
Location: Project menu > Report > Report Template >Edit in the main VERICUT
window.
File > Report Template in the Inspection Sequence window.
File > Report Template in the Tool Manager window.

The Menu Bar


File
See Report Template window for a description of the File features.
Edit
Add — Enables you to add records to a new or existing report template file.
NOTE: When starting a new report template, Add will not become
active until at least one style record has been added using the Styles tab.
Text — Use to add text related records to a report template. Select the
desired option from the pull-down list. The options in the list will vary
depending on where you accessed the Report Template window
(VERICUT main window, Tool Manager window, or the Inspection
Sequence window).
String — Adds a record to writes out a specified text string. Enter the
text in the "Content" field of the record.
Date — Adds a record to write out the date with the format selected
from the pull-down list.
Short — "12/24/03"
Medium — "Dec 24, 2003"
Long — "December 24, 2003"

581
Full — "Wednesday, December 24, 2003"
Time — Adds a record to write out the time with the format selected
from the pull-down list.
Short — "10:49 AM"
Medium — "10:49:48 AM"
Long — "10:49:48 AM PST"
Page Number — Adds a record to write out page numbers with the
format selected from the pull-down list.
# — "1"
Page # — "Page 1"
Page # of # — "Page 1 of 3"
File Name — Adds a record to write out the /path/file name of the type
selected from the pull-down list.
Project File — Adds a record to write out the /path/file name of the
"current" Project file.
Machine File — Adds a record to write out the /path/file name of the
"current" Machine file.
Control File — Adds a record to write out the /path/file name of the
"current" Control file.
Tool Library File — Adds a record to write out the /path/file name of
the "current" Tool Library file.
OptiPath Library File — Adds a record to write out the /path/file name
of the "current" OptiPath Library file.
Toolpath File — Adds a record to write out the /path/file name of the
"current" NC Program File.
Log File — Adds a record to write out the /path/file name of the
"current" Log file.
Optimized Toolpath File — Adds a record to write out the /path/file
name of the "current" Optimized Toolpath file.
Process Data — Adds a record to write out "process" related data of the
type selected from the pull-down list.
Material — Adds a record to write out the "material" specified on the
OptiPath Control window, Settings tab.
Machine — Adds a record to write out the "machine" specified on the
OptiPath Control window, Settings tab.
Total Time — Adds a record to write out the total time anticipated to
machine the part (as simulated by VERICUT).
Total Number of Errors — Adds a record to write out the number of
errors detected by VERICUT.
Total Number of Warnings — Adds a record to write out the number
of warning detected by VERICUT.

582
Total Optimized Time —Adds a record to write out the total time
anticipated to machine the part (as simulated by VERICUT) using
optimized toolpath files.
Total Time Difference— Adds a record to write out the total time
difference between Total Time and Total Optimized Time.
Total Distance — Adds a record to write out the total tool movement
distance.
Total Cut Distance % — Adds a record to write out the total percentage
of tool movement distance that occurred while in feed rate mode.
Total Volume Removed — Adds a record to write out the total volume
of material removed.
Tool Change Data — Adds a record to write out "tool" related data, of
the type selected from the pull-down list, for the current tool.
Seq — Adds a record to write out the sequential number of the last tool
change event.
Record — Adds a record to write out the last tool change record
processed. Includes both the sequential line number and the record text.
Tool Description — Adds a record to write out the tool ID and
description of a tool retrieved from a VERICUT Tool Library file. A
blank field indicates a description for this tool was not defined in the
library, or the tool did not come from a tool library.
Cutter Info — Adds a record to write out cutter shape geometry data.
Includes both the method used to define the cutter shape (shown in
square brackets “[ ]”, for example [Profile] indicates a profile type of
cutter definition) followed by the parameter values used to describe the
cutter.
Cutter Height — Adds a record to write out the height of the cutter.
Flute Length — Adds a record to write out the flute length of the cutter.
Gage Offset — Adds a record to write out the cutter's gage offset value.
OptiPath Record — Adds a record to write out the OptiPath tool
description and the number of teeth for the tool
Optimized By — Adds a record to write out the optimization method
used for the tool.
Original Time — Adds a record to write out the anticipated cutting time
(as simulated by VERICUT) for the tool.
Optimized Time — Adds a record to write out the anticipated optimized
cutting time (as simulated by VERICUT) for the tool.
Time Difference — Adds a record to write out the difference between
the optimized and un-optimized cutting times for the tool
Distance — Adds a record to write out the tool movement distance.
Distance % — Adds a record to write out the percentage of tool
movement distance while in feedrate mode.

583
Volume Removed — Adds a record to write out the volume of material
removed by the tool.
Errors — Adds a record to write out the number of errors detected by
VERICUT for the tool.
Warnings — Adds a record to write out the number of warnings output
by VERICUT for the tool.
Min Extension — Adds a record to write out the minimum height
required to avoid shank/holder collisions with the tool.
Add User-Defined Tag — Adds a record to write out the value of a
"text type" User Defined Tag. Use Add User-Defined Tag, to create a
new "text type" User-Defined Tag, or select an existing User-Defined
Tag from the pull-down list.
Table — Displays a window enabling you to add a VERICUT generated
table , or "custom" table, to a report template.
Table — Use to specify the type of table to add.
Add a custom table using:
Custom Table —
or choose one of the VERICUT generated tables:
File Summary Table — outputs a file summary table
Tool Summary Table — outputs a tool summary table
Shade Copy Table — outputs a shadecopy table.

NOTE: The "header" column in the in each of the above VERICUT


generated tables is customizable. On the Page Layout tab, highlight the
table to be edited.
or choose one of the existing (if any) "table type" User-Defined Tags at
the bottom of the list.

No. of Columns — Enter the number of columns for a "custom" table.


No. of Rows — Enter the number of rows for a "custom" table.
Use the following "Alignment" features to further define a "custom"
table.
Table Width — Use to specify the table width relative to the
window/page width. Enter the Table width as a percentage of the
window/page width.
Border Size — Use to specify a border size for a "custom" table. Enter
the border size in pixels.
Thumbnail Width — Use to specify the width of "images" included in
tables. Toggle "On" and enter the width value in pixels.
Thumbnail Height — Use to specify the width of "images" included in
tables. Toggle "On" and enter the width value in pixels.

584
NOTE: The following rules apply to Thumbnail Width/Thumbnail

Height:
y If only one of the Thumbnail dimensions is toggled "On", the
active dimension will be used and the other direction dimension
will be scaled to maintain the image aspect ratio.
y If neither of the Thumbnail dimensions is toggled "On", the native
image size will be used.
Row Height —Use to specify the row height for a "custom" table.
Toggle "On" and enter the height value in pixels.
Maximum Rows/Page —Use to specify the maximum number of rows
per page when printing a "custom" table.
Picture — Displays a window enabling you to add VERICUT generated
pictures, or custom pictures from a file, to a report template.
Picture — Use to specify the type of picture to add. Select from the pull-
down list.
Add a custom image using:
From File — outputs the image from the specified file.
or choose one of the VERICUT generated pictures:
Tool Use Graph — outputs a Tool Use graph image
Cutting Graph — outputs a Cutting Conditions graph image.
Start of Process Image — outputs an image at the start of processing.
When included within a "tool change loop", a shadecopy image of the
part at the start of cutting with current tool is output. When included
within a "toolpath loop", a shadecopy image of the part at the start of the
current toolpath is output.
End of Process Image — outputs an image at the end of processing.
When included within a "tool change loop", a shadecopy image of the
part at the end of cutting with current tool is output. When included
within a "toolpath loop", a shadecopy image of the part at the end of the
current toolpath is output.
Tool Image — outputs an image of the current tool. When included
within a "tool change loop", an image of the current tool is output at each
tool change.
or choose one of the existing (if any) "picture type" User-Defined Tags
at the bottom of the list.

File — Enter the /path/file name of the image file or use Browse to
display a file selection window and use it to pick the image file. This
feature is only active when Picture is set to From File.
Border Size — Use to add a border to the image. Enter the border size in
pixels.

585
Width — Use to specify the width for the displayed image. Toggle
"On" and enter the width value in pixels.
Height —Use to specify the height for the displayed image. Toggle "On"
and enter the height value in pixels.

NOTE: The following rules apply to Width/Height:


y If only one of the dimensions is toggled "On", the active dimension
will be used and the other direction dimension will be scaled to
maintain the image aspect ratio.
y If neither of the dimensions is toggled "On", the native image size
will be used.

Page Break — Enables you to manually add page breaks to control


printed output.
Start Toolpath Loop — Use to mark the "start" of a group of records
that will be output for each toolpath in user files containing multiple
toolpaths.
End Toolpath Loop — Use to mark the "end" of a group of records that
will be output for each toolpath in user files containing multiple
toolpaths.
Start Tool Change Loop — Use to mark the "start" of a group of
records that will be output at each tool change.
End Tool Change Loop — Use to mark the "end" of a group of records
that will be output at each tool change.

NOTE: PageBreak, Start Toolpath Loop, End Toolpath Loop,


Start Tool Change Loop, and End Tool Change Loop cannot be
edited. They can only be deleted.

The Record Table


Each record in the table consists of five columns of information. Click on any
column in a row to highlight a record for editing. The order of the records in the
table can be changed by clicking on the square button at the beginning of the record
and dragging the record to the desired position. Each record in the table consists of
the following information:
Category — Use the options in this column to specify what "part" of the report the
record is to be included. With the record highlighted, click on the record "category"
and select from the pull-down list (Body, Page Header, Page Footer, First Page
Header, or First Page Footer).
Type — Indicates the record type. With the record highlighted, double click Table
or Picture to display the corresponding window for editing the record.

586
Content — Indicates the "content" of the record. With the record highlighted,
double click on the content of a Table or Picture record to display the
corresponding window for editing the record. Double click on the "content' of a text
string record to add or modify the text.
Alignment — Indicates how the information will be aligned horizontally in the
report. With the record highlighted, click on the record "category" and select from
the pull-down list (Body, Page Header, Page Footer, First Page Header, or First
Page Footer).
Style — Indicates the "style" to be used for the record. With the record
highlighted, click on the record "style" and select from the pull-down list. The list
will contain all for the styles that have been defined, using the Styles tab, for the
current report template.

587
Report Template window, Styles tab
Location: Project menu > Report > Report Template >Edit in the main VERICUT
window.
File > Report Template in the Inspection Sequence window.
File > Report Template in the Tool Manager window.

The Menu Bar


File
See Report Template window for a description of the File features.
Edit
Add — Enables you to add "style" records to a report template file.
Delete — Enables you to delete "style" records from a report template file.
NOTE: Add and Delete can also accessed using the Add or Delete
button at the bottom of the Styles tab or by right clicking in the Style
Record table and selecting Add or Delete.

The Style Record Table


Each record in the table consists of nine columns of information describing a
particular style record. Click on any column in a row to highlight a record for
editing. Each record in the table consists of the following information:
Style Name — The name used to identify a particular style record, These are the
items that will appear in the Style pull-down list, in the record table, on the Page
Layout tab.
Font — Indicates the font type to be used for the style record. With the record
highlighted, click on the Font field and select from the pull-down list.

588
Size — Indicates the font size to be used for the style record. With the record
highlighted, click on the Size field and either select from the pull-down list or type
in a font size.
Bold — Toggle the "Bold" characteristic "On/Off" for the style record.
Italic — Toggle the "Italic" characteristic "On/Off" for the style record.
Underline — Toggle the "Underline" characteristic "On/Off" for the style record.
Font Color — With the record highlighted, double click on the Font Color field to
display a color pallet. (You can also right-click on a "color" field and select Set
Color to display the color pallet.) Click on the desired font color in the pallet. Click
on the X in the upper right corner of the color pallet to dismiss the pallet.
Background Color — With the record highlighted, double click on the
Background Color field to display a color pallet. (You can also right-click on a
"color" field and select Set Color to display the color pallet.) Click on the desired
background color in the pallet. Click on the X in the upper right corner of the color
pallet to dismiss the pallet.
Border Size — Indicates the border size to be used for the style record. With the
record highlighted, click on the border size and type in a font size (in pixels).

589
Report Template window, User-Defined Tags
tab
Location: Project menu > Report > Report Template >Edit in the main VERICUT
window.
File > Report Template in the Inspection Sequence window.
File > Report Template in the Tool Manager window.

User-Defined Tags enable you to define "generic" records in a report template, whose
value is specified at the time that the template is used to create a report. User-Defined
Tag values can be defined in the User-Defined Tags window or by using PPRINT data in
the toolpath file.

The Menu Bar

File
See Report Template window for a description of the File features.
Edit
Add — Enables you to add "User-Defined Tag" records to a report template
file.
Delete — Enables you to delete "User-Defined" records from a report
template file.

NOTE: Add and Delete can also accessed using the Add or Delete
button at the bottom of the User-Defined Tags tab or by right clicking in
the User-Defined Tags Record table and selecting Add or Delete.

590
The User-Defined Tag Record Table
Each record in the table consists of a Tag Name that is used to identify the record
and a Type (Text, Table or Picture from File). Click on any column in a row to
highlight a record for editing. Each record in the table consists of the following
information:
Tag Name — The name used to identify a particular User-Defined Tag record.
After adding a User-Defined Tag record, type in a unique tag name.
Type — Indicates the "type" of information represented by the tag. After adding a
and naming a User-Defined Tag record, click in the Type field and select the
appropriate data type (Text, Table, or Picture From File) from the pull-down list.

NOTE: Tag Name and Type can be edited by highlighting the record, then
clicking the appropriate field and either editing the text or selecting the
desired Type from the pull-down list. Once a Tag Name is referenced in a
report template, the User-Defined Tag record can no longer be edited.

591
User-Defined Tag Values
Location: Project menu > Report > User-Defined Tag Values
File > User-Defined Tag Values in the Inspection Sequence window.
File > User-Defined Tag Values in the Tool Manager window.

Opens the User-Defined Tags window enabling you to assign job specific information to
a "generic" User-Defined Tag, prior to creating a report. Double click on a Tag Value
field to enter or edit the tag value. If Tag Values are not specified prior to creating a
report, you will be prompted for them at the time the report is created. Once Tag Values
have been specified, they are stored in the user file. You can also specify User-Defined
Tag Values using PPRINT statements in the toolpath file.

592
MDI
Location: Configuration menu > MDI

VERICUT toolbar short cut:

Opens a window enabling you to manually enter and process blocks of G-code data. The
MDI, or "Manual Data Input" function provides a quick and easy way of verifying that
the machine/control combination responds to G-code data commands as expected.

SubSystem ID — Use this feature to specify which subsystem the G-code data
command is to be applied to.
History — Displays a list of the G-code data commands that have been entered
during the current VERICUT session.
To re-use a command from the History list, click on the command so it becomes
highlighted and click on Apply. The result of the command is immediately
displayed in the Machine view.
To remove a command from the History list, click on the command so it becomes
highlighted, then use the Delete button to remove the command from the History
list. Use the Clear All button to remove all commands from the History list.
Right-click in the History list area to display a pop-up window with the following
features:

Delete — Removes the highlighted command from the History list (same as
the Delete button described above).
Clear All — Removes all commands from the History list (same as the
Clear All button described above).
Replay Current — Processes the command row highlighted in the History
list (same as using the Apply button described above).
Multiple Line Mode — Left-click on this feature to activate (indicated by a
check mark) Multiple Line Mode. When active, much of the MDI behavior
changes as described below.
y A highlighted row is not inserted in the Selection field.
y The content of the Selection field is appended after the highlighted
row when Apply is pressed.
y A row's text can be edited directly by double clicking on the row.
y Rows with duplicate content are allowed.
y The Replay All feature requires a Machine Simulation license.

The remaining features are only available when Multiple Line Mode is active.

593
Replay All — Processes all of the command rows in the History list, in the
order that they appear in the list.
Re-order the rows in the History list by left-clicking on the square button at
the beginning of the row and drag the row (while keeping the left mouse
button depressed) to the desired position.

NOTE: Use of Replay All requires a Machine Simulation license.

Save As — Opens a "Save As" file selection box enabling you to save all
command rows in the History list to a file.
Copy — Copies the selected command row(s) to the Windows clipboard.
Use the "Shift" key to select a range of command rows. Use the "Ctrl" key to
select multiple individual command rows.
Paste — Appends the Windows clipboard text after the selected row in the
History list. You can also paste the contents of the Windows clipboard to a
file.

Selection — Enter the G-code data command in this field, then click on Apply (or
use the Enter key on your keyboard). The result of the command is immediately
displayed in the Machine view and the command is added to the History list
described above. Errors are displayed in the Message area.
Use Cancel to dismiss the MDI window.

NOTES:
1. Do not attempt to use MDI before machine construction is complete. If the
Stock, Tool, and all motion components are not present in the machine
definition, the machine may not respond to motion commands as expected.
2. After adding motion type components to a machine, always press Reset

Model before using MDI to test machine movements.


3. Calls to subroutines and NC macros are not supported in the MDI window.
Use a short test tool path file instead.
4. If you want the MDI motions to remove material, you have to press "Single
Step" once to get VERICUT to build the cut stock database.

594
Coordinate Systems

Coordinate System window


Location: Project menu > Coordinate Systems > Define

Toolbar shortcut:

Opens a window enabling you to define a coordinate system, also known as a "CSYS".
(See how) The active CSYS applies to X-caliper measurements, Section plane values,
and tool path motions (except when orientations are defined in a tool path list). To see
axes representing the active CSYS (XcsYcsZcs), select View menu > View Axes:
Coordinate System. A user-defined CSYS is typically used to locate an APT or CLS
tool path for proper relationship to the workpiece. You can also use a user-defined CSYS
for defining section planes, or for gathering measurement data. Use Project menu >
Coordinate Systems > Active Coordinate System to activate the desired coordinate
system.
NOTES:
1. Defining a CSYS is not recommended to locate G-code tool paths simulated
on a 3-D machine, as this can cause the workpiece to move in the machine
view. Instead, use an Input Program Zero table, or Work Offsets table if work
offsets are present in the tool path file.
2. Coordinate systems specified under NC Program Origin on the NC Program
window, override the active user-defined CSYS.
3. VERICUT can also be configured to process the following APT-CLS tool
path records to set the tool path CSYS: CATIA0, MSYS, VERICUT-
MATRIX.

595
Coordinate System Name— Enables you to add a new CSYS or select an existing
CSYS from the list for modification or deletion. Enter a name in the top position of the

Coordinate System Name list to create a new CSYS, or use New (described below) to
create a new CSYS and let VERICUT automatically supply a unique name.

596
New — Adds a new CSYS to the Coordinate System Name list. VERICUT
automatically provides a unique name to the CSYS. The following user actions also
automatically add a new CSYS:
y Translate tab: pressing Move
y Rotate tab: pressing one of the rotation direction buttons (X+/X-, Y+/Y-, Z+/Z-)
y Construct tab : pressing Update
y When VERICUT processes one of the following APT-CLS tool path records to
set the tool path CSYS: CATIA0, MSYS, VERICUT-MATRIX. The coordinate
system is relative to the first stock's machine component parent. The coordinate
system is named "filename_nn" where filename is the name of the toolpath file
and nn is the file's line number containing the matrix definition. Additional
coordinate systems are not created for matrices with identical values.

Delete — Deletes the selected CSYS from the Coordinate System Name list.

CSYS from File — Displays a file selection box enabling you to specify the CSYS file
to be used. VERICUT will read the file and creates CSYS's attached to the selected
component (typically the Stock). The Create CSYS While Simulating feature
(described below) must be toggled Off when using CSYS from File. This functionality is
also available via the csys_file command line option.
Attach Coordinate System To — Enables you to attach a CSYS to a particular
component so that if the component gets repositioned, the CSYS also gets repositioned,
maintaining the defined relationship. Select the component from the pull-down list.
Use for Cut Stock Transition — Use to designate that the coordinate system is used for
transitioning the cut stock from one setup position to another.

CSYS Construct/Modify features:


The features on the following tabs enable you construct a new, or modify an existing
CSYS.
Translate tab — Features on this tab enable you to translate the selected CSYS via
indicating "from" and "to" points to move the CSYS. Movement occurs each time
you press the Move button. If the applied rotation is incorrect, press Undo to return
the object to its previous location.
Rotate tab — Features on this tab enable you to rotate the selected CSYS about a
rotation center point. Movement occurs each time you press one of the rotation
direction buttons: X+/X-, Y+/Y-, Z+/Z-. If the applied rotation is incorrect, press
Undo to return the object to its previous location.
Construct tab — Features on this tab enable you to construct a CSYS via defining
3 points. Each point can be defined using points, planes, vectors, or the center of a
hole or boss.
Matrix tab — Features on this tab move the selected CSYS via a twelve parameter
transformation matrix.

597
Display features:
These features enable you to override the "global" visibility and color characteristics, as
set with View menu > Axes: Coordinate System, for the individual coordinate system
currently displayed in the Coordinate System Name list.
Visible — When coordinate systems are displayed using View menu > View Axes:
Coordinate System, Visible enables you to toggle the display of an individual
coordinate system "Off/On".
Specify Color — Enables you to override the "global" coordinate system display color
set using View menu > View Axes: Coordinate System, for an individual coordinate
system. Toggle Specify Color "On" and click on the Color Pallet icon, , then select
the desired color from the chart.

Location features:
These features show the selected CSYS's position and angle, and can be used to move the
CSYS or verify its current location. Values shown are relative to the workpiece origin.
Position — Specifies the absolute XYZ position of the CSYS, separated by spaces.
Component Origin — Enables you to position the origin of the coordinate system
currently displayed in the Coordinate System Name list at the origin of the selected
component. Toggle Component Origin "On", click in the Position field so that it
becomes highlighted yellow, then select the desired component in the graphics area. Press
Apply to move the coordinate system.
Angles — Specifies the absolute XYZ rotation of the CSYS, separated by spaces.
Undo — Returns the CSYS to its previous location, or as it was when the Coordinate
System window was opened.
Reverse X — Reverses the X axis of the "active" coordinate system. (See note below)
Reverse Y — Reverses the Y axis of the "active" coordinate system. (See note below)
Reverse Z — Reverses the Z axis of the "active" coordinate system. (See note below)

NOTE: In order to maintain a right handed csys, the following will occur when
an axis is reversed:
If the X axis is reversed, then the Z axis is also reversed.
If the Y axis is reversed, then the X axis is also reversed.
If the Z axis is reversed, then the Y axis is also reversed.

Create CSYS While Simulating — When toggled On (the default), coordinate systems
are unconditionally created when a matrix statement is encountered in the NC program
being simulated. The coordinate systems are attached to the stock's parent ( the "attach"
component). This feature must be toggled Off when creating them on your own or using
the CSYS from File feature (described above).

598
OK — Applies the changes and closes the Coordinate System window.
Apply — Applies the changes and leaves the Coordinate System window open.
Cancel — Closes the Coordinate System window without applying changes.

599
Coordinate System window, Translate tab
Location: Project menu > Coord. System > Define
Toolbar shortcut:

Features on this tab enable you to translate the selected CSYS via indicating "from" and
"to" points to move the CSYS. Movement occurs each time you press the Move button.

From / To — Specifies the locations to move the CSYS from and to, relative to the
workpiece origin. XYZ values can be entered (separated by spaces), or selected by
clicking in the field then clicking on a model. As you move the mouse over the
VERICUT model, a crosshair and vector show you the pending pick-point location.
Graphical selection supports picking corner points and midpoints of uncut model
geometry, or virtually any point on machined features.
Move — Moves the selected CSYS by the incremental distance, as calculated from the
"From" point to the "To" point location.
Local Translation — When toggled "on", From/To values are relative to the current
CSYS.
NOTE: This feature is useful when trying to align a CSYS to the center of a
machined hole.

600
Coordinate System window, Rotate tab
Location: Project menu > Coord. System > Define
Toolbar shortcut:

Features on this tab rotate the selected CSYS about a rotation center point. Movement
occurs each time you press one of the rotation direction buttons: X+/X-, Y+/Y-, Z+/Z-.

Center of Rotation — Specifies XYZ point location about which to rotate the CSYS.
XYZ values can be entered (separated by spaces), or selected by clicking in the field then

clicking on a model. To see the center of rotation, press . To remove the center of
rotation symbol press the button again, or close the Coordinate System window.
Increment — Specifies incremental degrees of rotation to apply when one of the rotation
direction buttons are pressed.
Rotation direction buttons — (X+/X-, Y+/Y-, Z+/Z-) When pressed, applies the
incremental rotation specified in the Increment field. Rotation occurs about the Center
of Rotation, relative to the workpiece origin.
Local Rotation — When toggled "on", the incremental rotation values are relative to the
current CSYS.

NOTE: This feature is useful when trying to align a CSYS to the center of a
machined hole.

601
Coordinate System window, Construct tab
Location: Project menu > Coord. System > Define
Toolbar shortcut:

The features on this tab enable you to construct a CSYS via a point representing the
CSYS origin, and two direction vectors representing the axes of the CSYS. Each can be
defined using points, planes and vectors.

While the Construct tab is active, a marker is displayed in the graphics area (see the
picture below) showing the current position/orientation of the axis being constructed
based on the Construct tab settings. The display is updated each time you change a value
on the Construct tab. The marker is automatically clears when you leave the Construct
tab.

602
Origin (XYZ) — Use these features to define a point representing the origin of the
CSYS.
Primary Axis (IJK) — Use these features to define a point or vector representing the
direction of the CSYS primary axis.
Secondary Axis (IJK) — Use these features to define a point or vector representing the
direction of the CSYS secondary axis.

For each of the items above, you can either enter the coordinates of the point, separated
by spaces, in the text field or select one of the construction methods and pick geometry in
the graphics area to define the item. Choose one of the construction methods from the
pull-down list, then click the arrow and follow the prompts in the message area to
define the item. The following construction methods are available:

Point — Use to select a point.


Vector/Plane — Define a point represented by the intersection of a vector with a
plane.
3 Planes — Define a point represented by the intersection of three planes.
Circle — Define a point represented by the center of a circle.

NOTE: When using one of the point construction methods to define the Primary
or Secondary Axis, the origin is subtracted from the generated point to define the
direction vector representing the axis.

Vector — Define the direction of a CSYS axis by selecting a vector. (not available
for Origin)
Plane/Plane — Define the direction of a CSYS axis by a vector represented by the
intersection of two planes. (not available for Origin)

Axis Order — Choose from the pull-down list to assign X, Y or Z to the Primary and
Secondary axes of the CSYS.

XY — assigns the Primary Axis to be X and the Secondary Axis to be Y.


YZ — assigns the Primary Axis to be Y and the Secondary Axis to be Z.
ZX — assigns the Primary Axis to be Z and the Secondary Axis to be X.

Update — Use the values selected above to update an existing CSYS, or create a new
CSYS. When the Update button is pressed the following occurs:

The Primary Axis and the Secondary Axis are crossed to determine the third axis.
The third axis is then crossed with the Primary Axis to ensure that the Secondary
Axis is orthogonal.
The CSYS currently active in the Coordinate System window is updated with the
resultant orthogonal coordinate system and the origin. If no CSYS is currently
active, VERICUT creates a new CSYS and automatically assigns it a unique
name.

603
Coordinate System window, Matrix tab
Location: Project menu > Coord. System > Define
Toolbar shortcut:

Features on this tab enable you to move the selected CSYS via a twelve parameter
transformation matrix.

Matrix Table — The transformation matrix table is similar to the matrix used in
programming APT tool paths. Its twelve parameters reveal the geometrical attributes of
the local (transformed) coordinate system (CSYS) in terms of the workpiece origin.

The format of the matrix table is as follows:


I J K D
X I1 J1 K1 D1
Y I2 J2 K2 D2
Z I3 J3 K3 D3

Each row represent an axis of the local CSYS. The first three columns represent the
vector associated with each axis: I1, J1, K1 as the positive X-axis vector; I2, J2,K2 as the
positive Y-axis vector; and I3, J3, K3 as the positive Z-axis vector. The fourth column
values D1, D2, D3 represent the coorinates of the the origin point of the local CSYS.
NOTE: If you prefer to see the the Matrix Table displayed with the I, J, K along
the vertical axis and the X, Y, Z along the horizontal axis, set the environment
variable, CGTECH_MATRIX_FORMAT=VERTICAL.

Update — Updates the CSYS location to reflect the matrix table transformation. After
updating, press OK or Apply to move the object.
Apply Inverse On Update — When selected, inverts the matrix so that its twelve
parameters reveal the geometrical attributes of the workpiece origin in terms of the local
(transformed) coordinate system.

604
Active Coordinate System
Location: Project menu > Coordinate Systems > Set Active Coord. Sys.

You control the "active" coordinate system, or "CSYS", that VERICUT uses for
simulating tool path motions, X-Caliper measurements, and sectioning models. A user-
defined coordinate system is typically used to locate an APT or CLS tool path in the
proper orientation to the workpiece.
To make an existing CSYS the "active" CSYS, use Project menu > Coordinate Systems
> Set Active Coord. Sys. and select the desired CSYS from the list of available

coordinate systems. The active coordinate system is displayed with an at the origin
as shown in the illustration below.

Shortcut: You can also change the active coordinate system by right-clicking in
the view, and selecting Set Active Coord. Sys. and selecting the desired
coordinate system from the displayed list.

Use Project menu > Coordinate Systems > Define... to create additional coordinate
systems.

605
Machine Configuration menu

Machine
Open (Machine file)
Location: Configuration menu > Machine > Open

Toolbar short cut for opening Machine files:

Opens a window to open (load) a Machine file. Machine files contain data that describes
NC machine construction, kinematics, and other properties.

Help on Samples — Opens the VERICUT on-line Help section on "Machine files". Both
library and sample machines are listed. Find the file you want in the on-line Help, then
cut & paste the file name into the file selection window. For machines located in the
library, set Shortcut=CGTECH_LIBRARY and press Open to open the file. For
"sample" machines, set Shortcut=CGTECH_SAMPLES and press Open.

606
Save (Machine file)
Location: Configuration menu > Machine > Save

Toolbar short cut for saving Machine files:

Saves (updates) an existing Machine file with the current NC machine settings.

607
Save As (Machine file)
Location: Configuration menu > Machine > Save As

Toolbar short cut for saving Machine files:

Opens a window to save a Machine file. Machine files contain data that describes NC
machine construction, kinematics, and other properties. Most features on this window are
standard file selection window features that enable you to navigate through directories,
filter files, and type or select file names. To save space, the features described below are
unique to VERICUT file selection windows or this window.

Units to Save—Controls the units (Inch or Millimeter) in which to store machine


configuration data. If the session units are different than the units to save, then values are
converted accordingly when stored in the new file.

608
Machine Settings

Machine Settings window


Location: Configuration menu > Machine Settings

Toolbar short cut for Machine Settings window:

Opens a window to configure settings for an NC machine, such as: collision checking,
travel limits, axis priority (for rapid motion), location tables, and when machine motions
are simulated.

Machine Simulation On — When toggled "On", simulates machine tool motions when a
3-D machine is displayed in a machine view.

Shortcut: You can quickly toggle Machine Simulation On, "On" or "Off" by

clicking on the No Machine Simulation icon in the toolbar.

609
Transparent Stock — When selected, displays the stock workpiece in a Machine/Cut
Stock view as transparent while the machine is in motion.
Machine Up — Specifies which way is "up" (towards the ceiling) for a machine when a
machine view displays walls in the background. (Ref. View menu > Attributes:
Background). The up direction is relative to the machine origin.
Collision Detect tab — Features on this tab control when collisions between machine
components are detected, which components are protected, and tolerances used for
detecting collisions.
Tables tab — Features on this tab are used to specify important machine locations and
detail tool change motion.
Travel Limits tab — Features on this tab define how far each machine axis can go, and
control when travel limit errors are detected.
Axis Priority tab — Features on this tab control how machine axes move in rapid
positioning mode (e.g. G0).
OK — Applies the changes and closes the Machine Settings window.
Apply — Applies the changes and leaves the Machine Settings window open.
Cancel — Closes the Machine Settings window without applying changes.

610
Machine Settings window, Collision Detect
tab
Location: Configuration menu > Machine Settings

Toolbar short cut for Machine Settings window:

Features on this tab control when collisions between machine components are detected,
which components are protected, and tolerances used for detecting collisions. (See how)

Colliding components are highlighted using the red Error color, and errors are issued to
the Log file identifying collision causing block(s) and machine components.

611
Collision Detection —When toggled "On", detects collisions between specified
components.
Ignore Collision between Cutter and Stock—Controls when collisions between the
cutter and the Stock component are ignored. This feature is useful when collision
detection is desired between the stock and shank or holder portions of the tool assembly
in the machine view, but not with the cutter. Options are:
y No—(default) Does not ignore cutter-stock collisions. All collisions are reported.
y All Tools—Ignores cutter-stock collisions for all tools, even inactive tools in
multi-tool machines.
y Active Tool—Ignores cutter-stock collisions for the active tool. However,
collisions between stock and inactive tools are detected.
Default Near Miss—Specifies the default collision tolerance applied to all collision
cases when Set All is pressed (see below).
Set All—Sets the default collision tolerance for all collision cases to the Default Near
Miss value. You can edit the supplied tolerance for individual cases.
Component/Component collision list—Lists the component-to-component collision
cases that are checked when collision detection is turned on.
Component1/Component 2 — These features are used to specify the component-to-
component collision cases to check. The Near Miss value controls how close the
components are permitted to be before reporting a collision.
NOTE: Do not configure for collision detection between components that move
(slide or rotate) against each other, such as connected motion axes. In these cases,
errors may occur each time the components move.
Sub-Components — Toggle On/Off to include Sub-Components of
Component1/Component2 during collision checking.
Near Miss—Specifies the tolerance to use for collision checking. Enter a positive value
to be alerted if components come near each other within the specified clearance, zero to
indicate components may not touch, or a negative value if components are expected to
collide by the specified value.
NOTE: "Near Miss" tolerances are not supported for collision checking against
the cut model. The accuracy of collisions with the cut stock is dependent on the
"Cutting Tolerance".
Add—Adds a new collision case to the list.
Delete—Deletes the selected collision case from the list.

612
Machine Settings window, Tables tab
Features on the Tables tab are used to specify Machine Tables to store important machine
locations and detail tool change motion. Machine Tables are used to specify "standard"
data values specific to a particular machine.

Tables list — A list of tables that are currently defined. The Machine Settings tables list
will contain only "machine" tables. The G-Code Settings tables list will contain both
"job" tables and "tool" tables.

Add/Modify — Use to access the Add/Modify Tables window enabling you to add
additional tables or modify existing tables. To Add a table , simply click on Add/Modify.
To modify an existing table, select the table to be modified from the Tables list and click
on Add/Modify. (You can also "double-click" on the table in the Tables list.)

Delete — Deletes the selected table entry from the Tables list. If it is the last entry for a
particular table, then the table is also deleted.

Use the G-Code Settings window: Tables tab to create Job Tables to specify values to
override "standard" values set in a Machine Table for particular NC program file(s).
Machine Tables values are stored in the Machine file.

The following Machine tables can be added or modified with the Machine Settings,
Tables tab:
y Base Work Offset
y Initial Machine Location

613
y Input Machine Zero (obsolete)
y Machine Reference Location
y Tool Change Location
y Tool Change Retraction
y Work Offsets
y Input Program Zero

614
Machine Settings window, Travel Limits tab
Location: Configuration menu > Machine Settings

Toolbar short cut for Machine Settings window:

Features on this tab define how far each machine axis can go, and control when travel
limit errors are detected. (See how)

Overtravel errors cause the violating machine component to "light up" in the Overtravel
Color and errors are output to the Log file identifying the problem component.

615
Overtravel Detection On—When active, turns on overtravel detection (travel limit
checking). Components that move beyond specified limits are highlighted in the
Overtravel Color and errors are issued to the Log file identifying error causing block(s)
and machine components.
Overtravel Color—Color in which components that move past their specified limits are
shaded. Available shade colors are defined on the Edit menu > Colors: Define tab.
Component Min/Max travel list—List of motion components in the machine and
corresponding axis limits.
Minimum / Maximum—Specifies the minimum and maximum travel limits for the
motion axis selected in the list
Ignore—When selected, ignores overtravel checking for the corresponding axis.
Modify—Modifies the selected component/travel entry in the list to have the values
configured in the window.

616
Machine Settings window, Axis Priority tab
Location: Configuration menu > Machine Settings

Toolbar short cut for Machine Settings window:

Features on this tab control how machine axes move in rapid positioning mode (e.g. G0).
By default, machine axes are interpolated with equal priority to arrive at their destinations
at the same time. You can change the priority to simulate non-interpolated rapid motion
such as "dog leg" or "squared off" movement. (See how)

Single — This option provides a single set of rapid priorities are used. The rapid
priorities applied to the tool moving in the negative Z direction are the same as those
applied to the tool moving in the positive Z direction.
Pos/Neg — This option provides different rapid priorities This option provides
depending on the tool moving in a positive or negative Z direction. With this option, two
rapid priority lists are provided. Use the Positive / Negative options to control which list
is seen.
Positive / Negative options — When Pos/Neg priority is selected, these options control
which rapid priority list is seen: the list applied when the tool is moving in the Positive Z
direction, or the list for Negative Z tool motion.
Axis Priority list — List of all machine motion axes and corresponding priorities.
Priority — Priority for moving motion axes move in rapid. A value of "1" moves that
axis first. A "2" moves the axis with secondary priority (after those with priority "1"), and
so on. Axes having the same priority move together.

617
Interpolated — When active, interpolates axes that move together such that they arrive
at their destination at the same time. Clear this checkbox to have axes move based on
their defined Rapid Rate- ref. Modeling window: Component Attributes tab.

618
Component Tree
VERICUT Users:
VERICUT Location: Configuration menu > Component Tree

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Advanced Options page > Modeling

Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Advanced Options page > Modeling

Notebook Feature:

Opens a window that shows the "tree" of components and how they are connected, as
well as provides a fast and easy way of manipulating components and their models. (See
how) The component tree shows defined components by name and their connect
positions. Indentation shows how components are connected in the tree. Select a
component by picking its name in the tree. Actions performed using Components Tree
window features are performed on the active (selected) component. To learn more about
modeling and using the component tree, see "About modeling in VERICUT" in the Using

VERICUT section. Always press Reset after changing components in the component
tree.

Component Tree—Tree of defined components and models. Indentation indicates that a


component is connected to a parent component. Component names are listed in bold text
with connect position values. Models added to a component are listed beneath the
component name. Click the + / - symbols to expand or collapse branches of items in the
tree.

619
Sample Component Tree window:

File menu —
y Open Machine, Save Machine and Save As Machine functions enaable you to
open or save a Machine file containing data that describes NC machine
construction, kinematics, and other properties.
y Save Cut Stock allows you to save the highlighted "Cut Stock" model as a
VERICUT Solid file (.vct). This option is only active when the Cut Stock model
is highlighted in the tree. The default file extension is .vct.
This functionality can also be accessed using File menu > Save Cut Stock.

Edit menu — Functions in this menu manipulate components in the tree, as well as
specify the component name, type, and attributes.
y Cut / Copy / Paste / Delete — Cuts, copies, pastes, or deletes a selected
component in the component tree. All connected components and models are also
affected.

Shortcut: Right-click on the component in the component tree, then choose the
desired option from the menu that appears. You can also move components via
dragging them from one parent component to another, and copy components via
holding down the <Ctrl> key and dragging.

620
Shortcut 2: Delete components or models by selecting the object in the graphics
area, then use the <Delete> key on your keyboard.
y Rename — Allows you to rename the selected component. Type the new
component name.
y Component Attributes — Accesses the features on the Modeling window:
Component Attributes tab-see that section for details.
y Component Type — Enables you to edit the component's "Type" setting which
determines the component's function in the simulation. Select the desired "Type"
from the pull-down list.
Component menu — Functions in this menu Insert or Append new components to the
selected component in the tree. The component type describes the component's function
in the simulation. Choose the appropriate component type from the option list, based on
the component's function in the simulation. Use Edit menu > Component Attributes to
supply any other attributes that are needed.
Component types:
y X Linear, Y Linear, Z Linear — Linear motion axes on an NC machine. Motion
axes are parallel to X,Y,Z axes, respectively-but this can be changed via the
Motion Axis component attribute.
y A Rotary, B Rotary, C Rotary — Rotary motion axes on an NC machine. The
component origin is the pivot point of rotation. By default, rotation occurs about
the X, Y, Z axes, respectively-but this can be changed via the Motion Axis
component attribute.
y U Linear, V Linear, W Linear — Co-linear motion axes on an NC machine.
Motion axes are parallel to X,Y,Z axes, respectively-but this can be changed via
the Motion Axis component attribute.
y A2 Rotary, B2 Rotary, C2 Rotary — Secondary rotary motion axes on an NC
machine. The component origin is the pivot point of rotation. By default, rotation
occurs about the X, Y, Z axes, respectively-but this can be changed via the
Motion Axis component attribute.
y A Turret, B Turret, C Turret — Indexing tool turret that rotates about X, Y, or
Z axes. Like rotary components, the turret component origin is the pivot point for
rotary indexing. The presence of these components cause all connected tools to be
displayed making it possible to detect collisions resulting from turret indexing. A
Turret component is commanded to move using a tool change command (e.g. Tn).
The turret indexes based upon activating a Tool component connected to the
turret. Tool component orientation determines the tool index position in the turret.
Rotary control settings determine how turrets rotate, e.g.: rotation direction, etc.
y Base — A non-moving component to which other components are connected.
Every machine definition begins with this component.
y Fixture — Hardware used to hold the workpiece for machining, such as: base
plates, clamps, bolts, vises, pallets, etc. VERICUT assumes fixtures are not to be
machined. Cuts in a fixture are shaded using the red Error color and an error is
issued to the Log file.

621
y Stock — Workpiece to be machined. This component type must be present in all
simulations.
y Design — Solid or surface representation of the theoretical designed part.
y Design Point — Point representation of the theoretical designed part.
y Spindle — Spindle on an NC machine. The function of this component is
different, depending on the machine type: milling or turning. Milling machine
spindle- portion of the machine where cutting tools are loaded. Turning machine
spindle- rotating component that turns the workpiece about the machine Z-axis.
y Tool — The location where cutting tools are loaded in an NC machine. Every NC
machine definition must include one or more of these components.
y Guide — Wire guides on a wire EDM machine.
y Electrode—Electrodes for Die Sinking Simulation (EDM machining).
y Tool Chain — The Tool Chain component is used to define and model large tool
handling mechanisms associated with machining centers. See Toolchain
Operation for more information.

622
NOTE: The ToolChain component's location, in the component tree, must not
precede any tool component(s). An error message will be displayed during loading,
and during resets, if the ToolChain component precedes tool component(s).

y Attach — The Attach component is used to connect "setup" components in the


project file to the machine.
y Setup components are saved in the project file, not the machine file.
y Stock/fixture/design components are "setup" components
y "Setup" components can be axes and have kinematics relationships
y Auxiliary devices can be connected to to the Attach component
How does the "Attach" component work?
A machine must have at least one Attach component, but multiple Attach
components are allowed. If none is found, one is automatically created at the
end of the first non-tool branch of the machine kinematics tree.
Components are contained in both in the machine, and in the setup.
A parent component in a "setup" references an Attach component in a machine.
y Other — Any non-moving component not represented by one of the preceding
types. This component type is often used to define housings, gear boxes, shields,
etc.

NOTES:
1. Right-click shortcut menu: Features used to manipulate components are
displayed in a shortcut menu when you right-click on a component in the
Component Tree window. Similarly, features used to manipulate models are
displayed when you right-click on a model in the tree.
2. Double-clicking on a model or component in the Component Tree window
opens the Model Definition window.
3. You can move objects in the Component Tree window via dragging them
from one parent component to another, or copy them via holding down the
<Ctrl> key and dragging.
4. Click repeatedly on a model in the graphics area to toggle selection between
the model and its component. Refer to the Component Tree window to review
what is selected.
5. Using the center mouse button of a three button mouse, click repeatedly on a
model in the graphics area to toggle selection between different models along
the line of sight from the pick point. Use this technique to select models
hidden from view by an object in the foreground.
6. After cutting, a "Cut Stock" model appears as in the Component
Tree window. This object can be manipulated using modeling features just
like any other component or model, allowing you to easily relocate the
workpiece for additional machining. You can also save the "Cut Stock" model
as a VERICUT Solid file (.vct).

623
Control

Open (Control file)


Location: Configuration menu > Control > Open

Toolbar short cut for opening Control files:

Opens a window to open (load) a Control file. Control files contain data that describes
how the NC control processes machine code data.

Help on Samples—Opens the VERICUT on-line Help section on "Library Control


Files". Assuming Shortcut=CGTECH_LIBRARY, you can find the file you want in the
on-line Help, then cut & paste the file name into the file selection window and press
Open to open the file.

624
Save (Control file)
Location: Configuration menu > Control > Save

Toolbar short cut for saving Control files:

Saves (updates) an existing Control file with the current NC control settings.

625
Save As (Control file)
Location: Configuration menu > Control > Save As

Toolbar short cut for saving Control files:

Opens a window to save a Control file. Control files contain data that describes how the
NC control processes machine code data. Most features on this window are standard file
selection window features that enable you to navigate through directories, filter files, and
type or select file names. To save space, the features described below are unique to
VERICUT file selection windows or this window.
Units to Save—Controls the units (Inch or Millimeter) in which to store control
configuration data. If the session units are different than the units to save, then values are
converted accordingly when stored in the new file.

626
Word Format
Location: Configuration menu > Word Format

VERICUT toolbar short cut:

Opens a window enabling you to specify how the NC control interprets G-code words
and special characters. (See how) Once words are defined, they can be "grouped" with
address values via the Configuration menu > Word/Address function to perform specific
actions by calling CGTech supplied or custom macros. Undefined words cause errors
when processed, and are not acted on by VERICUT.

NOTE: Always reset VERICUT (press on the VERICUT main window)


after making changes to the control configuration.

Word Table — List of machine code, or "G-code" data words and characters that are
interpreted by the control, arranged in alphabetical order. The list provides a summary of
word types, sub-types, inch and metric formats, and multipliers and composite
formats.(See table features)
Add — Adds a record to the Word Table enabling you to add words or special characters
to the control configuration.
Delete — Deletes the highlighted word record from the control configuration.
OK — Saves additions/modifications and dismisses the Word Format window.
Apply — Saves additions/modifications and leaves the Word Format window open.
Cancel — Closes the Word Format window without saving any additions/modifications.

627
Word Table Features
Each column in the Word table represents a specific feature that enables you to define
how the NC control interprets specific G-code words or special characters. (See how)

Name — Identifies the word or special character. Each word name must be unique.
Type — Specifies the type of control function performed by the word. Options:
y Logical—Evaluates a logical expression. See "Logical Sub-type" below for more
detailed classifications.
y Special—Accesses special NC control functions. See "Special Sub-type" below
for more detailed classifications.
y Math—Performs a mathematical operation. See "Math Sub-type" below for
more detailed classifications.
y Function—Calls the control function specified in the Function Name field.
y Type II—Specifies that the word is a three character mnemonic representing a
Type II data command, e.g. "AXO", "CLS", etc.
y Macro—Word will be paired with a value, then configured via the Configuration
menu> Word/Address function to call one or more action macros. (See list of
available macros)
y Conditional—Similar to the Functions word type, except performs multiple
functions, depending on the condition of word use. Conditional words are
typically supported by special routines written by CGTech or other developers to
evaluate word use.
y
Sub Type — Sub-types further differentiate word functions. Available sub-types are
dependent on the word Type.
y Logical Sub Type—Options for evaluating logical expressions:
• Equal
• Not Equal
• Greater than
• Greater Than or Equal
• Less Than
• Less Than or Equal
• AND
• OR
y Special Sub Type — Options for performing special control functions. Click on
the record "Sub Type" field and select from the list of available options in the
pull-down menu.
• Skip — Skip remaining data in block.

628
• Begin Data / End Data — Denotes the beginning (or ending) of G-code
data to be processed by the control. If a Begin Data special word is
defined with out specifying an End Data word, the Begin Data word is
used for both.
• Begin Comment / End Comment — Denotes the beginning (or ending)
of a comment record.
• Begin Type II / End Type II — Denotes the beginning (or ending) of a
Type II format record.
• Separator — Character used to separate data that is acted on differently
by the control, for example a list of arguments or values.
• Variable Tag — Character which identifies the number that follows as a
variable register number, e.g. "#". Example- "#100" indicates variable
register number "100" is being referenced.
• Variable Name — Alpha-numeric word that identifies a variable which
does not have an associated variable register number, e.g. "PPX" (type II
variable format).
• End of Block — Denotes the end of the G-code data block.
• Console Message — Identifies the block as a message displayed on the
machine operator's console.
• Quoted Text — Identifies start/end delimiter for a quoted text string. The
default character for delimiting a quoted text string is the double quote (").
If a different character(s) is used as a delimiter, it must be defined as a
SPECIAL type word with a sub-type of Quoted Text. Quoted text is valid
in Alpha-Numeric and List-Alpha-Numeric Word Value types.
• Ignore — Ignores specific words in the tool path file.
• Sin840D CASE — When this word is found, a special 840D parser will
be used to process the remainder of the block. (See "Notes about the
Siemens 840 CASE and REPEAT commands")
• Sin840D DEF — When this word is found, a special 840D parser will be
used to process the remainder of the block. (See "Notes about the Siemens
840 DEF command")
• Sin840D REPEAT — When this word is found, a special 840D parser
will be used to process the remainder of the block. (See "Notes about the
Siemens 840 CASE and REPEAT commands")
y Math Sub Type — Options for performing math operations. Click on the record
"Sub Type" field and select from the list of available options in the pull-down
menu.
y Add
y Subtract
y Multiply
y Divide

629
y Power
y Left Precedence
y Right Precedence
y Assignment
y Mod
The Mod math operation is calculated as follows:
N - D * INT(N/D) ==> -382 - 180 * INT(-2.12222) ==> -382 - 180 * -2
==> -22 <-- TRUNC Returns Integer part of number)
The Mod operator will produce the following results:
382 Mod 180 = 22
-382 Mod 180 = -22
10 Mod 3 = 1
10.1 Mod 3 = 1.1

y Function Sub Type — The control function that is called when the word is
processed. Click on in the record "Sub Type" field and select from the list of
available options in the pull-down menu.(See list of available mathematical
functions) You can also enter the name of a "custom" mathematical function,
created with the CGTech Macro Language (CML), in the Sub Type text field as
these will not appear in the pull-down list.

NOTE: The only time a value should ever be typed in is if it is a CMS


function.

y Type II Sub Type — Describes syntax expected in a "Type II" command. Enter
one or more of the descriptors listed below in the "Sub Type" text field to
describe the expected syntax. Descriptors used in combinations are separated by
commas.
y WV — word/value pair, e.g. "X1"
y T — text string
y V — numeric value

EXAMPLES:

1. Configuration for set axis offsets command "(AXO,X1,Y2,Z3)":


Name=AXO
Type= Type II
Sub Type = WV,WV,WV
2. Configuration for call subroutine command "(CLS,SUB1)":
Name=CLSType= Type II
Sub Type= T,V,V,V,V,V
NOTE: The "V" descriptors shown in the example above, allow
passing variables to the subroutine, although none are being passed
in the above call example.

630
y Macro Sub Type — Specifies how the control interprets values, or "addresses"
that follow the word. Click on the record "Sub Type" field and select from the list
of available options in the pull-down menu.
• Numeric — Interprets word values as numbers. The system reads the
numeric characters following the macro word until a non-numeric
character is found, for example: alphabet, symbol, or separator. The non-
numeric character indicates the beginning of a new word.
• Alphabet — Interprets word values as alphabet characters. The system
reads the alphabet characters following the macro word until a non-
alphabetic character is found, for example: number, symbol, or separator.
• Alpha-Numeric — Interprets word values as an alpha-numeric text string.
The system reads the characters following the macro word until a symbol
or separator character is found.
• Composite-Numeric — Separates word values into pieces which can be
individually acted on. The system uses the Composite Format to "parse"
the numeric characters following the word until a non-numeric character is
found, for example: alphabet, symbol, or separator. See Composite Format
for examples. Each separated piece of a composite-numeric word/value is
available for calling macros via the Configuration menu > Word/Address
function, and can be graphically selected from a word pick list.
• List-Numeric — Separates an argument list following the word into
pieces which can be individually acted on. This option is useful in a
situation like acting on "n" values differently in the sample codes:
TEXT(n,n,n,n,...) or TEXT n,n,n,n,... Parens may be present but are not
required, and commas separate the arguments. Up to 32 arguments can be
listed. Each argument must be numeric, or a math expression which
equates to a numeric value. Similar to Composite-Numeric value types,
each separated piece of a list-numeric word/value is available for calling
macros. However, these pieces do not appear in the word pick list. Specify
the pieces via listing the word followed by a space and the sequential
number of the argument in the list. Following the above example, you
could use the Configuration menu > Word/Address function to associate
macros with "TEXT 1" (corresponds to the first "n" parameter value,
"TEXT 2" (second "n" parameter), and so on.
• List-Alpha-Numeric — Same as above description for List-Numeric with
one addition. The value may be a quoted-text string. In this case the
quoted-text is not analyzed, and is just passed as text to an associated
Word/Address macro.
• None — Word does not have an associated value. The first character after
the word indicates the beginning of a new word.

631
EXAMPLES:
1. Assume the word "PGM" is defined as a Macro word type. The table below
shows how Sub Type can affect the interpretation of the values paired with
“PGM”.

Sample data Sub Sub Sub Type=Alpha- Sub


block Type=Numeric Type=Alphabet Numeric Type=None
PGM123ABC 123 none 123ABC none
PGMABC123 none ABC ABC123 none

2. Consider interpreting the following block of data: "TEST(10,20,30)"


3.
In Word Format, add word "TEST" as follows:

Name=TEST
Type=Macro
Sub Type=List-Numeric
In Word/Address, add group to act on first argument in TEST list "10":
Word=TEST 1
Range=*
Macroname=<desired macro> (group is passed a value of "10")
then add groups to act on second & third arguments in TEST list "20"
and "30":
Word=TEST 2
Range=*
Macroname=<desired macro> (passed value: "20")

Word=TEST 3
Range=*
Macroname=<desired macro> (passed value: "30")

y Conditional Sub Type — The conditional control function that is called when
the word is processed. Click on in the record "Sub Type" field and select
from the list of available options in the pull-down menu.(See list of available
conditional functions) You can also enter the name of a "custom" conditional
function, created with the CGTech Macro Language (CML), in the Sub Type text
field as these will not appear in the pull-down list.
NOTE: The only time a value should ever be typed in is if it is a CMS
conditional.
Inch Method — Specifies how to interpret inch address values. This feature is
significant only for values that do not contain a decimal point. Values with a decimal are
always interpreted via the "Decimal" method. (See NOTE below)
Options:
y Decimal — Interprets values as floating point decimals.

632
y Leading or Decimal — Interprets values without a decimal as having leading
zeros. Depending on the active unit system (inch or metric), values are interpreted
as described by the corresponding "Format" (see below).
y Trailing or Decimal — Similar to Leading or Decimal, except interprets values
as having trailing zeros.
Inch Format — Specifies the number of digits before and after the decimal point when
interpreting Inch Method, "leading", or "trailing" zero values. Data entry format is:
a.b where “a” specifies the number of digits before, and “b” specifies the number of
digits after the decimal point. (See NOTE below)
Metric Method — Specifies how to interpret metric address values. This feature is
significant only for values that do not contain a decimal point. Values with a decimal are
always interpreted via the "Decimal" method. See Inch Method, above, for list of
options. (See NOTE below)
Metric Format — Specifies the number of digits before and after the decimal point
when interpreting Metric Method, "leading", or "trailing" zero values . Data entry format
is: a.b where “a” specifies the number of digits before, and “b” specifies the number
of digits after the decimal point. (See NOTE below)
Multiply / Multiplier — When Multiply is set to "Yes", the word value is multiplied by
the amount specified in the Multiplier field. (Note that a multiplier of "1" has no affect
on the word value.)
NOTE: Only available when Type = Macro or Type = Conditional)
Composite Format — Specifies how to break up, or "parse" Composite-Numeric value
types. Enter one or more numbers separated by spaces to specify the quantity of parsed
number values and the significant places of each. An asterisk "*" can be used as a wild
card entry. Each parsed value appears in the word pick list of the Configuration menu >
Word/Address function to perform individual actions.

EXAMPLE:
Parsing "T" word/values:
Sample data Composite Parsed values
block Format
T0203 22 T=203, T1=02, T2=03
T102 12 T=102, T1=1, T2=02
T0304 or T304 *2 T=304, T1=03, T2=04
T10001 *2 T=10001, T1=100, T2=01
T102 111 T=102, T1=1, T2=0, T3=2
T12345678 2*2 T=12345678, T1=12,
T2=3456, T3=78
T102.3 * 2.1 T=102.3, T1=1, T2=02, T3=3
T102.3 2.1 T=102.3, T1=10, T2=3
T12345678.321 22.2 T=12345678.321, T1=12,
T2=34, T3=32

633
Conditionals - listed alphabetically
The conditionals which can be referenced via Configuration menu > Word Format are
listed below in alphabetical order. Conditionals are passed the text string of the current
block, up to and including the current word, and returns a word type specifying how the
current word is to be interpreted (typically identified by the characters "Cond" in the
function name)

AbCondEqual — This function determines if the "=" should be interpreted as an


assignment or as a logical operator. If the "=" is part of a IF or GTO Type II comand, it
will be defined as a logical operator. Otherwise, it will be determined as an assignment
operator.
AbCondLeftParen — Conditional function that looks at the next two characters to
determine if it is a known "TYPE II" command. If the following 2 characters are: AB,
AP, AT, CC, CL, CN, CS, CY, FA, KB, MD, MI, MT, NS, QU, RN, TA, TB, TC, TS,
TT, or ZT, then the left paren is interpreted as the beginning of a type II command.
Otherwise it is interpreted as a comment.
AbCondRightParen — If a comment is currently being processed, then the right paren
is interpreted as an "END COMMENT" special control word. Otherwise it is interpreted
as an "END TYPEII" word.
AtanCondDivide(block_str) — If the "/" symbol is part of a ATAN argument and its is
not imbedded within brackets ([ ]), then this function returns the type SEPARATOR.
Otherwise this function returns the type DIVIDE.
CinciCondEqual — If G10 exists in the block, ignore the current word. If G11 exists in
the block, interpret the current word as a logical EQUAL. Otherwise, interpret the current
word as an assignment
CinciCondLeftBracket — If the previous character was "T", ignore the current word.
Otherwise, interpret the current word as a LEFT PRECEDENCE. Requires values to be
initialized by the CinciBlockInit macro.
CinciCondLeftParen — Returns "Begin Type II" if a Type II command follows.
Otherwise returns "Left Precedence". Requires values to be initialized by the
CinciBlockInit macro.
CinciCondRightBracket — The current word will be either ignored or interpreted as a
RIGHT PRECEDENCE depending on how the matching CinciCondLeftBracket was
interpreted. Requires values to be initialized by the CinciBlockInit macro.
CinciCondRightParen — Returns "End Type II" if currently processing a Type II
command. Otherwise returns "Right Precedence". Requires values to be initialized by the
CinciBlockInit macro.
CinciCondTWord — If the current word was preceded by a "[", interpret the current
word as a VARIABLE TAG. Otherwise, interpret the current word as a MACRO.
CinciCondVWord — Returns "Assignment" if G10 is in the block. Otherwise returns
"Command".
CycleCondPWord — Sets P_1 (default) or P_2 after checking the context of the block
containing the P-word. P_2 is set when the block contains a G76 and either X, Y, U or W

634
words.
CycleCondQWord — Sets Q_1 (default) or Q_2 after checking the context of the block
containing the Q-word. Q_2 is set when the block contains a G76 and either X, Y, U or
W words.
CycleCondRWord — Sets R_1 (default) or R_2 after checking the context of the block
containing the R-word. R_2 is set when the block contains a G74, G75, G76 and either X,
Y, U or W words.
CycleCondUWord — Sets U_1 (default) or U_2 after checking the context of the block
containing the U-word. U_2 is set when the block contains a G71, G72, G73 and either P
or Q words.
CycleCondWWord — Sets W_1 (default) or W_2 after checking the context of the
block containing the W-word. W_2 is set when the block contains a G71, G72, G73 and
either P or Q words.
FadalCondAsteriskWord(block_str) — If the Asterisk Word comes after a "#"
character, then this function returns the type MULTIPLY. Otherwise this function returns
the type COMMENT.
FadalCondEqualWord(block_str) — If the Equal Word comes after the string “IF”,
then this function returns the type EQ . Otherwise, this function returns the type
ASSIGNMENT.
FadalCondLParenWord(block_str) — If the Left Parenthesis Word comes after a "#"
character, then this function returns the type LPAREN. Otherwise this function returns
the type COMMENT.
FadalCondNWord(block_str) — If the N Word comes after a "#" character, then this
function returns the type IGNORE. Otherwise this function returns the type
COMMAND.
FadalCondRParenWord(block_str) — If the Right Parenthesis Word comes after a "#"
character, then this function returns the type RPAREN. Otherwise this function returns
the type END_COMMENT.
FadalCondRWord(block_str) — If the R Word comes after a “G” character, then this
function returns the type COMMAND. Otherwise this function returns the type
VARIABLE_TAG.
GLCondPWord(block_str) — If the P word is part of a PDO command, in CYCLE
mode, or if the next non-space character on the block is a "=", then this functions returns
the type COMMAND. Otherwise this function returns the type VARIABLE_TAG.
GLCondPWord2(block_str) — The P word can either be part of a COMMAND, or a
VARIABLE_TAG. If P is part of a VALUE argument of a TYPE II command, or is
preceded by =, +, -, *, /, [, or (, then the P will be interpreted as a VARIABLE TAG. If an
integer value does not follow the P, then the P will be interpreted as a COMMAND. If
the integer number is followed by a =, +, -, *, /, ], or ), then the P will be interpreted as a
VARIABLE TAG. Otherwise the P will be interpreted as a COMMAND. This
conditional function is an alternative to GLCondPWord. You can use which ever function
produces the correct results for you.
HeidCondDivide — Conditional function which determines how a "/" character is to be
interpreted.
If a "REP" preceeds the "/" on the line, then it will be interpreted BEGIN
COMMENT.

635
If a "CYCL DEF 14.1" preceeds the "/" on the line, it is recognize as a list separator
used between contour subroutines. See Notes about simulating Heidenhain SL
pocket cycles for additional information.
Otherwise it will be interpreted as DIVIDE.
KtCondLeftParen(), KtCondRightParen() — These functions support the "(" and ")"
words when used as mathematical precedence and as Begin Type 2 data.
NumCondAWord(block_str) — If the non-white space character immediately
preceding the A Word is a "=", "<" , ">", "+", "-", "*", "/", "&", or "!", it is interpret as
type FUNCTION, and sets the word to mathematical function ATAN. Otherwise the
word is interpret as a COMMAND (or MACRO).
NumCondCWord(block_str) — If the non-white space character immediately
preceding the C Word is a "=", "<" , ">", "+", "-", "*", "/", "&", or "!", it is interpret as
type FUNCTION, and sets the word to mathematical function COS. Otherwise the word
is interpret as a COMMAND (or MACRO).
NumCondDollarSignWord(block_str) — If the Dollar Sign Word comes after a "=",
and the character "L" or "E" is present, then this function returns the type FUNCTION,
and sets the word to NUM_INPUT. Otherwise this function returns the type
CONSOLE_MSG.
NumCondEqualWord(block_str) — If the Equal Word comes after the string "G79" or
the string "IF", then this function returns the type EQ. Otherwise, this function returns the
type ASSIGNMENT.
NumCondEWord(block_str) — If the E Word comes after a number, or if it begins the
block , then this function returns the type VARIABLE_TAG. Otherwise this function
returns the type FUNCTIONS, and sets the word to E_FUNC.
NumCondRWord(block_str) — If the non-white space character immediately
preceding the R Word is a "=", "<" , ">", "+", "-", "*", "/", "&", or "!", it is interpret as
type FUNCTION, and sets the word to mathematical function SQRT. Otherwise the word
is interpret as a COMMAND (or MACRO).
NumCondSWord(block_str) — If the non-white space character immediately preceding
the S Word is a "=", "<" , ">", "+", "-", "*", "/", "&", or "!", it is interpret as type
FUNCTION, and sets the word to mathematical function SIN. Otherwise the word is
interpret as a COMMAND (or MACRO).
NumCondTWord(block_str) — If the non-white space character immediately
preceding the T Word is a "=", "<" , ">", "+", "-", "*", "/", "&", or "!", it is interpret as
type FUNCTION, and sets the word to FIX. Otherwise the word is interpret as a
COMMAND (or MACRO).
OkumaCondNWord(block_str) — This function internally redefines the "N" word
during parsing depending upon how it is being used:
y If the next non-space character is numeric and the string "IF" or "GOTO" existed
previously on the line, then this routine returns the type CONDITIONAL, and sets
the word to N_GOTO_LABEL.
y If the next non-space character is numeric and the string "IF" or "GOTO" does not
previously exist on the line, then this routine returns the type CONDITIONAL,
and sets the word to N_LABEL.
y If the next non-space character is not numeric, and the string "IF" or "GOTO"

636
existed previously on the line, then this routine returns the type CONDITIONAL,
and sets the word to N_GOTO_SEQ.
For this functionality to work, the following words must be defined in the Configuration
menu > Word Format window:
y Name=N, Type=Conditional, Function Name=OkumaCondNWord
y Name=N_GOTO_LABEL, Type=Macro, Value Type=Alpha-Numeric
y Name=N_GOTO_SEQ, Type=Macro, Value Type=Numeric, Inch Method/Metric
Method=Decimal
y Name=N_LABEL, Type=Macro, Value Type=Alpha-Numeric
Then, the Configuration menu > Word/Address function must also be configured to
process the above-listed words, for example in the "Specials" class:
y Word=N Range=*, Condition=* *, Macroname=Sequence, Scan=Yes, After=No
y Word=N_GOTO_LABEL Range=*, Condition=* *, Macroname=LabelName &
GotoLabel, Scan=No, After=No
y Word=N_GOTO_SEQ Range=*, Condition=* *, Macroname=GotoJump,
Scan=No, After=No
y Word=N_LABEL Range=*, Condition=* *, Macroname=LabelMacro,
Scan=Yes, After=No
OliCondLeftParent(block_str) — If the Left Parenthesis Word comes after a "="
character, then this function returns the type LPAREN. Otherwise this function returns
the type BEGIN_TYPEII.
OliCondRightParent(block_str) — If the RightParenthesis Word comes after a
BEGIN_TYPEII word, then this function returns the type END_TYPEII. Otherwise this
function returns the type RPAREN.
Siemens3RCond(block_str) — Same as SiemensRCond(block_str), except it also looks
to see if the @ command had finish prior to this point in the block. It does this by looking
backwards from the current point, and checking to see if a non-operator, non-R, non-digit
character exists between the current point and the @ command. When the R word is used
as a command, it typically calls the VariableArgument macro. This sets up the addition
arguments that are then processed by the specific Siemens macro.
SiemensCondLParenWord() — If MCALL is on the line, the word type is set to Left
Precedence, otherwise it is set to Begin Comment.
SiemensCondRParenWord() — If MCALL is on the line, the word type is set to Right
Precedence, otherwise it is set to End Comment.
SiemensRCond(block_str) — If the R Word comes after a "@" character, then this
function returns the type COMMAND. Otherwise this function returns the type
VARIABLE_TAG.

637
Functions - listed alphabetically
The functions which can be referenced via Configuration menu > Word Format are listed
below in alphabetical order. Functions are typically passed a single numerical value, and
returns a numerical value.
abs(value) — Returns the absolute value of the specified value.
AbsoluteDimension — This new functions will handle formats like: X=AC[2] Y=IC[3]
Z=AC[2] I=AC[1] J=AC[2] where "[" and "]" are the left and right precedence words. In
the above format, AC and IC should be defined as words which then call the function.
If the primary word is X,Y,Z,A,B,C,U,V,or W then:
AbsoluteDimension will cause the specified value to be interpreted as
absolute, and if the control is currently in incremental mode, it will convert
it.
If the primary word is I,J, or K then:
AbsoluteDimension will use the absolute mode, the "Circle Center Mode"
settings, and the "Incremental Circle Center Method" settings to determine
how to convert the value.
If the primary word is anything other then the above, no conversion will be
executed, and the incoming value will be returned.
Also see: IncrementalDimension
acos_d(value) — Returns the arc cosine of the specified value. The specified value must
be in the range of -1.0 to 1.0. The return value is in degrees, and is in the range of 0.0
to180.0.
acos_r(value) — Returns the arc cosine of the specified value. The specified value must
be in the range of -1.0 to 1.0. The return value is in radians, and is in the range of 0 to pi.
asin_d(value) — Returns the arc sine of the specified value. The specified value must be
in the range of -1.0 to 1.0. The return value is in degrees, and is in the range of -90.0 to
90.0.
asin_r(value) — Returns the arc sine of the specified value. The specified value must be
in the range of -1.0 to 1.0. The return value is in radians, and is in the range of -pi/2 to
pi/2.
atan2_d(yvalue, xvalue) — Returns the arc tangent of yvalue/xvalue. The return value is
in degrees, and is in the range of -180.0 to 180.0. If yvalue and xvalue are both zero, the
return value will be zero.
atan2_r(yvalue, xvalue) — Returns the arc tangent of yvalue/xvalue. The return value is
in radians, and is in the range of -pi to pi. If yvalue and xvalue are both zero, the return
value will be zero.
atan_d(value) — Returns the arc tangent of the specified value. The specified value must
be in the range of -1.0 to 1.0. The return value is in degrees, and is in the range of -90.0 to
90.0.

638
atan_r(value) — Returns the arc tangent of the specified value. The specified value must
be in the range of -1.0 to 1.0. The return value is in radians, and is in the range of -pi/2 to
pi/2.
ceil(value) — Returns the least integral value greater than or equal to the specified value.
cosh_d(angle) — Returns the hyperbolic cosine of the given angle specified in degrees.
cosh_r(angle) — Returns the hyperbolic cosine of the given angle specified in radians.
cos_d(angle) — Returns the cosine of the given angle specified in degrees.
cos_r(angle) — Returns the cosine of the given angle specified in radians.
exp(power) — Returns the natural logarithm "e" raised to the specified power.
floor(value) — Returns the greatest integral value less than or equal to the specified
value.
Fractional(value) — Returns the fractional portion of the specified value.
get_current_N_seqno() — Returns value of the current N word. If the N word was not
specified on the current line, the value of the last specified N word is returned.
IncrementalDimension — This new function will handle formats like: X=AC[2]
Y=IC[3] Z=AC[2] I=AC[1] J=AC[2] where "[" and "]" are the left and right precedence
words. In the above format, AC and IC should be defined as words which then call the
function.
If the primary word is X,Y,Z,A,B,C,U,V,or W then:
IncrementalDimension will cause the specified value to be interpreted as
incremental, and if the control is currently in absolute mode, it will convert
it.
If the primary word is I,J, or K then:
IncrementalDimension will use the incremental mode, the "Circle Center
Mode" settings, and the "Incremental Circle Center Method" settings to
determine how to convert the value.
If the primary word is anything other then the above, no conversion will be
executed, and the incoming value will be returned.
Also see: AbsoluteDimension
lntTrunc(value) — Returns the integer portion of the specified value.
ln(value) — Returns the natural logarithm of the specified value. The specified value
must be positive otherwise zero is returned.
log(value) — Returns the base 10 logarithm of the specified value. The specified value
must be positive otherwise zero is returned.
NumAtan(value) — Similar to atan2_d(yvalue, xvalue), except the return value is in
thousandths of a degree.
NumEFunc(value) — If the variable is being assigned to a COMMAND word, a
"NUM" specific factor is applied to the value of the variable.
NumInput() — Causes the program to prompt the user for input. If the first character of
input is a-z or A-Z, a value of 1-26 is returned. If the user enters a numeric value, the
value entered will be returned.
Round(value) — Returns the integral value closest to the specified value.

639
SiemensAxName — Passed the name of an AXIS, and returns the AXIS (an integer
value).
SiemensAxString — Passed an AXIS value, and returns the AXIS name (a string value).
sinh_d(value) — Returns the hyperbolic cosine of the given angle specified in degrees.
sinh_r(value) — Returns the hyperbolic cosine of the given angle specified in radians.
sin_d(value) — Returns the cosine of the given angle specified in degrees.
sin_r(value) — Returns the cosine of the given angle specified in radians.
sqr(value) — Returns the square of the specified value. This function can be used with
the word list to process statements like: #1 = SQR(#2 + #3)
sqrt(value) — Returns the square root of the specified value.
tanh_d(angle) — Returns the hyperbolic tangent of the given angle specified in degrees.
tanh_r(angle) — Returns the hyperbolic tangent of the given angle specified in radians.
tan_d(angle) — Returns the tangent of the given angle specified in degrees.
tan_r(angle) — Returns the tangent of the given angle specified in radians.
ToolnumToPocket — Returns the pocket number given the tool number. Specifically, it
searches the tool list for the first matching cutter tool id, and returns the corresponding
pocket number. If no list exist, or if the list is not based on pocket numbers, or if no
matching entry can be found, the function will return the tool number.

640
Word/Address
Location: Configuration menu > Word/Address

VERICUT toolbar short cut:


Opens a window to "group" G-code words previously defined via Configuration menu >
Word Format with a range of address values, and associate them with action macros to
simulate an action in the control, or on the machine. (See how) For simplicity, we'll call
each of these address/value associations a "group". Each group can be configured to call
one or more action macros. This functionality allows you to virtually "wire" a custom NC
control based on machine code information present in the tool path file. Groups with
similar functions are arranged into a "class". (See how) The listed order of classes in the
Word/Address window helps determine the timing of when corresponding actions occur.

The Word/Address window consists of a "menu bar" and a "tree structure" representing
the configuration of a particular NC control.
The Menu Bar
File
Open — Opens a window enabling you to open (load) a control file.
Provides the same function as Configuration menu > Control > Open.
Save — Saves (updates) an existing Control file with the current NC control
settings. Provides the same function as Configuration menu > Control >
Save.

641
Save As — Opens a window enabling you to save the current control file
under a different name or path. Provides the same function as Configuration
menu > Control > Save As.
Close — Closes the Word Address window without saving the control file.
Edit
Add/Modify — Opens the Add/Modify Word/Address window enabling you
to add or modify groups within the control configuration.
Cut — Enables you "cut" the object highlighted in the control configuration.
Copy — Enables you "cut" the object highlighted in the control
configuration.
Paste — Enables you "paste" a previously "cut" or "copied" object after the
object highlighted in the control configuration.
NOTE: When you "Cut", "Copy", or "Paste" an object in the "tree",
all objects below it in that particular "branch" (children) are cut, copied,
or pasted with it.
Utilities
Find — Opens the Find Word window enabling you to find the groups in a
control configuration that are associated with a specific word/address value,
or call specific macros.
Validate — Opens the Word/Address Validate window enabling you to
validate the control configuration.
Validate — Starts the validation process. VERICUT searches through
the control checking for errors or conflicts within the Word/Address
groups. If an error\conflict is detected, the validation process stops and
the entity that has the problem is highlighted and a message is output to
the message log area. If no errors/conflict are found, the validation
process continues until the end of the control configuration is reached.
Next — Use to continue the validation process after an error/conflict is
identified.
Previous — Use to go back to the previous error/conflict.
Close — Stops the validation process and closes the Word/Address
Validate window.
The Control Configuration
Object Hierarchy

The illustration above shows an expanded "group" from the configuration "tree".
The top level object, "Specials", represents a "class". The second level object (or

642
branch), "Variable : 3000 *" , represents "Word/Variable and Range", in this case
Variable and Range. The third level object (branch), "**", represents a
"conditional Word/State/Variable and conditional Range/Value ". The lowest level
objects (branches), "AlarmSignal and "EndProgram", represent Macro/Variable
Names with associated data. Each lower level (or branch) is considered to be " a
child or children" of the next higher level.
Configuration "tree"
The control configuration of a particular NC control is displayed as a "tree"
structure. When you expand a "class" object, the "Word/Range" branch shows the
word/address of the groups within the class. Expand a "Word/Range" object and
the "Condition" branch shows conditions defined for the selected group. Finally,
expanding a "Condition" object, displays the "Macro name" branch which shows
the macros associated with the selected condition in the group.
To summarize, expand a "class" to display the "groups" associated with it. Expand
a "group" to display the different "conditions" associated with it. Similarly, expand
a "condition" to display the macros/variables associated with the condition.
Change the order of class, group. condition and macro objects in the control
configuration by "left clicking" on an object and "dragging" it to the desired
position. When you reposition an object, all of the objects below it in the branch
(children) are also repositioned.
Right Mouse Button options
"Right click" in the Control Configuration window to display a shortcut menu with
the following features:
Add/Modify, Cut, Copy, Paste, and Find — These features provide the
same functionality described under Menu Bar above.
Contract All Children — Use to contract (remove the display) all
"children" of the highlighted object.
Expand All Children — Use to expand (display) all "children" of the
highlighted object.
NOTES:

Always reset VERICUT (press on the VERICUT main


window) after making changes to the control configuration.
Use the Debug Macro Arguments feature, on the Project menu >
Processing Options > G-Code > Process Options: Debug tab, to
output the macro name, the word, the text string value, and the
numeric value for each macro as it is called.

643
Add/Modify Word/Address window

Opened by pressing Add/Modify on the Word/Address window, the features on this


window enable you to maintain groups/conditions in the control configuration. (See how)
VERICUT will attempt to add a new group after the group selected in the list. A new
group condition is added after the selected condition, and so on. However, if the word
and range of an added group matches that of a previously defined group, the new group is
automatically added as a condition to the previously defined group. This occurs even
when the previously defined group resides in a different class.
Class Name — Enables you to add a new "class" or rename an existing "class".
Word / Variable option — Controls the type of group being defined. Options:
y Word, Word/Range—These features define a group whose actions are
performed when a G-code having a corresponding word and address value is
processed. Enter the group word and range of values into the data fields that
appear when this option is active. The word must be previously defined via the
Word Format function. You can type the word character, or select it from a pick
list. The Range field commonly specifies a single address. However, you can also
specify multiple range values (separated by spaces), inclusive ranges, or use "*"
as a wildcard to denote "all values". Setting "Range=NONE" supports processing
words (or conditional words) without values differently from the same words with
values. For example, you can configure N010X to be handled differently from
N010X0. Examples follow.
Examples of specifying "L" group Word and Range values:
Group Word Range G-codes acted on by
the group
L 2 L2
L 15 L1, L5
L 1 5-10 L1, L5, L6, L7, L8,
L9, L10
L NONE L ("L" without a
numeric value)
L * Ln (where "n" is any
value)
y Variable, Variable/Range—These features define a group whose actions are
performed when a specified variable is set to a corresponding value. Enter the
group variable name and range of values into the data fields that appear when this
option is active. Variable ranges are specified in the same manner as for words, as
described above.
NOTE: Typically, Range values are integers. If you need to specify a group
of NC codes, some of which contain decimal values (for example, G45,
G45.1 G46) define the group Range as a series (45 45.1 46), rather than as an

644
"inclusive" Range (45-46). Inclusive Ranges of real values may be defined
by including a decimal point with the value. For example, the Range (45.0-
46.0) will select all values between 45 and 46.
Conditions — Use to specify one or more conditions, which if met, causes the group to
perform different action(s).
y Operator — Choose and or not from the pull-down list.
y Word, Conditional Word/Conditional Value — When Type = Word, the
condition is based on another word and address value range appearing in the G-
code data block. This is the most common condition type. Select the desired
Condition from the pull-down list, then enter the Conditional Value(s). Use the
same considerations as described above for Word, Word/Range.
For example: G 81 not (X *) and not (Y *) and not (Z *) calls ErrorMacro

y State, Conditional State/Conditional Value — When Type = State, the


condition is based on a machine state. Choose the desired Condition from the
pull-down list, then choose a value from the Conditional Value pull-down list.
Notice that only values that are valid for the selected Condition appear in the list.
y Variable, Conditional Variable/Conditional Value — When Type = Variable,
the condition is based on when a variable is set to a corresponding conditional
value. In the Condition column enter the variable name. In the Conditional Value
column enter a value, range of values, or logical condition. Logical conditions
include <n, >n, <=n, >=n, =n (where n is a value or the contents of a variable
#name). The value or range is an integer, however if a decimal point is used or a
variable is referenced the range is inclusive.
Add — Use to add a condition to the conditions list. The new condition will be added
after the highlighted condition in the list.

645
NOTE: It is never necessary to have the list in any specific order since all items
in the list must be TRUE for the corresponding macro to be executed. As a personal
preference, you might want to read the list in a specific order. To this end, the new
condition is always added after the highlighted condition in the list. You can also
change the position of a condition in the list by clicking on the button, on the left
side of each row, and drag the condition to the desired position in the list.

Delete — Use to delete the highlighted condition from the conditions list.
Macroname/Variable option—Controls if group calls a macro, or sets a variable.
Depending on the active choice, features are provided for specifying the macro called
(select or type in field), or the Variable Name and Variable Description of the variable to
be set (enter the variable value in the Override Value field). You can select macronames,
or type them in. Text entered is not case sensitive. Use the automatic filtering capability
to help you find macros. When you enter text characters in the Macroname field, the list
of macros is automatically filtered to show those that match the specified text.
Process during Scan—When active, calls the macro during a "scan pass" prior to tool
path processing (ref. "Scan Toolpath Files" on the Project menu > Processing Options >
G-Code > Settings: Settings tab). The default condition, is to call the macro during tool
path processing.
Process After Motion—When active, performs the group action after motion commands
in the data block have been processed. The default condition is to perform the group
action according to the rules of normal G-code data processing. (Ref. "About building
NC controls" in the Using VERICUT section.)
Override Value—This feature acts differently, depending on if Macroname or Variable
is selected:

- With Macroname selected—Specifies a value to pass to the specified macro. If


blank, the address value accompanying the word is passed.
- With Variable selected—Specifies a value to assign to the specified variable.

Math expressions and variables understood by the control are supported. Enter "$"
to specify using the address value accompanying the word. Enter "#", followed
immediately by the variable name/number, followed by a space, to specify a
variable value. Multiple variables can be added, separated by a blank space. If the
override expression does not contain either of these characters, it is evaluated
immediately and only the value is retained. If the expression can not be evaluated
immediately, the full expression is retained in the control configuration and
evaluated separately for each block that activates the group.

646
Examples of using Override Value: (given that the variable, #2 = 3)
Text entered in What is retained in Sample G- Resulting value when
Override Value control configuration code data processed
field block
SIN(30) .5 X5 .5 (constant value- not
affected by G-code
data)
SIN(30) .5 X10 .5 (see note above)
$*10 $*10 X5 50
($+#2)*10 ($+#2)*10 X5 80

Also see "Using Equations/Expression In VERICUT" in the Using VERICUT


section for more information.

Override Text—Similar to Override Value, except specifies text to pass to the macro.
Only certain macros are designed to accept override text values. Consult "Macros - listed
alphabetically" for more information.
Expression(s) can be used in macro override text. If the override text contains the
sequence "{ expression }" the expression text inside the curly-braces is evaluated
and replaced with the calculated value.
For example, if the MessageMacro is used with the following override text:
"The spindle speed is {#speed} rpm"
The variable "#speed" is evaluated and if set to 500, the resulting
message would be:
"The spindle speed is 500 rpm"
The syntax for the expression(s) is the same as defined for override values.

Override Word Format—When toggled "on", the word format specified with the macro
will be used rather than the default word format. Use the Set button, described below, to
define the word format for the specific macro. For example, this feature would enable
you to define a P with a G71 to be decimal, and a P with a G76 to be Trailing 3.4.

NOTES:
1. This feature does not support expressions. For example, you could not use
this feature with: X=54000 + 30000
2. If there is an Override Value specified, Override Word Format will be
ignored.

647
Set—Used in conjunction with Override Word Format, described above. Displays a
window enabling you to specify a word format for a specific macro.
Inch Method / Metric Method—Specifies how to interpret inch (and metric)
address values. This feature is significant only for values that do not contain a
decimal point. Values with a decimal are always interpreted via the "Decimal"
method. Options:
y Decimal—Interprets values as floating point decimals.
y Leading or Decimal—Interprets values without a decimal as having
leading zeros. Depending on the active unit system (inch or metric), values
are interpreted as described by the corresponding "Format" (see below).
y Trailing or Decimal—Similar to Leading or Decimal, except interprets
values as having trailing zeros.
Inch Format / Metric Format—Specifies the number of digits before and after
the decimal point when interpreting leading or trailing zero values. Data entry
format is: a.b where "a" specifies the number of digits before, and "b" specifies the
number of digits after the decimal point.
Add — Select when adding a new group or condition.
Modify — Select when modifying an existing group or condition.
Close — Close the Add/Modify Word/Address window.

648
Find Word window
Opened using Utilities menu >Find on the Word/Address window, the features on this
window help you find the groups in a control configuration that are associated with a
specific word/address value, or call specific macros.

Words/Range tab — Enables you to find groups associated based on a specific


word/address value. Pick the desired word from the Word list, then enter the address
value in the Range field.
Macroname tab — Enables you to find groups that call a specific macro. Type or pick
the name of the desired macro from the Macroname list.
After configuring the window to find the desired group, use the buttons at the bottom of
the window to find the First, Next, or Previous occurrence in the control configuration.

649
Macros - listed alphabetically
The macros which can be referenced via groups in the Word/Address window, and the
"Events" advanced control options are listed below in alphabetical order.
NOTES:
The use of certain macros requires an Advanced Machine Features license. The
macros in this category are:
ClampOnOff
Ijk2AbcType (with a non-zero value)
ModeAsymTurningOnOff (with a non-zero value)
Use of the Probe macro requires a CNC Machine Probing license.
For information on special keywords CGTECH_MACRO and CGTECH_VAR
REAL, see About Simulating Subroutines in the Using VERICUT section.
Tip: Use the Debug Macro Arguments feature to see the macro name, the word, the text
string value, and the numeric value for the macro being called.
Short Cuts:
Click on See Macros Sorted by Function to see macros organized by function
(accel/Decel. block skip branching, etc.).
Click on See Macros Sorted by Status to see macros organized by status
(active, alternate, obsolete, etc.).
Click on a letter below to go directly to the macros that start with that letter.
Numbers A B C D E F G H I J K L M N O P Q R S T
U V W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
3dToolOffset Renamed to: Tool3dOffset.
3dToolXOffset, 3dToolYOffset, 3dToolZOffset Renamed to: Tool3dXOffset,
Tool3dYOffset, Tool3dZOffset.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
A2AxisIncreMotion Similar to AAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
A2AxisMachineMotion Similar to AAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the

650
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
A2AxisMachineRefMotion Same as its A2AxisMachineMotion counterpart,
except also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
A2AxisMotion Sets the A2 value used to command the machine's A2 rotary
component. A macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
AAxisIncreMotion Similar to AAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
AAxisMachineMotion Similar to AAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
AAxisMachineRefMotion Same as its AAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
AAxisMotion Sets the A value used to command the machine's A rotary
component. A macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
AbBlockInit Initializes Allen-Bradley specific variables. This macro should be
called along with the standard BlockInit macro at the "Start or Block Processing"
event.
AbsoluteShift Shifts the work coordinate system by the specified axis values. The
values will be interpreted as absolute. Any axis value which is not specified is
assumed to be zero. (Shift Offset 0, ABSOLUTE/NON-MODAL).
See "Notes about shift macros" in the Using VERICUT section for additional
information.
AbsoluteShiftModal Shifts the work coordinate system by the specified axis
values. The values will be interpreted as absolute. Only values specified on the
block will be adjusted. (Shift Offset 0, ABSOLUTE/MODAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
AbsoluteShiftNum Shifts the work coordinate system by the specified axis
values. The values will be interpreted as incremental or absolute depending on
the current state, incremental (ModeIncremental) or absolute (ModeAbsolute),
of the control . Only values specified on the block will be adjusted. (Shift
Offset 1, ABSOLUTE/MODAL or INCREMENTAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
ABType2CLS An Allen Bradley Type II subroutine call with no arguments. Same
as Type2CLS, except it strips all characters starting with the "/" character. For
example: (CLS,027sta/hd) would call subroutine file "027sta".

651
AccelTakeoffFactor Controls the length of the accel block output during
optimization for motions in a corner. When called with an Override Value greater
than "0", OptiPath outputs an accel block when suitable. A value of "0" (default)
causes the accel block to not be output. The value passed represents a % override to
apply to the calculated length for normal accel block output. For example, a value
of "1.0" specifies that 100% of the calculated accel block length should be used,
while "0.5" uses 50% of the calculated length.
ActivateAxis Marks this axis as active for this subsystem. Used with
InActivateAxis on synchronized turning tool paths to avoid conflict with
Stock/SubStock rotaries. Is passed the numeric value of the axis (1-12) or a text
value of All to activate. Each axis is associated with a numeric value as follows:
1=X axis, 2=Y axis, 3=Z axis, 4=A axis, 5=B axis, 6=C axis, 7=U axis, 8=V
axis, 9=W axis, 10=A2 axis, 11=B2 axis, 12=C2 axis, All=All axes will be
activated.
NOTE: When an axis is activated, it will pick up the current location of the
axis and offset from the machine. This logic does not take into account
rotation matrices that might be applied.
ActivatePreToolSubsystem Calls ActivateToolSubsystem with the component
number that was pre-selected with PreToolCompSelect.
ActivateSpindle Activates the Tool component with "Tool Index Number" equal
to the value specified by the SpindleValue macro. Intended to replace the
ActiveTool1-5 macros.
ActivateToolSubsystem Activates the tool component based on the specified
numeric value (Override Value = tool index) and the current subsystem.
ActiveSpindleActiveTool This macro sets the active spindle component name
based on the active tool. The "active tool" is either the tool component that has
been marked as active, or the first tool component in the machine list. If this active
tool has a corresponding spindle component, this component will be marked as the
active spindle component. If the active tool does not have a corresponding spindle
component, then the active tool component will be marked as the active spindle
component. This component will then be used to store the spindle attributes
(direction, speed, minimum speed, maximum speed, on/off, and direction). The
active spindle must be set prior to setting any spindle attributes.
See "Notes about spindle configuration in V6" in the Using VERICUT section
for additional information.
ActiveSpindleCompName Sets the active spindle component name based off of
the incoming text value. This component will be used to store the spindle attributes
(direction, speed, minimum speed, maximum speed, on/off, and direction). The
named component can be either a spindle component or a tool component. The
active spindle must be set prior to setting any spindle attributes.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
ActiveSpindleDir This macro sets the spindle direction to either clockwise or
counterclockwise for the active spindle component. If the text value is set to CW,

652
the direction will be set to clockwise. If the text value is set to CCW, the direction
will be set to counterclockwise. This macro does not turn the spindle on. It only
sets the direction attribute. The active spindle must be set prior to calling this
macro. See ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
ActiveSpindleMaxSpeed This macro sets the maximum speed for the active
spindle component to the input value. The active spindle must be set prior to calling
this macro. See ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
ActiveSpindleMinSpeed This macro sets the minimum speed for the active
spindle component to the input value. The active spindle must be set prior to calling
this macro. See ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
ActiveSpindleOnOff This macro turns the active spindle component On or Off. A
value of zero turns it Off, and a value of one turns it On. This can correspond to
either the stock spindle or tool spindle. The active spindle and its corresponding
children will be spun. It will also cause an APT "SPINDL" statement to be
generated, and the status to be updated.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
NOTE: The spinning status of a stock component determines whether this stock
is in "Turning" or "Milling" mode. The active spindle must be set prior to calling
this macro. See ActiveSpindleCompName and ActiveSpindleActiveTool.
ActiveSpindleSpeed This macro sets the spindle speed for the active spindle
component. This macro does not turn the spindle on. It only sets the speed attribute.
If the spindle is already turned on, then it will cause an APT "SPINDL" statement
to be generated, and the status to be updated. The active spindle must be set prior to
calling this macro. See ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
ActiveTool Activates the Tool component with "Tool Index Number" equal to the
value specified by this macro. Intended to replace the ActiveTool1-5 macros, and
support using more than five tool positions on a machine.
NOTES:
1. If the machine contains multiple subsystems, it is recommended that you
use the ActivateToolSubsystem macro rather than this macro.
2. If you are running in SYNC mode, it is required that you use the
ActivateToolSubsystem macro rather than this macro.
ActiveTool1, ActiveTool2, ActiveTool3, ActiveTool4, ActiveTool5 Activates the
Tool component with "Tool Index Number" of 1-5, respectively.

653
NOTES:
1. If the machine contains multiple subsystems, it is recommended that you
use the ActivateToolSubsystem macro rather than this macro.
2. If you are running in SYNC mode, it is required that you use the
ActivateToolSubsystem macro rather than this macro.
AdditionalWorkCoord Updates the work coordinate system based on values
retrieved from the Work Offsets table. The work coordinate index is used as an
index into this table.
AlarmSignal Similar to ErrorMacro, except it concatenates the Override Text
string and Override Value. It also looks to see if the "if condition" (if present) was
true. This produces a simple generic alarm message with an error code:
Error: <Override Text>: <Override Value>
ApplyGageOffset This macro provides an approach to using Tool Length
Compensation mode. The concept is the gage offset is not applied until G43 is
entered, and is canceled when G49 is entered. When called with an Override
Value of "1", the gage offset will be applied regardless of what programming mode
you are in. The default Override Value is "0". Prior to the calling of this macro,
the gage offset would not be applied if you are in Gage Length or Tool Length
Compensation programming mode (ref. Project menu > Processing Options > G-
Code > Settings: Settings tab).
The approach would look like the following: :
G43 calls ApplyGageOffset with Override Value = "1" (to apply the
gage offset)
G49 calls ApplyGageOffset with Override Value = "0" (to cancel the
application of the gage offset)
H calls ToolOffsetUpdate
ApplyGagePivotOffset This macro is passed a value of 0 or 1. The default value is
0. When set to 1, it will cause the tool offset to include the distance from the active
tool to the rotary pivot. The rotary pivot is being defined as the origin of the first
parent rotary (if there is only one), or the intersection of the axes of the first 2
rotary components up from the tool (if there are more than one tool side rotary
component). If there are two or more parent rotary components, and if the axes do
not intersect, the rotary pivot point is defined as the second parent rotary.
Compensation for the tool offset typically occur with a call to ToolOffsetUpdate.
This feature can now be used with RTCP. When used with RTCP, this Gage Pivot
Offset will be used rather than the RTCP Pivot Offset. Being in RTCP mode is not
a requirement to activate this offset.
The ApplyGagePivotOffset approach is the preferred method for handling the tool
to pivot offset. It has many advantages over the traditional approach. The
advantages are all associated with the new approach establishing a "relational"
offset (pivot point to current active tool). As described above, this approach
assumes a specific pivot point based on the machine configuration. In some cases,
this pivot point might not be the pivot point that you want to define. In these
instances use PivotOffsetCompName to define the component containing the

654
desired pivot point.
Using ApplyGagePivotOffset sets the Gage Pivot Offset flag for all subsystems.
ApplyGagePivotOffsetCurrent This macro is identical to the
ApplyGagePivotOffset macro except that it sets the Gage Pivot Offset flag only for
the current subsystem.
ApplyPivotOffset Specifies whether the RTCP Pivot Offset should be applied. A
value of 1=YES, 0=NO. When YES, the controller will compensate for the pivot
distance when running in RTCP mode. The pivot distance can be specified with the
RTCP Pivot Offset table. If the table is not specified, it will be calculated based on
the location of the Tool and its corresponding Rotary components.
NOTE: Even with this flag being set to YES, the RTCP Pivot Offset will
only be applied if in RTCP mode, or in a special
FanucToolLengthCompAxisOn mode.
ApplyRotationPlaneWithIjk2Abc Sets a flag specifying whether the current
rotation plane should be applied to the IJK vector associated with the IJK to ABC
conversion.1 = Yes, 0 = No. The default is No.
ApplyTurretOffset Automatically applies a turret offset to the gage offset a tool in
use. The turret offset is the distance from the active tool component to the turret
component. This allows tool components to be connected at their actual location on
the Turret component without having to include this distance in each tool's gage
offset values. This macro should be called during the "Start of Processing" event
with an Override Value of "1" (on) or "2" (on except for when the gage offset is
set to "0 0 0"). "0" is the default, and does not apply the turret offset.
See also: ToolOffsetUpdate
ArcAccelFeedrateFactor Sets a factor that will be used when calculating the
maximum feedrate when processing an arc. This is used with the ACCEL/DECEL
logic within OptiPath. The default for this factor is one. The formula to be used is:
Feedrate = sqrt(acceleration * radius * factor).
AutoScanOff Turns off the "automatic" setting of the Scan Toolpath Files flag
when a subroutine file is specified. This macro needs to be called during the
"Reset" event.
NOTE: Subroutine files will always be scanned.
AutosetCutterCompVars Reads the Cutter Compensation table and sets system
variable values based on table values. This macro is passed the starting variable
number as an "Override Value". For example: if the starting variable number is set
to "2000", and index 5 in the table is set to ".2", variable #2005 will be set to .2.
See also: "Notes about system variables" in the Using VERICUT section.
AutosetTableAxisVars Updates system variables based on current table values
(re-reads table values). This macro is passed a series of arguments in the Override
Text field. Arguments are as follows (separated by spaces):
table name
starting index value
ending index value
starting variable value

655
variable offset per index
variable offsets for axes: x y z a b c u v w
NOTE: Unused axes to the right do not need to be specified. Unused axis
in the middle should be specified with a "-1".
Examples:
The following defines the work offsets for a Fanuc 15MB with a 4-axis NC
machine where the B-axis is defined as the 4th axis (x,y,z are 1,2,3):
y Override Text= Base Work Offset 1 1 5200 20 1 2 3 -1 4 (Note that "-1"
represents the unused A-axis in this machine.)
y Override Text= Work Offsets 54 59 5220 20 1 2 3 -1 4
y Override Text= Work Offsets 1 48 7000 20 1 2 3 -1 4
The following loads registers 1-300 from the Cutter Compensation table
into variables starting at #2000
NOTE: This is only an example, typically you would call
AutosetCutterCompVars).
Override Text= Cutter Compensation 1 300 2000 1 1
See also: "Notes about system variables" in the Using VERICUT section.
AutosetToolLengthCompVars Reads the Tool Length Compensation table and
sets system variable values based on table values. This macro is passed the starting
variable number as an "Override Value". For example: if the starting variable
number is set to "4000", and index 5 in the table is set to "10", variable #4005 will
be set to 10. The setting of the variables is based strictly off the table and is NOT
dependent on programming method or Input Program Zero table.
See also: "Notes about system variables" in the Using VERICUT section.
AutoUpdateIPZ This macro is passed the text of the parent component name of
the assembly that is being attached to or removed from the main machine assembly.
Use the Override Text field to specify the component name. The offset will be
calculated based on the difference between the origins of the parent component (top
of the component list) and the lowest level child component of the associated
assembly.
The Override Text field is also used to pass a value of 1 or -1 to add or subtract
the auto-calculated values from the internal Input Program Zero (Special Z) table
offset.
NOTES:
1. This does not change any of the table values. The new value for IPZ
(Special Z) can be seen using Modals/Debug/Debug Offsets.
2. This macro should probably be executed after motion or on a block
by itself. Also, since the internal value for Input Program Zero
(Special Z) is being modified, this method will probably not work
when running in Tool Length Comp mode.
AutoUpdatePZThis macro is passed the text of the parent component name of the
assembly that is being attached to or removed from the main machine assembly.
Use the Override Text field to specify the component name. The offset will be

656
calculated based on the difference between the origins of the parent component (top
of the component list) and the lowest level child component of the associated
assembly.
The Override Text field is also used to pass a value of 1 or -1 to add or subtract
the auto-calculated values from the internal Program Zero table offset.
AxisMappingXtoU This macro maps the programmed X-axis to the machines U-
axis. It is designed for use when a U-axis facing head is programmed with X-axis
commands. An Override Value of "1" turns the mapping "On" and an Override
Value of "0" turns the mapping "Off".
AxisPriorityOnOff Turns On and Off the settings in the Axis Priority table. If
passed a value of 0, the Axis Priority setting will be turned off, and all axes will be
interpolated, and have the same priority. If passed a value of 1, the Axis Priority
settings will be used.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
B2AxisIncreMotion Similar to BAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
B2AxisMachineMotion Similar to BAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
B2AxisMachineRefMotion Same as its B2AxisMachineMotion counterpart,
except also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
B2AxisMotion Sets the B2 value used to command the machine's B2 rotary
component. A macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
BaseWorkOffsetValues Sets the base work offset-an offset that is added to any
current work offset. The XYZ offset is specified with the WorkCoord[axis]Value
macros.
BAxisIncreMotion Similar to BAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
BAxisMachineMotion Similar to BAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
BAxisMachineRefMotion Same as its BAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.

657
BAxisMotion Sets the B value used to command the machine's B rotary
component. A macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
BlockFinish Default event macro for the "End of Block Processing" event.
BlockInit Default event macro for the "Start of Block Processing" event.
BlockSkipAnywhere Allows the block skip character to be anywhere in the block.
This macro should be called during the "Reset" event with an Override Value of
"1". When active, the block will be processed up until the block skip token is read.
The remainder of the block will then be skipped.
NOTE: This macro should only be used when the block skip character can
not be interpreted as anything except a blockskip character. It should not be
used when this token could also mean divide.
BlockSkipSwitch1 Controls when block skip Switch 1 is on or off (ref. Project
menu > Processing Options > G-Code > Settings: Block Skip tab). An Override
Value of "1"=On, "0"=Off.
BlockSkipSwitchOff Turns off the specified Block Skip switch. Valid values are
0-9. (ref. Project menu > Processing Options > G-Code > Settings: Block Skip tab).
NOTE: In the GUI, switch 1 actually sets switch 0 and switch 1. With
these macros, you must explicitly set the switches that you want on or off.
The defaults are the GUI settings.
BlockSkipSwitchOn Turns on the specified Block Skip switch. Valid values are
0-9. (ref. Project menu > Processing Options > G-Code > Settings: Block Skip
tab).
NOTE: In the GUI, switch 1 actually sets switch 0 and switch 1. With these
macros, you must explicitly set the switches that you want on or off. The
defaults are the GUI settings.
BoschType2CYCLE Sets the ZAxisMotion, the CycleRapidLevelValue, and the
CycleStepValue based on the format of a Bosch Type II Cycle command.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
C2AxisIncreMotion Similar to CAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
C2AxisMachineMotion Similar to CAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
C2AxisMachineRefMotion Same as its C2AxisMachineMotion counterpart,
except also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
C2AxisMotion Sets the C2 value used to command the machine's B2 rotary

658
component. A macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
CallNCMacro Sets up the variables for calling a Fanuc style NC macro in the
machine code input file. The machine code macro which is called is specified with
the SubroutineName macro. This macro is also dependent on the calling of the
MacroVar macro for setting the parameters which are to be passed to the
subroutine. Up to 150 variable values can be passed by a call to an NC macro.
CallNCMacroBlock Sets the mode to call a NC Macro on every block.
CallNCMacroCancel Cancels the mode set with CallNCMacroBlock and
CallNCMacroMotion.
CallNCMacroMotion Sets the mode to call a NC Macro on every block with
motion.
CallSub Calls the machine code subroutine specified via the SubroutineName
macro.
CallSubCurrent Calls the subroutine or program that is currently being processed.
Typically this is combined in the control configuration with some type of GOTO
sequence number of label.
CallSubName Calls the machine code subroutine specified with the input value.
CallTextSubName Similar to CallSubName, except the subroutine name is
interpreted as text, regardless of the Type of Subroutine Names control setting. To
use this macro, use the Configuration menu > Word Format function to define a
"SubroutineName" word that takes an alpha-numeric argument.
NOTE: It is critical that the value type be set to Alpha-Numeric. Then use
Configuration menu > Word/Address to configure the SubroutineName
macro to call this macro.
Cancel3dToolOffset Cancels the 3D Tool Correction offset. Also see:
Tool3dOffset.
CancelAllWorkOffsets Cancels the shift offset (Fanuc G92), the work coordinate
offset (G54-59), and the Base offset (MAHO).
CancelShiftOffsets Cancels the shift offset (Fanuc G92).
CancelWorkOffsets Cancels the work coordinate system offset (G54-59)
CAxisIncreMotion Similar to CAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
CAxisMachineMotion Similar to CAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
CAxisMachineRefMotion Same as its CAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
CAxisMotion Sets the C value used to command the machine's C rotary
component. A macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
CGTechVarDefMacro This macro provides the ability to define variables. The
corresponding "word" will be added to the Word list. This word will be removed at

659
reset, and will not be written to the control file. A value of 0 will define the
variable(s) as local. Any other value will define the variable(s) as global. The
syntax of the text value is identical to the Sinumeric 840D DEF format. For
example:
OV= 1 OT=REAL PPP[15]
In the above example, PPP would be defined as a variable name, and it would be
defined as a single dimension array variable with an array size of 15.
The primary purpose of this macro is to define global system array variable in the
start of processing event, and thereby define the variable in the control. It is
common to set variables during the start of processing event. If the variable is not
defined, it will be created. An array variable can not be created when set in this
manner because of the dimension of the array is not given. This macro allows array
variable to be defined in the start of processing event. Since all macros called in the
start of processing event are stored in the control file, this macro allows array
variables to be defined in the control file.
ChangeSubsystemID Changes the subsystem that the current controller is driving
based on the input text value, and updates all of its local axis locations. The
difference between ChangeSubsystemID and SetSubsystemID is that
ChangeSubsystemID keeps the current "control" active and just changes which
subsystem is being driven. SetSubsystemID changes the active "control" to be the
one which drives the specified subsystem.
ChangeWorkCoord Defines the current position to be the specified XYZ value.
This is an incremental shift from the current working coordinate system. Any XYZ
value not specified is assumed to be zero.
See "Notes about shift macros" in the Using VERICUT section for additional
information.
ChangeWorkCoordZWTracking When in absolute mode, it defines the current
position to be the specified position. Only those values specified will be adjusted. Z
or W values honors ZW tracking. When in incremental mode, the offset will be
adjusted by the amount specified.
NOTE: The specified positions are entered using the
WorkCoord[x,y,z,a,b,c,u,v,w,a2,b2,c2]Value macros.
CheckForLooseMaterial Causes VERICUT to check for loose material that
should be removed. This macro triggers VERICUT to perform a check where the
detached stock pieces should be transferred, in the same manner as it is done in
turning. If no stock component supporting a loose piece is found, it is deleted and
put into the "Unclamped Stock" component. A value of 0 = Off, 1 = turns on the
check on for every block after the macro is called, 2 = performs a one-time check
as described above. This macro only applies to milling mode. It has no effect in
turning mode.
NOTE: To enable the loose material check, Update While Simulating, in
the Delete Material window, must be toggled "On". If it is not, this macro
will have no effect.
CinciBlockInit Cincinnati specific macro that sets internal values used by
CinciCondLeftParen, CinciCondRightParen, CinciCondLeftBracket, and

660
CinciCondRightBracket conditional functions. This macro should be called along
with the standard BlockInit macro at the "Start or Block Processing" event.
CinciGotoLabelName Branches to the label specified via Override Text value. If
the specified label is preceded by a "-", then this macro will search backwards from
the current position for the specified label (not including the "-"). Otherwise, it will
search forward from the current position for the specified label.
See also: LabelMacro and GotoLabel
CinciRotateCenterCalc Calculate the center of rotation based off of the specified
center and the mode set by CinciRotateXYZMode.
CinciRotateXYZMode Cincinnati (Acramatic 950) specific macro that sets a
parameter which indicates how rotation center positions should be interpreted.
Cinci_5axisToolLengthComp Turns On/Off a special Cincinnati form of 5-axis
tool length compensation. A value of 1=On, 0=Off.
CircleCenterReset Resets the XYZ coordinates of the center of a circle.
NOTE: The CircleCenter[XYZ] values are assumed to be modal. This
macro resets these values.
CircleCenterX, CircleCenterY, CircleCenterZ Sets the XYZ coordinates of the
center of a circle, respectively. The Circles control settings determine how these
values are interpreted.
CircleCenterZWTracking Identical to CircleCenterZ except provides additional
calculations required by ZW tracking machines.
CircleCurveFitQuadrants Specifies that circular records produced during curve
fitting be broken at quadrant boundaries.

NOTE: This macro should be used during the "Start of Processing" event.
Default when not used is OFF.
CircleDirectDrive Turns On and Off (default) the capability to drive the cutting
motion of a circle by the actual tessellated motions of the machine. A value of 1
turns on this feature, and a value of 0 turns off this feature. If the circle motion for
the machine does not match the circle motion for the stock, this macro can be
called with on OV=1 to directly pass the tessellated motions to the cutting logic. If
the tessellated motions equate to a circle, the cutter logic will process the
tessellated motions as 1 circular move. Otherwise, it will be processed as a series of
tessellated linear moves.

In the following instances, the circle motion for the machine may differ from the
circle motion for the stock:

When distinguishing 0 degree vs 360 degree circles.


When interpreting the direction of the circle in part coordinates.
Using the LinkAxis macros where X drives Y and Y drives X, which then
causes the reversal of circle direction.

661
Using the LinkFormula macro with circles.

See also: "Notes about link macros" in the Using VERICUT section.
CircleIntermediatePoint This macro defines an intermediate point for a circle.
The text value should be either X, Y, or Z. This specifies which axis point is being
specified. The numeric value should be the corresponding axis value. The axis
values are modal, and are initialized to zero at reset and when Motion3DCircle is
called.
NOTE: A new "3D_CIRCLES" value for the MOTION_TYPE state has now
been created. This can now be seen in the status window (motion type), and in the
Word/Address table (State/MOTION_TYPE menu).
CirclePresentAxis When called with Override Value of "1", supports processing
circles using the linear axes present in the circle motion block. This macro should
be called during the "Start of Processing" event, and is intended for use by controls
on NC machines that have colinear axes and perform circular motions. Examples
follow.
G2Y1.1242X-25.7855I.1171J.7743 - circle motion performed by Y & X linear axes
G2Y1.1242U-25.7855I.1171J.7743 - circle motion performed by Y & U linear axes
CircleRadius Sets the radius of a circle. A negative value specifies that an arc of at
least 180 degrees should be generated.
CircleRadiusLarge Sets the radius of a circle such that an arc of at least 180
degrees will be generated. The input value is sign independent.
ClampCompName Specifies the name of a clamp component (text value). This
macro is typically used to clamp parts during pick-off spindle operations. See also:
ClampOnOff.
ClampOnOff Specifies the state of the clamp specified with ClampCompName. A
value of 0 is off, a value of 1 is on. This macro is typically used to clamp parts
during pick-off spindle operations.
In general, at the end of ProcessMotion, VERICUT checks to see if there was a
change in clamp state (On/Off). If there was, all stock components are examined. If
the stock's parent fixture is still "clamp on", VERICUT does nothing. If the stock's
parent fixture is "clamp off", VERICUT checks to see if there is any other fixture
component whose boundaries overlap the cut stock and whose state is "clamp on".
If so, and the new fixture component contains a stock component, then the cut
stock will be transferred to the new stock component. If there is nothing holding the
stock anymore, it is dropped into the chip pan ("Unclamped Stock" component).
If ClampOnOff changes from 0 to 1 for the Fixture specified by ClampCompName,
VERICUT checks the bounds of all "cut stock" models on the active subsystem. If
any are inside the bounds of the models in the Fixture Component, the Fixture
"clamps" the "cut stock". However, the "cut stock" does not transfer to the new
Stock Component, yet.
If ClampOnOff state changes from 1 to 0 for the Fixture Component specified in
ClampCompName, the "cut stock" model is released from that Fixture. If the "cut
stock" is also clamped by another Fixture (see ClampOnOff above) then the cut

662
stock is transferred to the Stock Component attached to the clamped Fixture
Component. If it is not clamped by any other Fixture, it disappears, falls in the chip
pan, flies through the window, etc. Actually it is dropped into the "Unclamped
Stock" component. This component is automatically created.
If in turning mode and the "cut stock" is separated into two pieces, each piece is
checked for a clamped condition. If each piece is clamped by a different Fixture,
then the stock is separated into 2 "cut stock" models, one in the Stock component
attached to each clamping Fixture. Thus you end-up with a "cut stock" model in the
original Stock component, and a "cut stock" model in the another Stock
component. If either piece is "floating" in the air when separated, they drop into the
chip pan (aka Unclamped Stock).
NOTES:
1. Clamp macros do not change the component connections. They just
move the "cut stock".
2. Requires an Advanced Machine Features license.
CollisionCheckOnOff This macro allows machine simulation collision checking
to be temporarily suspended and restarted. The CollisionCheckOnOff macro is
ignored when Collision Detection, on the Configuration menu > Machine Settings:
Collision Detect tab, is toggled "Off". Machine simulation collision checking is
turned "Off" when used with an Override Value of "0", and "On" when used with
an Override Value of "1"
CollisionDiagonalSize For performance reasons, a diagonal collision check logic
has been added. This logic can make collision checking for large diagonal moves
much more efficient. In theory, it could slow down some jobs. To disable this
performance feature, call this macro with a value of zero.
This macro can also be used to adjust what is a "large" diagonal move. The default
is a move of at least 1 inch or 25 mm on at least 2 axes.
CollisionOnCutPart Controls when collisions between machine components and
the cut model are checked for. By default, collisions are detected when collision
checking is turned on between the Stock and machine components. Collision
checking can be turned off via calling this macro with an Override Value of "0",
while "1" turns collision checking on again.
NOTE: "Near Miss" tolerances are not supported for collision checking
against the cut model. The accuracy of collisions with the cut stock is
dependent on the "Cutting Tolerance".
CollisionSpecialComp Turns on/off special collision processing for the named
component. This routine should only turn on special processing if the component
contains a large number of triangles, and if rotations are involved, and there are
other components which typically comes close to this component, but stays outside
of its bounding box.
NOTE: In general, this macro should not be called. It should only be called
to overcome a collision performance issue related to the scenario described
above. This macro was created for the very special case described. In these
types of cases using this macro could improve performance. In most cases,

663
general use of this macro will cause a degradation in performance.
ConditionalEndOfBlock If the previous conditional was true, this macro will
cause nothing further to be processed on this block. If the previous condition was
false, it resets the condition to true, and continues processing the block. For
example:
!IFR<49.5;EB!IFR>50.5;EB!GON20!
EB would call the ConditionalEndOfBlock macro.
ConnectCompName Used with ConnectToCompName to dynamically connect
two components within the Component Tree. Use ConnectCompName to specify
the component to be connected. Everything under the component in the component
tree goes with it. Specify the component name in the Override Text field.
ConnectToCompName Connects the component specified with the
ConnectCompName macro to the component specified by the
ConnectToCompName macro. Can be any type of component. Everything under
the "ConnectCompName" component in the component tree comes with it. Specify
the component name in the Override Text field.
NOTE: Connect macros only move components around. They do not
change the models in the components.
Example:
To have "M10" connect a component named "Stock" to a "U" axis
component, use the Configuration menu > Word/Address function to define
2 groups as follows:
Word=M Range=10, Macroname=ConnectCompName, Override Text=Stock
Word=M Range=10, Macroname=ConnectToCompName, Override Text=U
ConstantSurfaceSpeed Sets the Constant Surface Speed.
ConstantSurfaceSpeedMode Sets the current mode to Constant Surface Speed.
ConversionFinish Default event macro for the "End of Processing" event.
Typically, added event macros should be placed before this macro.
ConversionInit Default event macro for the "Start of Processing" event. Typically,
added event macros should be placed after this macro.
CoolantFlood, CoolantMist Sets the coolant type to "Flood" or "Mist" and
outputs"COOLNT/FLOOD" or "COOLNT/MIST", respectively.
CoolantOff, CoolantOn Turns off/on the coolant and outputs the APT
"COOLNT/OFF" or COOLNT/ON" statement, respectively.
CornerMode Defines the type of "auto-corner" to be generated, if any. Options
are: 0 - for NONE, 1 - for CHAMFER, and 2 - for RADIUS.
The auto-corner capability uses "look ahead" logic for both CHAMFER and
RADIUS. The resulting values are then passed on to cutter compensation logic.
Corner RADIUS is only supported in the XY, YZ, or ZX planes. If the specified
corner can not be achieved, a warning message is given and auto-cornering is
ignored for that corner.
CornerValue When in CHAMFER mode, this macro defines the length from the
programmed corner to the point at which the chamfer is to begin. In RADIUS

664
mode, this defines the radius to be used in the corner. The start and end points of
the arc will be calculated such that the arc is tangent to the cut coming into and out
of the arc. In both cases, the original corner (as defined in the tool path) must be
defined with two line segments.
CoupleAxisOn, CoupleAxisOff Controls "coupling" of two motion axes, where
commands to one axis drives both axes.
CoupleAxisOn is passed an override text value in the form: "X1 X2". The first
argument in the name of the master component, the second argument is the name of
the slave component. After this call is made, any time the master component moves
the corresponding delta movement will be applied to the slave. At this point, the
feature is very limited. A master can have only one slave. This feature is currently
only implemented for linear motions. Unpredictable results may occur if circle
records are processed while in this mode.
CoupleAxisOff cancels the coupling affect for the specified master component.
This macro is passed the master component name as the text value. After turning
the coupling off, the subsystem that was in a wait state while its corresponding
components were being moved, should then call UpdateAxisValues.
CurveFitOnOff Curve fitting can be selectively turned on and off by embedded
comments in the G-code file being processed. The embedded comments must
contain the exact text "TURN CURVE FIT ON" and "TURN CURVE FIT OFF".
This macro can also be used to toggle curve fitting. An Override Value of "1" turns
curve fitting ON and an Override Value of "0" turns curve fitting Off. To use this
macro, the text of two unique comments must be defined as a control words. The
CurveFitOnOff macro with an override is associated with the ON and OFF
message. CurveFitOnOff is ignored when curve fitting is not active.
CutterComp3d Turns on 3-D Cutter Compensation. See also: Tool3dXOffset,
Tool3dYOffset, Tool3dZOffset, Unitize3DVector, CutterCompOff
CutterCompDoubleLong Increases the movement amount by twice the tool offset
value. The offset will be applied to each axis in which there is movement. (not
modal) Also see: ShortLongOffsetReset
CutterCompDoubleShort Decreases the movement amount by twice the tool
offset value. The offset will be applied to each axis in which there is movement.
(not modal) Also see: ShortLongOffsetReset
CutterCompLeft Sets the cutter compensation to be Left. See also:
CutterCompRight, CutterCompOff
CutterCompLong Increases the movement amount by the tool offset value. The
offset will be applied to each axis in which there is movement. (not modal) Also
see: ShortLongOffsetReset
CutterCompOff Turns off the cutter compensation. See also: CutterCompRight,
CutterCompLeft, CutterComp3d
CutterCompOffLookAheadX, CutterCompOffLookAheadY,
CutterCompOffLookAheadZ Specifies where the next XYZ point is on the part
(not the next GOTO point). These macros are called while ramping off of cutter
compensation. These values are used to avoid gouging the part while ramping off.
Look ahead cutter compensation will use these values to determine if the previous

665
compensated point needs to be adjusted.
CutterCompOffsetValue Uses the passed in numeric value as an index into the
Cutter Compensation table. The corresponding value (singular) is used when
processing CDC short/long commands (e.g. G45-G48). For this macro to work, the
G45-G48 word/value pairs must be found in the control configuration ahead of the
XYZ registers. For example, try defining these word/addresses in the "States"
supergroup.
CutterCompRight Sets the cutter compensation to be Right. See also:
CutterCompLeft, CutterCompOff
CutterCompShort Decreases the movement amount by the tool offset value. The
offset will be applied to each axis in which there is movement. (not modal) Also
see: ShortLongOffsetReset
CutterCompSuspend Temporarily suspends radius compensation for one block.
Must be called with Process after Motion toggled "On". This macro was
implemented to support the Heidenhain M98 open contours function, but might
have other applications.
CutterCompToolNum Uses the current tool number to index into the Cutter
Compensation table. The corresponding value is used as the compensation amount
when CDC is turned on. See also CutterCompToolNumSubValue.
NOTE: The current tool number refers to the tool number that is specified
in the MCD file (T1M6, T0101, &), not to the Tool Id that is specified in the
TLS file which is a string.
CutterCompToolNumSubValue Uses the current tool number and the specified
SubValue (SubRegister) to index into the Cutter Compensation table. The
corresponding value is used as the compensation value when CDC is turned on. See
also CutterCompToolNum.
NOTE: The current tool number refers to the tool number that is specified
in the MCD file (T1M6, T0101, &), not to the Tool Id that is specified in the
TLS file which is a string.
CutterCompValue Uses the passed in numeric value as an index into the Cutter
Compensation table. The corresponding value (singular) is used when in cutter
compensation mode (e.g. G41, G42).
CutterCompValueDirect Sets the cutter compensation value to the input value.
The corresponding value is used as the compensation amount when CDC is turned
on.
CutWire Cut/remove the EDM wire. This will output a "LOADTL/0" statement.
CycleBoreShiftFlags The boring cycles support 5 areas in which a shift may
occur. These are:
Value 1 Value 2 Value 3 Value 4 Value 5
Prior to After After After After
beginning moving to moving to moving moving
the drill the R the back to back to
cycle plane "bottom" the R the retract
position plane position

666
This macro is passed 5 values (each representing one of the possible shift areas as
indicated above), separated by blank spaces, in the override text field. These 5
values specify whether a shift should occur, and the direction of the shift. 0 = No
Shift, 1 = Shift Positive Direction, -1 = Shift Negative Direction
For a simple boring cycle, the override text value might look like: 0 0 -1 0 1
For a back boring cycle, the override text value might look like: -1 1 -1 0 1
CycleBoreShiftValue This macro is passed a positive value corresponding to the
length of the shift that should be applied during boring cycles. This shift will occur
along the tools X axis (as defined in Tool Manager prior to any orientation matrix).
CycleBoreSpindleOnOffFlags This command specifies the spindle condition in
10 different positions. The positions are: either side of the shifts defined in the
CycleBoreShiftFlags macros.
For a simple boring cycle, the override text value might look like: 1 1 1 1 0 0 0 0 0
1
NOTE: This command will turn on and off the spindle that has been set
with the SpindleCompName macro.
CycleClearanceDistance Sets the cycle clearance distance. This overrides the
default control setting.
CycleDepth Sets the Cycle Depth value.
CycleDepthInvIf the Cycle Depth is to be interpreted as an absolute value, the
Cycle Depth value is set to the input value. If the Cycle Depth is to be interpreted
as an incremental value, the Cycle Depth value is set to the negated input value.
CycleDepthType Specifies how the Cycle Depth is to be interpreted. 1= Absolute
value, 2= Incremental value, 3= G-Code dependent.
CycleDwellTime Sets the dwell time for a cycle. Dwell time is measure in
revolutions or seconds (dependent on the feed mode).
CycleIgnore Sets a flag which causes the cycle to not be executed on the current
block.
CycleIncDepthType Sets how an incremental Cycle Depth value is to be
interpreted. 1= Relative to the Rapid Level, 2= Relative to the Initial Level, 3=
Relative to the Part Surface.
CycleIncRapidType Sets how an incremental Cycle Rapid value is to be
interpreted. 1= Relative to the Rapid Level, 2= Relative to the Initial Level, 3=
Relative to the Part Surface.
CycleInitialOnMotion Specifies whether the cycle "Initial Point" should be
initialized on each motion. 0= FALSE, 1= TRUE. (Default: FALSE).
CycleMillPocketAngle Sets the rotation angle in degrees with respect to the
positive X-axis for a rectangular pocket.
CycleMillPocketBottomAllowance Sets the amount of bottom stock to remain
after roughing motions. The remaining bottom stock is removed during finishing
motions.See also: CycleMillPocketSideAllowance
CycleMillPocketBottomZ Sets the depth for the pocket specified by a Z-axis
position.
CycleMillPocketBoundarySub Sets the subroutine number used to define the

667
pocket's boundary. The macro CycleMillPocketType must be used with an override
value of 2 when a subroutine defines the pocket boundary.
CycleMillPocketCenterX, CycleMillPocketCenterY Sets the center (or drill
hole) location for a rectangular or circular milled pocket.
NOTE: Controls that use the current tool location for the pockets center do
not need to reference these macros.
CycleMillPocketCornerRadius Sets the corner radius for a rectangular pocket and
the major radius for a circular pocket. Default is tool radius.
CycleMillPocketCutDirection Sets the cut direction for conventional or climb
milling. Also sets cut direction for circular pockets to CLW or CCLW. An
Override Value of 0 or 2 selects conventional or CLW direction. An Override
Value of 1 or 3 selects climb or CCLW direction. Some controls use the sign of the
stepover to define the cutting direction. For these controls, use an Override Text of
SIGN to set the direction as CLW when the value is positive and CCLW when the
value is negative.
CycleMillPocketCutType Sets the type of motions for the pocket. Use an
Override Value of 0 for a lacing pattern (climb and conventional), 1 for single
direction conventional cuts with retracts between cuts, 2 for a lacing pattern with
finish cuts, 3 for an inside-out pattern, and 4 for finish bottom and sides (no
roughing).
NOTE: Use macro SiemensCycleMillPocketCutType for Siemens controls.
CycleMillPocketDepth Sets the relative depth for the pocket from top of the stock
to bottom of the pocket.
CycleMillPocketFinishFeed Sets the cutting feedrate for finishing pocket motions.
Defaults to 1/2 the roughing feedrate.
CycleMillPocketFinishStepover Sets the X or Y in-feed between finishing pocket
cuts.
CycleMillPocketInsideRadius Sets an inside radius for circular pockets when a
pre-drilled hole at the pocket center is used. Default is zero.
CycleMillPocketLength Sets the length along the X-axis for a rectangular milled
pocket.
CycleMillPocketMaxCutDepth Sets the maximum in-feed depth for each pocket
level until final pocket depth is reached.
CycleMillPocketPlungeFeed Sets the in-feed feedrate along the Z-axis for
plunging into the material.
CycleMillPocketRefPlane Sets the absolute Z-axis position for the top of the
pocket stock.
CycleMillPocketRetractPlane Sets the absolute Z-axis position where cycle
motions will start and end.
CycleMillPocketRoughFeed Sets the cutting feedrate for roughing pocket
motions. Defaults to last feedrate in effect when cycle is called.
CycleMillPocketSafeDistance Sets the distance above the pocket stock to the
retract plane.
CycleMillPocketSideAllowance Sets the amount of side stock to remain after

668
roughing motions. The remaining side stock is removed during finishing motions.
See also: CycleMillPocketBottomAllowance
CycleMillPocketSpeed Sets the spindle speed used with the pocket cutting
motions.
CycleMillPocketStepover Sets the X or Y in-feed between roughing pocket cuts.
When used with a Override Text of PERCENT, the value passed is defined as a
percent of the tool diameter and the stepover is calculated as a percentage of the
current tool diameter. Use a Text Overide of X or Y with the HAAS control to
define the cut stroking direction.
CycleMillPocketType Selects the type of pocket and processes the cutting
motions.
The Override Value should be zero (0) for rectangular, one (1) for circular, or two
(2) for when the boundary is defined in a subroutine. The CycleMillPocketType
macro must be called after all other pocket parameter macros have been called. The
HAAS control uses a subroutine to define the pocket boundary. Use an Override
Value of two (2) for the HAAS control.
Use an Override Text value of "AS_COMMANDED" to execute the pockets from
a "CALL CYCL"command. The default for the CycleMillPocketType macro is to
execute the pocket when this macro is processed. When the override is present, the
cycles are later executed AS_COMMANDED. See Notes about simulating
Heidenhain SL pocket cycles for additional information.
CycleMillPocketWidth Sets the width along the Y-axis for a rectangular milled
pocket.
CycleMotionPlaneCheckOnOff This macro turns on and off the error checking of
the tool axis being along the Z-axis of the local plane when a cycle is executed.
NOTE: Not all controls require this. Therefore, this error checking must be
turned on. By default, it is off.
CyclePresentAxis Similar to CirclePresentAxis. This macro sets a flag which
specifies whether or not to use the axis present on the cycle command as the motion
axis.
If set to 0 (the default), the X, Y, and Z axes will always be used (with the
exception of ZW tracking). The tracking whether the U or V axis is present for the
cycle is initialized to not-present during reset and whenever a cycle command is
specified.
If set to 1, the axis present on the cycle command will be used for initial point, part
surface calculations, square off, and pecking motions.
CycleRapidLevelInitial Similar to CycleRapidLevelValue, except that the value is
specified by the current X, Y, or Z axis value, depending on the current plane.
CycleRapidLevelInv Similar to CycleRapidLevelValue, except that the value is
negated if the rapid value is to be interpreted as incremental.
CycleRapidLevelKeep This macro is called to apply the cycle rapid level instated
via the CycleRapidLevelValue macro (see above) to cycles executed on command.
This macro must be called during initialization ("Start of Processing" event).
CycleRapidLevelValue Set the R point level.

669
CycleRapidLevelValueMult Similar to CycleRapidLevelValue, except that the
incoming value will be multiplied by the X/Y/Z multiplier, depending on the
current G17,18,19 state.
CycleRapidLevelZeroTracking Similar to CycleRapidLevelValue, except that it
applies to zero-tracking machines.
CycleRapidType Specifies how the Cycle Rapid value is to be interpreted. 1=
Absolute value, 2= Incremental value, 3= G-Code dependent..
CycleRetractInitial Sets the retract level position based of the current X, Y, or Z
position (depending on the current plane).
CycleRetraction Set the Cycle Retract value. This is typically used when the
retract level is an incremental distance from the clearance plane.
CycleRetractSpecifiedpoint Sets the retract level position to be the specified
value, independent of the current plane.
CycleRetractSpecifiedZT Similar to CycleRetractSpecifiedpoint, except that it
applies to zero-tracking machines.
CyclesBore Sets the cycle type to Bore.
CyclesBoreDrag Sets the cycle type to Bore Drag.
CyclesBoreOrient Sets the cycle type to Bore Orient.
CyclesCancel Cancels the cycle mode.
CyclesDeep Sets the cycle type to Deep.
CyclesDrill Sets the cycle type to Drill.
CyclesExecute Executes a single cycle (MAHO) based on cycle parameters that
were set by data in preceding blocks. Requires the Cycle Execute=As
Commanded cycle setting (ref. Configuration menu > Control Settings: Cycles
tab).
NOTE: If a value of 1 is passed to the macro,it will interpret the non-plane
axis as modal. This means, if you are in the XY plane, and Z is not specified
on the current block, then it will use the Z value from the last time
CyclesExecute was called.
CyclesExecuteModal Toggles the Cycle Execute control setting (ref.
Configuration menu > Control Settings: Cycles tab) and allows the square-off
motions to adjust the cycle part surface correctly before positioning to the X-Y
cycle point. When called with an Override Value of "0" and "Process After
Motion" set to No, the system uses square-off motions to move to the cycle
position. After the cycle is executed the Cycle Execute control setting should be
reset by calling CyclesExecuteModal a second time with an override value of "1"
and "Process After Motion" set to Yes.
NOTE: If X, Y or Z movement is not part of the block, the system
automatically executes the CyclesExecute macro instead.
CyclesExecuteOnMotionOnOff Toggles the Cycle Execute control setting (ref.
Configuration menu > Control Settings: Cycles tab) between "As Commanded" and
"On Motion". When called with an Override Value of "0" the system is set to "As
Commanded" mode, and when called with an Override Value of "1" the system is
set to "On Motion" mode. This macro allows the Cycle Execute mode to be

670
changed for all future blocks until changed again or the job is reset.
NOTE: The CyclesExecuteModal macro also toggles the Cycle Execute
control setting, but was designed for use with a single block.
CyclesFace Sets the cycle type to Face.
CyclesMill Sets the cycle type to Mill.
CyclesTap Sets the cycle type to Tap.
CycleStepUpValue Sets the Cycle Step Up value. Use in cycle "Deep" mode.
CycleStepValue Sets the Cycle Step Down value. Use in cycle "Deep" mode.
CyclesThru Sets the cycle type to Thru.
CycleSubroutineOff, CycleSubroutineOn Turns on and off the calling of the
specified subroutine on every motion, respectively. The name of the subroutine
may either be numeric or text, based on the Type of Subroutine Names control
setting.
CycleSubroutineOnNoMotion Same as CycleSubroutineOn, except doesn't
automatically turn motion on for the current block.
CycleTurnAllowanceX, CycleTurnAllowanceZ Specifies the offset along the X
and Z axes after roughing for finish allowance stock. Sets the finish allowance for
threading. This macro is also used for roughing canned cycles.
NOTE: The offset represented by CycleTurnAllowanceX is a "radius"
value.
CycleTurnCutDepth Specifies the cut depth for each roughing pass. This macro is
also used with grooving cycles to specify the cut peck depth.
CycleTurnEndSeq Specifies the sequence number of the last motion block used to
define the work shape profile being cut by the turning cycle.
CycleTurnFeed Specifies the feedrate to be apply to the expanded motions of a
"roughing" turning cycle. A "Finish" turning cycle uses the speeds and feeds that
are included on the motions blocks defining the cycle's profile.
CycleTurnFinalX, CycleTurnFinalZ Used to define a final X and Z axis position
after the cycle is executed. (Not required by most controls)
CycleTurnFinish Selects a single pass alone the turning cycle profile to finish the
profile. Normally called after a rough cut cycle to avoid programming the profile
twice. "Tool Nose Compensation" is used if Override Value = 1.
CycleTurnGroove Selects O.D./I.D. grooving cycles or a cut-off cycle.
CycleTurnGrooveAngle Specifies the amount of slope for a grooving cycle with
an angled bottom.
CycleTurnGrooveDepth Defines the bottom of the groove. (Either an X value for
I.D./O.D. grooves or a Z value for facing grooves). This is not the cut or peck
distance defined by CycleTurnCutDepth.
CycleTurnGrooveEnd Defines the bottom of the groove. (Either an Z value for
I.D./O.D. grooves or an X value for facing grooves).
CycleTurnGrooveEscape Allows a small side movement at the bottom of a
grooving plunge before the retract. Note that the manual cautions this can only be
used when the stock geometry allows it.

671
CycleTurnGrooveFace Selects face cut-off, face grooving, and deep hole drilling.
CycleTurnGrooveRelief Retract distance after each cutting peck motion during
groove cycles. Some NC controls define this value as a controller word. It can be
set as an override value in VERICUT (during "Start of Processing" event).
CycleTurnGrooveStep Groove step-over distance between plunge motions when
width of groove exceeds the tool width. Note that this normally a different word for
I.D./O.D. grooves and facing grooves.
CycleTurnLoopCount The loop cycle repeats a sequence of cut motions while
feeding into the stock until the loop count is completed. Use this macro to set the
number of times the motions are offset and repeated. The total stock in the along
the X and Z axis for closed loop rough cutting are defined using the
CycleTurnStockX, CycleTurnStockZ macros.
CycleTurnRetractX, CycleTurnRetractZ This macro uses an override value to
set the delta retract move in the X and Z direction for the expanded cycle. This
normally an internal NC control variable. Therefore, to simulate call once during
the "Start of Processing" event.
CycleTurnRoughCut Selects a turning cycle for roughing using a cutting pattern
parallel to the turning axis. "Tool Nose Compensation" is used if Override Value
= 1.
CycleTurnRoughFace Selects a turning cycle for roughing using a cutting pattern
normal to the turning axis. This is commonly called traverse cutting or facing.
"Tool Nose Compensation" is used if Override Value = 1.
CycleTurnRoughLoop Selects a turning cycle that offsets and repeats the turning
profile a given distance and number of times. Often called closed loop roughing.
"Tool Nose Compensation" is used if Override Value = 1.
CycleTurnSpeed Specifies the spindle speed to be apply to the expanded motions
of a "roughing" turning cycle. A "Finish" turning cycle uses the speeds and feeds
that are included on the motions blocks defining the cycle's profile.
CycleTurnStartBlank Specifies the first block sequence number for the motions
defining the stock geometry.
CycleTurnStartSeq Specifies the first block sequence number for the program of
finishing the work shape.
NOTES:
1. Scanning must be set when the turning cycles reference sequence
numbers. (Ref. Project menu > Processing Options > G-Code >
Settings: Settings tab: Scan Toolpath Files)
2. The NUM control should use the NumSequence macro for the start
and end sequence numbers. This allows the format N1 G64 N2 N3 ...
Where N2 defines the start and N3 defines the end sequence number.
3. The Okuma control should use the OkumaCondNWord function with
defined words: N, N_GOTO_LABEL, N_GOTO_SEQ and
N_LABEL.
CycleTurnStockX, CycleTurnStockZ Allows an additional offset in the X and Z
direction for clean-up stock machined by the roughing cycle after the roughing

672
passes. Also used to define the total stock being removed by a
CycleTurnRoughLoop cycle.
CycleTurnThread Sets the turning cycle type to threading. The current position is
used as the threading start point. When X and/or Z words are included on the block
they define the endpoint of the thread. When U and/or W words are included on the
block, the associated U-W values are interpreted as signed incremental values from
the start point to the end point. The XaxisIncreMotion and ZaxisIncreMotion
macros must be called when U and W are used to define the thread endpoint.
y No override = execute all threading passes with retracts and returns to cycle
start position.
y Override = 1, execute only the final thread pass with retract and return to
the cycle start position. This is typically used with a G92 word address.
y Override = 2, execute only the final thread pass and suppress retract and
return to the cycle start position. This is typically used with a G32 or G33
word address.
y Override = 4, should be used with the Fanuc G92 single pass thread cycle.
This override causes the G92 threading cycle to remain active allowing
additional blocks of the G92 cycle to be simulated until canceled by another
G-code.
See also: Notes about simulating lathe threading in the Using VERICUT section.
CycleTurnThreadAngleTaper Specifies the taper applied to threads.
CycleTurnThreadFinish Specifies the quantity of finish passes. If not specified,
default is to make one pass.
CycleTurnThreadFirstCut Depth of first threading cut (radius value).
CycleTurnThreadHeight Thread height (radius value).
CycleTurnThreadLead When used on a threading block the feed value defines the
thread lead distance.
CycleTurnThreadMinCut Minimum depth of cut. A modal value used to limit the
number of passes specified at startup or in the threading block. Default is 10% of
the thread height.
CycleTurnThreadTaper Specifies the distance of taper in X-axis direction (signed
value, radius).
CycleUvDepthSimilar to CycleXyzDepth. This macro, if passed a value of 1,
allows UAxisMotion and VAxisMotion to interpret its value as a depth value,
rather than a motion value. The default is 0 (UAxisMotion and VAxisMotion are
interpreted as motion).
CycleXyzDepth Specifies whether or not X,Y, or Z is used to specify cycle depth.
0= NO, 1= YES.
CycleZeroTrackingAdjOnOff Sets an on/off flag specifying whether the cycle
part surface calculation should be adjusted based on ZW Zero tracking. This was
specifically implemented for Siemens 840D version of ZW Zero tracking cycles. 0
= Don't adjust, 1 = Adjust for Zero tracking.
CylindricalDiameter This macro sets the diameter that will be used while
Cylindrical Interpolation is On. This parameter is required. Various controls will

673
specify various values (radius, diameter, conversion factor, or nothing). Whatever
is specified, it needs to be converted to a diameter, and then passed to this macro
via the "Override Value" field.
CylindricalInterpolation This macro is used to turn Cylindrical Interpolation On
and Off. When On, the INTERPOLATION STATE is set to CYLINDRICAL.
Cylindrical Interpolation is used to cut a 2D planar shape along the outside of a
cylinder at a constant depth using a rotary and a linear axis. The programmed input
may be two linear or one linear and one rotary axis. In this mode, both linear and
circular moves are supported. Cutter Compensation is also supported. A value of 0
turns this mode off, any other value turns this mode on. Typically the VERICUT
control must be configured to call standard macros at the correct time with the
correct values when Cylindrical Interpolation is On.
NOTES:
1. It is critical to also set the proper motion plane. Typically, the motion
plane will be either XY or YZ.
2. The "interpolation" state (None, Polar, or Cylindrical) is supported as
a conditional state, and can be displayed in the Status window.
CylindricalLinearAxis This macro specifies the "virtual" linear axis which will be
"wrapped" around the cylinder while Cylindrical interpolation is On. Valid values
are 1, 2, and 3. These values correspond to X, Y, and Z. The default is 2. If used,
this macro should be called under Events, Start of Processing. This macro is used in
conjunction with CylindricalRotationalAxis which specifies the rotary axis that will
be actually making the "virtual" linear axis motions. Typically, this macro will
never need to be called.
CylindricalRotationalAxis This macro specifies the rotary axis that will be
actually making the "virtual" linear axis motions while Cylindrical Interpolation is
On. Valid values are: 4, 5, 6, 10, 11, and 12. These values correspond to the A, B,
C, A2, B2, and C2 axis. The default is 6. If used, this macro should be called under
Events, Start of Processing. This macro is used in conjunction with
CylindricalLinearAxis. Typically, this macro will not need to be called unless there
is a sub-spindle.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
Debug Renamed to DebugMacro.
DebugMacro Debugging macro that prints the corresponding word, the string
associated with the value, and the value to the DEBUG destination.
DefaultWire Sets the current tool number to be the default wire EDM tool number.
DefineCsys This macro defines a coordinate system (CSYS). The text argument
contains the name of the CSYS followed by the name of the component to attach
the coordinate system to, followed by the 12 numeric values defining the matrix for
the coordinate system. The order of the values are: i j k x i j k y i j k z

674
Example:
Create the following lines in the mcd file:
(DEFINE_CSYS "csys1 Stock 1 0 0 -7.95 0 1 0 0 0 0 1 2.25"
(DEFINE_CSYS "csys2 Stock 1 0 0 -7.95 0 -1 0 0 0 0 -1 -.7"
Create the word "(DEFINE_CSYS" which expects an alpha-numeric
argument.
When "(DEFINE_CSYS" is encountered, the DefineCsys macro is called.
This example results in two new coordinate systems, called csys1 and
csy2,are created. Both are attached to the Stock component, with values
identical to position1 and position2 of the standard VERICUT part.
DefineDashAsAlphaNumeric Defines whether or not the dash character is to be
interpreted as an alphanumeric character. Default is no. A value of 1 causes a dash
to be interpreted as an alphanumeric character. If needed, this macro would
typically get called during Start of Processing. Defining the dash character as an
alphanumeric character will only effect words which are define to have an
alphanumeric argument.
DisableWorkShiftOffsets Disables the current Work and Shift offsets. The current
values are saved, and can be enabled via a call to EnableWorkShiftOffsets.
DoLoop Sets the input file locations of the do loop. During the first pass, the
locations are saved. During the second pass, the locations are restored. There is no
limit for the number of do-loops permitted within a G-code program.
This command is used with WhileLoop to process a "while/do" loop of the form:

While (expression) DO1


.
.
.
END1

The following Word Formats should be defined:

WHILE, DO and END should be defined as a word of Type = "Macro", Sub Type
= "Numeric".
() represent words of type left and right precedence.

Entries should be defined for WHILE, DO, and END in the Word/Address table as
illustrated below :

675
Dwell Renamed to DwellMacro.
DwellMacro Causes a dwell to occur. Typically called by G04, this macro must be
called after the DwellTime macro. Dwell length is determined by the DwellTime
variable value and the current feed mode (IPM/MMPM, IPR/MMPR):
DwellRevolutions Similar to DwellMacro, except the dwell time value is always
interpreted as revolutions.
DwellSeconds Similar to DwellMacro, except the dwell time value is always
interpreted as seconds.
DwellTime Sets the dwell time variable. Typically called by the "X" word when a
G04 is in the block, the dwell time variable is interpreted differently depending
upon the macro called after DwellTime:
DwellMacro seconds in IPM/MMPM mode, revolutions in IPR/MMPR
mode
DwellRevolutions always revolutions
DwellSeconds always seconds
DynamicWorkOffsets Controls when "dynamic work offsets" are applied (e.g.
G54.2). When called with an Override Value of "1", work, shift, and Program
Zero offsets are rotated based on the rotation that is applied to the stock. An
Override Value of "0" will turn this feature off.
Warning: If the offset is non-relational (not specified with From/To locations),
then the entire amount of the offset will be rotated. This behavior will only work if
the offset is being measured from the center of the rotary on the part side. This
limitation does not apply to relational offsets.
DynamicWorkOffsetsContour Controls the dynamic work offset mode:
contouring vs. non-contouring. When passed an OverrideValue of "1", puts the
dynamic work offsets in contouring mode. A value of "0", puts the dynamic work
offsets in non-contouring mode. The default is contouring.
NOTE: This command is dependent on dynamic work offsets being turned
on using the DynamicWorkOffsets macro.

676
DynamicWorkOffsetsLocalCoord Controls the coordinate system in which work
offsets are dynamically rotated. When called with an Override Value of "1",
dynamic work offsets are rotated based on the rotations specified within the local
coordinate system. When passed a value of "0" (default), dynamic work offsets are
rotated based on the actual rotation of the stock component.
NOTE: This command is dependent on dynamic work offsets being turned
on using the DynamicWorkOffsets macro.
DynamicWorkOffsetsTypes Determines which work offsets should be
dynamically rotated. When passed an OverrideValue of "1", turns on the
capability for the given work offset. A value of "0" turns off the capability for the
given work offset. The possible work offsets include: "BASE", "WORK" (Base and
work), "WORK_ONLY", "SECONDARY" (Secondary work offset), "SHIFT",
"PZ" (Program Zero), and "ALL". The type of work offset should be specified in
the OverrideText field. A separate call is required for each setting.
NOTES:
1. This command is dependent on dynamic work offsets being turned on
using the DynamicWorkOffsets macro.
2. The default is "On" for all types except for Program Zero.
DynamicWorkOffsetsWithMotion When passed an OverrideValue of "1",
causes the offsets to only take effect when the corresponding axis is specified. A
value of "0", causes the offsets to take effect immediately. For the most part, this
macro is only applicable when in non-contouring mode. The default is 1.
NOTE: This command is dependent on dynamic work offsets being turned
on using the DynamicWorkOffsets macro.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
EDMCalcUpperGuideHeight Causes the upper wire guide height to be
recalculated based off of changes to the EDMLower2Reference height,
EDMReference2Upper height, or the distance between the guides.
EDMCalcUpperGuideLocation Causes the position for the upper wire guide to be
recalculated based off of changes to the EDMLower2Reference or
EDMReference2Upper heights. This will actually cause a change in the position of
the upper guide. Typically this macro would not be used in Wire EDM.
EDMGuide2Guide Adjusts the Z component and upper wire guide height when
the Z value specifies the distance from the lower to upper guides.
EDMLower2Reference Specifies the distance from the wire EDM table top to the
XY plane.
EDMLowerGuideHeight Specifies the distance from the lower wire guide to the
top of the table.

677
EDMReference2Upper Specifies the distance from the wire EDM XY plane to the
UV plane.
EDMUpperGuideHeight Specifies the distance from the UV plane to the upper
wire guide.
ElseBlock Use to define an "ELSE" or "ELSE_IF" condition within an "IF" block
of code. For an "ELSE_IF" condition, specify the expression that is to be
evaluated to determine if the block is to be executed. For an "ELSE" statement,
specify an Override Value of 1. Process during Scan must be set to "Yes" for
this macro. Also see: IfBlock, EndIfBlock
EnableWorkShiftOffsets Enables the previously disabled work shift offset. See
DisableWorkShiftOffsets.
EndIfBlock Use to define the end of an "IF" block of code. Process during Scan
must be set to "Yes" for this macro. Also see IfBlock, ElseBlock.
EndLabelLoop Used to define a label name that marks the end of a label loop.
Action is only taken if the code is currently processing a label loop. If additional
loops are to be executed, control branches to the start of the loop. Otherwise control
branches to the line following the REPEAT command. Currently, this is only
implemented with the Sin840D REPEAT command. This command would
typically get called during the Start of Processing event. (See "Notes about the
Siemens 840 CASE and REPEAT commands")
EndLoop Sets the input file locations of the end of a do loop. During the first pass,
the locations are saved. During the second pass, the locations are restored.
EndProgram During the scan pass, this macro marks the current location as the
end of the current program. During the run pass, this macro will cause processing
to stop, will set a flag indicating that the end of program has been reached, and will
output the APT "FINI" statement.
EndProgramRewind During the scan pass, this macro marks the current location
as the end of the current program. During the run pass, this macro will output an
APT "REWIND" statement and call the EndProgram macro.
EndProgramRewindSpecial This macro is identical to EndProgramRewind except
it allows you to branch beyond the end of the program.
EndSub During the scan pass, the macro will cause the current location to be
marked as the end of the subroutine. This will prevent any branching from within
this subroutine to branch beyond this point. During the run pass, this macro will
cause a return from the current subroutine.
NOTE: If you do not want to mark the current location as the end of the
subroutine, make sure the Process during Scan is not toggled "On".
See SubroutineSequenceEnd as an alternative way to mark the end of a subroutine.
Enhanced5AxisLogicOnOff This macro turns On / Off the enhanced 5 axis logic
that was added to V5.4.4. The default is On. A value of 1 turns it on, and a value of
0 turns it off. This logic should only be turned off if the new logic is causing a
problem, or if the new logic is causing a significant slow down in performance.
ErrorMacro Creates an error message using the input text string value supplied
via the Override Text field. See Override Text in the Add/Modify Word/Address

678
window for information on using "expresssions" in the Override Text field.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
FadalLcode If less than 100, the value sets the loop count. If the value is an even
multiple of 100, it defines the beginning of a subroutine. Otherwise it is a call to a
subroutine, with the last 2 digits being the loop count.
FadalWorkCoord For Fadal, E54 is the same as E1. Therefore if the value is
greater than 53, 53 is subtracted from the value.
FanucRotationPlaneLocal2 Implemented to support the Fanuc G68 with IJK
vectors. This macro calculates a rotation matrix based on the following:
1. Rotation about an axis. The axis specified with calls to Ivector, Jvector, and
Kvector.
2. The center of rotation specified with RotationPlaneXPoint,
RotationPlaneYPoint, and RotationPlaneZPoint.
3. The angle specified with RotationPlaneAngle1.
The specified rotation is based on the current coordinate system. The current XYZ
position is automatically recalculated based on the new coordinate system. This
macro uses the standard rotation plane capabilities within VERICUT, and therefore
can be cancelled in the standard way (RotationPlaneCancel2).
FanucToolLengthComp Implements a Fanuc-style G43/G44 tool length
compensation. This macro would typically get called with the G43/G44
word/addresses. For G44, an override value of -1 should be passed. This macro
applies the previously set compensation amount to the axis specified on the block.
FanucToolLengthComp does not consider the current tool axis orientation
ToolLengthCompPos and ToolLengthCompNeg. It applies the MCH axis specified
in the block.
When X and/or Y are also specified in a G43 block with Z, FanucToolLengthComp
DOES NOT apply to the Z-axis, but to the first axis specified in the block.
FanucToolLengthCompAxisOn This macro turns on special Fanuc G43.1
handling, and initializes the corresponding offset. ToolLengthCompOff will cancel
the offset, and take you out of the special G43.1 mode.
FeedInvTime Sets the feedrate based on the input value (InverseTime). The
Feedrate will be calculated based on the formula: Feedrate = Distance *
InverseTime.
FeedInvTimeModalMultiplier Specifies a multiplier that is to be applied to the
value specified with the FeedInvTime macro. (Default = 1.0). This macro is
identical to FeedInvTimeMultiplier except the value being set is modal. If a value
other than 1.0 is set for both the modal and non-modal versions of this macro, the
non-modal version will take precedence.
FeedInvTimeMultiplier Specifies a multiplier that is to be applied to the value

679
specified with the FeedInvTime macro. (Default=1.0)
FeedInvTimeSec Similar to FeedInvTime, except that the units are in 1/seconds
rather than 1/minutes.
FeedModeMinute Sets the feed mode to Feed per Minute. This macro only sets
the feed mode. Use FeedPerMinute to set the feedrate "value".
FeedModeRevolution Sets the feed mode to Feed per Revolution. This macro only
sets the feed mode. Use FeedPerRev to set the feedrate "value".
FeedModeTime Sets the feed mode to Inverse Time. The Feedrate will be
calculated based on the formula: Feedrate = Distance * InverseTime.
FeedPerMinute Sets the feedrate based on the input value. The units will be either
IPM or MMPM. This macro only sets the feedrate "value". Use FeedModeMinute
to set the feed mode.
FeedPerMinuteType 5 axis motions often have special calculations for feed. This
macro allows the user to select which calculation type to use (specified with an
override value). This calculation type will only be used when interpolating (non-
rapid mode), and the feed mode is set to units per minute. Type 0 is the default.
This value is modal.
0: Treat the feedrate as a real units per minute feedrate. The actual distance being
travelled will be used for the time calculation.
1: This calculation treats all rotary tables as if they are linear, and calculates the
time for the motion accordingly. For example: on the block G91 X100 A90
F50, the time to execute the block would be sqrt((100*100) + (90*90))/50.
Stated another way:
If only linear axis moves, treat the feedrate as inches/mm per minute
If only a single rotary moves, tread the feedrate as degrees per minute
If linear and rotary axis moves, or if multiple rotaries move, treat all axis
as if they were linear.
2: The interpretation of the feedrate will be dependent on the type of motion on
the block
If only linear axis moves, treat the feedrate as inches/mm per minute.
If only rotaries axis move, treat the feedrate as degrees per minute. The rotary
moving the longest distance will determine the time for the block.
If both rotary and linear axis move, ignore the rotary motion in the time
calculation. The rotary axes will then move at a proportional rate so that
they finish the motion at the same time as the linear axes.
3: A new FeedPerMinuteType (3) for this version of the 840D control.
If only linear motions exist, treat the feedrate as a normal inches/mm per
minute.
If rotary's exist, treat the feedrate as degrees per minute, and ignore any linear
motion on the block as far as feedrate and time calculations.
Calculations are based on the largest rotary delta.
FeedPerRev Sets the feedrate based on the input value. The units will be either
IPR or MMPR. This macro only sets the feedrate "value". Use
FeedModeRevolution to set the feed mode.

680
FeedRate Sets the feedrate based on the input value. It will use the previously set
feedrate mode to output the corresponding units.
Fidia_ConvInit Initializes the Fidia specific rotation axis and center to 0.0.
Fidia_Rotate Turns on the Fidia specific rotation using the values set with the
Fidia_Rotate[XYZ]Axis and Fidia_Rotate[XYZ]Point commands. Also see:
Fidia_Rotate2
Fidia_Rotate2 This macro is identical to the Fida_Rotate command except it also
converts the current position into the new coordinate system.
Fidia_RotateCancel Cancels the rotation plane put into affect via the Fidia_Rotate
or Fidia_Rotate2 macros.
Fidia_RotateCancel2 Calls RotationPlaneRestoreAxis, and then cancels the
rotation plane put into affect via the Fidia_Rotate or Fidia_Rotate2 macros.
Fidia_RotateXAxis, Fidia_RotateYAxis, Fidia_RotateZAxis Sets the Fidia
specific X,Y,Z rotation values respectively.
Fidia_RotateXPoint, Fidia_RotateYPoint, Fidia_RotateZPoint Sets the Fidia
specific point of rotation of the X,Y,Z coordinate respectively.
ForEndLoop Use to mark the end of a "FOR" loop. Used with ForLoop. Process
during Scan must be set to "Yes" for this macro. Also see: ForToValue
ForLoop Use this macro to define a "FOR" loop. This macro expects a variable
assignment to follow. This variable will be used and compared against the "TO"
value (specified with ForToValue) to determine whether to continue in the loop.
When the value of the variable is no longer less than or equal to the "TO" value,
control will jump to the block after the "ENDFOR" block (specified with
ForEndLoop). Process during Scan must be set to "Yes" for this macro.
This command is used to process a "For" loop of the following form:

TEETH=2
FOR TOOTH = 1 TO TEETH
.
.
.
ENDFOR

The following Word Formats should be defined:

TEETH and TOOTH should be defined as words of Type = "Special", Sub Type =
"Variable Name".
FOR and ENDFOR should be defined as words of Type = "Macro", Sub Type =
"None".
TO should be defined as a word of Type = "Macro", Sub Type = "Numeric".

Entries should be defined for FOR, TO and ENDFOR in the Word/Address table as
illustrated below :

681
ForToValue Use to set the "TO" value which is used with ForLoop. Also see:
ForEndLoop

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
G65ResetVarsOnLoop Defines whether the local variables should be reset when
looping on a G65 call. The default is yes. A value of 1 turns on the resetting. Any
other value turns off the resetting. This macro would typically be called during
Start of Processing.
GageOffsetAttributes Defines attributes associated with the
GageOffsetDrivenPoint macro. The text override argument is used to set nine
values (default 100000100, where 1 represents TRUE and 0 represents FALSE):
The attributes are:
Set the gage offset to zero if the Driven Point ID is zero. Default = TRUE
Set the gage offset to zero and produce an error if the Driven Point ID does not
match the active Tool ID. Default = FALSE
Ignore the Driven Point ID. Use the first driven point if it exists. Default =
FALSE
If the Driven Point ID is being specified:
4. Set the gage offset to zero if a matching Driven Point ID does not exist.
Default = FALSE

682
5. Set the gage offset to zero if a matching Driven Point ID does not exist and
Driven Point Id’s exists for this tool. Default = FALSE
6. Produce an error message if a matching Driven Point ID does not exist.
Default = FALSE
7. Produce an error message if a matching Driven Point ID does not exist, and
Driven Point Id’s exists for this tool. Default = TRUE
8. Produce a warning message if a matching Driven Point ID does not exist.
Default= FALSE
9. Produce a warning message if a matching Driven Point ID does not exist,
and Driven Point Id’s exists for this tool. Default FALSE
GageOffsetDrivenPoint Sets the gage offset amount for the current tool loaded in
the active tool. The amount of offset is the difference between the Gage Point and
the Driven Point saved with the tool in the tool library. Each tool in the tool library
can have multiple Driven Point records, each with a unique ID. The ID is input as a
text string, but is typically a numeric value. The numeric argument passed to this
macro will be used to match the Driven Point ID in the tool library.
For example, if H calls GageOffsetDrivenPoint with an argument of 15, then the
value of Driven Point ID "15" is used in the calculation of the gage offset amount.
Gage OffsetDriven Point does not use the Gage Offset Table, it only uses the
calculated gage offset amount from the tool library file. If the Driven Point ID can
not be found, the Driven Point location is assumed to be at the tool's origin. Hence
the gage offset amount is equal to the tool's Gage Point value. If the numeric
argument is zero (for example, "H0" in the NC program), the gage offset amount is
set to zero.
See "Notes about Gage Offset and Cutter Compensation" in the Using VERICUT
section for additional information.
NOTE: GageOffsetDrivenPoint works with alpha-numeric Tool ID's and
numeric Driven Point ID's.
GageOffsetFirstDrivenPoint Sets the gage offset amount for the current tool
loaded in the active tool. The amount of offset is the difference between the Gage
Point and the first Driven Point saved with the tool in the tool library. Typically, no
arguments are passed to this macro.
For example, if H calls GageOffsetFirstDrivenPoint, then the first Driven Point for
the tool is used in the calculation of the gage offset amount. If "MATCHING" is
passed as the text argument, then the above will be done only if the current tool id
matches the numeric argument passed.
Gage OffsetFirstDriven Point does not use the Gage Offset Table, it only uses the
calculated gage offset amount from the tool library file. If the Driven Point ID can
not be found, the Driven Point location is assumed to be at the tool's origin. Hence
the gage offset amount is equal to the tool's Gage Point value. If the numeric
argument is zero (for example, "H0" in the NC program), the gage offset amount is
set to zero.
See "Notes about Gage Offset and Cutter Compensation" in the Using VERICUT
section for additional information.

683
NOTE: Gage OffsetFirstDriven Point works with alpha-numeric Tool
ID's and numeric Driven Point ID's.
GetCurrentDate Creates a control variable specified by the Override Text string
and saves the computer system's date into it. The date is saved as an integer value
in "yyyymmdd" format. If the specified variable exists, its value is updated.
GLSameAngle360OnOff This macro turns "On" and "Off" a special case logic
associated with rotary movement. This macro should be called during the Start of
Processing Events with an Override Value = 1 to turn this special case logic on. In
general, this macro should never be called unless you are certain that your machine
is configured as defined below.
If a rotary is defined as an absolute 360 table, and the absolute rotary direction is
set to either positive is CCW or positive is CW, and the angle was specified on the
block and the angle is equal to the previously set angle, and the angle is not equal
to zero, then a 360 degree move will be executed.
NOTE: This macro does not handle B-0 the same as B0. If you are using
B-0, it is recommended that you substitute B0.
GLSetCurrentZeroTrackingPos Sets the PPX, PPY, PPZ, and PPW system
variables based on the current position.
GLType2Begin Marks the beginning of a G&L Type 2 command.
GLType2CLS G&L Type 2 Call subroutine macro. This macro expect at least 1
argument. The first argument must be the subroutine name.
GLType2DFS G&L Type 2 Define subroutine macro. G&L subroutines can be
defined inline, but are not executed until called.
GLType2End G&L Type 2 End subroutine macro. A number of event can cause
the end of a Type 2 command. In order to correctly process a G&L Type 2 file, the
Begin/End must be kept in sync.
GLType2FXZ G&L Type 2 Fixture Offset Zero macro. Expects 1 or 2 arguments.
If 1, the specified fixture offset will be reset. If 2, the specified range of fixture
offsets will be reset.
GLType2FXZArg G&L Type 2 FXZ arguments macro. Specifies the arguments
for the GLType2FXZ macro.
GLType2PDO G&L Type 2 Probe Offset macro. Arguments are expected in Type
I format.
GLType2PdoId Typically called via a PDO record, for example (PDO,P1 X.105
Z.105), this macro loads probe offset values for a specific probe number (probe "1"
in this example) into a Probe Offset table. The values are accessed when the probe
is used. Plus and minus signs determine the direction for probe travel.
GLType2PGM G&L Type 2 Program name macro. This macro requires the
program name to be specified as the first argument.
GLType2PRB G&L Type 2 Probe Datum Offset Activate. This macro requires the
probe id to be specified as the first argument.
GLType2RPT G&L Type 2 Repeat macro. This macro requires the repeat count to
be specified as the first argument.

684
GLType2RTA G&L Type 2 Return Arguments macro. This causes a return from
subroutine and the passing back of specified values to the calling routine. The
values that are to be returned are specified as arguments to this macro.
GLType2UPD G&L Type 2 Update Probe Display macro. This routine is passed a
series of arguments that are messages to be display to the console.
GotoJump Jumps to the specified sequence number. Searching begins at the
beginning of the current program/subroutine.
See also: GotoJumpForwardBackward and GotoJumpForwardBackwardStart
GotoJumpForwardBackward Similar to GotoJump except uses the sign of the
value to determine the direction in which to search. A positive value looks in the
forward direction, a negative value looks backwards. Searching begins from the
current position. If within a subroutine, the forward and backwards search is
limited to the subroutine.
See also: GotoJump and GotoJumpForwardBackwardStart
GotoJumpForwardBackwardStart Similar to GotoJumpForwardBackward
except when the backward search does not find the jump sequence number, it then
searches forward starting at the beginning of the program/subroutine. Similarly,
when forward search does not find the jump sequence number, it then searches
forward starting at the beginning of the program/subroutine.
See also: GotoJumpForwardBackward and GotoJump
GotoLabel Branches to the label previously specified via calling the LabelName
macro. This macro searches for the first occurrence of the label within the file.
Searching begins at the top of the file.
See also: LabelMacro and CinciGotoLabelName
GotoLabelForwardBackward This macro causes the program to jump to the
specified label by searching either forward or backward from the current location.
Jumps are only supported within the current subroutine (or mainline program if you
are not in a subroutine). A value that is greater or equal to zero will cause a
forward search, and a negative value will cause a backward search. The label to
jump to should be specified with a call to LabelName or LabelNameValue, which
must occur prior to calling this macro. If a condition exist on the current block, the
jump will only occur if the condition is true.
See also: GotoJumpForwardBackward for similar capabilities for sequence
jumping.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
Hcode_Tool Calls ToolLengthCompValue, ToolCode, and ToolChange.
NOTE: This macro is no longer needed and may be deleted in the future.
HeidIso_Polar If passed a value of 1, it will set the current state to be polar. If
passed a value of 0, it will turn off the polar state. In polar mode, you are given a

685
pole, an angle, and a radius.
See also: HeidIso_PolarAngle, HeidIso_PolarRadius, and the Heid_CircleCenter
macros.
HeidIso_PolarAngle Defines the Heidenhain polar angle. The incoming value will
be interpreted as incremental or absolute based on the current incremental/absolute
state. The resulting value is modal.
See also: HeidIso_Polar, Heid_PolarMotionLinear, Heid_PolarMotionCW, and
Heid_PolarMotionCCW and Heid_PolarAngle.
HeidIso_PolarRadius Defines the Heidenhain polar radius. The incoming value
will be interpreted as incremental or absolute based on the current
incremental/absolute state. The resulting value is modal.
See also HeidIso_Polar, Heid_PolarMotionLinear, Heid_PolarMotionCW, and
Heid_PolarMotionCCW and Heid_PolarRadius.
HeidIso_SubDefCallEnd This macro is used to define a subroutine, mark the end
of a subroutine, and to call a subroutine for a Heidenhain ISO control. On a
Heidenhain ISO control, %ABC1 will either define the start of subroutine
"ABC1", mark the end of subroutine "ABC1", or call subroutine "ABC1". The
context in which it is used determines its function.
The concept is: A program or subroutine always begins and ends with a %xxx.
Any %yyy within %xxx must be a call to a subroutine.
NOTES: In order for the above macro to work, the following must be true:
1. Any program or subroutine which is defined by this macro must also be
ended by this macro.
2. Any program or subroutine which is ended by this macro must also have
been defined by this macro.
3. If a program or subroutine is called by this macro, it must also be
defined by this macro.
HeidMPlus_Subroutine_Sequence If this is the first sequence number for the
current subroutine, then the SubroutineSequence macro will be called. Otherwise,
the Sequence macro will be called.
Heid_BlockInit Heidenhain specific, block initialization macro. This macro is
identical to BlockInit, except the circle IJK parameters are modal. If used, this
macro should replace the standard BlockInit macro and be called at the "Start or
Block Processing" event.
Heid_CallLbl Either calls the current subroutine and branches to the specified
label or jumps to the start of a repeat section, depending on the status of the
Heid_RepeatCount macro. Heidenhain repeat sections are similar to subroutines
but do not include an end (LBL 0) block.
When the Heid_RepeatCount macro has been called, the section of code is repeated
until the repeat count is completed. Repeat sections may be nested to a maximum
depth of eight.
When the Heid_RepeatCount macro has not been called, the current subroutine will
be called, and then the GotoLabel macro will be called.

686
Enter the number of the Label in the Override Value field.
NOTE: This macro should be executed after motion allowing the repeat count to
call the Heid_RepeatCount macro first.
Heid_CallSubName Either calls a machine code subroutine or jumps to the start of
a repeat section,depending on the status of the Heid_RepeatCount macro.
Heidenhain repeat sections are similar to subroutines but do not include an end
(LBL 0) block.
Either calls a machine code subroutine or jumps to the start of a repeat
section,depending on the status of the Heid_RepeatCount macro. Heidenhain repeat
sections are similar to subroutines but do not include an end (LBL 0) block.
When the Heid_RepeatCount macro has been called, the section of code is repeated
until the repeat count is completed. Repeat sections may be nested to a maximum
depth of eight.
When the Heid_RepeatCount macro has not been called, a machine code
subroutine call is made. If code is currently processing the specified subroutine,
then an EndSub will be executed. Otherwise, a CallSubName will be executed.
Enter name of subroutine in the Override Text field or number of subroutine in the
Override Value field.
NOTE: This macro should be executed after motion allowing the repeat count to
call the Heid_RepeatCount macro first.
Heid_CallTextSubName Calls external subroutines using Heid_CallSubName.
The subroutine must be defined in the Configuration menu > C Adv. Options:
Subroutines tab.
Heid_CircleCenterIncX, Heid_CircleCenterIncY, Heid_CircleCenterIncZ Sets
the X,Y,Z coordinates of the center of a circle, respectively. The incremental
coordinates are relative to the last programmed tool position. The Circles... modals
determine how these values are interpreted.
Heid_CircleCenterX, Heid_CircleCenterY, Heid_CircleCenterZ Sets the
X,Y,Z coordinates of the center of a circle, respectively. The Circles... modals
determine how these values are interpreted. These macros are also used to define
the polar pole or base position used in Heidenhain polar motion commands.
Heid_EndSub Similar to EndSub, except a return from the main does not cause an
error message.
Heid_GetPocketContours Starts the processing of the contour subroutine(s) to
capture the contour geometry. This macro is used for simulating Heidenhain CYCL
DEF 22, 23, 24, and 25 pocketing/contouring with motions calculated by the DLL
from ModuleWorks. See Notes about simulating Heidenhain SL pocket cycles in
the Using VERICUT section for additional information.
NOTE: If "single step" is being used, you will have to step through all the
contour subroutines until the next program line will be processed.
Heid_GotoLabel Branches to the label previously specified via calling the
LabelName macro. If the branch point label is not found, this macro makes a
Heid_CallSubName to the label. This macro must be called with Process after
Motion toggled "On".

687
Heid_InitializePocketContours Initializes the geometry list and should be called
when the first contour subroutine is referenced. This macro is used for simulating
Heidenhain CYCL DEF 22, 23, 24, and 25 pocketing/contouring with motions
calculated by the DLL from ModuleWorks. See Notes about simulating Heidenhain
SL pocket cycles in the Using VERICUT section for additional information.
Heid_JumpDecrement If the G29 condition is true, this macro decrement the
variable specified by Heid_JumpDecrementVar by the amount specified by
Heid_JumpDecrement.
Example: Using the Heidenhain Mill Plus G29 Conditional Jump macro
NAME "G29" {
TYPE MACRO_CALL
INCH "DECIMAL"
METRIC "DECIMAL"
}
WORD_VALUE "N=" {
COND_AND "G" "22" {
MACRO "SubroutineName"
}
COND_AND "I" "-1"
COND_AND "G29" {
MACRO "GotoJumpForwardBackward" {
OVERRIDE_EXP "$ * -1"
}
MACRO "Heid_JumpDecrement" {
AFTER_MOTION Yes
}
}
COND_AND "I"
COND_AND "G29" {
MACRO "GotoJumpForwardBackward"
MACRO "Heid_JumpDecrement" {
AFTER_MOTION Yes
}
}
}
WORD_VALUE "G29" {
MACRO "IfCheck"
MACRO "Heid_JumpDecrementVar"
}
WORD_VALUE "K" {
COND_AND "G" "81-86" {
MACRO "CycleStepValue"
}
COND_AND "G29" {
MACRO "Heid_JumpDecrementValue"
}

688
MACRO "CircleCenterZ"
}
Heid_JumpDecrementValue This macro saves the amount that the variable set in
Heid_JumpDecrementVar should be decremented by if the jump occurs. See
Heid_JumpDecrement for an example.
Heid_JumpDecrementVar This macro is passed the expression associated with a
Heid Mill Plus G29 Conditional Jump command. This expression begins with 'E'
followed by the variable number that is to be used to evaluate the expression. This
macro saves this variable number so that it can be used by the
Heid_JumpDecrement macro. See Heid_JumpDecrement for an example.
Heid_LabelMacro Identifies the current line with the given Label (see
LabelMacro). In addition, this Heidenhain version checks for a label being used as
the start of a subroutine and calls SubroutineSequence when appropriate. Note that
"LBL 0" must call Heid_EndSub with the scan pass checked.
Heid_MotionCW, Heid_MotionCCW Sets the motion type to CW or CCW,
respectively. Similar to MotionCW, MotionCCW except with an additional check
to force a 360 degree circle when explicit end points are not specified.
Heid_MotionLinear Similar to MotionLinear, except this macro will also reset the
circle parameters.
Heid_PocketSub Adds a contour subroutine label to the geometry list. It should be
called for each element in a "contour subroutine" list. The TNC430 allows up to 12
contours for each pocket. This macro is used for simulating Heidenhain CYCL
DEF 22, 23, 24, and 25 pocketing/contouring with motions calculated by the DLL
from ModuleWorks. See Notes about simulating Heidenhain SL pocket cycles in
the Using VERICUT section for additional information.
Heid_PolarAngle Sets the polar angle used in the Heid_PolarMotionLinear macro.
Heid_PolarIncAngle Sets the incremental polar angle in the
Heid_PolarMotionCW and Heid_PolarMotionCCW macros.
Heid_PolarIncRadius Adjusts the polar radius (see Heid_PolarRadius) by the
incremental IPR value passed.
Heid_PolarMotionCW, Heid_PolarMotionCCW Processes a circular polar
clockwise or counter-clockwise command (with optional helix) using the
Heid_PolarIncAngle to specify the arc's included angle and Heid_CircleCenterX,
Heid_CircleCenterY, Heid_CircleCenterZ as the center.
Heid_PolarMotionLinear Calculates linear XY, ZX, or ZY motion using
Heid_PolarRadius as the radius, Heid_PolarAngle as the angle, and
Heid_CircleCenterX, Heid_CircleCenterY, Heid_CircleCenterZ as the center.
Heid_PolarRadius Sets the polar radius used in the Heid_PolarMotionLinear
macro.
Heid_ProcessRNDorCHF Processes a corner round or chamfer, using data stored
by Heid_XaxisMotion and Heid_YaxisMotion macros. The multiple block format
used by Heidenhain requires this type of look-ahead processing.
Heid_RepeatCount Sets the REP count for repeating Heidenhain machine code
sections. See description for Heid_CallSubName.

689
Heid_XaxisMotion, Heid_YaxisMotion Similar to XaxisMotion and YaxisMotion
with an additional look-ahead check being made for RND or CHF on the next
program block. When RND or CHF is detected on the next block, the actual
motion is deferred until the next block is processed and the corner round or
chamfer can be calculated. Also see Heid_ProcessRNDorCHF.
HelicalFullLoops Specifies the number of full loops should be processed for a
given helical motion. Using this value, the start and end angle, and the helical
offset, the pitch is then calculated. The default for this value is 0.0 (generally the
pitch if specified, and the number of loops is calculated).

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
Icode Depending on the motion type (circular or non-circular), either sets the X
coordinate of a circle, or establishes a 3D offset. The interpretation of the center
point is dependent on the Circles control settings.
IfBlock Defines the beginning of an "IF" block of code. It evaluates whether the
specified expression is TRUE or FALSE to determine whether or not to execute
the block of code. The end of the "IF" block of code is specified with EndIfBlock.
The "IF" block of code can also contain any number of "ELSE" or "ELSE_IF"
statements specified using ElseBlock. Process during Scan must be set to "Yes"
for this macro.
This command is used to process a "If" blocks of the form:

IF (expression)
.
.
.
ELSEIF (expression)
.
.
.
ELSE
.
.
.
ENDFOR

The following Word Formats should be defined:

690
IF and ELSEIF should be defined as a words of Type = "Macro", Sub Type =
"Numeric".
ELSE and ENDIF should be defined as words of Type = "Macro", Sub Type =
"None".
( ) represent words of type left and right precedence.

Entries should be defined for FOR, TO and ENDFOR in the Word/Address table as
illustrated below :

NOTE: Similar to IfCheck except that it allows the execution of multiple


blocks when the "If" condition is TRUE.
IfCheck Sets an internal variable indicating whether the corresponding "IF"
statement was TRUE or FALSE. This variable is reset at the beginning of the next
block.
This command is used to process a "If" check of the form:

If (expression) GOTO 30
.
.
.
GOTO 40
N30
.

691
.
GOTO 40
N40

The following Word Formats should be defined:

IF and GOTO should be defined as a word of Type = "Macro", Sub Type =


"Numeric".
() represent words of type left and right precedence.

Entries should be defined for IF and GOTO in the Word/Address table as illustrated
below :

NOTE: Similar to IfBlock except that it only applies to the current block
when the "IF" condition is TRUE.
See also: ResetIfCheck
IfCheckAllMacros If this macro is passed a value of 1, it causes the IfCheck
macro to be applied to all macros called after the IfCheck on the current block.
Typically, this macro would be called during Start of Processing.
NOTE: The IfCheck also applies to whether comments are passed on, and
if variable assignments are executed.This is independent of
IfCheckAllMacros.
IgnoreMacro Ignores the word/value that called it (causes no action). During the
creation of a report, the macro will create an unsupported word/value entry.
Ijk2AbcType Typically called during the "Start of Processing" event, this macro
controls the type of conversion required to convert tool vector information ( IJK
rotary motion data) into ABC rotations. The tool vector information is typically set
with [IJK]Vector macros. Conversion type is specified via Override Value.
NOTE: Requires an Advanced Machine Features license for all non-zero
Override Values.
There are two classes of conversion routines, "Generic" and "Specific". Specific
conversion types are meant for a very specific machine/control configuration.
Generic conversion types are for any machine/control that follow simple rules.

692
Generic conversion types:
y Assume that the Rotaries are set to "Absolute" and the direction set to
"Shortest Distance".
y When converting from IJK to ABC, typically there are 2 solutions. The
Generic routines will choose the solution which require the smallest total
rotary travel.
y Assume that the control will be configured to handle any RTCP/RPCP
issues.
y Assume that the only rotation applied to components will be on nutator
components.
y Are based on the order that the rotaries appear starting at the Tool, and
ending with the Stock. This means that an A on C head machine can use the
same Generic conversion type as an A head/C table machine, or a C on A
table machine. These 3 machine configurations would all be described as
"A-C".
NOTE: Changes to existing conversion types will only be made for
conversion types listed as "Specific", and will only be made as problems
arise for specific machine/control configurations.
Valid Override Values (conversion types):
1 Specific: Forest Line 5ax mill with A/B head rotation and ATEK control. In
this case, the macro also rotates the work and shift offsets based on the
rotation that is applied to the stock. An assumption is made that the entire
amount of the dynamic and work offsets should be rotated by the amount the
part is rotated. This logic will not work when the machine is not built about
zero, and only part of the work offset is to be rotated.
NOTES:
1. Rotary control settings should be set to "Absolute" with the
direction set to "Shortest Distance".
2. This option uses a rotation plane to adjust the coordinate system
for any rotation of the B axis (part side rotary). This option can
not be used with RPCP or Rotation Planes.
2 Semi Generic A-B. For example :Droop & Rein 5ax mill with A/B table
rotation and Makro 80 control. Similar case 1 above, except both A/B
rotaries are on the "tool side" of the machine. This means that a rotation
plane is not used to adjust for part side rotary, and therefore this option does
not have the restriction on RPCP or Rotation Planes.
3 Specific: 5ax tripod-type mill with A/B head rotation and Sinumerik 840D
control. A highly customized machine where as the spindle/tool assembly
rotates, it moves off center relative to the cylinder which surrounds it. To
simulate this, "virtual" U and V axes were included in the machine
definition. When offsets are applied to U and V, counter offsetsare applied
to X and Y. This macro option was designed to be driven via
Z1,A1,Z2,A2,Z3,A3 NC codes, the tool is actually driven with A,B,C. See
also: TripodArmLength / TripodRodLength.

693
4 Generic B-C with rotaries set to linear. For example: Droop & Rein 5ax mill
with B/C head rotation and Sin840D control.
5 Generic A-C with a 50 degree nutator. Adheres to "travel limits" unless
Setup > Machine > Settings, Travel Limits tab has Ignore is toggled "on".
For example: Dorries Scharmann AMC 5ax mill with A/C head rotation and
Heid ATEK HSPlus control. Converts PQR Vector programming to A,C
head rotations.
6 Specific: Maka CR27TM 5ax mill with A/B rotation and BWO 900C control.
5-axis orthogonal to 50.02 degree nutator conversion. Converts virtual A, B
angles into real A, B angles. See also: IjkAAxisMotion, IjkBAxisMotion.
7 Generic A-C. Supports both linear and absolute rotary tables. Adheres to
"travel limits" unless Configuration menu > Machine Settings: Travel Limits
tab has Ignore is toggled "on".
8 Generic B-C, also supports any angle nutator. This option looks at the X
rotation of the B axis to determine the nutator angle. Although the angle may
vary, the basic machine configuration must remain fairly constant in order
for this logic to work. Adheres to "travel limits". Supports both linear and
absolute rotary tables. This was initially implemented for the DMU50.
9 Generic B-C, also supports any angle nutator. This is an updated version of
8, described above. Typically this conversion type should be used rather than
8.
10 Generic A-C, also supports any angle nutator. Adheres to "travel limits".
Supports both linear and absolute rotary tables.
11 Generic B-A. Adheres to "travel limits". Supports both linear and absolute
rotary tables.
NOTE: Requires an Advanced Machine Features license.
12 Generic A-B. Adheres to "travel limits". Supports both linear and absolute
rotary tables. Includes special case for (0, 1, 0) vector where the B remains
unchanged, and only the A rotates.
13 General A-C with A,B,C input. The input A,B,C angles are converted
into an IJK tool vector, and then conversion type 10 is used.
14 Generic C-B, also supports any angle nutator. Adheres to "travel limits".
Supports both linear and absolute rotary tables.Includes special case for (0, 1,
0) vector where the B remains unchanged, and the C rotates.
IjkAAxisMotion, IjkBAxisMotion, IjkCAxisMotion These macros are specific to
the Maka CR27TM 5ax mill with A/B rotation and BWO 900C control, and are to
be used with Ijk2AbcType, Override Value=6. For this control, A should call
IjkCAxisMotion, and B should call IjkAAxisMotion. These macros work will
convert the CA orthogonal values into IJK, and then into CA with a 50 degree
nutator head. If 0.0 is passed to IjkAAxisMotion, then the C-axis will be driven to
the last specified value passed to IjkCAxisMotion.
InActivateAxis Marks this axis as inactive for this subsystem. Used with
ActivateAxis on synchronized turning tool paths to avoid conflict with
Stock/SubStock rotaries. Is passed the numeric value of the axis to inactivate (1-12)

694
or a text value of "All". Each axis is associated with a numeric value as follows:
1=X axis, 2=Y axis, 3=Z axis, 4=A axis, 5=B axis, 6=C axis, 7=U axis, 8=V axis,
9=W axis, 10=A2 axis, 11=B2 axis, 12=C2 axis, All=All axes are inactivated.
NOTE: Since the Spindle and Subspindle axis are common to both
subsystem 1 and 2, initially, their corresponding Axis are marked as
"inactive". This way, the subsystems do not conflict with each other.
IncrementalShift Shifts the work coordinate system by the specified axis values.
The values will be interpreted as incremental. Only values specified on the block
will be adjusted. (Shift Offset 0, INCREMENTAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
IncrementalShiftRotationDynamic This macro was implemented to support
incremental shift offsets while in Heidenhain DEF 19 mode. The macro, however,
is not specific to Heidenhain, and therefore it is not being marked as a Heidenhain
macro. The basic concept is that the offset is currently being defined within the
current "working plane". This "working plane" is a combination of the rotation
plane and the orientation of the stock. The offset specified (with the
WorkCoord&Value macros) will be multiplied by the current rotation plane, and
then if dynamic work offsets are turned on, it will be un-rotated by the current
rotation of the stock. The result is an un-rotated offset that will be added to the
existing shift offset. (Shift Offset 0, INCREMENTAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
NOTE: This macro will only work with X, Y, Z.
IndexCallMainSub Calls the appropriate subroutine for the head/subsystem
currently being processed. A typical example of use would call this subroutine the
first two times "M30" is processed. The default sub names called are "1001" for the
primary subsystem, and "2001" for the secondary subsystem, but can be overridden
via the "IndexChannel..." macros (see below).
NOTE: Requires an Advanced Machine Features license.
IndexChannel1Subroutine, IndexChannel2Subroutine Sets the subroutine
numbers to call for the primary and secondary subsystems, respectively, when
IndexCallMainSub is called. (Defaults: primary subsystem subroutine=1001,
secondary subsystem subroutine=2001)
Input Renamed to InputMacro.
InputMacro Stops the processing of the tool path file, and wait for user input.
InverseWordValue This macro enables you to define one word that will be in the
format: Value/Word rather than the standard Word/Value. This macro was
specifically created for the 840D control which defines its labels as: "LABEL:".
This macro must be called during the "Reset" Event, with an override text value of
the word that will be in this inverse format. The specified word must be defined in
the WORD table, must have the Type = "Macro", and must have the Sub Type =
"Alpha-Numeric". If this macro is called multiple times, only the last occurrence

695
will be used.
IVector, JVector, KVector Reads the IJK vector values for a rotary motion in IJK
format. See also: Ijk2AbcType.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
Jcode Depending on the motion type (circular or non-circular), either sets the Y
coordinate of a circle, or establishes a 3D offset. The interpretation of the center
point is dependent on the Circles control settings.
JVector See IVector, JVector, KVector.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
Kcode Depending on the motion type (circular or non-circular), either sets the Z
coordinate of a circle, or establishes a 3D offset. The interpretation of the center
point is dependent on the Circles control settings.
KtBlockInit This is a special block initialization macro to be used with K&T
controls. It should be called during the "Start of Block Processing" event, and after
the default BlockInit macro.
KtType2CLS K&T Type 2 call subroutine macro where the subroutine call record
does not have to specify loop count (defaults to 1). The second argument optionally
specifies the loop count when it is a single value. Otherwise the second argument
does not apply to loop count. The loop count can also be set via variable 0 within
the CLS command.
KVector See IVector, JVector, KVector.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
Label Renamed to LabelMacro.
LabelMacro Identifies the current line with the given Label.
LabelName Uses the text string value to set the name of the label which will be
used by the GotoLabel macro.
See also: LabelMacro and CinciGotoLabelName
LabelNameValue Uses the numeric value to set the name of the label which will
be used by the GotoLabel macro. Only integer values are supported

696
LinkAxisId Use to specify the Axis number, representing the "driving axis", when
using "link" capabilities defined with SetAxisCompLink. Valid values are 1-12,
which correspond to the X,Y,Z,A,B,C,U,V,W,A2,B2,C2 axes. This value is modal.
See also: "Notes about link macros" in the Using VERICUT section.
LinkCompName Use to specify the name of the component representing the
"driven (or linked)" component, when using "link" capabilities defined with
SetAxisCompLink. This value is modal.
See also: "Notes about link macros" in the Using VERICUT section.
LinkFormula Specifies the formula which is to be used by SetAxisCompLink. The
formula should be specifed as an Override Text value, and in the same syntax
which is used for normal Override Values. If no formula is desired, an Override
Text value of "NONE" should be specified. This value is modal.
See also: "Notes about link macros" in the Using VERICUT section.
LinkOffset This macro defines how offsets applied to the driving axis (See
LinkAxisId), are applied to the linked component (See LinkCompName), when
using the link capabilities (See SetAxisCompLink)
OV=0 Offset will be applied to the linked axis (default – same as
existing logic)
OV=1 Offset will not be applied to the linked axis, plus special
rotary logic to work with link axis
OV=2 Offset will be applied to linked axis, plus special rotary
logic to work with link axis
OV=3 Offset will be applied to linked axis based on the formula,
plus special rotary logic to work with link axis

See also: "Notes about link macros" in the Using VERICUT section.
LoadNextTool Loads the next tool listed in the Tool List. Tools are retrieved from
the list in sequential order. For example, the first tool change loads the first tool in
the list for the active subsystem, the second tool change loads the second tool in the
list, and so on. This macro is useful to automate tool change activity in VERICUT
for manual tool change machines; typically called via the "M 0" group.
LoadStocks Performs a "load stocks" operation where VERICUT loads new stock
models for Stock components having models defined, but a cut stock model does
not exist. Same action as Project menu > Setup Models > Load Stocks via the user
interface.
LoopCount Sets the loop count. The loop count is used for the number of times a
subroutine is to be executed, and is also used for the number of times the motion in
the current block should be repeated. (non-modal)

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status

697
MacroNotFoundMsgOnOff Turns "On" and "Off" the printing of the warning
message that a macro was not called for a given word/value. 0 is "Off". 1 is "On".
Default is "Off". Typically this macro would be called during the "Reset" event.

MacroVar Fanuc (or Fanuc like) specific macro that sets a block variable based on
the current word. These block variables are non-modal, and are used as subroutine
parameters with the following macros: CallNCMacro, CallNCMacroMotion, and
CallNCMacroBlock. Within the subroutine, specific variables are set based on the
following table
"A", 1,
"B", 2,
"C", 3,
"D", 7,
"E", 8,
"F", 9,
"H", 11,
"I", 4,
"J", 5,
"K", 6,
"M", 13,
"Q", 17,
"R", 18,
"S", 19,
"T", 20,
"U", 21,
"V", 22
"W", 23,
"X", 24,
"Y", 25,
"Z", 26,
Alternately, if multiple IJKs exist on the block, specific variables will be based on
the following table
"A", 1,
"B", 2,
"C", 3,
"I", 4,
"J", 5,
"K", 6,
"I", 7,

698
"J", 8,
"K", 9,
"I", 10,
"J", 11,
"K", 12,
"I", 13,
"J", 14,
"K", 15,
"I", 16,
"J", 17,
"K", 18,
"I", 19,
"J", 20,
"K", 21,
"I", 22,
"J", 23,
"K", 24,
"I", 25,
"J", 26,
"K", 27,
"I", 28,
"J", 29,
"K", 30,
"I", 31,
"J", 32,
"K", 33,
MahoSequence Similar to Sequence, except that it also uses the sequence number
to recognize the beginning of a new subroutine. Numbers 9000 or above are
reserved for program and subroutines. This is MAHO/PHILLIPS specific.
MahoVertical2Rest Rotates Maho's vertical spindle to the 180 position.
MahoVertical2Work Rotates Maho's vertical spindle to the 0 position.
MaxTableRPM Sets the max table RPM's to be the specified value. This is used in
turning when calculating the current RPM while in constant surface speed mode.
MaxTesselationAngle This value is used with the rotary tolerance to define the
number of intermediate points. This value is currently used if the new 5-axis spline
logic has been activated by MinTesselationPoints. The number of intermediate
points will be based on the maximum of the two calculation methods.
MazakMillingInterpolationOff, MazakMillingInterpolationOn Turns off/on a
special milling mode for a Mazak controller which causes X values to be multiplied
by 2, respectively.

699
MazakPartLoader On the first call, it calls PartTransformation with a value of 1
and loads the first fixture within VERICUT. On the third call, it calls
PartTransformation with a value of 2 and loads the second fixture within
VERICUT.
NOTE: The MazakPartLoader macro is obsolete and no longer supported.
If called, the following message: "The macro, MazakPartLoader, is no
longer supported" is output.
MazakSpindleRotation If in milling mode, the B axis will be rotated to the
specified value. In turning mode, the B axis will be rotated to the 0 position.
MessageMacro Creates a message using the text string input using the Override
Text field. The message type is specified by the input numeric value. 1= Error,
2=Warning, 3= Info, 4= Debug, 5= Input, 6=Output, 7= Macro Modal, 10= Error
Continuation
See Override Text in the Add/Modify Word/Address window for information on
using "expresssions" in the Override Text field.
MinTesselationPoints Used to define the minimum number of intermediate points
required to activate the new 5-axis spline logic. The default value is 4. If the value
of MinTesselationPoints is 0, or the number of intermediate points created is less
than the specified Override Value, the new 5-axis spline logic will not be used.
Also see: MaxTesselationAngle
MirrorA, MirrorB, MirrorC, MirrorA2, MirrorB2, MirrorC2 Mirrors
A,B,C,A2,B2,C2 rotations by negating the A,B,C,A2,B2,C2 values. All of the
above macros behave in a similar manner as the Mirror XYZ macros. Basically, if
mirroring is turned on for that axis, the value is negated. Similar to X,Y, and Z,
when the WorkCoord[*]Value is called with a text override of "MIRROR", and
the corresponding axis set to mirror, the input value will be mirrored.
NOTE: It is not clear whether this is correct for all combinations of linear
and absolute rotary tables.
MirrorACancel, MirrorBCancel, MirrorCCancel, MirrorA2Cancel,
MirrorB2Cancel, MirrorC2Cancel Cancels the mirroring about the
A,B,C,A2,B2,C2 axes, respectively- ref. MirrorA, MirrorB, MirrorC, MirrorA2,
MirrorB2, MirrorC.
MirrorAValue, MirrorBValue, MirrorCValue, MirrorA2Value,
MirrorB2Value, MirrorC2Value Same as MirrorA, MirrorB, MirrorC, MirrorA2,
MirrorB2, MirrorC.
MirrorCancel Cancels all mirroring.
MirrorX, MirrorY, MirrorZ Mirrors values about the XYZ axes.
MirrorXCancel, MirrorYCancel, MirrorZCancel Cancels the mirroring about
the XYZ axes- ref. MirrorX, MirrorY, MirrorZ
MirrorXValue, MirrorYValue, MirrorZValue Mirrors values about the XYZ
axes.
ModeAbsolute, ModeIncremental Sets the command mode to Absolute or
Incremental, respectively.
ModeAsymTurningOnOff Triggers the special motion in VERICUT, called

700
CRANK_MOTION. This motion is identified by X-Caliper and returns
point/normal information.
NOTE: Requires an Advanced Machine Features license for all non-zero
Override Values.
Motion3DCircle This macro sets the motion type to 3D_CIRCLES. This is similar
to MotionCCW and MotionCW except that the direction is not specified, and the
circle does not need to be in the local XY, YZ, or ZX plane. The direction and
plane is then determined by some other parameter. See CircleIntermediatePoint.
MotionBlockSyncOnOff This function turns on and off the capability to SYNC on
every motion block. A value of 1 turns on this capability. A value of 0 turns off this
capability.
NOTE: The sync occurs after motion. But by syncing with the G68 call, it
can be made to look as if the sync is occurring prior to motion.
MotionCCW, MotionCW Sets the motion type to CCW or CW, respectively.
MotionLinear Sets the motion type to Linear.
MotionNurbs Sets the motion type to Nurbs and initialize the nurbs data.
MotionOnOff These macros control when motions and cutting are simulated,
depending on values passed. Calling this macro outputs a "PPRINT/VERICUT-
MOTION" record to the Output file. Calling with an Overide Value of "1" turns
motion simulation and cutting on (default). A value of "0" turns motion simulation
and cutting off. Motion commands and positions are processed, but simulation,
cutting, collision detection, and axis overtravel detection are turned off during these
moves. When motion is turned on, the machine/tool "jumps" to its current position.
"1" is automatically set when a reset is done.
MotionOnOffSide, MotionOnSide These macros determine which codes from the
tool path are processed and which machine head is being simulated.
NOTE: These are special purpose macros designed for use with pre-5.0
VERICUT simulating a custom INDEX mill-turn NC machining center, and
are NOT intended for general use.
MotionPlaneXY, MotionPlaneYZ, MotionPlaneZX Sets the motion plane to be
the XY,YZ,ZX plane, respectively.
MotionPoly Sets the motion type to Poly.
MotionRapid Sets the motion type to Rapid.
MotionThread Sets the motion type to Thread.
MotionToolOffsetNeg, MotionToolOffsetPos By default, these macros use the
cutter compensation value and offset the XYZ values in the current block by this
amount opposite the direction of motion, or in the direction of motion, respectively.
If used with the macro MotionToolOffsetOnMotion with an override value of 1,
the offset associated with the MotionToolOffsetPos or the MotionToolOffsetNeg
will be applied to the next motion.
MotionToolOffsetOnMotion If the macro MotionToolOffsetOnMotion is called,
and passed in an override value of 1, the offset associated with the
MotionToolOffsetPos or the MotionToolOffsetNeg will be applied to the next

701
motion. The MotionToolOffsetOnMotion macro will typically be called during
the Start of Processing event. A override value other than 1 will cause the
MotionToolOffsetPos and MotionToolOffsetNeg to be applied only to the
current block.
MountTool Mounts the specified tool (Override Value = toolid) onto the specified
tool component (Override Text = name of the tool component).
NOTES:
1. This is NOT a tool change.
2. The tool id will be cross referenced with the tool list. Mounting the
tool DOES NOT change the active tool, execute a tool change retract,
increment the number of tools, or update tool offsets. It is strictly a
way to mount a tool. Typically, this will be used with a tool changer.
See also: UnMountTool
MountToolIndex Mounts the specified tool onto the tool component with the
matching tool index value (Override Value = tool index value) and subsystem
(Override Text = subsystem of tool component).
NOTES:
This is NOT a tool change.
The tool, represented by the tool index value, will be cross referenced
with the tool list. Mounting the tool DOES NOT change the active
tool, execute a tool change retract, increment the number of tools, or
update tool offsets. It is strictly a way to mount a tool. Typically, this
will be used with a tool changer. See also: UnMountToolIndex
MoveCutStockCompName This macro defines the name of the component whose
Cut Stock will be moved with the MoveCutStockToCsys macro. This value is
modal. If not called, the active stock for the current subsystem will be used.
MoveCutStockFromCsys This macro defines the "FROM" CSYS that will be
used with the MoveCutStockToCsys macro. This value is modal.
MoveCutStockToCsys This macro defines the "TO" CSYS. It then moves the
corresponding Cut Stock based on the "FROM" and "TO" CSYS. The "TO" CSYS
value is non-modal and must be specified on every call.
See also MoveCutStockCompName and MoveCutStockFromCsys
MoveDesignWithStock Specifies whether the design component(s) should be
moved when the stock is moved with the MoveCutStockToCsys macro. A value of
0 sets it to "No" (default), a value of 1 sets it to "Yes". All Design and Design Point
components that are at the same level or below the specified stock will be moved

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
NcodeSeqSub Similar to Sequence, except that it also marks the sequence number

702
as the beginning of a subroutine during the first pass.
NCVarDefaultValue This macro is used to determine how an NC variable should
be set when created by the MCD program.
0 = default to 0.0. This is the default value.
1 = default to un-initialized.
NOTES:
1. Option 0 is the default in order to stay compatible with previous
releases. 1 is the recommended setting for all controls. It is a good
programming practice to always set a variable before using it. By
setting this macro to 1, and setting NCVarWarnMessage to 2, enables
you to maximize the error checking that VERICUT can do for you.
2. This setting will have no effect on Fanucs G65.
NCVarWarnMessage This macro will determine when a warning message should
be printed associated with an un-initialized variable being referenced.
0 = Never print a warning message.
1 = Print a warning message only if the variable did not previously exist.
This is the default value.
2 = Always print a warning message.
NOTE: Option 1 is the default in order to stay compatible with previous
releases. This option really only makes sense for Fanuc users who knowingly
use un-initialized variables in expressions. Even in this case, the option really
doesnt make sense because the concept of the variable not being created is
something specific to VERICUT. Typically you will always want to know
when an un-initialized variable is being referenced.
NULL Renamed to NullMacro.
NullMacro Immediately returns-no action is performed. This macro can be used to
avoid error messages that are not important for the processing of the program. The
macro can also be used in the case of G73X1 (MAHO). In this example, the X1
will cause the mirroring in X to be cancelled (since G73 is also in the block). Since
the operation has been executed with the processing of the X value, there is nothing
left to be done with the G73 value. G73 can be set to call the "null" macro.
NumEndBlankContour Used with the NUM G80 block indicating the end of a
blank contour. The control then reads the cycle contour. After processing the cycle,
the block following the G80 is read.
NOTE: The NUM control should use the NumSequence macro for the start
and end sequence numbers. This allows the format N1 G64 N2 N3 ... Where
N2 defines the start and N3 defines the end sequence number.
NumIfCheck Similar to IfCheck except if no comparison is present, it will act as
an unconditional branch.
NumLengthCompX, NumLengthCompY, NumLengthCompZ Sets the
direction of the tool length compensation.
NumPlane Defines a motion plane in 3D space, typically used in the NUM control.
For example: If a circle is drawn in the XY plane, Z remains constant and only X

703
and Y changes. If a circle is drawn after a 3D plane is established, the circle would
be drawn within this 3D plane.
NumPlaneA, NumPlaneB, NumPlaneC, NumPlaneU, NumPlaneV,
NumPlaneW Defines a 3D plane orientation, typically used in the NUM control.
NumSequence Depending on the contents of the current block, this macro will
execute Sequence, SequenceStartEnd, or GotoJump.
NumSubroutineSequence Similar to SubroutineSequence except the beginning of
a new subroutine will automatically mark the end of the previous subroutine.
NumSubSequenceLoop If "H" is in the block, a call to the corresponding
subroutine will be made. Otherwise, the specified sequence of blocks will be
executed.
NumTurnCycle Indicates a NUM turning cycle will be performed. The type of
cycle is indicated by a R or P word in the cycle block. Macros CycleTurnRoughCut
and CycleTurnFace should be used with R and P respectively.
NurbsDegree Sets the NURBS order to the input value + 1.
NurbsInitialControl Adds an initial control point to the current NURBS data.
NurbsKnot Initializes the NURBS data (if this defines the beginning of a NURBS
statement), and adds a NURBS knot point to the current NURBS data.
NurbsOrder Initializes the NURBS data (if this defines the beginning of a
NURBS statement), and sets the NURBS order.
NurbsWeight Sets the NURBS weight.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
OkumaCancelShiftRotate Cancels both the shift offset and the rotation. (Shift
Offset 1)
OkumaControllingHead Sets the controlling head to be Turret A or Turret B. A
value of 110 defines Turret A as the controlling head, and a value of 111 defines
Turret B as the controlling head.
OkumaCopyEnd Processes the end of the "Copy" command for Okuma. This
includes the branching based off of the loop count, and the updating of the shift
offset and the rotation value. (Shift Offset 1, INCREMENTAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
OkumaCopyLoopCount Sets the Okuma loop count.
OkumaCopyStart Processes the start of the "Copy" command for Okuma. This
includes the initializing of the branching variables, and the updating of the shift
offset and the rotation value. (Shift Offset 1, INCREMENTAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.

704
OkumaCutDepth2 Depth of cut after cutting condition change point 2.
OkumaCutDepth3 Depth of cut after cutting condition change point 3.
OkumaEndContour Indicates the last block of an Okuma turning cycle contour.
OkumaFeedrate2 Feedrate after cutting condition change point 2.
OkumaFeedrate3 Feedrate after cutting condition change point 3.
OkumaGotoJump Branches to the specified sequence number like GotoJump, but
also saves the current position for a return after an Okuma cycle completed.
OkumaGotoLabel Branches to the specified label like GotoLabel, but also saves
the current position for a return after an Okuma cycle completed.
OkumaShiftRotate 2D rotation that causes the coordinate system to be rotated,
within the active plane, by a specified angle. The angle is specified with the
RotationAngle macro. In addition to the rotate, a shift can also be specified. The
shift can be specified with calls to the WorkCoordXValue, WorkCoordYValue, and
WorkCoordZValue macros. The XYZ values are based on the machine coordinate
system. The rotation angle is based on the machine coordinate system. (Shift Offset
1, ABSOLUTE/NON-MODAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
EXAMPLE:
G90X0Y0 ==> X0 Y0
G68X1Y1R45
X0Y0 ==> X1 Y1
X1 ==> X1.707 Y1.707
Y1 ==> X1, Y2.414
X0 ==> X.2929, Y1.707
Y0 ==> X1 Y1
G91G68X1Y1R45 ==> Because of the G91, rotate angle is now 90.
G90X0Y0 ==> X1 Y1
X1 ==> X1 Y2
Y1 ==> X0 Y2
X0 ==> X0 Y1
Y0 ==> X1 Y1
OkumaStartBlankContour Indicates the first block of an optional contour
defining the blank geometry of a turning cycle. The blocks are only processed
when a turning cycle is active, otherwise they are skipped.
OkumaStartContour Indicates the first block defining the contour for an Okuma
turning cycle. The blocks are only processed when a turning cycle is active,
otherwise they are skipped.
OkumaStartCutDepth2 Used with the Okuma G84 cycle to specify the point
where cutting conditions are changed to use cut 2.
OkumaStartCutDepth3 Used with the Okuma G84 cycle to specify the point
where cutting conditions are changed to use cut 3.
OkumaTurnCycle Indicates an Okuma turning cycle will be performed. The

705
control starts reading the contour referenced within the cycle block. After
processing the cycle, the block following the cycle is read.
Okuma_CallSubName Similar to CallSubName except assumes the subroutine
name begins with the second character-the first character of the input text string
argument.
OliConvInit Special Olivetti conversion initialization routine. This routine is to be
called along with the standard ConversionInit routine during initialization.
OliLabel Olivetti specific routine for handling labels.
OliType2EPP Olivetti specific routine for handline the TYPE II EPP command.
This command takes 2 label arguments, where to jump to, and when to jump back.
NOTE: This routine is dependent on OliLabel to define the labels and to
execute the jump when the second label is reached.
Optimizable Increments a counter each time it is called on a block. The counter is
used by OptiPath to determine if a block is optimizable, even if G-codes exist in the
block that are not typically optimizable. The block is optimizable when the number
of objects in a block equals the optimizable count. The optimizable count is re-
initialized with a new block.
OptiMWordLast Controls where M-codes appear in blocks optimized by
OptiPath. By default, VERICUT preserves the order of NC codes as they appeared
in the input block. When a feed rate code does not appear in the original input
block, optimized feed rates are added at the end of the block. On some NC controls,
M-codes (if present) must always appear at the end of the block. In this case, call
this macro with and Override Value of "1" at the "Start of Processing" event. That
causes X,Y,Z,S,F words to come before the first M word.
Examples follow:
Excerpt from a sample input tool path to optimize:
11LX.1981Y.6691Z3.3884R0F30M3
12LX.1295Y.7789Z3.3246R0M3
13LX.0153Y.8397Z3.2608R0M3
14LX-.114Y.8352Z3.1969R0M3
15LX-.2238Y.7666Z3.1331R0M3
16LX-.2846Y.6524Z3.0692R0M3
17LX-.2801Y.523Z3.0054R0M3
18LX-.2115Y.4133Z2.9415R0M3
19LX-.0973Y.3525Z2.8777R0M3
20LX.0321Y.357Z2.8138R0M3
21LX.1418Y.4255Z2.75R0M3
Feed rates added via default optimization:
11LX0.1981Y0.6691Z3.3884R0F2000M3
12LX0.1295Y0.7789Z3.3246R0M3
13LX0.0153Y0.8397Z3.2608R0M3
14LX-0.114Y0.8352Z3.1969R0M3
15LX-0.2238Y0.7666Z3.1331R0M3
16LX-0.2846Y0.6524Z3.0692R0M3
17LX-0.2801Y0.523Z3.0054R0M3

706
18LX-0.2115Y0.4133Z2.9415R0M3F100
19LX-0.0973Y0.3525Z2.8777R0M3F110
20LX0.0321Y0.357Z2.8138R0M3F100
21LX0.1418Y0.4255Z2.75R0M3F90
Feed rates added via optimization with OptiMWordLast active:
11LX0.1981Y0.6691Z3.3884R0F2000M3
12LX0.1295Y0.7789Z3.3246R0M3
13LX0.0153Y0.8397Z3.2608R0M3
14LX-0.114Y0.8352Z3.1969R0M3
15LX-0.2238Y0.7666Z3.1331R0M3
16LX-0.2846Y0.6524Z3.0692R0M3
17LX-0.2801Y0.523Z3.0054R0M3
18LX-0.2115Y0.4133Z2.9415R0F100M3
19LX-0.0973Y0.3525Z2.8777R0F110M3
20LX0.0321Y0.357Z2.8138R0F100M3
21LX0.1418Y0.4255Z2.75R0F90M3
OptipathExpandSubs Sets a flag indicating whether or not the current subroutine
should be expanded. The call to this macro should be associated with a Word rather
than the start of processing event. For example: M98 will call
OptiPathExpandSubs and then CallSub.
Set Override Value to: 0 = do not expand, 1 = expand, 2 = expand only if the
current tool is being optimized.
The subroutine Call, Start, and return will be commented out. For example: the
mcd line "N5 O100 (Example sub)" will get converted to "(Optipath Expansion: N5
O100) (Example sub)"
NOTES:
This flag is non-modal, and gets reset to "don't expand" on every block.
This macro and OptiPathOptimizeSubs are mutually exclusive.
OptiPathOptimizeCDC Turns on/off the capability to optimize while in cutter
comp mode. If passed a value of 1, optimization will be allowed in cutter comp
mode. The default is to not optimize when in cutter comp mode. If needed, this
macro would typically be called during the start of processing event.
NOTE: Optimizing with CDC is not supported with Inverse Time, Add
more Points, Accel/Decel or Sync. The Add more Points and Accel/Decel
features will automatically be turned off while processing CDC motion.
OptiPathOptimizeSubs Sets a flag indicating whether or not current subroutine
should optimized. The call to this macro should be associated with a Word rather
than the start of processing event. For example: M98 will call
OptiPathOptimizeSubs and then CallSub.
Set Override Value to: 0 = do not optimize, 1 = optimize, and 2 = optimize only
if the current tool is being optimized.
NOTES:
This flag is non-modal, and must be called when the corresponding

707
subroutine is called.
Each optimized subroutine will be output to a separate file. The name of
the file will be the subroutine name with a ".opti" extension. The
writing to separate files is independent of how or where the
subroutines were located in the original program. The user is then
responsible to do what ever is needed to incorporate these new
subroutines into the program.
This macro and OptipathExpandSubs are mutually exclusive.
OptiRestoreAdditionalCuts Restores the ability to add additional cuts, that was
previously suppressed via calling the OptiSuppressAdditionalCuts macro. Do not
call this macro unless the "suppress" macro was previously called.
OptiSettingsThis macro updates a field for the current Optipath Record. If a
current Optipath Record does not exist, a new one will be created with default
settings. This update is modal for the current Optipath Record. This update will
not be saved in the Optipath Library file.
NOTE: The existing PPRINT capabilities can be used to set the current
Optipath Library Record.
This macro should be called with an Override Text value of the feature being
updated, and its corresponding value. The following are the features and values
that are supported

FEATURE OVERRIDE VALUE

TEETH Numeric
UNITS "0"=Inch, "1"=Millimeter
OPTIMIZE_BY "0"=Volume, "1"=Tables,
"2"=CSS, "3"=Air Cuts, "4"=Chip,
"5"=Chip Volume, "6"=None,
"7"=API
OPTIMIZE_BY_VOLUME Numeric
CHIP THICKNESS Numeric
MODIFY "0"=Feedrates Only, "1"=Feedrates
and Cuts
FEEDRATE_CONTROL "0"=Off, "1"=Constant, "2"=Limit
VOLUME_REMOVAL_RATE_LI Numeric
MIT
MINIMUM_FEEDRATE_CHANG Numeric
E
CIRCLE_FEEDRATE_OPTION "0"=Programmed, "1"=Fixed,
"2"=Optimize, "3"=Break up
CIRCLE_FEEDRATE_FIXED Numeric
NURBS_FEEDRATE_OPTION "0"=Programmed, "1"=One
Feedrate, "2"=Multi Feedrate

708
FEEDRATE_WEAR_REDUCTIO Numeric
N
RESOLUTION_OPTION "0"=Off, "1"=On
RESOLUTION_DISTANCE Numeric
CLEAN_UP_FEEDRATE Numeric
MINIMUM_CUT_FEEDRATE Numeric
MAXIMUM_CUT_FEEDRATE Numeric
AIRCUT_FEEDRATE Numeric
DEPTH_OPTION "0"=Feed Per Minute, "1"=Percent
of Programmed, "2"=Feed Per
Tooth
WIDTH_OPTION "0"=Off, "1"=On
ANGLE_OPTION "0"=Off, "1"=On
PLUNGE_OPTION "0"=Off, "1"=On
PLUNGE_FEEDRATE Numeric
PLUNGE_PROGRAMMED Numeric
PLUNGE_CLEARANCE Numeric
RETRACT_OPTION "0"=Off, "1"=On
RETRACT_FEEDRATE Numeric
RETRACT_PROGRAMMED Numeric
ENTRY_FEEDRATE_OPTION "0"=Off, "1"=Feed Per Minute,
"2"=% of Programmed, "3"=% of
Calculated
ENTRY_FEEDRATE Numeric
ENTRY_PROGRAMMED Numeric
ENTRY_CALCULATED Numeric
ENTRY_CLEARANCE_DISTAN Numeric
CE
ENTRY_CUT_DISTANCE Numeric
EXIT_FEEDRATE_OPTION "0"=Off, "1"=Feed Per Minute,
"2"=% of Programmed, "3"=% of
Calculated
EXIT_FEEDRATE Numeric
EXIT_PROGRAMMED Numeric
EXIT_CALCULATED Numeric
EXIT_CLEARANCE_DISTANCE Numeric
EXIT_CUT_DISTANCE Numeric
SPINDLE_CONSTANT_SURFAC Numeric
E_SPEED
SPINDLE_MINIMUM_RPM_CH Numeric
ANGE
SPINDLE_MAXIMUM_RPM Numeric

709
SPINDLE_MINIMUM_RPM Numeric
SPINDLE_FPT Numeric
UNIT_POWER Numeric
ACCEL_MODE "0"=Off, "1"=On
SPINDLE_OVERRIDE "0"=Off, "1"=On

The following features are supported in the OLB file, but are not supported with
this macro:

STOCK_MATERIAL
MACHINE
TOOL_DESCRIPTION
DEPTH_VALUES
DEPTH_FEEDRATE_VALUES
WIDTH_VALUES
WIDTH_FEEDRATE_VALUES
ANGLE_VALUES
ANGLE_FEEDRATE_VALUES
CUTTER_DEPTH_WIDTH
TLS_FILE
TOOL_ID
OptiSuppressAdditionalCuts Suppresses additional cuts that would have been
added during optimization via the "Add More Cuts" OptiPath setting (ref.
OptiPath window: Settings tab). After calling this macro, be sure to call
OptiRestoreAdditionalCuts while processing the same tool.
OptiXYZFormat Controls if X,Y,Z tool position values are expanded when
Modify Existing Cuts Only is active during optimization by OptiPath. Use of this
macro is applicable when programming in variable format, e.g.
N10X#5Y#3Z#9F100. By default, optimized X,Y,Z tool position values are
expanded (variable values are resolved) to represent actual tool positions. Calling
this macro with an Override Value of "0" causes the X,Y,Z values to not be
expanded. The X,Y,Z values will be written out as they were on the input block.
NOTES:
This feature should NOT be used when the expansion of variables is
required, e.g. subroutines, branching, etc.
The expansion of X,Y,Z is only suppressed when the "Modify Existing
Cuts Only" OptiPath setting is active (ref. OptiPath window: Settings
tab).

Numbers A B C D E F G H I J K L M N O P Q R S T U V

710
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
PartNormalX, PartNormalY, PartNormalZ Used with Tool3dOffset to define
the normal to the part surface.
PartTransformation Uses the Part Transformation table to send a MATRIX and
optionally a REVERSE command to VERICUT. For this macro to work, "Process
Matrix" on the Project menu Processing Options > APT Settings: Motion tab must
be active.
NOTE: The PartTransformation macro is obsolete and no longer supported.
If called, the following message: "The macro, PartTransformation, is no
longer supported" is output.
PitchForcesHelical Sets a flag which indicates that if the pitch is specified on the
line, then interpret the current circular block as helical. The delta distance
perpendicular to the current plane will be calculated based on the delta angle of the
arc, and the number of full loops to be executed. This macro would typically get
called during start of processing.
See also: CircleCenterX, CircleCenterY, CircleCenterZ, CircleCenterZWTracking,
ICode, JCode, KCode, and the "Pitch Specified with IJK" modal.
PivotOffsetCompName Defines the component name to be used with
TurnOnOffGagePivotOffset in determining the distance from the pivot point to the
active tool component. If this value is defined, the corresponding component
origin will define the pivot point. If this value is not defined, the pivot point is
defined to be the parent rotary, or the intersection point of the 2 rotaries, or the
highest parent rotary if the rotary axis do not intersect. See the illustration below.

PivotOffsetCompNameB Defines the component name to be used with


TurnOnOffGagePivotOffset in determining the distance from the pivot point to the
tool component. If this value is defined, the corresponding tool component origin
will define the tool component point. If this value is not defined, the active tool
component origin will be used. See the illustration above.

711
PlaneAxisMapping Control mapping of working planes between XYZ and UVW
axes. This macro should be called via the G17, G18, G19 groups. It defaults to
defining the planes with the XYZ axes. If U,V, or W are specified on the line, the
corresponding axis will be used with circles and cutter comp. This macro should be
called after motion.
PlaneAxisVectorX This macro sets the X value for the specified axis. The axis is
specified with the text value. Valid axes are: "X", "Y, and "Z". This data can be
used with WorkingPlane2Abc.
PlaneAxisVectorY This macro sets the Y value for the specified axis. The axis is
specified with the text value. Valid axes are: "X", "Y", and "Z". This data can be
used with WorkingPlane2Abc.
PlaneAxisVectorZ This macro sets the Z value for the specified axis. The axis is
specified with the text value. Valid axes are: "X", "Y", and "Z". This data can be
used with WorkingPlane2Abc.
PolarAngle This macro accepts up to 2 polar angles. A simple form of a polar
command is: A140 X60 This says, start at an angle of 140 degrees, and continue
until you reach X60. We also support complex Siemens 840C commands in the
form: A110 A170 X90 Z-70 B15 B3
PolarInterpolation Turns on and off polar interpolation. 1 for On, 0 for Off.
NOTE: The "interpolation" state (None, Polar, or Cylindrical) is supported
as a conditional state, and can be displayed in the Status window.
PolarLinearAxis Sets the linear axis that will driven based on the Cartesian
coordinates. The data is passed as either a 1, 2, or 3 (X, Y, Z). The default is 1.
PolarRotationalAxis Sets the rotational axis that will be driven based on the
Cartesian coordinates. The data is passed as either a 4, 5, or 6 (A, B, C). The
default is 6.
PolarXValue, PolarYValue, PolarZValue Sets the XYZ Cartesian coordinate
values for Polar Interpolation.
PreToolCompSelect Stores the pre-selected tool component number.
Probe Turns on probing for the current block. This macro is associated with the
active tool component, and the corresponding tool must be a Probe Tool. The axes
move until they arrive at the programmed location, or until the probe contacts
something.
When a "Probe" action occurs:
The spherical probe tip(s) are processed through a special algorithm that computes
an accurate "hit" location. The location is based on the "great circle" of the sphere
which lies in the motion plane. The axes are moved to that location. If the spherical
probe tip contacts at any other location other than the "great circle" a warning
message is output and motion stops at the alternate location. If no contact is
detected, motion continues to the programmed location. Standard collision logic is
used to determine if any other component hits something during the probe motion,
but the motion continues to the probe destination.
NOTE: The Probe macro requires a CNC Machine Probing license.
ProcessCompNameValue Sets the position of the component whose name is

712
specified in the input text string to the specified numeric value.
ProcessCompRegValue Sets the position of the component whose register value is
specified in the input text string to the specified numeric value.
ProcessMotion Processes the motion associated with the previous set of
commands. This command is automatically called at the end of the block. This
command can also be called as a macro to create additional motion.
ProcessTimeOnOff Turns machining time On and Off during toolchain
operations. This allows the system to ignore times from tool changer motions and
only use the exact exchange time defined in the toolchain component dialog. A
override value of zero turns time off , and a value of one turns time back on.
ProgramStartNextLine Marks the following block as the first block of the
program. This is used when the beginning of a file contains subroutines followed
by a specific code which marks the beginning of the program.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
RapidPlanePriorityType Supports the concept of the motion of a rapid move
being dependent on the plane rather than the machine axis. To turn on this
capability, this macro should be called during start of processing with an override
value of 1.
Sets a flag which determines whether the rapid motion should be dependent on the
active plane, and if so, the type of rules that should apply. Default is zero. Currently
supported values are:
0: Rapid is NOT dependent on active plane.
1: Rapid IS dependent on active plane.
Movement to workpiece: rotaries, then linear in plane, then normal to plane
Movement away from workpiece: normal to plane, the linear in plane, then rotaries
NOTE: If motion is set to be dependent on active plane, the rapid priority
axis should probably be set to moving at the same time with all axis
interpolated.
Rcode Depending on the motion type (circular or non-circular), either sets the
radius of a circle, or sets the R point level of a cycle. For a circle the interpretation
of the center point is dependent on the Circles control settings.
ReferencePoint Causes a return to the machine reference point for the axes
specified on the block. This action occurs after block motion has been processed.
ReferencePointCancelOffsets Causes a return to the machine reference point for
the XYZ axes specified on the block. This action occurs after block motion has
been processed. The corresponding work and shift offsets for the specified axis are
also reset to 0.
ReferencePointIndex Causes a return to the machine reference point for the axes
specified on the block. This macro is identical to ReferencePoint, except the

713
incoming numeric value will be used as an index into the Machine Reference
Location table.
NOTE: ReferencePoint always uses index 1.
ResetIfCheck Resets the IfCheck condition to TRUE.
ResetWorkCoordParms The WorkCoord...Value macros set a flag indicating that
a value has been specified for the corresponding axis. These flags are reset (to not
present) on each block. This macro is also used to reset these flags. This macro
only needs to be called if the control allows multiple sets of Work Coordinate
values to be specified on a single block. This macro was specifically implemented
for the G&L control. See "Notes about shift macros" for additional information.
RestoreMotionType Restores the motion type to the last non-rapid motion.
RestoreSubsystemID Restores the active subsystem to the one that was active
prior to calling SetSubsystemID().
NOTE: This routine calls SetSubsystemID to set the active subsystem
RestoreUnits Restores the units to the previous saved value. See SaveUnits.
RetractLevelClearanceRetract Sets the Cycle Return Level to "Clearance +
Retraction". See corresponding documentation on the Configuration menu >
Control Settings: Cycles tab.
NOTE: The menu sets the default value for Cycle Return Level and this
macro updates the current value.
See also: RetractLevelInitial, RetractLevelRpoint, and
RetractLevelSpecifiedpoint.
RetractLevelInitial Sets the retract level to be the initial level at the point at which
the cycle mode was turned on.
RetractLevelRpoint Sets the retract level to the R point level.
RetractLevelSpecifiedpoint Sets the retract level to a specified point. This point is
specified with either [XYZ]RetractSpecifiedpoint macros.
ReturnFromSub This macro is identical to EndSub, except it does not mark the
current location as the end of the subroutine. This allows for multiple "returns"
from a given subroutine.
NOTE: If this macro is called rather than EndSub, there will need to be
some other event to mark the end of the subroutine.
ReturnFromSubCall This macro is identical to ReturnFromSub, except it will
only be executed if you are currently with a subroutine.
RotaryAxisLinearRewind Converts the current position of the specified rotary
component (specified by name) to a value between 0-360. No motion takes place.
Use the Overide Text field to pass the axis component name, e.g.:
A,B,C,A2,B2,C2.
See also: RotaryLinearRewind
RotaryAxisLinearRewind360_360 Converts the current position of the specified
rotary (specified by name) to a value between -360 and 360. No motion takes place.
Use the Overide Text field to pass the rotary name, e.g.: A,B,C,A2,B2,C2. This
conversion will be conditional upon the current position being beyond a minimal

714
position (specified by the numeric value).
See also: RotaryLinearRewind360_360
RotaryControlPointOnOff Sets the Rotary Tool Control Point ("RTCP") and/or
Rotary Part Control Point ("RPCP"), as determined by the NC machine
configuration. When called with a value of "1" the macro turns ON a combination
of RTCP and RPCP for the machine being used. A value of "0" turns OFF the
RPCP and/or RTCP functions.
See also: RpcpOn, RpcpOff and RtcpOn, RtcpOff
RotaryDirCCW, RotaryDirCW Sets the direction for a EIA (360 Absolute)
rotary table to be always Counter Clockwise or Clockwise, respectively. By
default, the affect applies to all rotary axes. Individual rotary axes can be controlled
via entering the axis name in the Override Text field, e.g.: "AAXIS", "BAXIS",
"CAXIS", "A2AXIS", "B2AXIS", "C2AXIS".
RotaryDirLinear Sets the direction for a EIA (360 Absolute) rotary table to be
linear. The value will be first converted into a number between 0 and 360, and then
the rotation will act as if it is a linear table. By default, the affect applies to all
rotary axes. Individual rotary axes can be controlled via entering the axis name in
the Override Text field, e.g.: "AAXIS", "BAXIS", "CAXIS", "A2AXIS",
"B2AXIS", "C2AXIS".
RotaryDirPosCCW Sets the direction for a EIA (360 Absolute) rotary table to be
Counter Clockwise when the angle is positive and Clockwise when the angle is
negative. By default, the affect applies to all rotary axes. Individual rotary axes can
be controlled via entering the axis name in the Override Text field, e.g.: "AAXIS",
"BAXIS", "CAXIS", "A2AXIS", "B2AXIS", "C2AXIS".
RotaryDirPosCW Similar to RotaryDirPosCCW, but rotary directions are
reversed.
RotaryDirShortestDist Sets the direction for a EIA (360 Absolute) rotary table to
be the direction which is the shortest distance from the current position. By default,
the affect applies to all rotary axes. Individual rotary axes can be controlled via
entering the axis name in the Override Text field, e.g.: "AAXIS", "BAXIS",
"CAXIS", "A2AXIS", "B2AXIS", "C2AXIS".
RotaryLinearRewind Converts the current positions of the A,B,C,A2,B2,C2
Rotary Linear tables to an absolute value between 0-360. No motion takes place.
See also: RotaryAxisLinearRewind
RotaryLinearRewind360_360 Converts the current positions of the
A,B,C,A2,B2,C2 Rotary Linear tables to an absolute value between -360 and 360.
No motion takes place. This conversion will be conditional upon the current
position being beyond a minimal position (specified by the numeric value).
See also: RotaryAxisLinearRewind360_360
RotaryTypeAbsolute This macro changes the Rotary Type to Absolute for the
specified axis. The corresponding axis is specified as a TEXT argument.
Possible options are: AAXIS, BAXIS, CAXIS, A2AXIS, B2AXIS, and C2AXIS.
No other action is taken. The type of Absolute table will be based on previous
settings.

715
NOTES:
1. When in absolute mode, the input angle will be converted to an angle
between 0-360 when the corresponding AxisMotion command is
executed.
2. RotaryTypeAbsolute only sets the rotary table type, and is NOT
related to the series of macros which set the direction for an Absolute
table (RotaryDirCCw, RotaryDirCW, RotaryDirLinear,
RotaryDirPosCCW, RotaryDirPosCW, RotaryDirShortestDist).
RotaryTypeLinear This macro changes the Rotary Type to Linear for the
specified axis. The corresponding axis is specified as a TEXT argument.
Possible options are: AAXIS, BAXIS, CAXIS, A2AXIS, B2AXIS, and C2AXIS.
NOTE: RotaryTypeLinear only sets the rotary table type, and is NOT
related to the series of macros which set the direction for an Absolute table
(RotaryDirCCw, RotaryDirCW, RotaryDirLinear, RotaryDirPosCCW,
RotaryDirPosCW, RotaryDirShortestDist).
Rotate Renamed to RotateMacro.
RotateCancel Cancels the current rotation.
RotateMacro Fanuc specific 2D rotation that causes the coordinate system to be
rotated, within the active plane, by a specified angle. The angle is specified with the
RotationAngle macro. The center of rotation can be specified with calls to the
RotateXValue, RotateYValue, and RotateZValue macros. The XYZ values are
based on the current coordinate system. The rotation angle is based on the machine
coordinate system.
If the first motion block following the call to RotateMacro is in Incremental mode,
the center of rotation will be ignored.

EXAMPLE:

G90X0Y0 ==> X0 Y0
G68X1Y1R45
X0Y0 ==> X1 Y-.4142 The G68 cause the origin to be
shifted
X1 ==> X1.707 Y.2929
Y1 ==> X1, Y1
X0 ==> X.2929, Y.2929
Y0 ==> X1 Y-.4142
G91G68X1Y1R45 ==> Because of the G91, rotate angle is now 90.
Center is independent of G90/G91 mode for this block.
G90X0Y0 ==> X2 Y0
X1 ==> X2 Y1
Y1 ==> X1 Y1
X0 ==> X1 Y0
Y0 ==> X2 Y0
RotateOrigin 2D rotation that causes the coordinate system to be rotated within
the active plane by a specified angle. The angle is specified with the RotationAngle

716
macro. The center of rotation is always the current origin. The rotation angle is
based on the machine coordinate system.
EXAMPLE:

G90X0Y0 ==> X0 Y0
G68X1Y1R45
X0Y0 ==> X0 Y0
X1 ==> X.707 Y.707
Y1 ==> X1, Y1.414
X0 ==> X-.707, Y.707
Y0 ==> X0 Y0
G91G68X1Y1R45 ==> Because of the G91, rotate angle is now 90.
G90X0Y0 ==> X0 Y0
X1 ==> X0 Y1
Y1 ==> X-1 Y1
X0 ==> X-1 Y0
Y0 ==> X0 Y0
RotateTurningTool Obsolete; no longer exists.
RotateXValue, RotateYValue, RotateZValue Sets the XYZ coordinate values of
the point of rotation.
RotateXYZ 2D rotation that causes the coordinate system to be rotated, within the
active plane, by a specified angle. The angle is specified with the RotationAngle
macro. The center of rotation can be specified with calls to the RotateXValue,
RotateYValue, and RotateZValue macros. The XYZ values are based on the
current coordinate system. The rotation angle is based on the machine coordinate
system. This macro is identical to the Fanuc specific RotateMacro except is
independent of the mode of the block following the G68 command. See
RotateMacro for a GCode example.
RotationAbsAngle Sets the total rotation angle to be the specified value.
RotationAngle Specifies the angle to be used with the 2D rotation macros
(RotateMacro, RotateXYZ, RotateOrigin, OkumaShiftRotate). The angle will be
interpreted as absolute or incremental depending on the current mode (G90/G91).
This macro will also adjust for mirroring.
See also: RotationAbsAngle and RotationIncAngle
RotationIncAngle Increments the total rotation angle by the specified value.
RotationPlane Turns on the rotation plane using the values specified via the
RotationPlaneX[YZ]Point and RotationPlaneAngle1-3 macros. (Don't recalculate
the current position into the new coordinate system.) The rotation plane remains
active until replaced by a new rotated plane, or cancelled via RotationPlaneCancel.
RotationPlane2 Similar to RotationPlane. However, these two macros differ in
how they calculate the initial motion after setting the rotation plane, particularly in
the case where all axes are not programmed. RotationPlane2 recalculates the
current position into the new coordinate system, where RotationPlane does not.
RotationPlaneAngle1, RotationPlaneAngle2, RotationPlaneAngle3 Defines the
first, second, third angles to be applied, respectively. An Override Text value of

717
"X", "Y", or "Z" defines the axis about which to apply each rotation. Rotation is
performed in numeric order- angle 1 first, angle 2 second, and so on.
See also: RotationPlaneIncAngle1-3
RotationPlaneCancel Cancels the rotation plane put into affect via the
RotationPlane or RotationPlane2 macros.
RotationPlaneCancel2 Calls RotationPlaneRestoreAxis, then cancels the rotation
plane put into affect via the RotationPlane or RotationPlane2 macros.
RotationPlaneCancelReset Resets all rotation plane values to 0.0, calls
RotationPlane2 to restore the current axis values, and then turns off the rotation
plane.
RotationPlaneEnable2 This macro restores the restores the previously set rotation
plane, and converts the current local axis position into the new coordinate system.
Inputs:
Text Value: Unused
Numeric Value: Unused
NOTE: This macro does not recalculate the matrix. If RotationPlaneCancel2 is
used to turn off the rotation plane, then this macro can be used to get you back to
where you were.
RotationPlaneIncAngle1, RotationPlaneIncAngle2, RotationPlaneIncAngle3
Defines incremental adjustments to be made to the first, second, third rotation plane
angles defined via the RotationPlaneAngle1-3 macros. An Override Text value of
"X", "Y", or "Z" defines the axis about which to apply each incremental
adjustment.
RotationPlaneIncXPoint, RotationPlaneIncYPoint, RotationPlaneIncZPoint
Defines the XYZ center point of rotation for incremental rotation adjustments
performed by the RotationPlaneIncAngle1-3 macros.
RotationPlaneLocal Adjusts how the existing rotation plane values are interpreted
(ref. RotationPlaneAngle1). When called, rotation plane values are interpreted as
incremental rotations and translations within the current rotation plane.
RotationPlaneLocal2 Similar to RotationPlaneLocal, but they differ in how they
calculate the initial motion after setting the rotation plane, particularly in the case
where all axes are not programmed. RotationPlaneLocal2 recalculates the current
position into the new coordinate system, where RotationPlaneLocal does not
RotationPlaneRestoreAxis Converts the previously specified axis into a non-
rotated plane coordinate system. This macro should be called prior to cancelling a
rotation plane via RotationPlaneCancel.
RotationPlaneSpecialOffset Specifies whether or not to specially handle the
changing of offsets while a RotationPlane is in effect. Passing an Override value of
"1" turns on this feature. Any other value passed to the macro turns this feature off.
The default is no special handling of offsets for rotation planes
RotationPlaneXPoint, RotationPlaneYPoint, RotationPlaneZPoint Defines the
XYZ center point of rotation performed by the RotationPlaneAngle1-3 macros.
RpcpOn, RpcpOff Turns Rotary Part Control Point ("RPCP") processing on or

718
off, respectively. When RPCP is active, the part is moved relative to the tool tip to
reflect changes in any rotary axis on the part side of the NC machine (Base to Stock
components). An RPCP Pivot Offset table is available to override the system-
calculated RPCP pivot offset distance. When the table exists, its value is used to
offset the part during rotary operations.
See also: RotaryControlPointOnOff and RtcpOn, RtcpOff
RPM Renamed to RPMSpeed.
RPMMode Sets the current mode to constant RPM's.
RPMSpeed Sets the spindle speed in RPM's.
RtcpContour Controls the RTCP mode: contouring vs. non-contouring. When
passed an OverrideValue of "1", puts the RTCP in contouring mode (offsets are
updated on every intermediate move). A value of "0", puts the RTCP in non-
contouring mode. The default is 1.
NOTE: The default mode for RtcpContour can be set in the Configuration
menu > Control Settings: Rotary tab. You can then over-ride the default
mode with this macro.
RtcpOn, RtcpOff Turns Rotary Tool Control Point ("RTCP") processing on or off,
respectively. After turning RTCP on, the UpdateRotaryOffsets macro should be
called to make sure that all internal offsets are updated. This macro should
probably be executed after motion or a block by itself. An RTCP Pivot Offset table
is available to override the system-calculated RTCP pivot offset distance. When the
table exists, its value is used to offset the part during rotary operations.
See also: RpcpOn, RpcpOff and RotaryControlPointOnOff
RtcpWithMotion When passed an OverrideValue of "1", causes the RTCP
updated offsets to only take effect when the corresponding axis is specified. A
value of "0", causes the offsets to take effect immediately. For the most part, this
macro is only applicable when in non-contouring mode. The default is 1.
NOTES:
1. This command is dependent on RTCP being turned on (See RtcpOn).
2. The default mode for RtcpWithMotion can be set in the
Configuration menu > Control Settings: Rotary tab. You can then
over-ride the default mode with this macro.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
SaveUnits Saves the current Units settings. See also RestoreUnits.
SecondaryRefWorkCoord This macro is identical to SecondaryWorkCoord,
except it interprets all rotary angles as a reference position from which the offset
was measured.
SecondaryWorkCoord This macro is identical to AdditionalWorkCoord, except it

719
establishes a secondary work offset which is added to the existing work offset (e.g.
G54-G59). Both of these macros reference the same work offset table.
Sequence During pass 1, updates the sequence table and set the current sequence
number.
SequenceEnd Specifies the ending sequence number within a sequence loop.
SequenceLoop Executes the sequence loop based on previously set parameters. If
the loop count was not specified, 1 is assumed. If the ending sequence number was
not specified, the starting sequence number is assumed.
SequenceLoopCount Specifies the number of times to execute the sequence loop.
SequenceOrSubroutine Determines whether the current input is a sequence
number, or a subroutine name. At the time the macro is called, if it is currently
within a program or subroutine, it will be interpreted as a "sequence number", and
the Sequence macro called. Otherwise, it will be interpreted as a "subroutine name"
and the SubroutineSequence macro will be called.
For example:
O100
.
.
.
N10
.
.
M99
N20
O: Defines the beginning of subroutine 100
N10: Defines Sequence 10
M99: Defines the end of subroutine 100
N20: Defines the beginning of subroutine 20
NOTE: The defining of the start and ending of subroutines, and the
sequence numbers that exists for a given subroutine, occurs during the scan
pass.
SequenceStart Specifies the starting sequence number within a sequence loop.
SequenceStartEnd Defines the start and ending sequence number within a
sequence loop. This macro is called twice within a block. On each call, either the
start or ending sequence number is passed. The starting sequence number is defined
to be the lower of the two numbers.
SetAbsWorkCoord Similar to SetAdditionalWorkCoord, except the offsets are
always interpreted as absolute values (not incremental).
SetActiveSpindleName Specifies the active spindle component for the current
subsystem. The spindle name is specified by the Text argument. This macro is
typically used to change where material removal occurs when simulating pick-off
spindle operations. Specifically, this macro has 2 main functions:
When in turning mode, it is used to defines the point of rotation. This is

720
important when in Constant Surface Speed (CSS) mode.
It defines the active stock component. The stock that is a child of the active
spindle component becomes the active stock component. This setting is
critical for a number of different calculations within VERICUT.
NOTE: If not specified, the active spindle will default to the parent
Spindle, or Rotary, of the active stock component. If the active stock
component is not specified, the active stock will default to the first stock
component in the component tree.
SetActiveStockName Specifies the active stock component for the current
subsystem. The stock name is specified by the Text argument. This macro is
typically used to change where material removal occurs when simulating pick-off
spindle operations. Specifically, this macro has 2 main functions:
When in turning mode, it is used to define the point of rotation. The point of
rotation is the parent spindle axis. This is important when in Constant
Surface Speed (CSS) mode.
It defines the active stock component. This setting is critical for a number of
different calculations within VERICUT.
NOTES:
The calling of this macro is only necessary for SYNC type jobs or jobs with
multiple Stock components.
This macro is functionally identical to SetActiveSpindleName. Its main
purpose is to specify whether you are working on the stock (spindle) or
the sub-stock (pick-off spindle). To avoid confusion with
ActiveSpindleName (which has a similar name but a totally different
functionality), it is recommended that you use SetActiveStockName
rather then SetActiveSpindleName. The difference between these 2
macros is that SetActiveStockName is passed the name of the stock
component, and SetActiveSpindleName is passed the name of the
Stocks spindle component.
SetAdditionalWorkCoord Sets entries 0-59 in the Work Offsets table. The work
coordinate index must be between 0-59. The corresponding entry in the table are
then updated based on the specified XYZ values. If an XYZ value is not specified,
the corresponding entry is not updated. Also see:
SetAdditionalWorkCoordNonModal
SetAdditionalWorkCoordNonModal This macro is identical to
SetAdditionalWorkCoord except that all offset values are non-modal. Any axis
offset value not specified on the current block will be set to zero.
SetAxisCompLink Establishes a "link" which allows the axis specified by
LinkAxisId to drive the component specified with LinkCompName, using the
formula specified by LinkFormula. For situations where an "offset" is applied to
driving axis, use the LinkOffset macro to specify how the offset is to be applied to
the driven component. The Override Text field value determines the action that
occurs:
CLEARALL Deletes all linkages established for all axis.

721
CANCEL Deletes the linkage specified by the specified axis and component
name.
ADD Adds a new linkage based on the specified axis, component name, and
formula. If a "linkage" exists for a given axis, the specified actions will
override the default actions.
See also: "Notes about link macros" in the Using VERICUT section.
SetAxisRegisterName Enables you to switch which "Register" is associated with a
particular axis (X, Y, Z, A, B, C, U, V, W, ...). It is passed in an axis value to
change (1-12), and a text value with the new register name.
For example: to have X drive the U register, and U drive nothing, the following
calls would be made.
SetAxisRegisterName OV=1 OT=U
SetAxisRegisterName OV=7 OT=XXX
SetBaseWorkOffset Sets a base offset and cancels any shift or work coordinate
offsets. The base offset is retrieved from the Base Work Offset table.
SetCircle360Tolearance Sets a tolerance which will be used to determine whether
a small arc or a 360 degree arc should be processed. If the X, Y, and Z start and
finish positions are all within this tolerance, the arc will be interpreted as a 360
degree arc.
NOTE: This value is typically used when problems occur with cutter
compensation.
SetComponentColor Sets the component specified with the override text value, to
the specified color index.
NOTE: See the documentation on Color Definition for a description of
color index value. Basically, it corresponds to the index number in the list of
colors defined on the Color Definition window.
SetComponentVisibility Enables you to "temporarily" change a component's
visibility status by commands in the NC program. The visibility status that is set
will be temporary, and will be reset to the initial values when a "reset" or "rewind"
is executed.
NOTE: A "reset" is executed as part loading a new usr file.
The initial values are defined as the values that are either read in from the
usr/machine file, or were set using the "Visibility" feature on the Model > Model
Definition window, Component Attributes tab. When the job file or machine file is
saved, only the initial value will be saved.
Override Text Value = Component Name
Set Override Value to: 0 = Blank, 1 = Workpiece, 2 = Machine, and 3=Both.
NOTE: This macro does not support setting the visibility of "Tool" or
"Stock" components.
SetCycleSquareOffType Controls how the tool is positioned for a canned cycle
operation (e.g. G81-89). By default, VERICUT uses "squared off" motion to
position for a canned cycle. Squared off motion behaves differently, depending on

722
if the positioning point for the canned cycle is higher or lower relative to the
current tool position:
Positioning point lower than current position Tool moves within the plane,
then drops along the tool axis to the new positioning point.
Positioning point higher than current position Tool retracts first, then moves
within the plane to the new positioning point.
Calling this macro with an Override Value of "1" forces VERICUT to always
move the tool within the plane first, then moving the tool up or down along the tool
axis to the new positioning point. A value of "0" (default) moves the tool as
described above.
SetDynamicVarsConfigures VERICUT for setting Dynamic variables based on
internally calculated values. The macro should be called with the "Start of
Processing" event, and will typically be called multiple times with different
arguments. This macro establishes the values that should automatically update
variables during processing. The macro is passed a series of arguments in the
Override Text field. The first argument defines the Dynamic variable you are
interested in (see below). The remaining arguments depend on the first argument.
(Values are only printed for subsystem 1.) Dynamic variable types:
CurTool #The current tool number will be set in the specified variable
number. The tool number will be as defined before any tool indirection, such
as can occur when a Tool List is in use. Example: Override Text=CurTool
7000
CurCDC #The current cutter comp value will be set in the specified variable
number. Example: Override Text=CurCDC 7000
CurTime #The current time (cycle time) will be placed in the specified
variable. This time is the total time since the last reset. Example: Override
Text = CurTime 3001
NOTE: The status window displays the total time for the current
toolpath.
CurTLCMP #The current tool length comp value will be set in the specified
variable number. This value includes the special "Input Program Zero" logic
for when the programming method is set to "Tool Length Compensation".
Example: Override Text=CurTLCMP 7000
CurToolDiam #The current tool diameter will be set in the specified
variable number. Example: Override Text=CurToolDiam 7000
CurGageOffset # # #The current X,Y,Z gage offset values, as read from
either the Gage Offset table or the Tool Library file, will be set in the 3
specified variable numbers. Example: Override Text=CurGageOffset 7000
7001 7002
CurToolOffset # # # # # # # # #The sum of all tool offsets (Gage Offset,
Tool Nose, Tool Length Comp, Turret, Pivot, RTCP, etc.) will be used to set
the corresponding registers. The register numbers correspond to
XYZABCUVW. Note that this command does not cause the gage offset to be
applied to XYW; it just specifies the variables that should be set for the tool
offsets. Unused axes to the right do not need to be specified. Unused axis in

723
the middle should be specified with a "-1". Examples follow:
Tool offsets applied to the XYZ axes: Override Text=CurToolOffset 3001
3002 3003
Tool offsets applied to the XYW axes: Override Text=CurToolOffset 3001
3002 -1 -1 -1 -1 -1 -1 3003
CurToolType # The current tool type will be set in the specified variable
number. The tool type will be set to 1 for milling tools, and 2 for turning
tools. Example: Override Text=CurToolType 7000
AxisMachineMinus # # # # # # # # #These switches are used to set the
variables associated with the axis positions in a "machine" coordinate
space. These values begin with absolute machine axis location values,
then you can turn off individual offsets to have them subtracted from the
stored machine position. Set the switch to "1" if you want it subtracted,
and "0" if you do not want it subtracted. With all switches set to "0", the
machine axis positions will match the machine axis position fields seen on
the Status window. The available switches from left to right are: Gage
Offset, Tool Offset, Work Offsets (Sum of Base Work Offset and Work
Offset), Shift Offsets (Sum of all shift offsets), 3D Tool Offset, Input
Program Zero, Input Machine Zero. Unused axes to the right do not need
to be specified. Unused axis in the middle should be specified with a "-1".
The switches default to 0. Trailing zeros do not need to be specified. The
field must contains at least one 0/1 character. Examples follow.
Print the machine's axes for a 4-axis machine with a B rotary: Override
Text=AxisMachineMinus 0 1000 1001 1002 -1 1004
Print the machine's axes minus the Input Program Zero values for a 4-
axis machine with a B rotary: Override Text=AxisMachineMinus
000001 1000 1001 1002 -1 1004
AxisLocalPlus # # # # # # # # #These switches are used to set the variables
associated with the axis positions in a "local" coordinate space. This
option is similar to AxisMachineMinus, except they begin with the G-
code tool path input values, then add on offsets. Note that turning all
switches on is NOT the same as AxisMachineMinus with all switches set
to "0". Rotated planes, cutter compensation, and other special commands
are only being applied to the machine axis values. With all switches set to
"0", the values will be equal to the G-code tool path input except when in
incremental mode, G68/69 rotations in affect, or mirroring is active. The
switches are the same as described above for AxisMachineMinus.
Unused axes to the right do not need to be specified. Unused axis in the
middle should be specified with a "-1". The switches default to 0. Trailing
zeros do not need to be specified. The field must contains at least one 0/1
character. Examples follow.
Print the local axes for a 4-axis machine with a B rotary: Override
Text=AxisLocalPlus 0 1000 1001 1002 -1 1004
Print the local axes plus the gage offset for a 4-axis machine with a B
rotary: Override Text=AxisMachineMinus 1 1000 1001 1002 -1

724
1004
See also: "Notes about system variables" in the Using VERICUT section.
SetGageOffset Sets the Gage Offset based on the Gage Offset table and the
specified index value. If the entry does not exist, and the index value is zero, the
Gage Offset is set to zero. If neither of these conditions are true, the Gage Offset is
picked up from the TLS file (referencing the active tool). Also see:
SetGageOffsetSubValue and SetMatchingGageOffset.
NOTE: It is not necessary to call ToolOffsetAptAdj when using this macro.
SetGageOffsetSubValue Sets the Gage Offset based on the Gage Offset table, the
current tool number and the specified SubValue (SubRegister). If the entry does
not exist, and the SubValue is zero, The Gage Offset is set to zero. If neither of
these is true, it picks up the Gage Offset from the TLS file (referencing the active
tool). Also see: SetGageOffset.
NOTES:
1. It is not necessary to call ToolOffsetAptAdj when using this macro.
2. The current tool number refers to the tool number that is specified in
the MCD file (T1M6, T0101, &), not to the Tool Id that is specified
in the TLS file which is a string.
SetIncWorkCoord Similar to SetAdditionalWorkCoord, except the offsets are
always interpreted as incremental values (not absolute).
SetLocalVariableCount Sets the number of local variables that are defined within
a "MACRO" subroutine. The default is 34 (0-33).
SetMatchingGageOffset This macro is identical to SetGageOffset, except that if
the specified value is non-zero, and it does not exist in the Gage Offset table, and it
does not match the current tool, then an error message will be produced, and the
offset will default to (0,0,0).
SetMaxSubsystemVar Sets the "Maximum" value of a NC variable that is
subsystem specific.
NOTES:
1. In the variables window, 1:45 corresponds to variable 45 for
subsystem 1. If a variable is higher than the max, it will be referenced
as global, and not specific to a subsystem.
2. You can define both a "Minimum" and a "Maximum" value by also
using SetMinSubsystemVar.
SetMinSubsystemVar Sets the "Minimum" value of a NC variable that is
subsystem specific. The default is -1, which means that there is no minimum value.
NOTE: You can define both a "Minimum" and a "Maximum" value by also
using SetMaxSubsystemVar.
SetMotionFlag This macro sets a flag saying that there is motion on the block.
Typically, this macro never needs to be called. This flag will automatically be set if
a macro is called which causes motion. An example of where this macro would
need to be called is:

725
G81 R1=.1 R2=.2
A cycle command is being issued, but no XYZ command is being specified.
Typically, G81 is interpreted as "Cycle on Motion". If no motion is specified, then
a cycle is not executed. If the cycle is to be executed on this block, then the
SetMotionFlag could be called with the G81 to process the block as a motion
block.
SetPivotOffset Sets the pivot offset for a tool component connected to a rotary
component. This macro should be passed the index into the RTCP Pivot Offset
table. If the entry in the table does not exist, the system automatically calculates the
Z offset value using the distance from the Tool component to the pivot point of the
rotary axis to which the Tool component is connected (X and Y offsets set to 0). If
the tool axis and the rotary axis are collinear, then the RTCP Pivot Offset will be
set the to difference between the Tool and the Rotary component origins.
NOTE: If a spindle changer is being used for a job in Tool Tip mode and
using RTCP, then the RTCP Pivot Offset table needs to be set whenever a
new spindle is attached.
SetProgrammingMethod Use to set the programming method through the MCD
file. This macro should be passed a numeric value which will determine the
programming method. A value of: 0 = Tool Tip, 1 = Gage Length, 2 = Tool Length
Compensation
The new setting will be in effect until the next call to this macro, or until the next
reset.
Warning: The programming method effects how various tool offsets are applied.
Calling this function will not effect the offsets that are already in effect. It will,
however, effect the offsets that next time they are updated (for example, tool
change, rotary move with dynamic offset, call to UpdateRotaryOffsets, call to
ToolOffsetUpdate, ...).
SetSubsystemID Sets the current subsystem to the input text string value.
SetTableCoord The text string contains the table name to be set. This macro sets
the entry (specified by TableIndex) in this table to the values specified with the
WorkCoord[axis]Value macros. Nine values will be stored in the table. Any value
not set in the block will assume to be zero.
SetTableValues This macro sets the entry (specified by TableIndex in this table)
to the values specified in TableValues. The order of the values passed to
TableValues will be the order stored in the table. The number of values stored will
be equal to the number of times TableValues was called on this block. Use the
Override Text field to specify the name of the table.
NOTES:
1. The table must be defined before this macro is called. See About
configuring tables for more information.
2. TableIndex and TableValues must be called before calling
SetTableValues. The order in which TableIndex and TableValues
macros are called is not significant, as long as they are called before
calling SetTableValues.

726
SetToolNumVar When passed an override text value of the variable to be set, this
macro will set this variable to be the current tool number. Typically, this would be
called immediately after ToolChange.
SetVCMultiTools When passed an override value of 1, VERICUT will cut with all
tools defined on the machine at every block.
SetVNCKOption This macro sets several 840D Virtual NC Kernel and
Interface (VNCK interface) options. See the VNCK Interface documentation, in
the Converters and Interfaces section, for complete details.
SetWorkCoord Sets entries 53-59 in the Work Offsets table. The work coordinate
index must be between 0-6. The corresponding entry in the table are then updated
based on the specified XYZ values. If an XYZ value is not specified, the
corresponding entry is not updated.
ShortLongOffsetReset Turns off CutterCompDoubleLong,
CutterCompDoubleShort, CutterCompLong and CutterCompShort.
Siemens3CmdBranch The value passed is the sequence number to branch to. If an
additional argument is passed, then it is added to the absolute value of the sequence
number. This routine then calls the GotoJumpForwardBackward macro. If more
than 2 arguments were passed, then an error message will be printed.
Siemens3CmdIfEqual The value passed is the sequence number to branch to. If
argument 1 is equal to argument 2, then GotoJumpForwardBackward is called to
branch to the specified sequence number. If an additional argument is passed, then
it is added to the absolute value of the sequence number. If less than 2 arguments,
or more than 3 arguments were passed, then an error message will be printed.
Siemens3CmdIfGreater The value passed is the sequence number to branch to. If
argument 1 is greater than argument 2, then GotoJumpForwardBackward is called
to branch to the specified sequence number. If an additional argument is passed,
then it is added to the absolute value of the sequence number. If less than 2
arguments, or more than 3 arguments were passed, then an error message will be
printed.
Siemens3CmdIfGreaterEqual The value passed is the sequence number to branch
to. If argument 1 is greater than or equal to argument 2, then
GotoJumpForwardBackward is called to branch to the specified sequence number.
If an additional argument is passed, then it is added to the absolute value of the
sequence number. If less than 2 arguments, or more than 3 arguments were passed,
then an error message will be printed.
Siemens3LoadAddress Sets the contents of the address parameter specified by
Siemens3SetAddressParm to the specified value. If a variable argument is
specified, it will override the input value. A value of 1 corresponds to the X Axis, a
value of 2 corresponds to the Z axis.
Siemens3PreProcessorControls when a Siemens 3T PreProcessor translates blocks
of Siemens 3T type data into a more standard form. This preprocessor is specific to
the Siemens 3T syntax, and should not be used with the Siemens 880 or the
Siemens 7M controllers. The preprocessor will be activated after reading a block
from the MCD file, and before substitutions.
This macro should be passed a value of 0 or 1. A value of 0 turns off the Siemens 3

727
preprocessor, a value of 1 turns on the Siemens 3 preprocessor. If used, this macro
should be called during the NEW "Reset" event.
The following conversions are made by the preprocessor:
R20 200 R30 300 => R20=200 R30=300
R30 R20 => R30=R30+R20
R30-R20 => R30=R30-R20
R30/R20 => R30=R30/R20
R30.R20 => R30=R30*R20
R305 => R30 =5
R30.5 => R30 =.5
Z1.6 R07 => Z1.6+R07
R30 0 R20 => R30=R20
R10 R20.R30 => R10=R10+R20 R20=R20*R30
X1.5 R10 R20 => X1.5+R10 R10=R10+R20
X R10 R20 => X R10 R10=R10+R20
NOTE: OptiPath is not supported with the Sinumerik 3T control.
Siemens3SetAddressParm Sets the address parameter that will be accessed (90-
93). This is necessary since @90 command might be followed by 2 values (@90 0
R10). This allows for @90 to be defined as a word. This word can then have a
value and an optional variable argument.
Siemens3TAddressAxis Calls the corresponding "AxisMotion" macro with the
specified value. If a variable argument is specified, it will override the input value.
The axis to move is specified by contents of the specified address parameter. The
address parameter is set using the Siemens3SetAddressParm macro.
Siemens840DProc This macro processes a Siemens 840D PROC statement. This
includes the processing of all the input Arguments.
The typical scenario would be:
Define the Word: PROC with a subtype of Alpha-Numeric + Arguments.
In the Word Address table, the PROC word will call this macro.
See also: "Notes about the Siemens 840D PROC command" in the Using
VERICUT section.
Siemens840DProcCall This macro is called when calling a Siemens 840D
subroutine (PROC) The text argument passed should be the subroutine name,
optionally followed by a series of arguments enclosed by ( ).
NOTE: This is a black box parser. The user has no flexibility on what can
or cannot be parsed.
The typical scenario would be:
Define the Word: SubroutineName with a subtype of Alpha-Numeric +
Arguments.
When a undefined word is found, a check is made to see if it matches a
subroutine name. If it does, and SubroutineName exists in the word list, then

728
it will associate the value that follows with the SubroutineName word.
In the Word Address table, this word should then call the above macro.
See also: "Notes about the Siemens 840D PROC command" in the Using
VERICUT section.
Siemens840DSubroutineSequence This is a Siemens 840D specific version of the
SubroutineSequence macro. This macro will look for a series of suffixes, and if it
finds one, it will strip it, and then pass the name to SubroutineSequence. The
suffixes that will be stripped include: _MPF, _SPF, _TEA, _SEA, _TOA, _UFR,
_INI, _GUD, _RPA, _COM, and _DEF
The typical configuration will be as follows:
Define %_N_ as a word with an Alpha-Numeric variable type
Within the word address table, have the word "%_N_" call
Siemens840DSubroutineSequence
SiemensActualSpindle Marks which spindle this controller is currently working
on. If this spindle has previously been marked as being controlled by this
controller, this controller will now takes control. (M*=26)
This macro:
y Sets a Siemens internal value defining the actual spindle.
y Passes the spindle number as the numeric value.
y Restores the internal spindle speed for this channel if the speed for this
spindle is being controlled by this channel.
y Sets the controlling head (sync mode).
NOTE: SetActiveSpindleName should also be called.
SiemensCmd300,SiemensCmd302 The NC-Machine addresses (@300-@302) are
referenced as subsystem 10.
The following notes apply to all "300 series" macros described below:
NOTES:
1. All series 300 macros "transfer machine data into R-Parameter". All
macros in this series treat machine addresses as variables.
2. In Machine Simulation, these addresses have no additional meaning.
This means that each must be set before they are used.
SiemensCmd303,SiemensCmd305 The Cycle Machine addresses (@303-@305)
are referenced starting at subsystem 100. (For example if the command references
channel 2, the macro would reference subsystem 102).
See general "300 series" notes above.
SiemensCmd306, SiemensCmd308 The PLC address (@306-@308) are
referenced as subsystem 11.
See general "300 series" notes above.

SiemensCmd330 This macro is used to process the Siemens @330 command. This
macro sets a variable with the value of the associated work offset. It must be passed

729
the order of the Axes as an Override Text value. For example: XYZAC. It also
must be passed 4 arguments See ValueArgument.
The arguments have the following meanings:
y variable to be set
y offset number (1 for G54 , 2 for G55, 3 for G56, 4 for G57)
y axis number (the order of the axis must be specified in the Override Text
argument)
y Coarse/Fine value (currently ignored)
Example: @330 R81 K1 K2 K0 The second axis value of the G54 offset is
loaded into parameter R81.
SiemensCmd331 Loads the G58/G59 offset for the specified axis.
NOTE: This macro has been hard coded to work with machines with
subsystem "1" for the upper turret, "2" for the lower turret, and "4" for the Z
axis of the subspindle. Subsystems 3 and 5 are not currently supported.
See general "300 series" notes above.
SiemensCmd360 This macro assumes the following:
y The workpiece is located at 0 0 0.
y For rotaries, the last rotary move has completed.
y The following specific component names:
Turret 1 X - X1
Turret 1 Z - Z1
Turret 2 X - X2
Turret 2 Z - Z2
Counter Spindle Z - Z4
Turret 1 Y - Y1
See general "300 series" notes above.
SiemensCmd383 The following are the only arguments that are supported. The
corresponding bit flag will be placed into the first argument.
ARG 2 ARG3 ARG4 ARG5 MEANIN
G
1 32 5 15 Z-axis
mirroring
on channel
1
1 32 17 15 Z-axis
mirroring
on channel
2
SiemensCmd400 The NC-Machine addresses (@400-@402) are referenced as
subsystem 10.
The following notes apply to all "400 series" macros described below:

730
NOTES:
All series 400 macros "load values into system storage". All macros in
this series treat machine addresses as variables.
In Machine Simulation, these addresses have no additional meaning.
This means that each must be set before they are used.
SiemensCmd403, SiemensCmd404 The Cycle Machine addresses (@403-@405)
are referenced starting at subsystem 100. (For example if the command references
channel 2, the macro would reference subsystem 102).
SiemensCmd430 This command is used to process the Siemens @430 command.
This command sets the values associated with a specific work offset. It must be
passed the order of the axes as an Override Text value. For example: XYZAC. It
also must be passed 4 arguments See ValueArgument. The arguments have the
following meanings:
Offset number (1 for G54 , 2 for G55, 3 for G56, 4 for G57)
Axis number (the order of the axis must be specified in the Override Text
argument
Coarse/Fine value (currently ignored)
Offset value
Example: @430 K1 K2 K0 K500 The value 500 is loaded into the G54
offset for the second axis.
SiemensCmdAbs Take the absolute value of the second argument and stores the
result in the variable specified by the first argument. Arguments are set using
ValueArgument and VariableArgument.
SiemensCmdAngle Takes the arc tangent of y/x (second/third arguments), and
stores the result in degrees in the variable specified by the first argument.
Arguments are set using ValueArgument and VariableArgument.
SiemensCmdASin Takes the arc sine of the second argument, and stores the result
in degrees in the variable specified by the first argument. Arguments are set using
ValueArgument and VariableArgument.
SiemensCmdATan If 2 arguments were passed, takes the atan of the second
argument, converts the results to degrees, and stores the result in the first argument.
If only one argument was passed, takes the atan of the first argument, converts the
results to degrees, and stores the result in the first argument. If no arguments or
more than 2 arguments were passed, issues an error message.
SiemensCmdBranch Branches to the location specified by the first argument.
Arguments are set using ValueArgument and VariableArgument.
SiemensCmdCase Processes a Siemens "Case" statement. The first argument is the
value being tested. It is followed by a series of value pairs (value, branch location).
If the values match, a branch is made to the specified location. Arguments are set
using ValueArgument and VariableArgument.
SiemensCmdCos Takes the cosine of the second argument (in degrees), and store
the result in the variable specified by the first argument. Arguments are set using
ValueArgument and VariableArgument.

731
SiemensCmdDec Decrements the value of the specified variable. Arguments are
set using VariableArgument.
SiemensCmdGetChannel Returns the current channel number. This macro
assumes that the channel number is the subsystem. In our system, the subsystem is
an alphanumeric string. Channel numbers are integers. This macro therefore
requires that all INDEX machines be built with integer subsystems. (@372)
SiemensCmdGetGCode This macro will return the G-Code state in variable 1 of
the corresponding group specified in variable 3. The channel number in variable 2
is currently being ignored. (@36b)
The following values are returned based on the group:
GROUP VALUES
0 0, 1, 2, 3
1 9
2 17, 18, 19
3 40, 41, 42
4 53
5 Current
Work Offset
6 4
7 60
8 70, 71
9 80
10 90, 91
11 94, 95
12 147
13 50
14 150
15 130
16 230
17 330
18 930
19 400
20 171
21 175
22 720
23 220
24 450
25 455
27 420
28 600
Else 0
SiemensCmdHypot Takes the square root of the sum of the squares of the second

732
and third arguments, and store the result in the variable specified by the first
argument. Arguments are set using ValueArgument and VariableArgument.
SiemensCmdIfEqual, SiemensCmdIfGreater, SiemensCmdIfGreaterEqual,
SiemensCmdIfLess, SiemensCmdIfLessEqual, SiemensCmdIfNotEqual These
macros process Siemens conditional logic. They are in the form: IF A
<conditional> B THEN continue ELSE jump to C. Arguments are set using
ValueArgument and VariableArgument.
SiemensCmdInc Increments the value of the specified variable. Arguments are set
using VariableArgument.
SiemensCmdIntegral Truncates the decimal contents of the specified variable.
Arguments are set using VariableArgument.
SiemensCmdPopVarGroup Causes a series of variables from argument 1 to
argument 2 to be restored by copying them from variable 300+n.
NOTE: This might not be identical to the way the control processes this
command, but it should work for variables 0-200. Various problems and
unknowns were associated with treating this command like a true push/pop
stack.
Example: @043 R61 R69 Copies the contents of variables 361-369 to 61-69.
SiemensCmdPushVarGroup Causes a series of variables from argument 1 to
argument 2 to be copied to variable 300+n.
NOTE: This might not be identical to the way the control processes this
command, but it should work for variables 0-200. Various problems and
unknowns were associated with treating this command like a true push/pop
stack.
Example: @041 R61 R69 Copies the contents of variables 61-69 to 361-369.
SiemensCmdSin Takes the sine of the second argument (in degrees) and stores the
result in the variable specified by the first argument. Arguments are set using
ValueArgument and VariableArgument.
SiemensCmdSquareRoot Takes the square root of the second argument and stores
the result in the variable specified by the first argument. Arguments are set using
ValueArgument and VariableArgument.
SiemensCmdTan Takes the tangent of the second argument (in degrees) and stores
the result in the variable specified by the first argument. Arguments are set using
ValueArgument and VariableArgument.
SiemensCornerValue Sinumerik 3T version of the CornerMode/CornerValue
macros. A negative value sets the Mode to CHAMFER, and a positive value set the
mode to RADIUS. The value also defines the CornerValue.
SiemensCycle95 Executes a Siemen's 840D stock removal turning cycle
(CYCLE95). Parameters for this cycle are programmed as a comma separated
alpha-numeric list. The SiemensCycle95 macro must be associated with the first
list parameter and used with the "after-motion" option to insure all the cycle's
parameters have been processed before the cycle's motions are expanded. The first
parameter of the CYCLE95 is the Siemen's subroutine name defining the cycle's
contour and must be defined as "quoted_text". In addition, the CYCLE95 word

733
must be defined as a "List_alpha_numeric" word type.
SiemensCycle95Type Sets the type of machining being requested with the
Siemen's CYCLE95 stock removal cycle. Legal values are 1 through 12 as defined
in the Siemen's 840D programming manual.
SiemensCycle97 Executes a Siemen's 840D thread turning cycle (CYCLE97).
Parameters for this cycle are programmed as a comma separated numeric list. The
SiemensCycle97 macro must be used with the "after-motion" option to insure all
the cycle's parameters have been processed before the cycle's threading motions are
expanded. The thread endpoints must be set be calling SiemensCycle97Xstart,
SiemensCycle97Xend, SiemensCycle97Zstart, and SiemensCycle97Zend prior to
calling the SiemensCycle97 macro.
SiemensCycle97ArcIn Sets the unsigned arc in extension for a Siemen's 840D
thread turning cycle (CYCLE97).
SiemensCycle97ArcOut Sets the unsigned arc out extension for a Siemen's 840D
thread turning cycle (CYCLE97).
SiemensCycle97FinalAllowance Sets the final allowance for a Siemen's 840D
thread turning cycle (CYCLE97).
SiemensCycle97FinishCuts Sets the number of finish passes for a Siemen's 840D
thread turning cycle (CYCLE97).
SiemensCycle97RoughCuts Sets the number of rough passes for a Siemen's 840D
thread turning cycle (CYCLE97).
SiemensCycle97ThreadStart Sets the thread starting orientation (0 to 359.999
degrees) for multiple threads in a Siemen's 840D thread turning cycle (CYCLE97).
SiemensCycle97Type Sets the type of machining (1 through 4) for a Siemen's
840D thread turning cycle (CYCLE97).
SiemensCycle97Xstart, SiemensCycle97Xend,SiemensCycle97Zstart,
SiemensCycle97Zend Sets the start and end points for a Siemen's 840D thread
turning cycle (CYCLE97). X axis values are defined as radii.
SiemensCycleMillPocketCutType Sets the milled pocket cut type for Siemens
controls. Use instead of macro CycleMillPocketCutType for Siemens controls.
SiemensEndlessFeedLinkOnOff Sets a flag which tells if the feedrate is
dependent on the Siemens Endlessly Rotating axis. The Text value must be set to
the corresponding Rotary component register name, and the Numeric value must be
set to 0 (OFF) or 1 (ON), indicating whether the dependency should be turned on or
off).
SiemensEndlessFeedMode Sets the feedmode for the endless rotating axis. The
Text value must be set to the corresponding Rotary component register name, and
the Numeric value must be set to 1 (degrees per minute) or 2 (revolutions per
minute), indicating feedmode.
SiemensEndlessFeedRate Sets the feedrate for the Siemens Endlessly Rotating
axis. The Text value must be set to the corresponding Rotary component register
name, and the Numeric value must be set to the feedrate.
SiemensEndlessOnOffDir Turns on or off the Siemens endless rotary feature. The
Text value must be set to the corresponding Rotary component register name, and

734
the Numeric value must be set to -1 (CCW), 0 (OFF), or 1 (CW), indicating on/off
and direction.
SiemensL137COffset Used to implement Siemens Polar interpolation. This macro
is specific to the Siemens L137 command. It causes the current shift offset for the
A or C axis to be incremented by the current position of this axis. The axis that will
be adjusted is based on the value passed to the SiemensActualSpindle macro (3
applies to the A axis, 4 applies to the C axis, the default is 4.).
SiemensL137COffsetCancel Used to cancel Siemens Polar interpolation.
Removes the additional offset that was added by SiemensL137COffset. The offset
that is removed is based on the SiemensActualSpindle setting (3 applies to the A
axis, 4 applies to the C axis).
SiemensLoadToolRegister This macro is used to support Siemens @320
command.
NOTE: This macro only works with the fourth parameter set to K7 or K8.
Example: @320 R900 K1 R101 K7
If the fourth parameter is K7 look in the Tool Length CompTable at the register
that is = to variable 101 and assign that value to variable 900.
If the fourth parameter is K8 look in the Cutter Comp Table at the register that is =
to variable 101 and assign that value to variable 900.
SiemensNurbsKnot Adds a Siemens specific incremental knot value.
SiemensNurbsProcess Siemens specific. Checks to see if the NURBS statement
has been completed, and if so, processes the NURBS statement..
SiemensPlaneOverrideArg Similar to SiemensPlaneSelectionArg, except
considers the Override Text field value rather than the word.
SiemensPlaneSelection Resets the plane selection argument count to zero.
SiemensPlaneSelectionArg Processes the arguments for the Siemens G16
command. The general format for a Siemens G16 command is: G16 X Y X Z
D256, where the "word" for each of the arguments determines the action to take.
Therefore, the plane is set based on "X", "Y", or "Z". The first 2 parameters set the
motion plane. The third parameter specifies the axis in which the tool length is to
be applied, and the fourth parameter specifies whether the additional offset is to be
applied to either the tool length (tool length comp) or the cutter comp.
This functionality is provided with the exception that the tool length (gage offset) is
always applied in the direction of the tool at the time the offset is applied (typically
tool change), and there are still unanswered questions about how the fourth
argument is applied.
See also: SiemensPlaneOverrideArg
SiemensPolarAngle Version of PolarAngle used with the 840D ANG processing.
When the ANG word appears in an NC block, either none, one or both of the axes
in the ZX plane may also be programmed. This macro considers the context of the
NC block. If no axes are programmed the ANG word is considered ANG1 (first
block of a two block contour definition). If exactly one axis is programmed then it
is either ANG1, or if it is the second block of a two block contour definition, it is
ANG2. If both axes are programmed then ANG2 is assumed.

735
SiemensPolyT Set the POLY T value.
SiemensPolyx Sets the X axis, ax, and the bx values based on the Siemens specific
input text string argument.
SiemensPolyy Sets the Y axis, ay, and the by values based on the Siemens specific
input text string argument.
SiemensPolyz Sets the Z axis, az, and the bz values based on the Siemens specific
input text string argument.
SiemensShiftAngleA, SiemensShiftAngleB Specifies the absolute rotation angle.
The sum of Angle A and Angle B is the total rotation angle that will be applied.
SiemensShiftOffsetA Shifts the work coordinate system by the specified axis
values. The values will be interpreted as absolute. Only values specified on the
block will be adjusted. (Shift Offset 0, ABSOLUTE/MODAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
SiemensShiftOffsetB Shifts the work coordinate system by the specified axis
values. The values will be interpreted as absolute. Only values specified on the
block will be adjusted. (Shift Offset 1, ABSOLUTE/MODAL)
See "Notes about shift macros" in the Using VERICUT section for additional
information.
SiemensSpecifiedSpindle Marks the specified spindle (numeric value) as being
controlled by this controller. If the spindle is the one that is currently being worked
on (actual), then this controller will take control of this spindle and call the
RPMSpeed and ConstantSurfaceSpeed macros to restore the corresponding spindle
speed. (M*=33)
SiemensSpindleSpeed Sets an internal Siemens spindle speed variable for the
specified spindle. The spindle is a numeric value specified by the Override Text
value. If this head is the controlling head for this spindle, then call the RPMSpeed
and ConstantSurfaceSpeed macros to set the internal spindle speed. (S*=*)
SiemensSubroutineCallDefine Processes the Sinumerik L word as described in
the Siemens Controller Functions document. If the last 2 digits are zero, the L word
is being used to define a subroutine. If it is non-zero, the last 2 digits represents the
number of times the specified subroutine should be called. The remaining portion
of the value represents the subroutine name. Also, the Sequence macro is
automatically called to update the sequence table and set the current sequence
number.
SimpleForLoop This command is used to process a simple "for" loop of the form:
LOOP number
.
.
.
NEXT

The following Word Formats should be defined:

736
NEXT should be defined as a word of Type = "Macro", Sub Type = "None".
LOOP should be defined as a word of Type = "Macro", Sub Type = "Numeric".

Entries should be defined for NEXT and LOOP in the Word/Address table as
illustrated below :

SkipWordIsOptimizable Controls when a "SKIP" word is optimizable (e.g. "$").


Calling this macro with an Override Value of "0", indicates that blocks containing a
SKIP character are not optimizable. Passing any non-zero value indicates the SKIP
character is optimizable. Optimizable is the default condition for SKIP characters.
SpecialRotoTrans This macro is passed the name of the rototrans.txt file. It will
read the specified file and set the G54 offset and the rotation matrix.
NOTE: This macro requires the rototrans.txt file to be in the exact syntax
as defined below.
The rototrans.txt program will look like the following:

$P_UIFR[1,X,TR]= 2.25
$P_UIFR[1,Y,TR]= 1.32
$P_UIFR[1,Z,TR]= 5.78
G54
ROT Z= 1.23
AROT X= 0.12
AROT Z= 0.92
SpecialRotoTransComp This command will move and rotate the specified
component. The initial position is being defined by the Ball1 CSYS. The final
position is being defined by the current G54 offset and the current rotation matrix.
SpindleChanger Unloads the current spindle (if one exists), and loads the spindle
specified with the SpindleValue macro. This macro is a MasterCenter specific
macro.
SpindleCompName Prior toV6, this macro set the internal spindle component
name based off the incoming text value. It was used with SpindleCompOnOff. In

737
V6, this macro is automatically replaced by ActiveSpindleCompName.
NOTE: This macro now applies to the active spindle component. See
ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleCompOnOff Prior to V6, this macro was passed a numeric value of 1 for
ON, and 0 for OFF. It set the spindle component, specified by
SpindleCompName, to either ON or OFF. It was only used with boring bars and
facing tools. In V6, this macro is automatically replaced by ActiveSpindleOnOff.
NOTE: This macro now applies to the active spindle component. See
ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleMotionCCW If the spindle speed was set, outputs the APT
"SPINDL/%n,CCLW" statement. Otherwise, the APT "SPINDL/ON" statement is
output.
This macro is equivalent to calling ActiveSpindleDir with an Override Text =
CCW, and ActiveSpindleOnOff with Override Value = 1.
NOTE: This macro now applies to the active spindle component. For
compatibility reasons, if the system is currently in "milling" mode (set by
default, by VC_ModeMilling, or by VC_ModeMillingComp), then the
ActiveSpindleActiveTool will be automatically called to set the active
spindle component. This macro should be replaced by the new ActiveSpindle
macros.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleMotionCW If the spindle speed was set, outputs the "SPINDL/%n,CLW"
statement. Otherwise, the APT "SPINDL/ON" statement is output.
This macro is equivalent to calling ActiveSpindleDir with an Override Text =
CW, and ActiveSpindleOnOff with Override Value = 1.
NOTE: This macro now applies to the active spindle component. For
compatibility reasons, if the system is currently in "milling" mode (set by
default, by VC_ModeMilling, or by VC_ModeMillingComp), then
ActiveSpindleActiveTool will be automatically called to set the active
spindle component. This macro should be replaced by the new ActiveSpindle
macros.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleMotionOff Outputs the APT "SPINDL/OFF" statement.
This macro is equivalent to calling ActiveSpindleOnOff with an Override Value =
0.
NOTE: This macro now applies to the active spindle component. For
compatibility reasons, if the system is currently in "milling" mode (set by

738
default, by VC_ModeMilling, or by VC_ModeMillingComp), then
ActiveSpindleActiveTool will be automatically called to set the active
spindle component. This macro should be replaced by the new ActiveSpindle
macros.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleSpeed Sets the spindle speed to the input value, outputs a "SPINDL"
command, updates the Status window to have the specified spindle speed, and sets
the spindle mode to RPM.
This macro is equivalent to calling RPMMode and ActiveSpindleSpeed.
NOTE: This macro now applies to the active spindle component. See
ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleSpeedMax Prior to V6, this macro set the maximum spindle speed to the
input value. In V6, this macro is automatically replaced by
ActiveSpindleMaxSpeed.
NOTE: This macro now applies to the active spindle component. See
ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleSpeedMin Prior to V6, this macro set the minimum spindle speed to the
input value. In V6, this macro is automatically replaced by
ActiveSpindleMinSpeed.
NOTE: This macro now applies to the active spindle component. See
ActiveSpindleCompName and ActiveSpindleActiveTool.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
SpindleValue Sets the spindle value which is to be loaded.
StopOptional If Tool Change By is set to "List" (Project menu > NC Programs
window), and "List Tool Change By" is set to "Program Stop" (Project menu >
NC Programs window > Build Tool List window), then this macro will cause a tool
change to occur. The tool change will be based off the tool list.
If Stop At is set to "Optional Stop" (Project menu Processing Options > Motion
window), this macro will cause processing to stop.
StopProgram If Tool Change By is set to "List" (Project menu > NC Programs
window), and "List Tool Change By" is set to "Program Stop" (Project menu >
NC Programs window > Build Tool List window), then this macro will cause a tool
change to occur. The tool change will be based off the tool list.
If Stop At is set to Program Stop (Project menu Processing Options > Motion
window), this macro will cause processing to stop.
StopUnconditional This macro will cause processing to stop. If this macro is
invoked within an "IF" condition, a check is done to determine that the "IF

739
condition" is true before processing is stopped. The calling of this macro will not
be considered as a possible tool change event.
SubEndingSeq This macro defines the ending sequence number for the current
subroutine being called. The value is non-modal. When the sequence number is
reached within the subroutine, a return from the subroutine is executed. Also see:
SubStartingSeq
SubroutineBlock This macro defines the start of a subroutine. This macro is
similar to SubroutineSequence, except if the start of subroutine line was reached
without being called, it will immediately jump to the end of the subroutine.
NOTE: Use this macro to support the Acramatic DFS (define subroutine)
command.
SubroutineName Sets the subroutine name that is then used by the CallNCMacro
or CallSub macros.
SubroutineSequence Similar to Sequence, if the job is defined as a single pass job.
On multi-pass jobs, the current location within the file is marked during the first
pass as the beginning of a subroutine.
SubroutineSequenceEnd This routine is identical to SubroutineSequence except it
also marks the previous subroutine if any as ended.
NOTE: A new routine was created to avoid causing problems with existing
customers where SubroutineSequence was being called for something other
than the start of a subroutine.
SubSpindleTransform Causes a VERICUT/MATRIX command to be processed
based on the auto-calculated offset for the sub-spindle.
NOTE: This is a special purpose macro designed for use with pre-5.0
VERICUT simulating a custom INDEX mill-turn NC machining center, and
is NOT intended for general use.
SubStartingSeq Sets the starting sequence number for a call into a subroutine.
Also see: SubEndingSeq
SubsystemActivateTool Activates the tool associated with the current subsystem.
SurfaceSpeed Specifies that the part spindle RPM's will be set such that the
surface speed of the tool will remain constant at the given rate. The rate is specified
as Feet Per Minute or Meters Per Minute.
SuspendCutting Stops the normal processing of the current block. This means that
cutting and positional updates will not occur.
Sync Renamed to SyncMacro.
SyncCode Sets the current Sync value. This value is used by the SyncId macro to
cause the current head (also known as subsystem, program, system, or channel) to
wait until the specified head reaches the corresponding Sync value.
Previous macros like SyncMacro and SyncValue were based on a 2 sync head
only scenario. These macros caused a wait until the "other" head reaches a
corresponding spot.
SyncId Causes the current head (also known as subsystem, program, system, or
channel) to wait until the specified head (specified as an index value; 1 to n)

740
reaches the corresponding Sync value. The Sync value needs to be set prior to this
call. This Sync value is set by calling the SyncCode macro.
SyncMacro Causes the active head to wait at the current location until the other
head reaches the corresponding sync location.
SyncMismatchHandling This macro determines how a SyncValue mismatch
should be handled. The default is to have the head with the lower value continue
on.
Valid input values are:
0 : Head with lower sync value continues on.
1 : Produce an error message and stop.
SyncTransfer Causes the controlling/slave heads to swap
SyncValue Sets the current Sync value. This will cause the current head to wait
until the other processes a Sync value that is greater than or equal to the specified
value.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
TableIndex Sets the index/register number of the table entry to be modified. Used
with SetTableValues and SetTableCoord. Default is 1. Use the Override Value
field to specify the table index number. TableIndex must be called before calling
SetTableValues.
TableValues Can be called up to nine times to store nine values. Used with
SetTableValues. TableValues must be called before calling SetTableValues.
ThreadWire Thread the wire EDM wire. This will cause the Wire to be displayed
within the simulator, and a "PPRINT/VERICUT-TC" statement to be printed. The
height for the cutter will be set to the maximum length of the wire based off of the
vertical distance between the guides, and the maximum angle.
Tool3dOffset Turns on 3D Tool Correction to keep the tool tangent with the
cutting surface. The actual tool offset will vary based on the vector which is normal
to the part surface at each given point. This type of tool offset can only be used
with standard bull nose and ball nose cutters. Also see: PartNormalX,
PartNormalY, PartNormalZ, ToolVectorX, ToolVectorY, ToolVectorZ,
Cancel3dToolOffset
Tool3dXOffset, Tool3dYOffset, Tool3dZOffset Sets the 3D offset in the XYZ
directions, respectively. This is a form of cutter compensation where the offset can
be in 3D, and is specified directly in the MCD file.
NOTE: These macros are not related to Tool3dOffset.
Also see: CutterComp3d, Unitize3DVector, CutterCompOff
ToolChainExchange Unloads the tool currently in the spindle (if one is loaded),
then loads the selected tool from the toolchain into the machines spindle. The

741
unloaded tool is either placed in the pocket just emptied by the new tool, or
replaced into its original toolchain position depending on the setting of Replace
tool in its original pocket in the Toolchain Parameters window. If a
ToolChainExchange macro is used before the amount of time to move the chain
has elapsed, then the chain is moved and the total job time is increased by the
remaining time required to position the toolchain. When the time to reposition the
chain has elapsed before the exchange occurs, the time to reposition the chain is not
counted against the total job time. ToolChainExchange normally corresponds the
machines tool load (M6) code.
NOTE: The ToolChainExchange macro does not provide any motion of
tool exchanger arms or components. It simply loads the selected tool into the
spindle and attaches the unloaded tool to the toolchain pocket.
Also see: ToolChainMotion, ToolChainFromCompName,
ToolChainToCompName, and UnloadToolToCompName.
ToolChainFromCompName Removes the tool from the specified component and
attaches it to a toolchain pocket. This toolchain pocket is either the pocket from
which the selected tool was just loaded or the tools original pocket, depending on
the setting of Replace tool in its original pocket in the Toolchain Parameters
window.
ToolChainMotion Moves a selected tool in the chain to the exchange position.
When a tool is selected by calling macro ToolChainMotion, the time to move the
toolchain is calculated using the shortest direction of chain motion. The toolchains
display is updated when cutting motions have used the amount of time or when a
command to load the selected tool is processed. The ToolChainMotion macro
normally corresponds to the controls T-code. The macro ToolCode should be used
before calling ToolChainMotion.
Also see: ToolChainExchange
ToolChainToCompName Removes the selected tool from the toolchain pocket
and attaches it to the tool changer component specified by the text override. Macro
ToolCode should be used before calling ToolChainToCompName to select the
new tool..
ToolChange When the modal Tool Number Method=Select Only, unloads the
current tool (if one exists) and load the new tool.
ToolChangeAlpha Identical to ToolChange, except uses the tool id set by the
macro ToolCodeAlpha.
ToolChangeByToolNum Executes a tool change based on the tool number set by
the ToolCode macro. This macro is identical to the ToolChange macro except that
this macro will NOT reference the Tool List.
NOTE: The Tool Number Method must be set to "Select Only"
(Configuration menu > Control Settings: Tooling tab) for a tool change to
occur with this macro call.
ToolChangeIfDifferent Calls the ToolChange macro only when the new tool
number is different from the current tool.

742
ToolChangeNoRetract Similar to ToolChange, except that the machine
components will not retract to their tool change locations.
ToolChangeSave Causes the previously saved tool number to be loaded. See
ToolCodeSave.
ToolCode When the modal Tool Number Method=Select Only, set the new tool
number to the input value. But, when Select & Change is the active choice, this
macro set the new tool number to the input value and executes the corresponding
tool change.
ToolCodeAlpha Identical to ToolCode, except uses the text argument as the tool
id rather than the numeric argument as the tool number. Since this routine assumes
the "tool code" is alphanumeric, it sets the tool number to zero. This means that any
feature in VERICUT which references the tool number will not work.
ToolCodeSave Saves the current tool number. See ToolChangeSave.
ToolCutterComp Sets the cutter compensation amount for the current tool loaded
in the active spindle. The amount of cutter compensation is the value of the Cutter
Compensation record saved with the tool in the tool library. Each tool in the tool
library can have multiple Cutter Compensation records, each with a unique ID. The
ID is input as a text string, but is typically a numeric value. The numeric argument
passed to this macro will be used to match the Cutter Compensation ID in the tool
library. For example, if D calls ToolCutterComp with an argument of 15, then the
value of Cutter Compensation ID "15" is used as the cutter compensation amount.
The default cutter comp value will either be zero or the full radius of the tool
depending on the setting of the Process Cutter Comp option on the G-Code Settings
window: Settings tab.
This macro does not use the Cutter Compensation table. It gets the cutter
compensation amount from the tool library file. If the Cutter Compensation ID is
not found, the Cutter Compensation value is zero, and no adjustment is made.
NOTE: This macro uses alpha-numeric Tool IDs and numeric Cutter
Compensation ID's.
See "Notes about Gage Offset and Cutter Compensation" in the Using VERICUT
section for additional information.
ToolLengthCompNeg Sets the tool length offset mode to Negative.
ToolLengthCompOff Turns off the tool length offset.
ToolLengthCompPos Sets the tool length offset mode to Positive.
ToolLengthCompToolNum Uses the current tool number to index into the Tool
Length Compensation table. The corresponding value is used as the compensation
amount when Tool Length Compensation is active. Also see:
ToolLengthCompToolNumSubValue.
NOTE: The current tool number refers to the tool number that is specified
in the MCD file (T1M6, T0101, &), not to the Tool Id that is specified in the
TLS file which is a string.
ToolLengthCompToolNumSubValue Uses the current tool number and the
specified SubValue (SubRegister) to index into the Tool Length Compensation
table. The corresponding value is used as the compensation amount when Tool

743
Length Compensation is active. Also see: ToolLengthCompToolNum.
NOTE: The current tool number refers to the tool number that is specified
in the MCD file (T1M6, T0101, &), not to the Tool Id that is specified in the
TLS file which is a string.
ToolLengthCompUpdate Updates the Tool Length Compensation amount. It
assumes that Tool Length Comp (pos/neg) has previously been turned on.
ToolLengthCompValue Uses the input value to index into the Tool Length
Compensation table. The corresponding value is used as the compensation amount
when Tool Length Compensation is turned on.
ToolLengthCompValueDirect Sets the Tool Length Compensation value to the
specified input value. The value is used as the compensation amount when Tool
Length Compensation is turned on.
ToolLengthOffsetValue Sets the tool offset value based off of the corresponding
entry in the Tool Length Compensation table. This value is modal.
ToolNoseCompApply This macro is no longer functional in V6.0. If called, it will
produce the following warning message: "Macro ToolNoseCompApply is obsolete
in V6.0".
NOTES:
1. ToolNoseComp will be automatically applied when cutter compensation is
applied with a non-zero value.
2. The amount of the ToolNoseComp will typically be set automatically based
on the tool definition. This value is set when the gage offset is retrieved
from tool definition. This value can be overridden by calling
ToolNoseCompValue, ToolNoseCompToolNum, or
ToolNoseCompToolNumSubValue.
ToolNoseCompCancel Turns off tool nose compensation.
ToolNoseCompToolNum Uses the current tool number to index into the Tool
Nose Compensation table, which then specifies the XYZ tool nose compensation
that is to be applied. These values are typically only active while in cutter
compensation mode. Also see: ToolNoseCompToolNumSubValue.
NOTE: The current tool number refers to the tool number that is specified
in the MCD file (T1M6, T0101, &), not to the Tool Id that is specified in the
TLS file which is a string.
ToolNoseCompToolNumSubValue Uses the current tool number and the
specified SubValue (SubRegister) to index into the Tool Nose Compensation table.
The corresponding values are used as the XYZ tool nose compensation that is to be
applied. These values are typically only active while in cutter compensation mode.
Also see: ToolNoseCompToolNum.
NOTE: The current tool number refers to the tool number that is specified
in the MCD file (T1M6, T0101, &), not to the Tool Id that is specified in the
TLS file which is a string.
ToolNoseCompValue Specifies the index into the Tool Nose Compensation table,
which then specifies the xyz tool nose compensation that is to be applied. These

744
values are typically only active while in cutter compensation mode.
ToolOffsetAptAdj VERICUT workpiece view does not support the concept of
multiple driven points for a given tool. However, machine views do. This macro
allows Gage Offset table to drive a secondary offset on the tool, while the tool
position is still based on the driven point defined by the Tool Library file. The
Gage Offset is calculated by: GAGEPOINT_OFFSET -
DRIVENPOINT_OFFSET.
ToolOffsetAptAdj2 No longer used. If found in an NC control configuration, it is
automatically replaced with ToolOffsetAptAdj.
ToolOffsetIndex Specifies the entry in the Gage Offset table that is to be used to
specify the distance from the driven point of the tool to the spindle face. This
macro will need to be called to actually update the offset.
ToolOffsetUpdate Updates the gage offset based off of the register value specified
by the ToolOffsetIndex macro. VERICUT first checks for a corresponding entry in
a Gage Offset table. Otherwise, if the specified register value is non-zero it uses the
gage offset defined for the tool in the Tool Library. If the gage offset is (0,0,0) and
ApplyTurretOffset=2, the turret offset is also cleared.
ToolOffsetUpdate2 No longer used. If found in an NC control configuration, it is
automatically replaced with ToolOffsetUpdate.
ToolRetract Retract the tool along its tool axis. If ToolRetractDistance is set
(>=0), it will retract this distance or until the first axis limit is reached. If the
ToolRetractDistance is negative, the tool will retract until one of the XYZ axis
reaches its axis limit.
ToolRetractDistance Sets the tool retract distance (Override Value = distance to
retract). A negative value means to retract until one of the XYZ axis reaches its
limit. This value is used with ToolRetract. This value is modal. The default value
is -1.
NOTE: To make the distance value non-modal, this macro can be called a
second time after motion with a value of -1.
ToolVectorX, ToolVectorY, ToolVectorZ Sets the tool vector. Is specified with
ToolChange.
NOTE: These macros are redundant and may be deleted in the future. Also
see: Tool3dOffset
Touch Turns on "Move until you touch" for the current block. Default touch
component is the active tool (see TouchComponentName). The axes move until the
touch component arrives at the programmed location, or when the object contacts
something.
NOTE: The Touch macro only supports linear axis motion.
TouchComponentName Specifies the "Touch" component used by the Touch
macro. Default is the active tool component. Use this when moving a component
such as a tail stock or steady rest into "contact" with another component, such as
the stock. Use the Override Text Field to specify the component name. The
TouchComponentName must be specified prior to calling the Touch macro.
The algorithm used approximates the hit location based on the current model

745
tolerance and other factors. When any portion of the touch component contacts any
other component, the axes are moved to that location. Standard collision logic is
used to determine if any other component hits something during the touch motion,
but the motion continues to the touch destination.
TripodArmLength Defines the distance from the center of the spindle to a ball
joint in a tripod-type machine.
TripodRodLength Defines the length of the vertical rods attached to the spindle
platform in a tripod-type machine.
NOTE: The value passed to this macro must correspond with the length of
the corresponding model of the rod in order to get proper simulation.
TurnOnOffGageOffset This macro is intended to be used when in Tool Length
Compensation Mode. A value of "0" turns "Off" the Gage Offset. Any other value
turns "On" the Gage Offset. The default is to not apply the gage offset when in
Tool Length Compensation Mode. This macro is intended to replace
ApplyGageOffset.
For example:
G43 calls TurnOnOffGageOffset with Override Value = "1" (to turn on
the gage offset)
G49 calls TurnOnOffGageOffset with Override Value = "0" (to turn off
the gage offset)

Enter IMMEDIATE in the Override Text field to immediately apply or cancel the
offset. Using this option causes the change in offsets to take place immediately,
which then causes motion, even if there is no motion axis being programmed on the
block.
TurnOnOffGagePivotOffset This macro turns On/Off the offset from the Tool
component to the rotary pivot point. A value of "0" turns "Off" this offset, and any
other value turns "On" this offset. The default is to not apply this offset.
Enter IMMEDIATE in the Override Text field to immediately apply or cancel the
offset. Using this option causes the change in offsets to take place immediately,
which then causes motion, even if there is no motion axis being programmed on the
block.
The rotary pivot point is defined as the origin of the first parent rotary (if there is
only one), or the intersection of the axes of the first 2 rotary components up from
the tool (if there are more than one tool side rotary component). If there are two (or
more) parent rotary components and the axes do not intersect, the rotary pivot point
is defined as the second parent rotary.
This feature can be used with RTCP. When used with RTCP, this Gage Pivot
Offset will be used rather then the RTCP Pivot Offset. Being in RTCP mode is not
a requirement to activate this offset. This feature can now be used rather than using
the ApplyTurretOffset.
The TurnOnOffGagePivotOffset approach is the preferred method for handling
the tool to pivot offset. It has many advantages over the traditional approach. The

746
advantages are all associated with the new approach establishing a "relational"
offset between the pivot point and the current active tool component origin.
As described above, this approach assumes a specific pivot point based on the
machine configuration. In some cases, this pivot point might not be the pivot point
that you want to define. In these instances use PivotOffsetCompName to define the
component containing the desired pivot point.
In addition, this approach also assumes the offset to be between the pivot point and
the current active tool component origin. In some cases, the current active tool
component origin might not produce offset from the pivot point that you want to
define. In these instances use PivotOffsetCompNameB to define something other
than the active tool component origin.
NOTE: It is expected that the TurnOnOffGagePivotOffset macro will
replace the ApplyGagePivotOffset and ApplyGagePivotOffsetCurrent
macros.
TurnOnOffRealTimeClock Turns on and off a real time clock. A value of zero
turns the clock "Off". All other values turns the clock "On". The default is "Off". If
the clock is turned on, the real time will be calculated for each block. The time to
process the block will be stored in the variable CGT_REAL_TIME. The units of
the variable will be in seconds. The concept is to support the following type of
MCD logic:
#3001 = 0
While (#3001 < 2000) DO1
END1
The above loop would sit and wait for 2000 milliseconds.
IF #3001 was tracking milliseconds, then the following should be added to the
"End of Block Processing" event (after BlockFinish).
Variable 3001 = #3001 + (#CGT_REAL_TIME * 1000)
TurnOnOffTravelLimits This macro gives the capability to turn off travel limits
for all components within the current subsystem. The default is to adhere to the
settings in the Machine Settings window: Travel Limits tab. A value of 1 restores
this setting, any other value turns travel limit checking off. For travel limits to be
checked, the main Travel Limit switch must be on, the component ignore switch
must be off, and this switch must be on.
TurretActivateTool Marks the tool associated with the specified tool index as the
active tool, Updates the status window to reflect status for the active tool, and
initializes the turret offset.
NOTE: APT output for reverse postprocessing is generated from the active
tool.
Do not call this macro using the Configuration menu > Word/Address
function. Instead, use the TurretToolChange macro as it automatically calls
all macros needed to change tools connected to Turret components.
TurretIndex Rotates the turret so that the specified tool index number is in cutting
position. This macro will then search for a tool with the specified index number
(index number only applies to tools that are connected to a turret). If an entry exists

747
for the specified tool index in the Turret Rotations table, the corresponding value
will be used as the absolute angle of this tool. If an entry does not exist, the angle
will be calculated based off of the XAXIS/ZAXIS matrix for the associated tool.
The register name of the corresponding turret will be used to rotate the turret into
position. The Rotary control settings determine the direction (CW,CCW) of
motion. Typically this should be set to Shortest Distance. While the turret is being
rotated, no APT will be generated. An APT GOTO will be generated at the final
position.
Do not call this macro using the Configuration menu > Word/Address
function. Instead, use the TurretToolChange macro as it automatically calls
all macros needed to change tools connected to Turret components.
TurretLoadTool For a turret, a tool is not actually "loaded", but instead is indexed
for cutting. This macro is used with turret machines and does the following: cancels
cycles (if active), resets the motion type to "Rapid", sets the machining type (Mill
vs. Turn) based on the type of tool loaded, and issues a LOADTL command to load
the tool for cutting.
Do not call this macro using the Configuration menu > Word/Address
function. Instead, use the TurretToolChange macro as it automatically calls
all macros needed to change tools connected to Turret components.
TurretRetract Causes the Turret to retract to the tool_change retract position. All
corresponding tool change modals/table values are used to determine if the retract
should actually occur, which components should retract, and the position of the
retract.
Do not call this macro using the Configuration menu > Word/Address
function. Instead, use the TurretToolChange macro as it automatically calls
all macros needed to change tools connected to Turret components.
TurretRotationOffset This macro is used when a single tool connected to a Turret
component is oriented in multiple positions during the simulation. The macro
specifies the delta angle between the normal cutting position and the new cutting
position. This angle is then used to cause proper the Turret indexing.
TurretToolChange When the Tool component with the corresponding Tool Index
value is found in the NC machine configuration, call the following macros:
TurretRetract, TurretIndex, TurretActivateTool, TurretLoadTool. These macros are
not called if the specified Tool component is already active, or the Tool component
with the corresponding Tool Index value is not found.
NOTE: When reading a pre-5.1 Control file this new macro will
automatically replace the above 4 macros when the 4 macros are found
together (in any order). This is important, because the order of these 4
macros is now critical.
TurretToolChangeAlpha This macro searches all tools on the current turret
(based on subsystem) for a tool with a matching toolid (specified by the text value).
If found, TurretToolChange will be called with the corresponding Tool index
number.
TurretToolChangeByToolNum This macro searches all tools on the current turret
(based on subsystem) for a tool with a matching toolid (specified by the numeric

748
value). If found, TurretToolChange will be called with the corresponding Tool
index number.
Type2Begin This macro was created to handle K&T Type II commands. This
macro gets called during the "Start of Type II command" events. This macro
initializes a couple values, and keeps track of the number of active Type II
commands that are currently being processed. Also see: Type2End
Type2BEQLabel Type II "Equal" logical-if true, then branch to a specified label.
This macro expects three Type2 arguments: 2 numeric and 1 text (in any order). It
will compare the 2 numeric values and if the condition is true, a branch will be
made to the specified label.
N1090 (BEQ,E13,0,LB01) => Interpret as: if variable E13 is Equal to the
value "0", then branch to label "LB01".
By default, GotoLabel is automatically called to execute the branch. The macro
Type2GotoLableFunction can be used to control branching. If it is passed an
Override Text value of "0", GotoLabel is used. Passing a value of "1" causes
CinciGotoLabelName to be used instead.
Type2BGELabel Similar to Type2BEQLabel, except "Greater Than or Equal"
logic applies.
Type2BGTLabel Similar to Type2BEQLabel, except "Greater Than" logic
applies.
Type2BLELabel Similar to Type2BEQLabel, except ""Less Than or Equal" logic
applies.
Type2BLTLabel Similar to Type2BEQLabel, except "Less Than" logic applies.
Type2BNELabel Similar to Type2BEQLabel, except "Branch if Not Equal" logic
applies.
Type2CLS A generic Type II subroutine call with no arguments.
Type2CommentAllArgs This is a Type 2 macro which can except any number of
arguments. The text string associated with each argument will be concatenated
together and will be processed as a control comment and passed to VERICUT as a
"PPRINT".
Type2DFS A generic Type 2 subroutine definition with the ability to jump over the
subroutine if it is being defined and not called. This macro should be passed one
argument which is the subroutine name. Additional arguments are ignored.
Type2End This macro was created to handle K&T Type II commands. This macro
gets called during the "End of Type II command" events. This macro decrements
the number of active Type II commands that are currently being processed. Also
see: Type2Begin
Type2Goto This is a Type 2 macro which expects one argument. This argument
can either be a label or a sequence number (a label will take precedence). This
macro executes a branch to the specified location.
Type2GotoLabelCond This macro supports the TYPE II GOTO command that is
in the form: (GTO, label [,conditional]). When searching for the specified label, the
search will begin at the beginning of the current program or subprogram. If the
conditional exists, the branch to the specified label will only be executed if the

749
conditional is TRUE. If the conditional does not exist, the branch to the specified
label will be executed unconditionally. The type II word format for this macro is "T
V".
Type2GotoLabelFunction Controls branching by "Type2...Label" macros. If it is
passed an Override Text value of "0", GotoLabel is used. Passing a value of "1"
causes CinciGotoLabelName to be used instead.
Type2If This is a Type 2 macro which expects one argument. If the argument
equates to TRUE, the corresponding statement will be executed. This routine might
be G&L specific.
Type2IfBlock This macro supports the TYPE II IF command that is in the form:
(IF, conditional). This is a type Type II version of the IfBlock macro. The general
format the of NC code will look as follows:
(IF, &.)
.
.
(ELSE)
.
.
(ENDIF)
The ElseBlock and EndIfBlock macros should be used to handle the corresponding
ELSE and ENDIF statements. The type II word format for this macro is "V"
Type2Label This is a Type 2 macro which expects one argument. The argument is
the label name that is to be applied to the current block.
Type2NELabel Similar to Type2BEQLabel, except "Not Equal" logic applies.
Type2OpMsg This is a Type 2 macro which expects one argument. The argument
is the operator message that is to be printed to the console.
Type2OpMsgAllArgs This is a Type 2 macro which can except any number of
arguments. The text string associated with each argument will be concatenated
together and will be printed as an INFO message.
Type2OpMsgStop This is a Type 2 macro which has one optional argument. The
argument is the operator message that is to be printed to the console. This macro
will also cause the processing of the MCD file to stop.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
UAxisIncreMotion Similar to UAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
UAxisMachineMotion Similar to UAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
UAxisMachineRefMotion Same as its UAxisMachineMotion counterpart, except

750
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
UAxisMotion Sets the U value used to process the machine's U component. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
Unitize3DVector Sets a flag to determine whether the vector associated with 3D
tool offsets should be unitized or not. 0= No, 1= YES. Default value is 1. See also:
CutterComp3d, Tool3dXOffset, Tool3dYOffset, Tool3dZOffset, CutterCompOff
UnitsInch, UnitsMetric Sets the units mode to Inch or Metric, respectively.
UnloadTool Unloads the current tool.
UnloadToolNoRetract Similar to UnloadTool, except that the machine
components will not retract to their tool change locations.
UnloadToolToCompName Unloads the current tool and attaches it to the
specified component (normally a tool changer return arm).
UnMountTool Un-mounts the current tool from the specified tool component
(Override Text = name of the tool component).
NOTES:
1. This is NOT a tool change.
2. Un-mounting the tool DOES NOT change the active tool, execute a
tool change retract, increment the number of tools, or update tool
offsets. It is strictly a way to un-mount the tool. Typically, his will be
used with a tool changer.
See also:MountTool
UnMountToolIndex Un-mounts the current tool from the specified tool
component (specified by the tool index value (Override Value = tool index value)
and subsystem (Override Text = subsystem of tool component).
NOTES:
This is NOT a tool change.
Un-mounting the tool DOES NOT change the active tool, execute a tool
change retract, increment the number of tools, or update tool offsets.
It is strictly a way to un-mount the tool. Typically, this will be used
with a tool changer.
See also: MountToolIndex
Unsupported Prints a warning message that the specified word/value pair is
unsupported.
UntilLoop Used with a REPEAT UNTIL loop, and is associated with the UNTIL
word. If the expression associated with UNTIL word is false, this macro will cause
a jump back up to the line following the corresponding REPEAT command.
Currently, this macro is only valid when used with the Sin840D REPEAT
command. (See "Notes about the Siemens 840 CASE and REPEAT commands" in
the Using VERICUT section)
UpdateAxisValues This macro causes the internal axis positions for a subsystem to
be updated based on the current position of the machine. This macro was

751
specifically designed to work with the CoupleAxisOn/Off macros. After turning the
coupling off, the subsystem that was in a wait state while its corresponding
components were being moved, should then call this macro.
UpdateIPZ This macro is passed an index into the Input Program Zero (Special Z)
table via the Override Value field. Use this macro to specifically set the internal
values for the Input Program Zero offset; a capability that is mainly useful when
working with a "spindle changer" type of machine and running in Tool Tip mode.
NOTES:
1. This does not change any of the table values. The new value for IPZ
(Special Z) can be seen using Modals/Debug/Debug Offsets.
2. This macro should probably be executed after motion or on a block
by itself. Also, since the internal value for Input Program Zero
(Special Z) is being modified, this method will probably not work
when running in Tool Length Comp mode.
UpdateModalMacroVar This macro is identical to MacroVar (which sets a block
variable), except this macro updates the modal variables that were previously set
with a call to CallNCMacroMotion or CallNCMacroBlock.
UpdatePZ This macro is passed an index into the Program Zero table via the
Override Value field. Use this macro to specifically set the internal values for the
Program Zero offset; a capability that is mainly useful when working with a
"spindle changer" type of machine and running in Tool Tip mode.
UpdateRotaryOffsets Updates rotary pivot offset values that may have changed
due to turning RTCP on/off.
uvw_axis Renamed to UvwAxis.
UvwAxis Cutter Compensation can only be applied along the x,y,and z axis. In the
case of a dual head system where xyzuvw all exists, cutter compensation can only
be applied along the xyz or uvw axis at a given time. This macro activates the uvw
axis and deactivates the xyz axis.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
ValueArgument Specifies a value that is to be added to the list of value arguments.
VariableArgument Specifies a variable that is to be added to the list of variable
arguments. The contents of the variable is also added to the list of value arguments.
VarUpdateMacroVars When this macro is passed with a value of 1, it will allow
variables 1-34 to update the modal macro vars. Passing a value of 0 turns off this
feature. Zero is the default. Typically, this would be turned on with a G66.1 and
turned off with a G67.
VAxisIncreMotion Similar to VAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
VAxisMachineMotion Similar to VAxisMotion, except it ignores all

752
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
VAxisMachineRefMotion Same as its VAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
VAxisMotion Sets the V value used to process the machine's V component. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
VC_LoadFix Outputs a "DISPLAY_FIXTURES" PPRINT.
VC_ModeMilling, VC_ModeTurning Tells VERICUT to switch to Milling or
Turning machining mode, respectively. For milling, a spinning tool removes
material when in contact with Stock/Fixture. For turning, a Spindle spins the
Stock/Fixture assembly and a stationary tool (not spinning) removes material when
in contact with Stock/Fixture. The Default Machining Mode specifies which
machining mode is assumed at the start of processing. (Ref. File menu > Properties:
General tab)
Using these macros affects how all defined Stock components are machined. To
change the machining mode of individual Stock components by component name,
use the VC_ModeMillingComp/VC_ModeTurningComp macros instead.
NOTE: These VC_Mode macros can now be replaced with
ActiveSpindleCompName and ActiveSpindleOnOff. The main difference is
that the VC_Mode macros produce a "PPRINT/VERICUT-
MODAL:MACHTYPE" APT statement, and SpindleCompOnOff produces
a "SPINDLE" APT statement.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
VC_ModeMillingComp, VC_ModeTurningComp Same as described above for
VC_ModeMilling/VC_ModeTurning, except uses the Override Text string value
to specify the name of the single Stock component to mill (or turn).
Using these macros affects how specified individual Stock components are
machined. To change the machining mode of all defined Stock components at once,
use the VC_ModeMilling / VC_ModeTurning macros instead.
NOTE: These VC_Mode macros can now be replaced with
ActiveSpindleCompName and ActiveSpindleOnOff. The main difference is
that the VC_Mode macros produce a "PPRINT/VERICUT-
MODAL:MACHTYPE" APT statement, and SpindleCompOnOff produces
a "SPINDLE" APT statement.
See "Notes about spindle configuration in V6" in the Using VERICUT section for
additional information.
VC_UnloadFix Outputs a "REMOVE_FIXTURES" PPRINT.
VirtualXAxis Allows you to drive a non-orthogonal X axis with virtual values
based on a orthogonal coordinate system.
This macro is passed in the offset angle (about the Z axis) that the X axis is rotated.

753
When called with a non-zero value, this macro will establish a rotation plane which
will allow for virtual XYZ values to be input. When called with a value of zero, the
rotation plane will be cancelled, and the axis will be driven directly.
NOTE: This macro and VirtualYAxis are mutually exclusive.
VirtualYAxis Allows you to drive a non-othogonal Y axis with virtual values
based on a orthogonal coordinate system.
This macro is passed in the offset angle (about the Z axis) that the Y axis is rotated.
When called with a non-zero value, this macro will establish a rotation plane which
will allow for virtual XYZ values to be input. When called with a value of zero,
the rotation plane will be cancelled, and the axis will be driven directly.
NOTE: This macro and VirtualXAxis are mutually exclusive.
VoltageOff, VoltageOn Controls when a SPINDLE/OFF or SPINDLE/ON
statement is output during wire EDM machining, respectively.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
WAxisIncreMotion Similar to WAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
WAxisMachineMotion Similar to WAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system. A macro exists for each motion axis:
A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
WAxisMachineRefMotion Same as its WAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
WAxisMotionSets the W value used to process the machine's W component. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W. Also see:
WAxisMotionNoCycle
WAxisMotionNoCycle Same as WAxisMotion, except the value is never
interpreted as a cycle depth value.
WAxisZeroTracking Sets the W value used to process the machine's W
component on a Zero-Tracking machine.
WhileLoop Sets the while condition to the input value.
This command is used with DoLoop to process a "while/do" loop of the
form:

While (expression) DO1


.
.

754
.
END1

The following Word Formats should be defined:

WHILE, DO and END should be defined as a word of Type = "Macro", Sub


Type = "Numeric".
() represent words of type left and right precedence.

Entries should be defined for WHILE, DO, and END in the Word/Address
table as illustrated below :

WorkCoord Updates the work coordinate system based off of the values in the
Work Offsets table. The input value is used as an index into this table. Any non-
negative number is valid.
WorkCoordA2Value, WorkCoordB2Value, WorkCoordC2Value Sets values
for the A2,B2,C2 axes for use with various Work Coordinate System Offset
macros. A macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
When the WorkCoord[*]Value is called with a text override of "MIRROR", and
the corresponding axis set to mirror, the input value will be mirrored.
WorkCoordAValue, WorkCoordBValue, WorkCoordCValue Sets values for
the A,B,C axes for use with various Work Coordinate System Offset macros. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
When the WorkCoord[*]Value is called with a text override of "MIRROR", and
the corresponding axis set to mirror, the input value will be mirrored.
WorkCoordIndex Set the index into the Work Coordinate Offset values. Valid
values are from 0 to 59.
WorkCoordUValue, WorkCoordVValue, WorkCoordWValue Sets values for
the U,V,W axes for use with various Work Coordinate System Offset macros. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
When the WorkCoord[*]Value is called with a text override of "MIRROR", and

755
the corresponding axis set to mirror, the input value will be mirrored.
WorkCoordWithMotion This macro should be passed a value of zero or one. A
value of zero means that the work offset should be applied immediately. A value
of 1 means that the offset will be applied with motion on the corresponding axis.
The default value is 1. This macro effects all macros which sets or cancels the
base, primary, or secondary work offsets.
NOTE: In the case of Fadal, a call to this macro could be made during start
of processing.
WorkCoordXValue, WorkCoordYValue, WorkCoordZValue Sets values for
the X,Y,Z axes for use with various Work Coordinate System Offset macros. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
When the WorkCoord[*]Value is called with a text override of "MIRROR", and
the corresponding axis set to mirror, the input value will be mirrored.
WorkingPlane2Abc This macro converts the "working plane" into real A,B,C
angle that applies to the current machine, and establishes a rotation plane if
necessary. The resulting angles are then stored in the specified variables. The text
value passed to this macro contains the names of the variables, typically for
Heidenhain, this will be set to "120 121 122". This macro makes use of the
WorkingPlane2AbcType as defined below. The input value defines how the
"working plane" was defined.
Valid Override Values (input types):
Override Value = 0 Rotation Plane Angles and offsets. These values are
set with the following macros:
y RotationPlaneAngle1
y RotationPlaneAngle2
y RotationPlaneAngle3
y RotationPlaneIncAngle1
y RotationPlaneIncAngle2
y RotationPlaneIncAngle3
y RotationPlaneXPoint
y RotationPlaneYPoint
y RotationPlaneZPoint
y RotationPlaneIncXPoint
y RotationPlaneIncYPoint
y RotationPlaneIncZPoint
Overide Value = 1 X and Z Vectors. These vectors are set with the
following macros:
y PlaneAxisVectorX
y PlaneAxisVectorY
y PlaneAxisVectorZ
WorkingPlane2AbcType Typically called during the "Start of Processing" event,
this macro controls the type of conversion required to convert a rotated coordinate
system into ABC rotations. Conversion type is specified via Override Value.

756
There are two classes of conversion routines, "Generic" and "Specific". Specific
conversion types are meant for a very specific machine/control configuration.
Generic conversion types are for any machine/control that follow simple rules.
Generic conversion types:
y Assume that if the rotaries are set to "Absolute", then the direction will be
set to "Shortest Distance".
y When converting to ABC, typically there are 2 solutions. The Generic
routines will choose the solution which requires the smallest total rotary
travel.
y Assume that the control will be configured to handle any RTCP/RPCP
issues.
y Assume that the only rotation applied to components will be on nutator
components.
y Are based on the order that the rotaries appear starting at the Tool, and
ending with the Stock. This means that an A on C head machine can use the
same Generic conversion type as an A head/C table machine, or a C on A
table machine. These 3 machine configurations would all be described as
"A-C".
y Travel limits will be obeyed.
y If the tool angle is (0,0,1), the C angle will be set to match the input C
angle.
Valid Override Values (conversion types):
Override Value = 1 Generic A-C. A Nutator may exist on the table.
Override Value = 2 Generic B-C. A Nutator may exist on either head or
table
Override Value = 3 Special A-C table on table machine with a horizontal
head. A nutator on the table is NOT supported. It is assumed that the NC
program has been posted for a horizontal head machine (Tool along the
machines Y axis).
WPrimaryTrackingAxis Marks the W as the primary axis and the Z as the
secondary axis on a zero tracking machine.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
XAxisIncreMotion Similar to XAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
XAxisMachineMotion Similar to XAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system.
XAxisMachineRefMotion Same as its XAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine

757
Reference Location table). Thus, motion is relative to the machine's reference
location.
XAxisMotion Sets the X value used to process the machine's X component. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
XLeadRate Sets the distance to move along the X axes per revolution while
threading. If 2 or more axes are in motion, the lead rate of the axis which is moving
the greatest distance will be used.
XRetractSpecifiedpoint Sets the retract level X position.
XToolOffsetCompName Specifies the name of the component to which the "X
tool offset" is applied. Also see: YToolOffsetCompName, ZToolOffsetCompName
xyz_axis Renamed to XyzAxis.
XyzAxis Cutter Compensation can only be applied along the x,y,and z axis. In the
case of a dual head system where xyzuvw all exists, cutter compensation can only
be applied along the xyz or uvw axis at a given time. This macro activates the xyz
axis and deactivates the uvw axis.

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status
YAxisIncreMotion Similar to YAxisMotion except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
YAxisMachineMotion Similar to YAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system.
YAxisMachineRefMotion Same as its YAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
YAxisMotion Sets the Y value used to process the machine's Y component. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
YLeadRate Sets the distance to move along the Y axes per revolution while
threading. If 2 or more axes are in motion, the lead rate of the axis which is moving
the greatest distance will be used.
YRetractSpecifiedpoint Sets the retract level Y position.
YToolOffsetCompName Specifies the name of the component to which the "Y
tool offset" is applied. Also see: XToolOffsetCompName, ZToolOffsetCompName

Numbers A B C D E F G H I J K L M N O P Q R S T U V
W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status

758
ZAxisIncreMotion Similar to ZAxisMotion, except it ignores the
Absolute/Incremental mode setting, and increments by the value specified.
ZAxisMachineMotion Similar to ZAxisMotion, except it ignores all
transformations and is used to move a component to an absolute position within the
machine coordinate system.
ZAxisMachineRefMotion Same as its ZAxisMachineMotion counterpart, except
also adds in the offset from the Machine Reference Location (ref. Machine
Reference Location table). Thus, motion is relative to the machine's reference
location.
ZAxisMotion Sets the Z value used to process the machine's Z component. A
macro exists for each motion axis: A,B,C,A2,B2,C2,X,Y,Z,U,V,W.
ZAxisMotionNoCycle Same as ZAxisMotion, except the value is never interpreted
as a cycle depth value.
ZAxisZeroTracking Sets the Z value used to process the machine's W component
on a Zero-Tracking machine.
ZLeadRate Sets the distance to move along the Z axes per revolution while
threading. If 2 or more axes are in motion, the lead rate of the axis which is moving
the greatest distance will be used.
ZPrimaryTrackingAxis Marks the Z as the primary axis and the W as the
secondary axis on a zero tracking machine.
ZRetractSpecifiedpoint Set the retract level Z position.
ZToolOffsetCompName Specifies the name of the component to which the "Z
tool offset" is applied. Also see: XToolOffsetCompName, YToolOffsetCompName
ZTranslateStockComp Specifies the name of a Stock component in which the
turning "PROFILE" primitive is to be translated. This macro is typically used when
simulating pick-off spindle operations.
ZTranslateValue Specifies the "Z" amount that a turning "PROFILE" primitive is
to be translated. This macro is typically used when simulating pick-off spindle
operations.
ZWBTiltTableLength Designed for use with NC machines that use two linear
axes connected at opposing ends of a table that act as a "pseudo-rotary" table. Such
a machine has Z,W,B axes which act together to cause table tilt action. You can
call this macro during the "Start of Processing" event, and pass it an Override
Value equal to the length of a tilting table. This is then used as a flag to correct the
B rotary value based on Z and W during rotary moves.
NOTE: The setting of the B value through the user interface is still required,
even though the G-Code tool path on contains Z and W axis commands (no
B commands present).
Numbers A B C D E F G H I J K L M N O P Q R S T
U V W X Y Z
See Macros Sorted by See Macros Sorted by
Function Status

759
Macros Sorted by Function

NOTE: For information on special keywords CGTECH_MACRO and CGTECH_VAR


REAL, see About Simulating Subroutines in the Using VERICUT section.
Function List
ACCEL_DECEL CUTTER_COMP MOTION SHIFT_WORK_PZ TYPE2
ACTIVATION CYLIN_POLAR NURBS_POLY SIEMENS_CMD VARIABLES
BLOCK_SKIP DRILL_CYCLES OPTIPATH SUBROUTINES WIRE_EDM
BRANCHING DWELL POCKET_CYCLES SYNC WORK_OFFSETS
CHAMFER_RND EVENTS PROGRAM_ZERO TABLES

CIRCLES FEEDS_SPEEDS ROTATE_2D TOOL_OFFSETS

COOLANT MIRROR ROTATION_PLANE TOOLING

CURVE_FIT MISCELLANEOUS SHIFT_OFFSETS TURNING_CYCLES

Goto Function See Macros Listed See Macros Sorted


List Alphabetically by Status

MACRO MACRO FUNCTION STATUS COMMENTS

AccelTakeoffFactor ACCEL_DECEL ACTIVE


ArcAccelFeedrateFactor ACCEL_DECEL ACTIVE

ActivateAxis ACTIVATION ACTIVE


ActivatePreToolSubsystem ACTIVATION ALTERNATE
ActivateSpindle ACTIVATION NOT
RECOMMENDED
ActivateToolSubsystem ACTIVATION ACTIVE
ActiveTool ACTIVATION NOT Use
RECOMMENDED ActivateToolSubsystem
ActiveTool1 ACTIVATION OBSOLETE Use
ActivateToolSubsystem
ActiveTool2 ACTIVATION OBSOLETE Use
ActivateToolSubsystem
ActiveTool3 ACTIVATION OBSOLETE Use
ActivateToolSubsystem
ActiveTool4 ACTIVATION OBSOLETE Use
ActivateToolSubsystem
ActiveTool5 ACTIVATION OBSOLETE Use
ActivateToolSubsystem
InActivateAxis ACTIVATION ACTIVE
SpindleValue ACTIVATION NOT
RECOMMENDED
SubsystemActivateTool ACTIVATION ALTERNATE Use
ActivateToolSubsystem

760
BlockSkipAnywhere BLOCK_SKIP SPECIAL
BlockSkipSwitch1 BLOCK_SKIP ACTIVE
BlockSkipSwitchOff BLOCK_SKIP ACTIVE
BlockSkipSwitchOn BLOCK_SKIP ACTIVE

CinciGotoLabelName BRANCHING ACTIVE


ConditionalEndOfBlock BRANCHING ACTIVE Added V6.0
DoLoop BRANCHING ACTIVE
ElseBlock BRANCHING ACTIVE
EndIfBlock BRANCHING ACTIVE
EndLabelLoop BRANCHING SPECIAL
EndLoop BRANCHING ACTIVE
ForEndLoop BRANCHING ACTIVE
ForLoop BRANCHING ACTIVE
ForToValue BRANCHING ACTIVE
GotoJump BRANCHING ACTIVE
GotoJumpForwardBackward BRANCHING ACTIVE
GotoJumpForwardBackwardStart BRANCHING ACTIVE
GotoLabel BRANCHING ACTIVE
GotoLabelForwardBackward BRANCHING ACTIVE
Heid_GotoLabel BRANCHING ACTIVE Added V6.0
Heid_JumpDecrement BRANCHING ACTIVE
Heid_JumpDecrementValue BRANCHING ACTIVE
Heid_JumpDecrementVar BRANCHING ACTIVE
Heid_RepeatCount BRANCHING ACTIVE
IfBlock BRANCHING ACTIVE
IfCheck BRANCHING ACTIVE
IfCheckAllMacros BRANCHING ACTIVE
LabelMacro BRANCHING ACTIVE
LabelName BRANCHING ACTIVE
LabelNameValue BRANCHING ACTIVE
LoopCount BRANCHING ACTIVE
MahoSequence BRANCHING ACTIVE
NumIfCheck BRANCHING ALTERNATE Use IfCheck
NumSequence BRANCHING ACTIVE
OkumaGotoJump BRANCHING ACTIVE
OkumaGotoLabel BRANCHING ACTIVE
OliLabel BRANCHING ACTIVE
ResetIfCheck BRANCHING ACTIVE Added V6.0
Sequence BRANCHING ACTIVE

761
SequenceEnd BRANCHING ACTIVE
SequenceLoop BRANCHING ACTIVE
SequenceLoopCount BRANCHING ACTIVE
SequenceStart BRANCHING ACTIVE
SequenceStartEnd BRANCHING ACTIVE
SimpleForLoop BRANCHING ACTIVE
UntilLoop BRANCHING ACTIVE
WhileLoop BRANCHING ACTIVE

CornerMode CHAMFER_RND ACTIVE


CornerValue CHAMFER_RND ACTIVE
Heid_ProcessRNDorCHF CHAMFER_RND ACTIVE
SiemensCornerValue CHAMFER_RND ACTIVE

CircleCenterReset CIRCLES ACTIVE


CircleCenterX CIRCLES ACTIVE
CircleCenterY CIRCLES ACTIVE
CircleCenterZ CIRCLES ACTIVE
CircleCenterZWTracking CIRCLES ACTIVE
CircleDirectDrive CIRCLES ACTIVE Added V6.0
CircleIntermediatePoint CIRCLES ACTIVE Added V6.0
CirclePresentAxis CIRCLES ACTIVE
CircleRadius CIRCLES ACTIVE
CircleRadiusLarge CIRCLES ACTIVE
Heid_CircleCenterIncX CIRCLES ACTIVE
Heid_CircleCenterIncY CIRCLES ACTIVE
Heid_CircleCenterIncZ CIRCLES ACTIVE
Heid_CircleCenterX CIRCLES ACTIVE
Heid_CircleCenterY CIRCLES ACTIVE
Heid_CircleCenterZ CIRCLES ACTIVE
HelicalFullLoops CIRCLES ACTIVE
Icode CIRCLES ALTERNATE Use Conditionals to call
macros directly
Jcode CIRCLES ALTERNATE UseConditionals to call
macros directly
Kcode CIRCLES ALTERNATE Use Conditionals to call
macros directly
PitchForcesHelical CIRCLES ACTIVE
Rcode CIRCLES ALTERNATE Use Conditionals to call
macros directly
SetCircle360Tolearance CIRCLES ACTIVE

762
CoolantFlood COOLANT ACTIVE
CoolantMist COOLANT ACTIVE
CoolantOff COOLANT ACTIVE
CoolantOn COOLANT ACTIVE

CircleCurveFitQuadrants CURVE_FIT ACTIVE


CurveFitOnOff CURVE_FIT ACTIVE

Cancel3dToolOffset CUTTER_COMP ACTIVE


CutterComp3d CUTTER_COMP ACTIVE
CutterCompDoubleLong CUTTER_COMP ACTIVE
CutterCompDoubleShort CUTTER_COMP ACTIVE
CutterCompLeft CUTTER_COMP ACTIVE
CutterCompLong CUTTER_COMP ACTIVE
CutterCompOff CUTTER_COMP ACTIVE
CutterCompOffLookAheadX CUTTER_COMP ACTIVE
CutterCompOffLookAheadY CUTTER_COMP ACTIVE

CutterCompOffLookAheadZ CUTTER_COMP ACTIVE


CutterCompOffsetValue CUTTER_COMP ACTIVE
CutterCompRight CUTTER_COMP ACTIVE
CutterCompShort CUTTER_COMP ACTIVE
CutterCompSuspend CUTTER_COMP ACTIVE
CutterCompToolNum CUTTER_COMP OBSOLETE Use ToolCutterComp
CutterCompToolNumSubValue CUTTER_COMP OBSOLETE Use ToolCutterComp
CutterCompValue CUTTER_COMP OBSOLETE Use ToolCutterComp
CutterCompValueDirect CUTTER_COMP ACTIVE
MotionToolOffsetNeg CUTTER_COMP ACTIVE
MotionToolOffsetOnMotio CUTTER_COMP ACTIVE
n
MotionToolOffsetPos CUTTER_COMP ACTIVE
PartNormalX CUTTER_COMP ACTIVE
PartNormal CUTTER_COMP ACTIVE
PartNormalZ CUTTER_COMP ACTIVE
ShortLongOffsetReset CUTTER_COMP ACTIVE
Tool3dOffset CUTTER_COMP ACTIVE
Tool3dXOffset CUTTER_COMP ACTIVE
Tool3dYOffset CUTTER_COMP ACTIVE
Tool3dZOffset CUTTER_COMP ACTIVE
ToolCutterComp CUTTER_COMP ACTIVE Added V6.0
ToolVectorX CUTTER_COMP ACTIVE

763
ToolVectorY CUTTER_COMP ACTIVE
ToolVectorZ CUTTER_COMP ACTIVE
Unitize3DVector CUTTER_COMP ACTIVE
UvwAxis CUTTER_COMP ACTIVE
XyzAxis CUTTER_COMP ACTIVE

CylindricalDiameter CYLIN_POLAR ACTIVE


CylindricalInterpolation CYLIN_POLAR ACTIVE
CylindricalLinearAxis CYLIN_POLAR ACTIVE
CylindricalRotationalAxis CYLIN_POLAR ACTIVE
Heid_PolarAngle CYLIN_POLAR ACTIVE
Heid_PolarIncAngle CYLIN_POLAR ACTIVE
Heid_PolarIncRadius CYLIN_POLAR ACTIVE
Heid_PolarMotionCCW CYLIN_POLAR ACTIVE
Heid_PolarMotionCW CYLIN_POLAR ACTIVE
Heid_PolarMotionLinear CYLIN_POLAR ACTIVE
Heid_PolarRadius CYLIN_POLAR ACTIVE
HeidIso_Polar CYLIN_POLAR ACTIVE
HeidIso_PolarAngle CYLIN_POLAR ACTIVE
HeidIso_PolarRadius CYLIN_POLAR ACTIVE
PolarAngle CYLIN_POLAR ACTIVE
PolarInterpolation CYLIN_POLAR ACTIVE
PolarLinearAxis CYLIN_POLAR ACTIVE
PolarRotationalAxis CYLIN_POLAR ACTIVE
PolarXValue CYLIN_POLAR ACTIVE
PolarYValue CYLIN_POLAR ACTIVE
PolarZValue CYLIN_POLAR ACTIVE
SiemensL137COffset CYLIN_POLAR ACTIVE
SiemensL137COffsetCancel CYLIN_POLAR ACTIVE
SiemensPolarAngle CYLIN_POLAR ACTIVE Added V6.0

CycleBoreShiftFlags DRILL_CYCLES ACTIVE


CycleBoreShiftValue DRILL_CYCLES ACTIVE
CycleBoreSpindleOnOffFlags DRILL_CYCLES ACTIVE
CycleClearanceDistance DRILL_CYCLES ACTIVE
CycleDepth DRILL_CYCLES ACTIVE
CycleDepthInv DRILL_CYCLES ACTIVE
CycleDepthType DRILL_CYCLES ACTIVE
CycleDwellTime DRILL_CYCLES ACTIVE
CycleIgnore DRILL_CYCLES ACTIVE
CycleIncDepthType DRILL_CYCLES ACTIVE

764
CycleIncRapidType DRILL_CYCLES ACTIVE
CycleInitialOnMotion DRILL_CYCLES ACTIVE
CycleMotionPlaneCheckOnOff DRILL_CYCLES ACTIVE
CyclePresentAxis DRILL_CYCLES ACTIVE
CycleRapidLevelInitial DRILL_CYCLES ACTIVE
CycleRapidLevelInv DRILL_CYCLES ACTIVE
CycleRapidLevelKeep DRILL_CYCLES ACTIVE
CycleRapidLevelValue DRILL_CYCLES ACTIVE
CycleRapidLevelValueMult DRILL_CYCLES ACTIVE
CycleRapidLevelZeroTracking DRILL_CYCLES ACTIVE
CycleRapidType DRILL_CYCLES ACTIVE
CycleRetractInitial DRILL_CYCLES ACTIVE
CycleRetraction DRILL_CYCLES ACTIVE
CycleRetractSpecifiedpoint DRILL_CYCLES ACTIVE
CycleRetractSpecifiedZT DRILL_CYCLES ACTIVE
CyclesBore DRILL_CYCLES ACTIVE
CyclesBoreDrag DRILL_CYCLES ACTIVE
CyclesBoreOrient DRILL_CYCLES ACTIVE
CyclesCancel DRILL_CYCLES ACTIVE
CyclesDeep DRILL_CYCLES ACTIVE
CyclesDrill DRILL_CYCLES ACTIVE
CyclesExecute DRILL_CYCLES ACTIVE
CyclesExecuteModal DRILL_CYCLES ACTIVE
CyclesExecuteOnMotionOnOff DRILL_CYCLES ACTIVE
CyclesFace DRILL_CYCLES ACTIVE
CyclesMill DRILL_CYCLES ACTIVE
CyclesTap DRILL_CYCLES ACTIVE
CycleStepUpValue DRILL_CYCLES ACTIVE
CycleStepValue DRILL_CYCLES ACTIVE
CyclesThru DRILL_CYCLES ACTIVE
CycleUvDepth DRILL_CYCLES ACTIVE
CycleXyzDepth DRILL_CYCLES ACTIVE
CycleZeroTrackingAdjOnOff DRILL_CYCLES ACTIVE
RetractLevelClearanceRetract DRILL_CYCLES ACTIVE
RetractLevelInitial DRILL_CYCLES ACTIVE
RetractLevelRpoint DRILL_CYCLES ACTIVE
RetractLevelSpecifiedpoint DRILL_CYCLES ACTIVE
SetCycleSquareOffType DRILL_CYCLES ACTIVE
XRetractSpecifiedpoint DRILL_CYCLES ACTIVE
YRetractSpecifiedpoint DRILL_CYCLES ACTIVE
ZRetractSpecifiedpoint DRILL_CYCLES ACTIVE

765
DwellMacro DWELL ACTIVE
DwellRevolutions DWELL ACTIVE
DwellSeconds DWELL ACTIVE
DwellTime DWELL ACTIVE

AbBlockInit EVENTS ACTIVE


BlockFinish EVENTS ACTIVE
BlockInit EVENTS ACTIVE
CinciBlockInit EVENTS ACTIVE
ConversionFinish EVENTS ACTIVE
ConversionInit EVENTS ACTIVE
Fidia_ConvInit EVENTS ACTIVE
Heid_BlockInit EVENTS ACTIVE
KtBlockInit EVENTS ACTIVE
OliConvInit EVENTS ACTIVE
ProcessMotion EVENTS ACTIVE

ActiveSpindleActiveTool FEEDS_SPEEDS ACTIVE


ActiveSpindleCompName FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleDir FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleMaxSpeed FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleMinSpeed FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleOnOff FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleSpeed FEEDS_SPEEDS ACTIVE Added V6.0
ConstantSurfaceSpeed FEEDS_SPEEDS ACTIVE
ConstantSurfaceSpeedMod FEEDS_SPEEDS ACTIVE
e
FeedInvTime FEEDS_SPEEDS ACTIVE
FeedInvTimeModalMultiplier FEEDS_SPEEDS ACTIVE
FeedInvTimeMultiplier FEEDS_SPEEDS ACTIVE
FeedInvTimeSec FEEDS_SPEEDS ACTIVE
FeedModeMinute FEEDS_SPEEDS ACTIVE
FeedModeRevolution FEEDS_SPEEDS ACTIVE
FeedModeTime FEEDS_SPEEDS ACTIVE
FeedPerMinute FEEDS_SPEEDS ACTIVE
FeedPerMinuteType FEEDS_SPEEDS ACTIVE
FeedPerRev FEEDS_SPEEDS ACTIVE
FeedRate FEEDS_SPEEDS ACTIVE
MaxTableRPM FEEDS_SPEEDS ACTIVE
MazakSpindleRotation FEEDS_SPEEDS ACTIVE
OkumaFeedrate2 FEEDS_SPEEDS ACTIVE Added V6.0

766
OkumaFeedrate3 FEEDS_SPEEDS ACTIVE Added V6.0
RPMMode FEEDS_SPEEDS ACTIVE
RPMSpeed FEEDS_SPEEDS ACTIVE
SetActiveSpindleName FEEDS_SPEEDS ALTERNATE Use SetActiveStockName
SetActiveStockName FEEDS_SPEEDS ACTIVE
SiemensActualSpindle FEEDS_SPEEDS ACTIVE
SiemensEndlessFeedLinkO FEEDS_SPEEDS ACTIVE
nOff
SiemensEndlessFeedMode FEEDS_SPEEDS ACTIVE
SiemensEndlessFeedRate FEEDS_SPEEDS ACTIVE
SiemensSpecifiedSpindle FEEDS_SPEEDS ACTIVE
SiemensSpindleSpeed FEEDS_SPEEDS ACTIVE
SpindleMotionCCW FEEDS_SPEEDS ACTIVE
SpindleMotionCW FEEDS_SPEEDS ACTIVE
SpindleMotionOff FEEDS_SPEEDS ACTIVE
SpindleSpeed FEEDS_SPEEDS ACTIVE
SubSpindleTransform FEEDS_SPEEDS ACTIVE
SurfaceSpeed FEEDS_SPEEDS ACTIVE

MirrorA MIRROR ACTIVE


MirrorA2 MIRROR ACTIVE
MirrorA2Cancel MIRROR ACTIVE
MirrorA2Value MIRROR ACTIVE
MirrorACancel MIRROR ACTIVE
MirrorAValue MIRROR ACTIVE
MirrorB MIRROR ACTIVE
MirrorB2 MIRROR ACTIVE
MirrorB2Cancel MIRROR ACTIVE
MirrorB2Value MIRROR ACTIVE
MirrorBCancel MIRROR ACTIVE
MirrorBValue MIRROR ACTIVE
MirrorC MIRROR ACTIVE
MirrorC2 MIRROR ACTIVE
MirrorC2Cancel MIRROR ACTIVE
MirrorC2Value MIRROR ACTIVE
MirrorCancel MIRROR ACTIVE
MirrorCCancel MIRROR ACTIVE
MirrorCValue MIRROR ACTIVE
MirrorX MIRROR ACTIVE
MirrorXCancel MIRROR ACTIVE
MirrorXValue MIRROR ACTIVE
MirrorY MIRROR ACTIVE
MirrorYCancel MIRROR ACTIVE

767
MirrorYValue MIRROR ACTIVE
MirrorZ MIRROR ACTIVE
MirrorZCancel MIRROR ACTIVE
MirrorZValue MIRROR ACTIVE

AlarmSignal MISC ACTIVE


AutoScanOff MISC ACTIVE
AxisMappingXtoU MISC ACTIVE
ChangeSubsystemID MISC ACTIVE Added V6.0
CheckForLooseMaterial MISC ACTIVE
ClampCompName MISC ACTIVE
ClampOnOff MISC ACTIVE
CollisionCheckOnOff MISC SPECIAL
CollisionDiagonalSize MISC ACTIVE Added V6.0
CollisionOnCutPart MISC NOT
RECOMMENDED
CollisionSpecialComp MISC SPECIAL
ConnectCompName MISC ACTIVE
ConnectToCompName MISC ACTIVE
CoupleAxisOff MISC ACTIVE
CoupleAxisOn MISC ACTIVE
DebugMacro MISC ACTIVE
DefineCsys MISC ACTIVE
DefineDashAsAlphaNumeric MISC ACTIVE
Enhanced5AxisLogicOnOff MISC SPECIAL Added V6.0 - Use only if
there is a problem
ErrorMacro MISC ACTIVE
GetCurrentDate MISC ACTIVE
IgnoreMacro MISC ACTIVE
InputMacro MISC ACTIVE
InverseWordValue MISC ACTIVE
LinkAxisId MISC ACTIVE Added V6.0
LinkCompName MISC ACTIVE Added V6.0
LinkFormula MISC ACTIVE Added V6.0
LoadStocks MISC ACTIVE
MacroNotFoundMsgOnOff MISC ACTIVE Added V6.0
MazakMillingInterpolationOff MISC ACTIVE
MazakMillingInterpolationOn MISC ACTIVE
MazakPartLoader MISC OBSOLETE
MessageMacro MISC ACTIVE
ModeAsymTurningOnOff MISC ACTIVE
MotionBlockSyncOnOff MISC ACTIVE
MoveCutStockCompName MISC ACTIVE

768
MoveCutStockFromCsys MISC ACTIVE
MoveCutStockToCsys MISC ACTIVE
MoveDesignWithStock MISC ACTIVE
NullMacro MISC ACTIVE
OkumaControllingHead MISC ACTIVE
OkumaCutDepth2 MISC ACTIVE Added V6.0
OkumaCutDepth3 MISC ACTIVE Added V6.0
OkumaStartCutDepth2 MISC ACTIVE Added V6.0
OkumaStartCutDepth3 MISC ACTIVE Added V6.0
PartTransformation MISC OBSOLETE
Probe MISC ACTIVE
ProcessTimeOnOff MISC ACTIVE
ProgramStartNextLine MISC ACTIVE
RapidPlanePriorityType MISC ACTIVE
ReferencePoint MISC ACTIVE
ReferencePointCancelOffsets MISC ACTIVE
ReferencePointIndex MISC ACTIVE
RestoreSubsystemID MISC ACTIVE
RestoreUnits MISC ACTIVE
SaveUnits MISC ACTIVE
SetAxisCompLink MISC ACTIVE Added V6.0
SetAxisRegisterName MISC NOT Concept is being tested
RECOMMENDED
SetComponentColor MISC ACTIVE
SetComponentVisibility MISC ACTIVE
SetProgrammingMethod MISC ACTIVE
SetSubsystemID MISC ACTIVE
SetVNCKOption MISC ACTIVE Added V6.0
Siemens3PreProcessor MISC ACTIVE
SiemensEndlessOnOffDir MISC ACTIVE
SpecialRotoTrans MISC SPECIAL
SpecialRotoTransComp MISC SPECIAL
SpindleChanger MISC SPECIAL
StopOptional MISC ACTIVE
StopProgram MISC ACTIVE
StopUnconditiona MISC ACTIVE
SuspendCutting MISC ACTIVE
Touch MISC ACTIVE
TouchComponentName MISC ACTIVE
TripodArmLength MISC SPECIAL
TripodRodLength MISC SPECIAL
TurnOnOffRealTimeClock MISC ACTIVE
TurnOnOffTravelLimits MISC ACTIVE
UnitsInch MISC ACTIVE

769
UnitsMetric MISC ACTIVE
Unsupported MISC ACTIVE
UpdateAxisValues MISC ACTIVE
ValueArgument MISC ACTIVE
VariableArgument MISC ACTIVE
VC_LoadFix MISC ACTIVE
VC_ModeMilling MISC ACTIVE
VC_ModeMillingComp MISC ACTIVE
VC_ModeTurning MISC ACTIVE
VC_ModeTurningComp MISC ACTIVE
VC_UnloadFix MISC ACTIVE
VirtualXAxis MISC ACTIVE
VirtualYAxis MISC ACTIVE
ZTranslateStockComp MISC OBSOLETE
ZTranslateValue MISC OBSOLETE
ZWBTiltTableLength MISC SPECIAL

A2AxisIncreMotion MOTION ACTIVE


A2AxisMachineMotion MOTION ACTIVE
A2AxisMachineRefMotion MOTION ACTIVE
A2AxisMotion MOTION ACTIVE
AAxisIncreMotion MOTION ACTIVE
AAxisMachineMotion MOTION ACTIVE
AAxisMachineRefMotion MOTION ACTIVE
AAxisMotion MOTION ACTIVE
AxisPriorityOnOff MOTION ACTIVE Added V6.0
B2AxisIncreMotion MOTION ACTIVE
B2AxisMachineMotion MOTION ACTIVE
B2AxisMachineRefMotion MOTION ACTIVE
B2AxisMotion MOTION ACTIVE
BAxisIncreMotion MOTION ACTIVE
BAxisMachineMotion MOTION ACTIVE
BAxisMachineRefMotion MOTION ACTIVE
BAxisMotion MOTION ACTIVE
C2AxisIncreMotion MOTION ACTIVE
C2AxisMachineMotion MOTION ACTIVE
C2AxisMachineRefMotion MOTION ACTIVE
C2AxisMotion MOTION ACTIVE
CAxisIncreMotion MOTION ACTIVE
CAxisMachineMotion MOTION ACTIVE
CAxisMachineRefMotion MOTION ACTIVE
CAxisMotion MOTION ACTIVE

770
GLSetCurrentZeroTrackingPos MOTION ACTIVE
Heid_MotionCCW MOTION ALTERNATE Use MotionCCW
Heid_MotionCW MOTION ALTERNATE Use MotionCW
Heid_MotionLinear MOTION ACTIVE
Heid_XAxisMotion MOTION ACTIVE
Heid_YAxisMotion MOTION ACTIVE
ModeAbsolute MOTION ACTIVE
ModeIncremental MOTION ACTIVE
Motion3DCircle MOTION ACTIVE Added V6.0
MotionCCW MOTION ACTIVE
MotionCW MOTION ACTIVE
MotionLinear MOTION ACTIVE
MotionNurbs MOTION ACTIVE
MotionOnOff MOTION SPECIAL
MotionOnOffSide MOTION OBSOLETE
MotionOnSide MOTION OBSOLETE
MotionPlaneXY MOTION ACTIVE
MotionPlaneYZ MOTION ACTIVE
MotionPlaneZX MOTION ACTIVE
MotionPoly MOTION ACTIVE
MotionRapid MOTION ACTIVE
MotionThread MOTION ACTIVE
PlaneAxisMapping MOTION ACTIVE
ProcessCompNameValue MOTION ACTIVE
ProcessCompRegValue MOTION ALTERNATE Use
ProcessCompNameValue
RestoreMotionType MOTION ACTIVE
SetMotionFlag MOTION SPECIAL
SiemensPlaneOverrideArg MOTION ACTIVE
SiemensPlaneSelection MOTION ACTIVE
SiemensPlaneSelectionArg MOTION ACTIVE
UAxisIncreMotion MOTION ACTIVE
UAxisMachineMotion MOTION ACTIVE
UAxisMachineRefMotion MOTION ACTIVE
UAxisMotion MOTION ACTIVE
VAxisIncreMotion MOTION ACTIVE
VAxisMachineMotion MOTION ACTIVE
VAxisMachineRefMotion MOTION ACTIVE
VAxisMotion MOTION ACTIVE
WAxisIncreMotion MOTION ACTIVE
WAxisMachineMotion MOTION ACTIVE
WAxisMachineRefMotion MOTION ACTIVE
WAxisMotion MOTION ACTIVE
WAxisMotionNoCycle MOTION ACTIVE

771
WAxisZeroTracking MOTION ACTIVE
WPrimaryTrackingAxis MOTION ACTIVE
XAxisIncreMotion MOTION ACTIVE
XAxisMachineMotion MOTION ACTIVE
XAxisMachineRefMotion MOTION ACTIVE
XAxisMotion MOTION ACTIVE
XLeadRate MOTION ALTERNATE
YAxisIncreMotion MOTION ACTIVE
YAxisMachineMotion MOTION ACTIVE
YAxisMachineRefMotion MOTION ACTIVE
YAxisMotion MOTION ACTIVE
YLeadRate MOTION ALTERNATE
ZAxisIncreMotion MOTION ACTIVE
ZAxisMachineMotion MOTION ACTIVE
ZAxisMachineRefMotion MOTION ACTIVE
ZAxisMotion MOTION ACTIVE
ZAxisMotionNoCycle MOTION ACTIVE
ZAxisZeroTracking MOTION ACTIVE
ZLeadRate MOTION ALTERNATE
ZPrimaryTrackingAxis MOTION ACTIVE

NurbsDegree NURBS_POLY ACTIVE


NurbsInitialControl NURBS_POLY ACTIVE
NurbsKnot NURBS_POLY ACTIVE
NurbsOrder NURBS_POLY ACTIVE
NurbsWeight NURBS_POLY ACTIVE
SiemensNurbsKnot NURBS_POLY ACTIVE
SiemensNurbsProcess NURBS_POLY ACTIVE
SiemensPolyT NURBS_POLY ACTIVE
SiemensPolyx NURBS_POLY ACTIVE
SiemensPolyy NURBS_POLY ACTIVE
SiemensPolyz NURBS_POLY ACTIVE

Optimizable OPTIPATH ACTIVE


OptiMWordLast OPTIPATH ACTIVE
OptiPathExpandSubs OPTIPATH ACTIVE
OptiPathOptimizeCDC OPTIPATH ACTIVE
OptiPathOptimizeSubs OPTIPATH ACTIVE
OptiRestoreAdditionalCuts OPTIPATH ACTIVE
OptiSettings OPTIPATH ACTIVE
OptiSuppressAdditionalCuts OPTIPATH ACTIVE

772
OptiXYZFormat OPTIPATH ACTIVE
SkipWordIsOptimizable OPTIPATH ACTIVE

CycleMillPocketAngle POCKET_CYCLES ACTIVE


CycleMillPocketBottomAllowanc POCKET_CYCLES ACTIVE
e
CycleMillPocketBottomZ POCKET_CYCLES ACTIVE
CycleMillPocketBoundarySub POCKET_CYCLES ACTIVE
CycleMillPocketCenterX POCKET_CYCLES ACTIVE
CycleMillPocketCenterY POCKET_CYCLES ACTIVE
CycleMillPocketCornerRadius POCKET_CYCLES ACTIVE
CycleMillPocketCutDirection POCKET_CYCLES ACTIVE
CycleMillPocketCutType POCKET_CYCLES ACTIVE
CycleMillPocketDepth POCKET_CYCLES ACTIVE
CycleMillPocketFinishFeed POCKET_CYCLES ACTIVE
CycleMillPocketFinishStepover POCKET_CYCLES ACTIVE
CycleMillPocketInsideRadius POCKET_CYCLES ACTIVE
CycleMillPocketLength POCKET_CYCLES ACTIVE
CycleMillPocketMaxCutDepth POCKET_CYCLES ACTIVE
CycleMillPocketPlungeFeed POCKET_CYCLES ACTIVE
CycleMillPocketRefPlane POCKET_CYCLES ACTIVE
CycleMillPocketRetractPlane POCKET_CYCLES ACTIVE
CycleMillPocketRoughFeed POCKET_CYCLES ACTIVE
CycleMillPocketSafeDistance POCKET_CYCLES ACTIVE
CycleMillPocketSideAllowance POCKET_CYCLES ACTIVE
CycleMillPocketSpeed POCKET_CYCLES ACTIVE
CycleMillPocketStepover POCKET_CYCLES ACTIVE
CycleMillPocketType POCKET_CYCLES ACTIVE
CycleMillPocketWidth POCKET_CYCLES ACTIVE
Heid_GetPocketContours POCKET_CYCLES ACTIVE
Heid_InitializePocketContours POCKET_CYCLES ACTIVE
Heid_PocketSub POCKET_CYCLES ACTIVE
SiemensCycleMillPocketCutTyp POCKET_CYCLES ACTIVE
e

AutoUpdateIPZ PROGRAM_ZERO OBSOLETE Use AutoUpdatePZ


AutoUpdatePZ PROGRAM_ZERO NR Try using Gage and Gage
Pivot Offsets
GLSameAngle360OnOff PROGRAM_ZERO ACTIVE
MahoVertical2Rest PROGRAM_ZERO ALTERNATE Drive axis directly
MahoVertical2Work PROGRAM_ZERO ALTERNATE Drive axis directly
MaxTesselationAngle PROGRAM_ZERO SPECIAL
MinTesselationPoints PROGRAM_ZERO ACTIVE

773
RotaryAxisLinearRewind PROGRAM_ZERO ACTIVE
RotaryAxisLinearRewind360 PROGRAM_ZERO ACTIVE
_360
RotaryDirCCW PROGRAM_ZERO ACTIVE
RotaryDirCW PROGRAM_ZERO ACTIVE
RotaryDirLinear PROGRAM_ZERO ACTIVE
RotaryDirPosCCW PROGRAM_ZERO ACTIVE
RotaryDirPosCW PROGRAM_ZERO ACTIVE
RotaryDirShortestDist PROGRAM_ZERO ACTIVE
RotaryLinearRewind PROGRAM_ZERO ACTIVE
RotaryLinearRewind360 PROGRAM_ZERO ACTIVE
_360
RotaryTypeAbsolute PROGRAM_ZERO ACTIVE
RotaryTypeLinear PROGRAM_ZERO ACTIVE
UpdateIPZ PROGRAM_ZERO OBSOLETE
UpdatePZ PROGRAM_ZERO SPECIAL

CinciRotateCenterCalc ROTATE_2D ACTIVE


CinciRotateXYZMode ROTATE_2D ACTIVE
OkumaCopyEnd ROTATE_2D ACTIVE
OkumaCopyLoopCount ROTATE_2D ACTIVE
OkumaCopyStart ROTATE_2D ACTIVE
OkumaShiftRotate ROTATE_2D ACTIVE
RotateCancel ROTATE_2D ACTIVE
RotateMacro ROTATE_2D SPECIAL
RotateOrigin ROTATE_2D ACTIVE
RotateXValue ROTATE_2D ACTIVE
RotateXYZ ROTATE_2D ACTIVE
RotateYValue ROTATE_2D ACTIVE
RotateZValue ROTATE_2D ACTIVE
RotationAbsAngle ROTATE_2D ACTIVE
RotationAngle ROTATE_2D ACTIVE
RotationIncAngle ROTATE_2D ACTIVE
SiemensShiftAngleA ROTATE_2D ACTIVE
SiemensShiftAngleB ROTATE_2D ACTIVE

ApplyRotationPlaneWithIjk2Abc ROTATION_PLANE ACTIVE


FanucRotationPlaneLocal2 ROTATION_PLANE ALTERNATE Added V6.0 Use
TurnOnOffGageOffset
Fidia_Rotate ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_Rotate2 ROTATION_PLANE ALTERNATE Use standard rotation plane
macros

774
Fidia_RotateCancel ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_RotateCancel2 ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_RotateXAxis ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_RotateXPoint ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_RotateYAxis ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_RotateYPoint ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_RotateZAxis ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Fidia_RotateZPoint ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
Ijk2AbcType ROTATION_PLANE ACTIVE
IjkAAxisMotion ROTATION_PLANE ACTIVE
IjkBAxisMotion ROTATION_PLANE ACTIVE
IjkCAxisMotion ROTATION_PLANE ACTIVE
IVector ROTATION_PLANE ACTIVE
JVector ROTATION_PLANE ACTIVE
KVector ROTATION_PLANE ACTIVE
NumPlane ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
NumPlaneA ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
NumPlaneB ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
NumPlaneC ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
NumPlaneU ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
NumPlaneV ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
NumPlaneW ROTATION_PLANE ALTERNATE Use standard rotation plane
macros
PlaneAxisVectorX ROTATION_PLANE ACTIVE
PlaneAxisVectorY ROTATION_PLANE ACTIVE
PlaneAxisVectorZ ROTATION_PLANE ACTIVE
RotationPlane ROTATION_PLANE ALTERNATE Use RotationPlane2
RotationPlane2 ROTATION_PLANE ACTIVE
RotationPlaneAngle1 ROTATION_PLANE ACTIVE
RotationPlaneAngle2 ROTATION_PLANE ACTIVE
RotationPlaneAngle3 ROTATION_PLANE ACTIVE
RotationPlaneCancel ROTATION_PLANE ALTERNATE Use
RotationPlaneCancelReset
RotationPlaneCancel2 ROTATION_PLANE ACTIVE Use
RotationPlaneCancelReset
RotationPlaneCancelReset ROTATION_PLANE ACTIVE Added V6.0

775
RotationPlaneEnable2 ROTATION_PLANE ACTIVE Added V6.0
RotationPlaneIncAngle1 ROTATION_PLANE OBSOLETE Use non incremental
angles and
RotatonPlaneLocal2
RotationPlaneIncAngle2 ROTATION_PLANE OBSOLETE Use non incremental
angles and
RotatonPlaneLocal2
RotationPlaneIncAngle3 ROTATION_PLANE OBSOLETE Use non incremental
angles and
RotatonPlaneLocal2
RotationPlaneIncXPoint ROTATION_PLANE ACTIVE
RotationPlaneIncYPoint ROTATION_PLANE ACTIVE
RotationPlaneIncZPoint ROTATION_PLANE ACTIVE
RotationPlaneLocal ROTATION_PLANE ALTERNATE Use RotationPlaneLocal2
RotationPlaneLocal2 ROTATION_PLANE ACTIVE
RotationPlaneRestoreAxis ROTATION_PLANE NR Use Rotation macros
ending with 2
RotationPlaneSpecialOffset ROTATION_PLANE ACTIVE
RotationPlaneXPoint ROTATION_PLANE ACTIVE
RotationPlaneYPoint ROTATION_PLANE ACTIVE
RotationPlaneZPoint ROTATION_PLANE ACTIVE
WorkingPlane2Abc ROTATION_PLANE ACTIVE
WorkingPlane2AbcType ROTATION_PLANE ACTIVE

AbsoluteShift SHIFT_OFFSETS ACTIVE


AbsoluteShiftModal SHIFT_OFFSETS ACTIVE
AbsoluteShiftNum SHIFT_OFFSETS ACTIVE
CancelShiftOffsets SHIFT_OFFSETS ACTIVE
ChangeWorkCoord SHIFT_OFFSETS SPECIAL
IncrementalShift SHIFT_OFFSETS ACTIVE
IncrementalShiftRotationDynami SHIFT_OFFSETS ACTIVE
c
OkumaCancelShiftRotate SHIFT_OFFSETS ACTIVE
SiemensShiftOffsetA SHIFT_OFFSETS ACTIVE
SiemensShiftOffsetB SHIFT_OFFSETS ACTIVE

DisableWorkShiftOffsets SHIFT_WORK_PZ ACTIVE


DynamicWorkOffsets SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsContour SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsLocalCoord SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsTypes SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsWithMotion SHIFT_WORK_PZ ACTIVE
EnableWorkShiftOffsets SHIFT_WORK_PZ ACTIVE
ResetWorkCoordParms SHIFT_WORK_PZ ACTIVE

776
RpcpOff SHIFT_WORK_PZ ACTIVE
RpcpOn SHIFT_WORK_PZ ACTIVE
UpdateRotaryOffsets SHIFT_WORK_PZ ACTIVE

Siemens3CmdBranch SIEMENS_CMD ACTIVE


Siemens3CmdIfEqual SIEMENS_CMD ACTIVE
Siemens3CmdIfGreater SIEMENS_CMD ACTIVE
Siemens3CmdIfGreaterEqual SIEMENS_CMD ACTIVE
Siemens3LoadAddress SIEMENS_CMD ACTIVE
Siemens3SetAddressParm SIEMENS_CMD ACTIVE
Siemens3TAddressAxis SIEMENS_CMD ACTIVE
SiemensCmd300 SIEMENS_CMD ACTIVE
SiemensCmd302 SIEMENS_CMD ACTIVE
SiemensCmd303 SIEMENS_CMD ACTIVE
SiemensCmd305 SIEMENS_CMD ACTIVE
SiemensCmd306 SIEMENS_CMD ACTIVE
SiemensCmd308 SIEMENS_CMD ACTIVE
SiemensCmd330 SIEMENS_CMD ACTIVE
SiemensCmd331 SIEMENS_CMD ACTIVE
SiemensCmd360 SIEMENS_CMD ACTIVE
SiemensCmd383 SIEMENS_CMD ACTIVE
SiemensCmd400 SIEMENS_CMD ACTIVE
SiemensCmd403 SIEMENS_CMD ACTIVE
SiemensCmd404 SIEMENS_CMD ACTIVE
SiemensCmd430 SIEMENS_CMD ACTIVE
SiemensCmdAbs SIEMENS_CMD ACTIVE
SiemensCmdAngle SIEMENS_CMD ACTIVE
SiemensCmdASin SIEMENS_CMD ACTIVE
SiemensCmdATan SIEMENS_CMD ACTIVE
SiemensCmdBranch SIEMENS_CMD ACTIVE
SiemensCmdCase SIEMENS_CMD ACTIVE
SiemensCmdCos SIEMENS_CMD ACTIVE
SiemensCmdDec SIEMENS_CMD ACTIVE
SiemensCmdGetChannel SIEMENS_CMD ACTIVE
SiemensCmdGetGCode SIEMENS_CMD ACTIVE
SiemensCmdHypot SIEMENS_CMD ACTIVE
SiemensCmdIfEqual SIEMENS_CMD ACTIVE
SiemensCmdIfGreater SIEMENS_CMD ACTIVE
SiemensCmdIfGreaterEqual SIEMENS_CMD ACTIVE
SiemensCmdIfLess SIEMENS_CMD ACTIVE
SiemensCmdIfLessEqual SIEMENS_CMD ACTIVE
SiemensCmdIfNotEqual SIEMENS_CMD ACTIVE

777
SiemensCmdInc SIEMENS_CMD ACTIVE
SiemensCmdIntegral SIEMENS_CMD ACTIVE
SiemensCmdPopVarGroup SIEMENS_CMD ACTIVE
SiemensCmdPushVarGroup SIEMENS_CMD ACTIVE
SiemensCmdSin SIEMENS_CMD ACTIVE
SiemensCmdSquareRoot SIEMENS_CMD ACTIVE
SiemensCmdTan SIEMENS_CMD ACTIVE

CallNCMacro SUBROUTINES ACTIVE


CallNCMacroBlock SUBROUTINES ACTIVE
CallNCMacroCancel SUBROUTINES ACTIVE
CallNCMacroMotion SUBROUTINES ACTIVE
CallSub SUBROUTINES ACTIVE
CallSubCurrent SUBROUTINES ACTIVE Added V6.0
CallSubName SUBROUTINES ACTIVE
CallTextSubName SUBROUTINES ACTIVE
CycleSubroutineOff SUBROUTINES ACTIVE
CycleSubroutineOn SUBROUTINES ACTIVE
CycleSubroutineOnNoMotion SUBROUTINES ACTIVE
EndProgram SUBROUTINES ACTIVE
EndProgramRewind SUBROUTINES ACTIVE
EndProgramRewindSpecial SUBROUTINES ACTIVE
EndSub SUBROUTINES ACTIVE
FadalLcode SUBROUTINES ACTIVE
G65ResetVarsOnLoop SUBROUTINES ACTIVE
Heid_CallLbl SUBROUTINES ACTIVE Added V6.0
Heid_CallSubName SUBROUTINES ACTIVE
Heid_CallTextSubName SUBROUTINES ACTIVE
Heid_EndSub SUBROUTINES ACTIVE
Heid_LabelMacro SUBROUTINES ACTIVE
HeidIso_SubDefCallEnd SUBROUTINES ACTIVE
HeidMPlus_SubroutineSequenc SUBROUTINES ACTIVE Added V6.0
e
IndexCallMainSub SUBROUTINES ACTIVE
IndexChannel1Subroutine SUBROUTINES ACTIVE
IndexChannel2Subroutine SUBROUTINES ACTIVE
MacroVar SUBROUTINES ACTIVE
NcodeSeqSub SUBROUTINES OBSOLETE
NumSubroutineSequence SUBROUTINES ACTIVE
NumSubSequenceLoop SUBROUTINES ACTIVE
Okuma_CallSubName SUBROUTINES ACTIVE
ReturnFromSub SUBROUTINES ACTIVE
ReturnFromSubCall SUBROUTINES ACTIVE Added V6.0

778
SequenceOrSubroutine SUBROUTINES ACTIVE
Siemens840DProc SUBROUTINES ACTIVE
Siemens840DProcCall SUBROUTINES ACTIVE
Siemens840DSubroutineSequen SUBROUTINES ACTIVE
ce
SiemensSubroutineCallDefine SUBROUTINES ACTIVE
SubEndingSeq SUBROUTINES ACTIVE
SubroutineBlock SUBROUTINES ACTIVE
SubroutineName SUBROUTINES ACTIVE
SubroutineSequence SUBROUTINES ACTIVE
SubroutineSequenceEnd SUBROUTINES ACTIVE
SubStartingSeq SUBROUTINES ACTIVE
UpdateModalMacroVar SUBROUTINES ACTIVE Added V6.0
VarsUpdateMacroVars SUBROUTINES ACTIVE Added V6.0

SyncCode SYNC ACTIVE Added V6.0


SyncId SYNC ACTIVE Added V6.0
SyncMacro SYNC ACTIVE
SyncMismatchHandling SYNC ACTIVE Added V6.0
SyncTransfer SYNC ACTIVE
SyncValue SYNC ACTIVE

SetTableCoord TABLES ACTIVE


SetTableValues TABLES ACTIVE
TableIndex TABLES ACTIVE
TableValues TABLES ACTIVE

ApplyGageOffset TOOL_OFFSETS OBSOLETE Use TurnOnOffGageOffset


ApplyGagePivotOffset TOOL_OFFSETS OBSOLETE Use
TurnOnOffGagePivotOffset
ApplyGagePivotOffsetCurrent TOOL_OFFSETS OBSOLETE Use
TurnOnOffGagePivotOffset
ApplyPivotOffset TOOL_OFFSETS ALTERNATE This macro is associated
with the older RTCP
method
ApplyTurretOffset TOOL_OFFSETS ALTERNATE Use
TurnOnOffGagePivotOffset
Cinci_5axisToolLengthComp TOOL_OFFSETS ALTERNATE
FanucToolLengthComp TOOL_OFFSETS ALTERNATE Use TurnOnOffGageOffset
FanucToolLengthCompAxisOn TOOL_OFFSETS ALTERNATE
GageOffsetAttributes TOOL_OFFSETS ACTIVE Added V6.0
GageOffsetDrivenPoint TOOL_OFFSETS ACTIVE Added V6.0

779
GageOffsetFirstDrivenPoint TOOL_OFFSETS ACTIVE Added V6.0
NumLengthCompX TOOL_OFFSETS ALTERNATE
NumLengthCompY TOOL_OFFSETS ALTERNATE
NumLengthCompZ TOOL_OFFSETS ALTERNATE
PivotOffsetCompName TOOL_OFFSETS ACTIVE
PivotOffsetCompNameB TOOL_OFFSETS ACTIVE
RotaryControlPointOnOff TOOL_OFFSETS ACTIVE
RtcpContour TOOL_OFFSETS ACTIVE
RtcpOff TOOL_OFFSETS ACTIVE
RtcpOn TOOL_OFFSETS ACTIVE
RtcpWithMotion TOOL_OFFSETS ACTIVE
SetGageOffset TOOL_OFFSETS OBSOLETE
SetGageOffsetSubValue TOOL_OFFSETS OBSOLETE
SetMatchingGageOffset TOOL_OFFSETS OBSOLETE
SetPivotOffset TOOL_OFFSETS ALTERNATE This macro is associated
with the old style RTCP
ToolLengthCompNeg TOOL_OFFSETS ALTERNATE
ToolLengthCompOff TOOL_OFFSETS ALTERNATE
ToolLengthCompPos TOOL_OFFSETS ALTERNATE
ToolLengthCompToolNum TOOL_OFFSETS ALTERNATE
ToolLengthCompToolNumSubV TOOL_OFFSETS ALTERNATE
alue
ToolLengthCompUpdate TOOL_OFFSETS ALTERNATE
ToolLengthCompValue TOOL_OFFSETS ALTERNATE
ToolLengthCompValueDirect TOOL_OFFSETS ACTIVE Added V6.0
ToolLengthOffsetValue TOOL_OFFSETS SPECIAL
ToolNoseCompApply TOOL_OFFSETS OBSOLETE As of V6.0
ToolNoseCompCancel TOOL_OFFSETS ACTIVE
ToolNoseCompToolNum TOOL_OFFSETS ACTIVE
ToolNoseCompToolNumSubVal TOOL_OFFSETS ACTIVE
ue
ToolNoseCompValue TOOL_OFFSETS ACTIVE
ToolOffsetAptAdj TOOL_OFFSETS OBSOLETE Use GageOffsetDrivenPoint
ToolOffsetIndex TOOL_OFFSETS NR Use GageOffsetDrivenPoint
ToolOffsetUpdate TOOL_OFFSETS NR Use GageOffsetDrivenPoint
TurnOnOffGageOffset TOOL_OFFSETS ACTIVE
TurnOnOffGagePivotOffset TOOL_OFFSETS ACTIVE
TurretRotationOffset TOOL_OFFSETS ACTIVE
XToolOffsetCompName TOOL_OFFSETS ACTIVE
YToolOffsetCompName TOOL_OFFSETS ACTIVE
ZToolOffsetCompName TOOL_OFFSETS ACTIVE

Hcode_Tool TOOLING ALTERNATE


LoadNextTool TOOLING ACTIVE

780
MountTool TOOLING ACTIVE
MountToolIndex TOOLING ACTIVE
PreToolCompSelect TOOLING ACTIVE
SetVcMultiTools TOOLING ACTIVE
SiemensLoadToolRegister TOOLING ACTIVE
ToolChainExchange TOOLING ACTIVE
ToolChainFromCompName TOOLING ACTIVE
ToolChainMotion TOOLING ACTIVE
ToolChainToCompName TOOLING ACTIVE
ToolChange TOOLING ACTIVE
ToolChangeAlpha TOOLING ACTIVE
ToolChangeByToolNum TOOLING ACTIVE
ToolChangeIfDifferent TOOLING ACTIVE
ToolChangeNoRetract TOOLING ACTIVE
ToolChangeSave TOOLING ACTIVE
ToolCode TOOLING ACTIVE
ToolCodeAlpha TOOLING ACTIVE
ToolCodeSave TOOLING ACTIVE
ToolRetract TOOLING ACTIVE
ToolRetractDistance TOOLING ACTIVE
TurretActivateTool TOOLING OBSOLETE
TurretIndex TOOLING OBSOLETE
TurretLoadTool TOOLING OBSOLETE
TurretRetract TOOLING OBSOLETE
TurretToolChange TOOLING ACTIVE
TurretToolChangeAlpha TOOLING ACTIVE Added V6.0
TurretToolChangeByToolNum TOOLING ACTIVE
UnloadTool TOOLING ACTIVE
UnloadToolNoRetract TOOLING ACTIVE
UnloadToolToCompName TOOLING ACTIVE
UnMountTool TOOLING ACTIVE
UnMountToolIndex TOOLING ACTIVE

CycleTurnAllowanceX TURNING_CYCLES ACTIVE


CycleTurnAllowanceZ TURNING_CYCLES ACTIVE
CycleTurnCutDepth TURNING_CYCLES ACTIVE
CycleTurnEndSeq TURNING_CYCLES ACTIVE
CycleTurnFeed TURNING_CYCLES ACTIVE
CycleTurnFinalX TURNING_CYCLES ACTIVE
CycleTurnFinalZ TURNING_CYCLES ACTIVE
CycleTurnFinish TURNING_CYCLES ACTIVE
CycleTurnGroove TURNING_CYCLES ACTIVE

781
CycleTurnGrooveAngle TURNING_CYCLES ACTIVE
CycleTurnGrooveDepth TURNING_CYCLES ACTIVE
CycleTurnGrooveEnd TURNING_CYCLES ACTIVE
CycleTurnGrooveEscape TURNING_CYCLES ACTIVE
CycleTurnGrooveFace TURNING_CYCLES ACTIVE
CycleTurnGrooveRelief TURNING_CYCLES ACTIVE
CycleTurnGrooveStep TURNING_CYCLES ACTIVE
CycleTurnLoopCount TURNING_CYCLES ACTIVE
CycleTurnRetractX TURNING_CYCLES ACTIVE
CycleTurnRetractZ TURNING_CYCLES ACTIVE
CycleTurnRoughCut TURNING_CYCLES ACTIVE
CycleTurnRoughFace TURNING_CYCLES ACTIVE
CycleTurnRoughLoop TURNING_CYCLES ACTIVE
CycleTurnSpeed TURNING_CYCLES ACTIVE
CycleTurnStartBlank TURNING_CYCLES ACTIVE
CycleTurnStartSeq TURNING_CYCLES ACTIVE
CycleTurnStockX TURNING_CYCLES ACTIVE
CycleTurnStockZ TURNING_CYCLES ACTIVE
CycleTurnThread TURNING_CYCLES ACTIVE
CycleTurnThreadAngleTaper TURNING_CYCLES ACTIVE
CycleTurnThreadFinish TURNING_CYCLES ACTIVE
CycleTurnThreadFirstCut TURNING_CYCLES ACTIVE
CycleTurnThreadHeight TURNING_CYCLES ACTIVE
CycleTurnThreadLead TURNING_CYCLES ACTIVE
CycleTurnThreadMinCut TURNING_CYCLES ACTIVE
CycleTurnThreadTaper TURNING_CYCLES ACTIVE
NumEndBlankContour TURNING_CYCLES ACTIVE
NumTurnCycle TURNING_CYCLES ACTIVE
OkumaEndContour TURNING_CYCLES ACTIVE
OkumaStartBlankContour TURNING_CYCLES ACTIVE
OkumaStartContour TURNING_CYCLES ACTIVE
OkumaTurnCycle TURNING_CYCLES ACTIVE
SiemensCycle95 TURNING_CYCLES ACTIVE
SiemensCycle95Type TURNING_CYCLES ACTIVE
SiemensCycle97 TURNING_CYCLES ACTIVE
SiemensCycle97ArcIn TURNING_CYCLES ACTIVE
SiemensCycle97ArcOut TURNING_CYCLES ACTIVE
SiemensCycle97FinalAllowance TURNING_CYCLES ACTIVE
SiemensCycle97FinishCuts TURNING_CYCLES ACTIVE
SiemensCycle97RoughCuts TURNING_CYCLES ACTIVE
SiemensCycle97ThreadStart TURNING_CYCLES ACTIVE
SiemensCycle97Type TURNING_CYCLES ACTIVE
SiemensCycle97Xend TURNING_CYCLES ACTIVE

782
SiemensCycle97Xstart TURNING_CYCLES ACTIVE
SiemensCycle97Zend TURNING_CYCLES ACTIVE
SiemensCycle97Zstart TURNING_CYCLES ACTIVE

ABType2CLS TYPE2 ACTIVE


BoschType2CYCLE TYPE2 ACTIVE
GLType2Begin TYPE2 ACTIVE
GLType2CLS TYPE2 ACTIVE
GLType2DFS TYPE2 ACTIVE
GLType2End TYPE2 ACTIVE
GLType2FXZ TYPE2 ACTIVE
GLType2FXZArg TYPE2 ACTIVE
GLType2PDO TYPE2 ACTIVE
GLType2PdoId TYPE2 ACTIVE
GLType2PGM TYPE2 ACTIVE
GLType2PRB TYPE2 ACTIVE
GLType2RPT TYPE2 ACTIVE
GLType2RTA TYPE2 ACTIVE
GLType2UPD TYPE2 ACTIVE
KtType2CLS TYPE2 ACTIVE
OliType2EPP TYPE2 ACTIVE
Type2Begin TYPE2 ACTIVE
Type2BEQLabel TYPE2 ACTIVE
Type2BGELabel TYPE2 ACTIVE
Type2BGTLabel TYPE2 ACTIVE
Type2BLELabel TYPE2 ACTIVE
Type2BLTLabel TYPE2 ACTIVE
Type2BNELabel TYPE2 ACTIVE
Type2CLS TYPE2 ACTIVE
Type2CommentAllArgs TYPE2 ACTIVE
Type2DFS TYPE2 ACTIVE
Type2End TYPE2 ACTIVE
Type2Goto TYPE2 ACTIVE
Type2GotoLabelCond TYPE2 ACTIVE Added V6.0
Type2GotoLabelFunction TYPE2 ACTIVE
Type2If TYPE2 ACTIVE
Type2IfBlock TYPE2 ACTIVE Added V6.0
Type2Label TYPE2 ACTIVE
Type2OpMsg TYPE2 ACTIVE
Type2OpMsgAllArgs TYPE2 ACTIVE
Type2OpMsgStop TYPE2 ACTIVE

783
AutosetCutterCompVars VARIABLES ACTIVE
AutosetTableAxisVars VARIABLES ACTIVE
AutosetToolLengthCompVars VARIABLES ACTIVE
CGTechVarDefMacro VARIABLES ACTIVE Added V6.0
NCVarDefaultValue VARIABLES ACTIVE
NCVarWarnMessage VARIABLES ACTIVE
SetDynamicVars VARIABLES ACTIVE
SetLocalVariableCount VARIABLES ACTIVE
SetMaxSubsystemVar VARIABLES ACTIVE
SetMinSubsystemVar VARIABLES ACTIVE
SetToolNumVar VARIABLES ACTIVE

CutWire WIRE_EDM ACTIVE


DefaultWire WIRE_EDM ACTIVE
EDMCalcUpperGuideHeight WIRE_EDM ACTIVE
EDMCalcUpperGuideLocation WIRE_EDM ACTIVE
EDMGuide2Guide WIRE_EDM ACTIVE
EDMLower2Reference WIRE_EDM ACTIVE
EDMLowerGuideHeight WIRE_EDM ACTIVE
EDMReference2Upper WIRE_EDM ACTIVE
EDMUpperGuideHeight WIRE_EDM ACTIVE
ThreadWire WIRE_EDM ACTIVE
VoltageOff WIRE_EDM ACTIVE
VoltageOn WIRE_EDM ACTIVE

AdditionalWorkCoord WORK_OFFSETS ACTIVE


BaseWorkOffsetValues WORK_OFFSETS ACTIVE
CancelAllWorkOffsets WORK_OFFSETS ACTIVE
CancelWorkOffsets WORK_OFFSETS ACTIVE
ChangeWorkCoordinateZWT WORK_OFFSETS ACTIVE Added V6.0
racking
FadalWorkCoord WORK_OFFSETS ACTIVE
SecondaryRefWorkCoord WORK_OFFSETS ACTIVE
SecondaryWorkCoord WORK_OFFSETS ACTIVE
SetAbsWorkCoord WORK_OFFSETS ACTIVE
SetAdditionalWorkCoord WORK_OFFSETS ACTIVE
SetAdditionalWorkCoordNonMo WORK_OFFSETS ACTIVE
dal
SetBaseWorkOffset WORK_OFFSETS ACTIVE
SetIncWorkCoord WORK_OFFSETS ACTIVE

784
SetWorkCoord WORK_OFFSETS ACTIVE
WorkCoord WORK_OFFSETS ACTIVE
WorkCoordA2Value WORK_OFFSETS ACTIVE
WorkCoordAValue WORK_OFFSETS ACTIVE
WorkCoordB2Value WORK_OFFSETS ACTIVE
WorkCoordBValue WORK_OFFSETS ACTIVE
WorkCoordC2Value WORK_OFFSETS ACTIVE
WorkCoordCValue WORK_OFFSETS ACTIVE
WorkCoordIndex WORK_OFFSETS ACTIVE
WorkCoordUValue WORK_OFFSETS ACTIVE
WorkCoordVValue WORK_OFFSETS ACTIVE
WorkCoordWithMotion WORK_OFFSETS ACTIVE
WorkCoordWValue WORK_OFFSETS ACTIVE
WorkCoordXValue WORK_OFFSETS ACTIVE
WorkCoordYValue WORK_OFFSETS ACTIVE
WorkCoordZValue WORK_OFFSETS ACTIVE

785
Macros Sorted by Status

NOTE: For information on special keywords CGTECH_MACRO and CGTECH_VAR


REAL, see About Simulating Subroutines in the Using VERICUT section.
Status List
ACTIVE ALTERNATE NOT RECOMMENDED OBSOLETE SPECIAL

Goto Status List See Macros Sorted Alphabetically

MACRO MACRO FUNCTION STATUS COMMENTS

A2AxisIncreMotion MOTION ACTIVE


A2AxisMachineMotion MOTION ACTIVE
A2AxisMachineRefMotion MOTION ACTIVE
A2AxisMotion MOTION ACTIVE
AAxisIncreMotion MOTION ACTIVE
AAxisMachineMotion MOTION ACTIVE
AAxisMachineRefMotion MOTION ACTIVE
AAxisMotion MOTION ACTIVE
AbBlockInit EVENTS ACTIVE
AbsoluteShift SHIFT_OFFSETS ACTIVE
AbsoluteShiftModal SHIFT_OFFSETS ACTIVE
AbsoluteShiftNum SHIFT_OFFSETS ACTIVE
ABType2CLS TYPE2 ACTIVE
AccelTakeoffFactor ACCEL_DECEL ACTIVE
ActivateAxis ACTIVATION ACTIVE
ActivateToolSubsystem ACTIVATION ACTIVE
ActiveSpindleActiveTool FEEDS_SPEEDS ACTIVE
ActiveSpindleCompName FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleDir FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleMaxSpeed FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleMinSpeed FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleOnOff FEEDS_SPEEDS ACTIVE Added V6.0
ActiveSpindleSpeed FEEDS_SPEEDS ACTIVE Added V6.0
AdditionalWorkCoord WORK_OFFSETS ACTIVE
AlarmSignal MISC ACTIVE
ApplyRotationPlaneWithIjk2Abc ROTATION_PLANE ACTIVE
ArcAccelFeedrateFactor ACCEL_DECEL ACTIVE

786
AutoScanOff MISC ACTIVE
AutosetCutterCompVars VARIABLES ACTIVE
AutosetTableAxisVars VARIABLES ACTIVE
AutosetToolLengthCompVars VARIABLES ACTIVE
AxisMappingXtoU MISC ACTIVE
AxisPriorityOnOff MOTION ACTIVE Added V6.0
B2AxisIncreMotion MOTION ACTIVE
B2AxisMachineMotion MOTION ACTIVE
B2AxisMachineRefMotion MOTION ACTIVE
B2AxisMotion MOTION ACTIVE
BaseWorkOffsetValues WORK_OFFSETS ACTIVE
BAxisIncreMotion MOTION ACTIVE
BAxisMachineMotion MOTION ACTIVE
BAxisMachineRefMotion MOTION ACTIVE
BAxisMotion MOTION ACTIVE
BlockFinish EVENTS ACTIVE
BlockInit EVENTS ACTIVE
BlockSkipSwitch1 BLOCK_SKIP ACTIVE
BlockSkipSwitchOff BLOCK_SKIP ACTIVE
BlockSkipSwitchOn BLOCK_SKIP ACTIVE
BoschType2CYCLE TYPE2 ACTIVE
C2AxisIncreMotion MOTION ACTIVE
C2AxisMachineMotion MOTION ACTIVE
C2AxisMachineRefMotion MOTION ACTIVE
C2AxisMotion MOTION ACTIVE
CallNCMacro SUBROUTINES ACTIVE
CallNCMacroBlock SUBROUTINES ACTIVE
CallNCMacroCancel SUBROUTINES ACTIVE
CallNCMacroMotion SUBROUTINES ACTIVE
CallSub SUBROUTINES ACTIVE
CallSubCurrent SUBROUTINES ACTIVE Added V6.0
CallSubName SUBROUTINES ACTIVE
CallTextSubName SUBROUTINES ACTIVE
Cancel3dToolOffset CUTTER_COMP ACTIVE
CancelAllWorkOffsets WORK_OFFSETS ACTIVE
CancelShiftOffsets SHIFT_OFFSETS ACTIVE
CancelWorkOffsets WORK_OFFSETS ACTIVE
CAxisIncreMotion MOTION ACTIVE
CAxisMachineMotion MOTION ACTIVE
CAxisMachineRefMotion MOTION ACTIVE
CAxisMotion MOTION ACTIVE

787
CGTechVarDefMacro VARIABLES ACTIVE Added V6.0
ChangeSubsystemID MISC ACTIVE Added V6.0
ChangeWorkCoordinateZWTrackin WORK_OFFSETS ACTIVE Added V6.0
g
CheckForLooseMaterial MISC ACTIVE
CinciBlockInit EVENTS ACTIVE
CinciGotoLabelName BRANCHING ACTIVE
CinciRotateCenterCalc ROTATE_2D ACTIVE
CinciRotateXYZMode ROTATE_2D ACTIVE
CircleCenterReset CIRCLES ACTIVE
CircleCenterX CIRCLES ACTIVE
CircleCenterY CIRCLES ACTIVE
CircleCenterZ CIRCLES ACTIVE
CircleCenterZWTracking CIRCLES ACTIVE
CircleCurveFitQuadrants CURVE_FIT ACTIVE
CircleDirectDrive CIRCLES ACTIVE Added V6.0
CircleIntermediatePoint CIRCLES ACTIVE Added V6.0
CirclePresentAxis CIRCLES ACTIVE
CircleRadius CIRCLES ACTIVE
CircleRadiusLarge CIRCLES ACTIVE
ClampCompName MISC ACTIVE
ClampOnOff MISC ACTIVE
CollisionDiagonalSize MISC ACTIVE Added V6.0
ConditionalEndOfBlock BRANCHING ACTIVE Added V6.0
ConnectCompName MISC ACTIVE
ConnectToCompName MISC ACTIVE
ConstantSurfaceSpeed FEEDS_SPEEDS ACTIVE
ConstantSurfaceSpeedMode FEEDS_SPEEDS ACTIVE
ConversionFinish EVENTS ACTIVE
ConversionInit EVENTS ACTIVE
CoolantFlood COOLANT ACTIVE
CoolantMist COOLANT ACTIVE
CoolantOff COOLANT ACTIVE
CoolantOn COOLANT ACTIVE
CornerMode CHAMFER_RND ACTIVE
CornerValue CHAMFER_RND ACTIVE
CoupleAxisOff MISC ACTIVE
CoupleAxisOn MISC ACTIVE
CurveFitOnOff CURVE_FIT ACTIVE
CutterComp3d CUTTER_COMP ACTIVE
CutterCompDoubleLong CUTTER_COMP ACTIVE

788
CutterCompDoubleShort CUTTER_COMP ACTIVE
CutterCompLeft CUTTER_COMP ACTIVE
CutterCompLong CUTTER_COMP ACTIVE
CutterCompOff CUTTER_COMP ACTIVE
CutterCompOffLookAheadX CUTTER_COMP ACTIVE
CutterCompOffLookAheadY CUTTER_COMP ACTIVE
CutterCompOffLookAheadZ CUTTER_COMP ACTIVE
CutterCompOffsetValue CUTTER_COMP ACTIVE
CutterCompRight CUTTER_COMP ACTIVE
CutterCompShort CUTTER_COMP ACTIVE
CutterCompSuspend CUTTER_COMP ACTIVE
CutterCompValueDirect CUTTER_COMP ACTIVE
CutWire WIRE_EDM ACTIVE
CycleBoreShiftFlags DRILL_CYCLES ACTIVE
CycleBoreShiftValue DRILL_CYCLES ACTIVE
CycleBoreSpindleOnOffFlags DRILL_CYCLES ACTIVE
CycleClearanceDistance DRILL_CYCLES ACTIVE
CycleDepth DRILL_CYCLES ACTIVE
CycleDepthInv DRILL_CYCLES ACTIVE
CycleDepthType DRILL_CYCLES ACTIVE
CycleDwellTime DRILL_CYCLES ACTIVE
CycleIgnore DRILL_CYCLES ACTIVE
CycleIncDepthType DRILL_CYCLES ACTIVE
CycleIncRapidType DRILL_CYCLES ACTIVE
CycleInitialOnMotion DRILL_CYCLES ACTIVE
CycleMillPocketAngle POCKET_CYCLES ACTIVE
CycleMillPocketBottomAllowance POCKET_CYCLES ACTIVE
CycleMillPocketBottomZ POCKET_CYCLES ACTIVE
CycleMillPocketBoundarySub POCKET_CYCLES ACTIVE
CycleMillPocketCenterX POCKET_CYCLES ACTIVE
CycleMillPocketCenterY POCKET_CYCLES ACTIVE
CycleMillPocketCornerRadius POCKET_CYCLES ACTIVE
CycleMillPocketCutDirection POCKET_CYCLES ACTIVE
CycleMillPocketCutType POCKET_CYCLES ACTIVE
CycleMillPocketDepth POCKET_CYCLES ACTIVE
CycleMillPocketFinishFeed POCKET_CYCLES ACTIVE
CycleMillPocketFinishStepover POCKET_CYCLES ACTIVE
CycleMillPocketInsideRadius POCKET_CYCLES ACTIVE
CycleMillPocketLength POCKET_CYCLES ACTIVE
CycleMillPocketMaxCutDepth POCKET_CYCLES ACTIVE
CycleMillPocketPlungeFeed POCKET_CYCLES ACTIVE

789
CycleMillPocketRefPlane POCKET_CYCLES ACTIVE
CycleMillPocketRetractPlane POCKET_CYCLES ACTIVE
CycleMillPocketRoughFeed POCKET_CYCLES ACTIVE
CycleMillPocketSafeDistance POCKET_CYCLES ACTIVE
CycleMillPocketSideAllowance POCKET_CYCLES ACTIVE
CycleMillPocketSpeed POCKET_CYCLES ACTIVE
CycleMillPocketStepover POCKET_CYCLES ACTIVE
CycleMillPocketType POCKET_CYCLES ACTIVE
CycleMillPocketWidth POCKET_CYCLES ACTIVE
CycleMotionPlaneCheckOnOff DRILL_CYCLES ACTIVE
CyclePresentAxis DRILL_CYCLES ACTIVE
CycleRapidLevelInitial DRILL_CYCLES ACTIVE
CycleRapidLevelInv DRILL_CYCLES ACTIVE
CycleRapidLevelKeep DRILL_CYCLES ACTIVE
CycleRapidLevelValue DRILL_CYCLES ACTIVE
CycleRapidLevelValueMult DRILL_CYCLES ACTIVE
CycleRapidLevelZeroTracking DRILL_CYCLES ACTIVE
CycleRapidType DRILL_CYCLES ACTIVE
CycleRetractInitial DRILL_CYCLES ACTIVE
CycleRetraction DRILL_CYCLES ACTIVE
CycleRetractSpecifiedpoint DRILL_CYCLES ACTIVE
CycleRetractSpecifiedZT DRILL_CYCLES ACTIVE
CyclesBore DRILL_CYCLES ACTIVE
CyclesBoreDrag DRILL_CYCLES ACTIVE
CyclesBoreOrient DRILL_CYCLES ACTIVE
CyclesCancel DRILL_CYCLES ACTIVE
CyclesDeep DRILL_CYCLES ACTIVE
CyclesDrill DRILL_CYCLES ACTIVE
CyclesExecute DRILL_CYCLES ACTIVE
CyclesExecuteModal DRILL_CYCLES ACTIVE
CyclesExecuteOnMotionOnOff DRILL_CYCLES ACTIVE
CyclesFace DRILL_CYCLES ACTIVE
CyclesMill DRILL_CYCLES ACTIVE
CyclesTap DRILL_CYCLES ACTIVE
CycleStepUpValue DRILL_CYCLES ACTIVE
CycleStepValue DRILL_CYCLES ACTIVE
CyclesThru DRILL_CYCLES ACTIVE
CycleSubroutineOff SUBROUTINES ACTIVE
CycleSubroutineOn SUBROUTINES ACTIVE
CycleSubroutineOnNoMotion SUBROUTINES ACTIVE
CycleTurnAllowanceX TURNING_CYCLES ACTIVE

790
CycleTurnAllowanceZ TURNING_CYCLES ACTIVE
CycleTurnCutDepth TURNING_CYCLES ACTIVE
CycleTurnEndSeq TURNING_CYCLES ACTIVE
CycleTurnFeed TURNING_CYCLES ACTIVE
CycleTurnFinalX TURNING_CYCLES ACTIVE
CycleTurnFinalZ TURNING_CYCLES ACTIVE
CycleTurnFinish TURNING_CYCLES ACTIVE
CycleTurnGroove TURNING_CYCLES ACTIVE
CycleTurnGrooveAngle TURNING_CYCLES ACTIVE
CycleTurnGrooveDepth TURNING_CYCLES ACTIVE
CycleTurnGrooveEnd TURNING_CYCLES ACTIVE
CycleTurnGrooveEscape TURNING_CYCLES ACTIVE
CycleTurnGrooveFace TURNING_CYCLES ACTIVE
CycleTurnGrooveRelief TURNING_CYCLES ACTIVE
CycleTurnGrooveStep TURNING_CYCLES ACTIVE
CycleTurnLoopCount TURNING_CYCLES ACTIVE
CycleTurnRetractX TURNING_CYCLES ACTIVE
CycleTurnRetractZ TURNING_CYCLES ACTIVE
CycleTurnRoughCut TURNING_CYCLES ACTIVE
CycleTurnRoughFace TURNING_CYCLES ACTIVE
CycleTurnRoughLoop TURNING_CYCLES ACTIVE
CycleTurnSpeed TURNING_CYCLES ACTIVE
CycleTurnStartBlank TURNING_CYCLES ACTIVE
CycleTurnStartSeq TURNING_CYCLES ACTIVE
CycleTurnStockX TURNING_CYCLES ACTIVE
CycleTurnStockZ TURNING_CYCLES ACTIVE
CycleTurnThread TURNING_CYCLES ACTIVE
CycleTurnThreadAngleTaper TURNING_CYCLES ACTIVE
CycleTurnThreadFinish TURNING_CYCLES ACTIVE
CycleTurnThreadFirstCut TURNING_CYCLES ACTIVE
CycleTurnThreadHeight TURNING_CYCLES ACTIVE
CycleTurnThreadLead TURNING_CYCLES ACTIVE
CycleTurnThreadMinCut TURNING_CYCLES ACTIVE
CycleTurnThreadTaper TURNING_CYCLES ACTIVE
CycleUvDepth DRILL_CYCLES ACTIVE
CycleXyzDepth DRILL_CYCLES ACTIVE
CycleZeroTrackingAdjOnOff DRILL_CYCLES ACTIVE
CylindricalDiameter CYLIN_POLAR ACTIVE
CylindricalInterpolation CYLIN_POLAR ACTIVE
CylindricalLinearAxis CYLIN_POLAR ACTIVE
CylindricalRotationalAxis CYLIN_POLAR ACTIVE

791
DebugMacro MISC ACTIVE
DefaultWire WIRE_EDM ACTIVE
DefineCsys MISC ACTIVE
DefineDashAsAlphaNumeric MISC ACTIVE
DisableWorkShiftOffsets SHIFT_WORK_PZ ACTIVE
DoLoop BRANCHING ACTIVE
DwellMacro DWELL ACTIVE
DwellRevolutions DWELL ACTIVE
DwellSeconds DWELL ACTIVE
DwellTime DWELL ACTIVE
DynamicWorkOffsets SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsContour SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsLocalCoord SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsTypes SHIFT_WORK_PZ ACTIVE
DynamicWorkOffsetsWithMotion SHIFT_WORK_PZ ACTIVE
EDMCalcUpperGuideHeight WIRE_EDM ACTIVE
EDMCalcUpperGuideLocation WIRE_EDM ACTIVE
EDMGuide2Guide WIRE_EDM ACTIVE
EDMLower2Reference WIRE_EDM ACTIVE
EDMLowerGuideHeight WIRE_EDM ACTIVE
EDMReference2Upper WIRE_EDM ACTIVE
EDMUpperGuideHeight WIRE_EDM ACTIVE
ElseBlock BRANCHING ACTIVE
EnableWorkShiftOffsets SHIFT_WORK_PZ ACTIVE
EndIfBlock BRANCHING ACTIVE
EndLoop BRANCHING ACTIVE
EndProgram SUBROUTINES ACTIVE
EndProgramRewind SUBROUTINES ACTIVE
EndProgramRewindSpecial SUBROUTINES ACTIVE
EndSub SUBROUTINES ACTIVE
ErrorMacro MISC ACTIVE
FadalLcode SUBROUTINES ACTIVE
FadalWorkCoord WORK_OFFSETS ACTIVE
FeedInvTime FEEDS_SPEEDS ACTIVE
FeedInvTimeModalMultiplier FEEDS_SPEEDS ACTIVE
FeedInvTimeMultiplier FEEDS_SPEEDS ACTIVE
FeedInvTimeSec FEEDS_SPEEDS ACTIVE
FeedModeMinute FEEDS_SPEEDS ACTIVE
FeedModeRevolution FEEDS_SPEEDS ACTIVE
FeedModeTime FEEDS_SPEEDS ACTIVE
FeedPerMinute FEEDS_SPEEDS ACTIVE

792
FeedPerMinuteType FEEDS_SPEEDS ACTIVE
FeedPerRev FEEDS_SPEEDS ACTIVE
FeedRate FEEDS_SPEEDS ACTIVE
Fidia_ConvInit EVENTS ACTIVE
ForEndLoop BRANCHING ACTIVE
ForLoop BRANCHING ACTIVE
ForToValue BRANCHING ACTIVE
G65ResetVarsOnLoop SUBROUTINES ACTIVE
GageOffsetAttributes TOOL_OFFSETS ACTIVE Added V6.0
GageOffsetDrivenPoint TOOL_OFFSETS ACTIVE Added V6.0
GageOffsetFirstDrivenPoint TOOL_OFFSETS ACTIVE Added V6.0
GetCurrentDate MISC ACTIVE
GLSameAngle360OnOff PROGRAM_ZERO ACTIVE
GLSetCurrentZeroTrackingPos MOTION ACTIVE
GLType2Begin TYPE2 ACTIVE
GLType2CLS TYPE2 ACTIVE
GLType2DFS TYPE2 ACTIVE
GLType2End TYPE2 ACTIVE
GLType2FXZ TYPE2 ACTIVE
GLType2FXZArg TYPE2 ACTIVE
GLType2PDO TYPE2 ACTIVE
GLType2PdoId TYPE2 ACTIVE
GLType2PGM TYPE2 ACTIVE
GLType2PRB TYPE2 ACTIVE
GLType2RPT TYPE2 ACTIVE
GLType2RTA TYPE2 ACTIVE
GLType2UPD TYPE2 ACTIVE
GotoJump BRANCHING ACTIVE
GotoJumpForwardBackward BRANCHING ACTIVE
GotoJumpForwardBackwardStart BRANCHING ACTIVE
GotoLabel BRANCHING ACTIVE
GotoLabelForwardBackward BRANCHING ACTIVE
Heid_BlockInit EVENTS ACTIVE
Heid_CallLbl SUBROUTINES ACTIVE Added V6.0
Heid_CallSubName SUBROUTINES ACTIVE
Heid_CallTextSubName SUBROUTINES ACTIVE
Heid_CircleCenterIncX CIRCLES ACTIVE
Heid_CircleCenterIncY CIRCLES ACTIVE
Heid_CircleCenterIncZ CIRCLES ACTIVE
Heid_CircleCenterX CIRCLES ACTIVE
Heid_CircleCenterY CIRCLES ACTIVE

793
Heid_CircleCenterZ CIRCLES ACTIVE
Heid_EndSub SUBROUTINES ACTIVE
Heid_GetPocketContours POCKET_CYCLES ACTIVE
Heid_GotoLabel BRANCHING ACTIVE Added V6.0
Heid_InitializePocketContours POCKET_CYCLES ACTIVE
Heid_JumpDecrement BRANCHING ACTIVE
Heid_JumpDecrementValue BRANCHING ACTIVE
Heid_JumpDecrementVar BRANCHING ACTIVE
Heid_LabelMacro SUBROUTINES ACTIVE
Heid_MotionLinear MOTION ACTIVE
Heid_PocketSub POCKET_CYCLES ACTIVE
Heid_PolarAngle CYLIN_POLAR ACTIVE
Heid_PolarIncAngle CYLIN_POLAR ACTIVE
Heid_PolarIncRadius CYLIN_POLAR ACTIVE
Heid_PolarMotionCCW CYLIN_POLAR ACTIVE
Heid_PolarMotionCW CYLIN_POLAR ACTIVE
Heid_PolarMotionLinear CYLIN_POLAR ACTIVE
Heid_PolarRadius CYLIN_POLAR ACTIVE
Heid_ProcessRNDorCHF CHAMFER_RND ACTIVE
Heid_RepeatCount BRANCHING ACTIVE
Heid_XAxisMotion MOTION ACTIVE
Heid_YAxisMotion MOTION ACTIVE
HeidIso_Polar CYLIN_POLAR ACTIVE
HeidIso_PolarAngle CYLIN_POLAR ACTIVE
HeidIso_PolarRadius CYLIN_POLAR ACTIVE
HeidIso_SubDefCallEnd SUBROUTINES ACTIVE
HeidMPlus_SubroutineSequence SUBROUTINES ACTIVE Added V6.0
HelicalFullLoops CIRCLES ACTIVE
IfBlock BRANCHING ACTIVE
IfCheck BRANCHING ACTIVE
IfCheckAllMacros BRANCHING ACTIVE
IgnoreMacro MISC ACTIVE
Ijk2AbcType ROTATION_PLANE ACTIVE
IjkAAxisMotion ROTATION_PLANE ACTIVE
IjkBAxisMotion ROTATION_PLANE ACTIVE
IjkCAxisMotion ROTATION_PLANE ACTIVE
InActivateAxis ACTIVATION ACTIVE
IncrementalShift SHIFT_OFFSETS ACTIVE
IncrementalShiftRotationDynamic SHIFT_OFFSETS ACTIVE
IndexCallMainSub SUBROUTINES ACTIVE
IndexChannel1Subroutine SUBROUTINES ACTIVE

794
IndexChannel2Subroutine SUBROUTINES ACTIVE
InputMacro MISC ACTIVE
InverseWordValue MISC ACTIVE
IVector ROTATION_PLANE ACTIVE
JVector ROTATION_PLANE ACTIVE
KtBlockInit EVENTS ACTIVE
KtType2CLS TYPE2 ACTIVE
KVector ROTATION_PLANE ACTIVE
LabelMacro BRANCHING ACTIVE
LabelName BRANCHING ACTIVE
LabelNameValue BRANCHING ACTIVE
LinkAxisId MISC ACTIVE Added V6.0
LinkCompName MISC ACTIVE Added V6.0
LinkFormula MISC ACTIVE Added V6.0
LoadNextTool TOOLING ACTIVE
LoadStocks MISC ACTIVE
LoopCount BRANCHING ACTIVE
MacroNotFoundMsgOnOff MISC ACTIVE Added V6.0
MacroVar SUBROUTINES ACTIVE
MahoSequence BRANCHING ACTIVE
MaxTableRPM FEEDS_SPEEDS ACTIVE
MazakMillingInterpolationOff MISC ACTIVE
MazakMillingInterpolationOn MISC ACTIVE
MazakSpindleRotation FEEDS_SPEEDS ACTIVE
MessageMacro MISC ACTIVE
MinTesselationPoints PROGRAM_ZERO ACTIVE
MirrorA MIRROR ACTIVE
MirrorA2 MIRROR ACTIVE
MirrorA2Cancel MIRROR ACTIVE
MirrorA2Value MIRROR ACTIVE
MirrorACancel MIRROR ACTIVE
MirrorAValue MIRROR ACTIVE
MirrorB MIRROR ACTIVE
MirrorB2 MIRROR ACTIVE
MirrorB2Cancel MIRROR ACTIVE
MirrorB2Value MIRROR ACTIVE
MirrorBCancel MIRROR ACTIVE
MirrorBValue MIRROR ACTIVE
MirrorC MIRROR ACTIVE
MirrorC2 MIRROR ACTIVE
MirrorC2Cancel MIRROR ACTIVE

795
MirrorC2Value MIRROR ACTIVE
MirrorCancel MIRROR ACTIVE
MirrorCCancel MIRROR ACTIVE
MirrorCValue MIRROR ACTIVE
MirrorX MIRROR ACTIVE
MirrorXCancel MIRROR ACTIVE
MirrorXValue MIRROR ACTIVE
MirrorY MIRROR ACTIVE
MirrorYCancel MIRROR ACTIVE
MirrorYValue MIRROR ACTIVE
MirrorZ MIRROR ACTIVE
MirrorZCancel MIRROR ACTIVE
MirrorZValue MIRROR ACTIVE
ModeAbsolute MOTION ACTIVE
ModeAsymTurningOnOff MISC ACTIVE
ModeIncremental MOTION ACTIVE
Motion3DCircle MOTION ACTIVE Added V6.0
MotionBlockSyncOnOff MISC ACTIVE
MotionCCW MOTION ACTIVE
MotionCW MOTION ACTIVE
MotionLinear MOTION ACTIVE
MotionNurbs MOTION ACTIVE
MotionPlaneXY MOTION ACTIVE
MotionPlaneYZ MOTION ACTIVE
MotionPlaneZX MOTION ACTIVE
MotionPoly MOTION ACTIVE
MotionRapid MOTION ACTIVE
MotionThread MOTION ACTIVE
MotionToolOffsetNeg CUTTER_COMP ACTIVE
MotionToolOffsetOnMotion CUTTER_COMP ACTIVE
MotionToolOffsetPos CUTTER_COMP ACTIVE
MountTool TOOLING ACTIVE
MountToolIndex TOOLING ACTIVE
MoveCutStockCompName MISC ACTIVE
MoveCutStockFromCsys MISC ACTIVE
MoveCutStockToCsys MISC ACTIVE
MoveDesignWithStock MISC ACTIVE
NCVarDefaultValue VARIABLES ACTIVE
NCVarWarnMessage VARIABLES ACTIVE
NullMacro MISC ACTIVE
NumEndBlankContour TURNING_CYCLES ACTIVE

796
NumSequence BRANCHING ACTIVE
NumSubroutineSequence SUBROUTINES ACTIVE
NumSubSequenceLoop SUBROUTINES ACTIVE
NumTurnCycle TURNING_CYCLES ACTIVE
NurbsDegree NURBS_POLY ACTIVE
NurbsInitialControl NURBS_POLY ACTIVE
NurbsKnot NURBS_POLY ACTIVE
NurbsOrder NURBS_POLY ACTIVE
NurbsWeight NURBS_POLY ACTIVE
Okuma_CallSubName SUBROUTINES ACTIVE
OkumaCancelShiftRotate SHIFT_OFFSETS ACTIVE
OkumaControllingHead MISC ACTIVE
OkumaCopyEnd ROTATE_2D ACTIVE
OkumaCopyLoopCount ROTATE_2D ACTIVE
OkumaCopyStart ROTATE_2D ACTIVE
OkumaCutDepth2 MISC ACTIVE Added V6.0
OkumaCutDepth3 MISC ACTIVE Added V6.0
OkumaEndContour TURNING_CYCLES ACTIVE
OkumaFeedrate2 FEEDS_SPEEDS ACTIVE Added V6.0
OkumaFeedrate3 FEEDS_SPEEDS ACTIVE Added V6.0
OkumaGotoJump BRANCHING ACTIVE
OkumaGotoLabel BRANCHING ACTIVE
OkumaShiftRotate ROTATE_2D ACTIVE
OkumaStartBlankContour TURNING_CYCLES ACTIVE
OkumaStartContour TURNING_CYCLES ACTIVE
OkumaStartCutDepth2 MISC ACTIVE Added V6.0
OkumaStartCutDepth3 MISC ACTIVE Added V6.0
OkumaTurnCycle TURNING_CYCLES ACTIVE
OliConvInit EVENTS ACTIVE
OliLabel BRANCHING ACTIVE
OliType2EPP TYPE2 ACTIVE
Optimizable OPTIPATH ACTIVE
OptiMWordLast OPTIPATH ACTIVE
OptiPathExpandSubs OPTIPATH ACTIVE
OptiPathOptimizeCDC OPTIPATH ACTIVE
OptiPathOptimizeSubs OPTIPATH ACTIVE
OptiRestoreAdditionalCuts OPTIPATH ACTIVE
OptiSettings OPTIPATH ACTIVE
OptiSuppressAdditionalCuts OPTIPATH ACTIVE
OptiXYZFormat OPTIPATH ACTIVE
PartNormalX CUTTER_COMP ACTIVE

797
PartNormalY CUTTER_COMP ACTIVE
PartNormalZ CUTTER_COMP ACTIVE
PitchForcesHelical CIRCLES ACTIVE
PivotOffsetCompName TOOL_OFFSETS ACTIVE
PivotOffsetCompNameB TOOL_OFFSETS ACTIVE
PlaneAxisMapping MOTION ACTIVE
PlaneAxisVectorX ROTATION_PLANE ACTIVE
PlaneAxisVectorY ROTATION_PLANE ACTIVE
PlaneAxisVectorZ ROTATION_PLANE ACTIVE
PolarAngle CYLIN_POLAR ACTIVE
PolarInterpolation CYLIN_POLAR ACTIVE
PolarLinearAxis CYLIN_POLAR ACTIVE
PolarRotationalAxis CYLIN_POLAR ACTIVE
PolarXValue CYLIN_POLAR ACTIVE
PolarYValue CYLIN_POLAR ACTIVE
PolarZValue CYLIN_POLAR ACTIVE
PreToolCompSelect TOOLING ACTIVE
Probe MISC ACTIVE
ProcessCompNameValue MOTION ACTIVE
ProcessMotion EVENTS ACTIVE
ProcessTimeOnOff MISC ACTIVE
ProgramStartNextLine MISC ACTIVE
RapidPlanePriorityType MISC ACTIVE
ReferencePoint MISC ACTIVE
ReferencePointCancelOffsets MISC ACTIVE
ReferencePointIndex MISC ACTIVE
ResetIfCheck BRANCHING ACTIVE Added V6.0
ResetWorkCoordParms SHIFT_WORK_PZ ACTIVE
RestoreMotionType MOTION ACTIVE
RestoreSubsystemID MISC ACTIVE
RestoreUnits MISC ACTIVE
RetractLevelClearanceRetract DRILL_CYCLES ACTIVE
RetractLevelInitial DRILL_CYCLES ACTIVE
RetractLevelRpoint DRILL_CYCLES ACTIVE
RetractLevelSpecifiedpoint DRILL_CYCLES ACTIVE
ReturnFromSub SUBROUTINES ACTIVE
ReturnFromSubCall SUBROUTINES ACTIVE Added V6.0
RotaryAxisLinearRewind PROGRAM_ZERO ACTIVE
RotaryAxisLinearRewind360_360 PROGRAM_ZERO ACTIVE
RotaryControlPointOnOff TOOL_OFFSETS ACTIVE
RotaryDirCCW PROGRAM_ZERO ACTIVE

798
RotaryDirCW PROGRAM_ZERO ACTIVE
RotaryDirLinear PROGRAM_ZERO ACTIVE
RotaryDirPosCCW PROGRAM_ZERO ACTIVE
RotaryDirPosCW PROGRAM_ZERO ACTIVE
RotaryDirShortestDist PROGRAM_ZERO ACTIVE
RotaryLinearRewind PROGRAM_ZERO ACTIVE
RotaryLinearRewind360_360 PROGRAM_ZERO ACTIVE
RotaryTypeAbsolute PROGRAM_ZERO ACTIVE
RotaryTypeLinear PROGRAM_ZERO ACTIVE
RotateCancel ROTATE_2D ACTIVE
RotateOrigin ROTATE_2D ACTIVE
RotateXValue ROTATE_2D ACTIVE
RotateXYZ ROTATE_2D ACTIVE
RotateYValue ROTATE_2D ACTIVE
RotateZValue ROTATE_2D ACTIVE
RotationAbsAngle ROTATE_2D ACTIVE
RotationAngle ROTATE_2D ACTIVE
RotationIncAngle ROTATE_2D ACTIVE
RotationPlane2 ROTATION_PLANE ACTIVE
RotationPlaneAngle1 ROTATION_PLANE ACTIVE
RotationPlaneAngle2 ROTATION_PLANE ACTIVE
RotationPlaneAngle3 ROTATION_PLANE ACTIVE
RotationPlaneCancel2 ROTATION_PLANE ACTIVE Use
RotationPlaneCanc
elReset
RotationPlaneCancelReset ROTATION_PLANE ACTIVE Added V6.0
RotationPlaneEnable2 ROTATION_PLANE ACTIVE Added V6.0
RotationPlaneIncXPoint ROTATION_PLANE ACTIVE
RotationPlaneIncYPoint ROTATION_PLANE ACTIVE
RotationPlaneIncZPoint ROTATION_PLANE ACTIVE
RotationPlaneLocal2 ROTATION_PLANE ACTIVE
RotationPlaneSpecialOffset ROTATION_PLANE ACTIVE
RotationPlaneXPoint ROTATION_PLANE ACTIVE
RotationPlaneYPoint ROTATION_PLANE ACTIVE
RotationPlaneZPoint ROTATION_PLANE ACTIVE
RpcpOff SHIFT_WORK_PZ ACTIVE
RpcpOn SHIFT_WORK_PZ ACTIVE
RPMMode FEEDS_SPEEDS ACTIVE
RPMSpeed FEEDS_SPEEDS ACTIVE
RtcpContour TOOL_OFFSETS ACTIVE
RtcpOff TOOL_OFFSETS ACTIVE

799
RtcpOn TOOL_OFFSETS ACTIVE
RtcpWithMotion TOOL_OFFSETS ACTIVE
SaveUnits MISC ACTIVE
SecondaryRefWorkCoord WORK_OFFSETS ACTIVE
SecondaryWorkCoord WORK_OFFSETS ACTIVE
Sequence BRANCHING ACTIVE
SequenceEnd BRANCHING ACTIVE
SequenceLoop BRANCHING ACTIVE
SequenceLoopCount BRANCHING ACTIVE
SequenceOrSubroutine SUBROUTINES ACTIVE
SequenceStart BRANCHING ACTIVE
SequenceStartEnd BRANCHING ACTIVE
SetAbsWorkCoord WORK_OFFSETS ACTIVE
SetActiveStockName FEEDS_SPEEDS ACTIVE
SetAdditionalWorkCoord WORK_OFFSETS ACTIVE
SetAdditionalWorkCoordNonModal WORK_OFFSETS ACTIVE
SetAxisCompLink MISC ACTIVE Added V6.0
SetBaseWorkOffset WORK_OFFSETS ACTIVE
SetCircle360Tolearance CIRCLES ACTIVE
SetComponentColor MISC ACTIVE
SetComponentVisibility MISC ACTIVE
SetCycleSquareOffType DRILL_CYCLES ACTIVE
SetDynamicVars VARIABLES ACTIVE
SetIncWorkCoord WORK_OFFSETS ACTIVE
SetLocalVariableCount VARIABLES ACTIVE
SetMaxSubsystemVar VARIABLES ACTIVE
SetMinSubsystemVar VARIABLES ACTIVE
SetProgrammingMethod MISC ACTIVE
SetSubsystemID MISC ACTIVE
SetTableCoord TABLES ACTIVE
SetTableValues TABLES ACTIVE
SetToolNumVar VARIABLES ACTIVE
SetVcMultiTools TOOLING ACTIVE
SetVNCKOption MISC ACTIVE Added V6.0
SetWorkCoord WORK_OFFSETS ACTIVE
ShortLongOffsetReset CUTTER_COMP ACTIVE
Siemens3CmdBranch SIEMENS_CMD ACTIVE
Siemens3CmdIfEqual SIEMENS_CMD ACTIVE
Siemens3CmdIfGreater SIEMENS_CMD ACTIVE
Siemens3CmdIfGreaterEqual SIEMENS_CMD ACTIVE
Siemens3LoadAddress SIEMENS_CMD ACTIVE

800
Siemens3PreProcessor MISC ACTIVE
Siemens3SetAddressParm SIEMENS_CMD ACTIVE
Siemens3TAddressAxis SIEMENS_CMD ACTIVE
Siemens840DProc SUBROUTINES ACTIVE
Siemens840DProcCall SUBROUTINES ACTIVE
Siemens840DSubroutineSequence SUBROUTINES ACTIVE
SiemensActualSpindle FEEDS_SPEEDS ACTIVE
SiemensCmd300 SIEMENS_CMD ACTIVE
SiemensCmd302 SIEMENS_CMD ACTIVE
SiemensCmd303 SIEMENS_CMD ACTIVE
SiemensCmd305 SIEMENS_CMD ACTIVE
SiemensCmd306 SIEMENS_CMD ACTIVE
SiemensCmd308 SIEMENS_CMD ACTIVE
SiemensCmd330 SIEMENS_CMD ACTIVE
SiemensCmd331 SIEMENS_CMD ACTIVE
SiemensCmd360 SIEMENS_CMD ACTIVE
SiemensCmd383 SIEMENS_CMD ACTIVE
SiemensCmd400 SIEMENS_CMD ACTIVE
SiemensCmd403 SIEMENS_CMD ACTIVE
SiemensCmd404 SIEMENS_CMD ACTIVE
SiemensCmd430 SIEMENS_CMD ACTIVE
SiemensCmdAbs SIEMENS_CMD ACTIVE
SiemensCmdAngle SIEMENS_CMD ACTIVE
SiemensCmdASin SIEMENS_CMD ACTIVE
SiemensCmdATan SIEMENS_CMD ACTIVE
SiemensCmdBranch SIEMENS_CMD ACTIVE
SiemensCmdCase SIEMENS_CMD ACTIVE
SiemensCmdCos SIEMENS_CMD ACTIVE
SiemensCmdDec SIEMENS_CMD ACTIVE
SiemensCmdGetChannel SIEMENS_CMD ACTIVE
SiemensCmdGetGCode SIEMENS_CMD ACTIVE
SiemensCmdHypot SIEMENS_CMD ACTIVE
SiemensCmdIfEqual SIEMENS_CMD ACTIVE
SiemensCmdIfGreater SIEMENS_CMD ACTIVE
SiemensCmdIfGreaterEqual SIEMENS_CMD ACTIVE
SiemensCmdIfLess SIEMENS_CMD ACTIVE
SiemensCmdIfLessEqual SIEMENS_CMD ACTIVE
SiemensCmdIfNotEqual SIEMENS_CMD ACTIVE
SiemensCmdInc SIEMENS_CMD ACTIVE
SiemensCmdIntegral SIEMENS_CMD ACTIVE
SiemensCmdPopVarGroup SIEMENS_CMD ACTIVE

801
SiemensCmdPushVarGroup SIEMENS_CMD ACTIVE
SiemensCmdSin SIEMENS_CMD ACTIVE
SiemensCmdSquareRoot SIEMENS_CMD ACTIVE
SiemensCmdTan SIEMENS_CMD ACTIVE
SiemensCornerVaue CHAMFER_RND ACTIVE
SiemensCycle95 TURNING_CYCLES ACTIVE
SiemensCycle95Type TURNING_CYCLES ACTIVE
SiemensCycle97 TURNING_CYCLES ACTIVE
SiemensCycle97ArcIn TURNING_CYCLES ACTIVE
SiemensCycle97ArcOut TURNING_CYCLES ACTIVE
SiemensCycle97FinalAllowance TURNING_CYCLES ACTIVE
SiemensCycle97FinishCuts TURNING_CYCLES ACTIVE
SiemensCycle97RoughCuts TURNING_CYCLES ACTIVE
SiemensCycle97ThreadStart TURNING_CYCLES ACTIVE
SiemensCycle97Type TURNING_CYCLES ACTIVE
SiemensCycle97Xend TURNING_CYCLES ACTIVE
SiemensCycle97Xstart TURNING_CYCLES ACTIVE
SiemensCycle97Zend TURNING_CYCLES ACTIVE
SiemensCycle97Zstart TURNING_CYCLES ACTIVE
SiemensCycleMillPocketCutType POCKET_CYCLES ACTIVE
SiemensEndlessFeedLinkOnOff FEEDS_SPEEDS ACTIVE
SiemensEndlessFeedMode FEEDS_SPEEDS ACTIVE
SiemensEndlessFeedRate FEEDS_SPEEDS ACTIVE
SiemensEndlessOnOffDir MISC ACTIVE
SiemensL137COffset CYLIN_POLAR ACTIVE
SiemensL137COffsetCancel CYLIN_POLAR ACTIVE
SiemensLoadToolRegister TOOLING ACTIVE
SiemensNurbsKnot NURBS_POLY ACTIVE
SiemensNurbsProcess NURBS_POLY ACTIVE
SiemensPlaneOverrideArg MOTION ACTIVE
SiemensPlaneSelection MOTION ACTIVE
SiemensPlaneSelectionArg MOTION ACTIVE
SiemensPolarAngle CYLIN_POLAR ACTIVE Added V6.0
SiemensPolyT NURBS_POLY ACTIVE
SiemensPolyx NURBS_POLY ACTIVE
SiemensPolyy NURBS_POLY ACTIVE
SiemensPolyz NURBS_POLY ACTIVE
SiemensShiftAngleA ROTATE_2D ACTIVE
SiemensShiftAngleB ROTATE_2D ACTIVE
SiemensShiftOffsetA SHIFT_OFFSETS ACTIVE
SiemensShiftOffsetB SHIFT_OFFSETS ACTIVE

802
SiemensSpecifiedSpindle FEEDS_SPEEDS ACTIVE
SiemensSpindleSpeed FEEDS_SPEEDS ACTIVE
SiemensSubroutineCallDefine SUBROUTINES ACTIVE
SimpleForLoop BRANCHING ACTIVE
SkipWordIsOptimizable OPTIPATH ACTIVE
SpindleMotionCCW FEEDS_SPEEDS ACTIVE
SpindleMotionCW FEEDS_SPEEDS ACTIVE
SpindleMotionOff FEEDS_SPEEDS ACTIVE
SpindleSpeed FEEDS_SPEEDS ACTIVE
StopOptional MISC ACTIVE
StopProgram MISC ACTIVE
StopUnconditional MISC ACTIVE
SubEndingSeq SUBROUTINES ACTIVE
SubroutineBlock SUBROUTINES ACTIVE
SubroutineName SUBROUTINES ACTIVE
SubroutineSequence SUBROUTINES ACTIVE
SubroutineSequenceEnd SUBROUTINES ACTIVE
SubSpindleTransform FEEDS_SPEEDS ACTIVE
SubStartingSeq SUBROUTINES ACTIVE
SurfaceSpeed FEEDS_SPEEDS ACTIVE
SuspendCutting MISC ACTIVE
SyncCode SYNC ACTIVE Added V6.0
SyncId SYNC ACTIVE Added V6.0
SyncMacro SYNC ACTIVE
SyncMismatchHandling SYNC ACTIVE Added V6.0
SyncTransfer SYNC ACTIVE
SyncValue SYNC ACTIVE
TableIndex TABLES ACTIVE
TableValues TABLES ACTIVE
ThreadWire WIRE_EDM ACTIVE
Tool3dOffset CUTTER_COMP ACTIVE
Tool3dXOffset CUTTER_COMP ACTIVE
Tool3dYOffset CUTTER_COMP ACTIVE
Tool3dZOffset CUTTER_COMP ACTIVE
ToolChainExchange TOOLING ACTIVE
ToolChainFromCompName TOOLING ACTIVE
ToolChainMotion TOOLING ACTIVE
ToolChainToCompName TOOLING ACTIVE
ToolChange TOOLING ACTIVE
ToolChangeAlpha TOOLING ACTIVE
ToolChangeByToolNum TOOLING ACTIVE

803
ToolChangeIfDifferent TOOLING ACTIVE
ToolChangeNoRetract TOOLING ACTIVE
ToolChangeSave TOOLING ACTIVE
ToolCode TOOLING ACTIVE
ToolCodeAlpha TOOLING ACTIVE
ToolCodeSave TOOLING ACTIVE
ToolCutterComp CUTTER_COMP ACTIVE Added V6.0
ToolLengthCompValueDirect TOOL_OFFSETS ACTIVE Added V6.0
ToolNoseCompApply TOOL_OFFSETS ACTIVE
ToolNoseCompCancel TOOL_OFFSETS ACTIVE
ToolNoseCompToolNum TOOL_OFFSETS ACTIVE
ToolNoseCompToolNumSubValue TOOL_OFFSETS ACTIVE
ToolNoseCompValue TOOL_OFFSETS ACTIVE
ToolRetract TOOLING ACTIVE
ToolRetractDistance TOOLING ACTIVE
ToolVectorX CUTTER_COMP ACTIVE
ToolVectorY CUTTER_COMP ACTIVE
ToolVectorZ CUTTER_COMP ACTIVE
Touch MISC ACTIVE
TouchComponentName MISC ACTIVE
TurnOnOffGageOffset TOOL_OFFSETS ACTIVE
TurnOnOffGagePivotOffset TOOL_OFFSETS ACTIVE
TurnOnOffRealTimeClock MISC ACTIVE
TurnOnOffTravelLimits MISC ACTIVE
TurretRotationOffset TOOL_OFFSETS ACTIVE
TurretToolChange TOOLING ACTIVE
TurretToolChangeAlpha TOOLING ACTIVE Added V6.0
TurretToolChangeByToolNum TOOLING ACTIVE
Type2Begin TYPE2 ACTIVE
Type2BEQLabel TYPE2 ACTIVE
Type2BGELabel TYPE2 ACTIVE
Type2BGTLabel TYPE2 ACTIVE
Type2BLELabel TYPE2 ACTIVE
Type2BLTLabel TYPE2 ACTIVE
Type2BNELabel TYPE2 ACTIVE
Type2CLS TYPE2 ACTIVE
Type2CommentAllArgs TYPE2 ACTIVE
Type2DFS TYPE2 ACTIVE
Type2End TYPE2 ACTIVE
Type2Goto TYPE2 ACTIVE
Type2GotoLabelCond TYPE2 ACTIVE Added V6.0

804
Type2GotoLabelFunction TYPE2 ACTIVE
Type2If TYPE2 ACTIVE
Type2IfBlock TYPE2 ACTIVE Added V6.0
Type2Label TYPE2 ACTIVE
Type2OpMsg TYPE2 ACTIVE
Type2OpMsgAllArgs TYPE2 ACTIVE
Type2OpMsgStop TYPE2 ACTIVE
UAxisIncreMotion MOTION ACTIVE
UAxisMachineMotion MOTION ACTIVE
UAxisMachineRefMotion MOTION ACTIVE
UAxisMotion MOTION ACTIVE
Unitize3DVector CUTTER_COMP ACTIVE
UnitsInch MISC ACTIVE
UnitsMetric MISC ACTIVE
UnloadTool TOOLING ACTIVE
UnloadToolNoRetract TOOLING ACTIVE
UnloadToolToCompName TOOLING ACTIVE
UnMountTool TOOLING ACTIVE
UnMountToolIndex TOOLING ACTIVE
Unsupported MISC ACTIVE
UntilLoop BRANCHING ACTIVE
UpdateAxisValues MISC ACTIVE
UpdateModalMacroVar SUBROUTINES ACTIVE Added V6.0
UpdateRotaryOffsets SHIFT_WORK_PZ ACTIVE
UvwAxis CUTTER_COMP ACTIVE
ValueArgument MISC ACTIVE
VariableArgument MISC ACTIVE
VarsUpdateMacroVars SUBROUTINES ACTIVE Added V6.0
VAxisIncreMotion MOTION ACTIVE
VAxisMachineMotion MOTION ACTIVE
VAxisMachineRefMotion MOTION ACTIVE
VAxisMotion MOTION ACTIVE
VC_LoadFix MISC ACTIVE
VC_ModeMilling MISC ACTIVE
VC_ModeMillingComp MISC ACTIVE
VC_ModeTurning MISC ACTIVE
VC_ModeTurningComp MISC ACTIVE
VC_UnloadFix MISC ACTIVE
VirtualXAxis MISC ACTIVE
VirtualYAxis MISC ACTIVE
VoltageOff WIRE_EDM ACTIVE

805
VoltageOn WIRE_EDM ACTIVE
WAxisIncreMotion MOTION ACTIVE
WAxisMachineMotion MOTION ACTIVE
WAxisMachineRefMotion MOTION ACTIVE
WAxisMotion MOTION ACTIVE
WAxisMotionNoCycle MOTION ACTIVE
WAxisZeroTracking MOTION ACTIVE
WhileLoop BRANCHING ACTIVE
WorkCoord WORK_OFFSETS ACTIVE
WorkCoordA2Value WORK_OFFSETS ACTIVE
WorkCoordAValue WORK_OFFSETS ACTIVE
WorkCoordB2Value WORK_OFFSETS ACTIVE
WorkCoordBValue WORK_OFFSETS ACTIVE
WorkCoordC2Value WORK_OFFSETS ACTIVE
WorkCoordCValue WORK_OFFSETS ACTIVE
WorkCoordIndex WORK_OFFSETS ACTIVE
WorkCoordUValue WORK_OFFSETS ACTIVE
WorkCoordVValue WORK_OFFSETS ACTIVE
WorkCoordWithMotion WORK_OFFSETS ACTIVE
WorkCoordWValue WORK_OFFSETS ACTIVE
WorkCoordXValue WORK_OFFSETS ACTIVE
WorkCoordYValue WORK_OFFSETS ACTIVE
WorkCoordZValue WORK_OFFSETS ACTIVE
WorkingPlane2Abc ROTATION_PLANE ACTIVE
WorkingPlane2AbcType ROTATION_PLANE ACTIVE
WPrimaryTrackingAxis MOTION ACTIVE
XAxisIncreMotion MOTION ACTIVE
XAxisMachineMotion MOTION ACTIVE
XAxisMachineRefMotion MOTION ACTIVE
XAxisMotion MOTION ACTIVE
XRetractSpecifiedpoint DRILL_CYCLES ACTIVE
XToolOffsetCompName TOOL_OFFSETS ACTIVE
XyzAxis CUTTER_COMP ACTIVE
YAxisIncreMotion MOTION ACTIVE
YAxisMachineMotion MOTION ACTIVE
YAxisMachineRefMotion MOTION ACTIVE
YAxisMotion MOTION ACTIVE
YRetractSpecifiedpoint DRILL_CYCLES ACTIVE
YToolOffsetCompName TOOL_OFFSETS ACTIVE
ZAxisIncreMotion MOTION ACTIVE
ZAxisMachineMotion MOTION ACTIVE

806
ZAxisMachineRefMotion MOTION ACTIVE
ZAxisMotion MOTION ACTIVE
ZAxisMotionNoCycle MOTION ACTIVE
ZAxisZeroTracking MOTION ACTIVE
ZPrimaryTrackingAxis MOTION ACTIVE
ZRetractSpecifiedpoint DRILL_CYCLES ACTIVE
ZToolOffsetCompName TOOL_OFFSETS ACTIVE

ActivatePreToolSubsystem ACTIVATION ALTERNATE


ApplyPivotOffset TOOL_OFFSETS ALTERNATE This macro is
associated with
the older RTCP
method
ApplyTurretOffset TOOL_OFFSETS ALTERNATE Use
TurnOnOffGage
PivotOffset
Cinci_5axisToolLengthComp TOOL_OFFSETS ALTERNATE
FanucRotationPlaneLocal2 ROTATION_PLANE ALTERNATE Use
TurnOnOffGage
Offset Added
V6.0
FanucToolLengthComp TOOL_OFFSETS ALTERNATE Use
TurnOnOffGage
Offset
FanucToolLengthCompAxisOn TOOL_OFFSETS ALTERNATE
Fidia_Rotate ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_Rotate2 ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_RotateCancel ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_RotateCancel2 ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_RotateXAxis ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_RotateXPoint ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_RotateYAxis ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_RotateYPoint ROTATION_PLANE ALTERNATE Use standard
rotation plane

807
macros
Fidia_RotateZAxis ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Fidia_RotateZPoint ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
Hcode_Tool TOOLING ALTERNATE
Heid_MotionCCW MOTION ALTERNATE Use
MotionCCW
Heid_MotionCW MOTION ALTERNATE Use MotionCW
Icode CIRCLES ALTERNATE Use
Conditionals to
call macros
directly
Jcode CIRCLES ALTERNATE UseConditionals
to call macros
directly
Kcode CIRCLES ALTERNATE Use
Conditionals to
call macros
directly
MahoVertical2Rest PROGRAM_ZERO ALTERNATE Drive axis
directly
MahoVertical2Work PROGRAM_ZERO ALTERNATE Drive axis
directly
NumIfCheck BRANCHING ALTERNATE Use IfCheck
NumLengthCompX TOOL_OFFSETS ALTERNATE
NumLengthCompY TOOL_OFFSETS ALTERNATE
NumLengthCompZ TOOL_OFFSETS ALTERNATE
NumPlane ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
NumPlaneA ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
NumPlaneB ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
NumPlaneC ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
NumPlaneU ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
NumPlaneV ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros
NumPlaneW ROTATION_PLANE ALTERNATE Use standard
rotation plane
macros

808
ProcessCompRegValue MOTION ALTERNATE Use
ProcessCompN
ameValue
Rcode CIRCLES ALTERNATE Use
Conditionals to
call macros
directly
RotationPlane ROTATION_PLANE ALTERNATE Use
RotationPlane2
RotationPlaneCancel ROTATION_PLANE ALTERNATE Use
RotationPlaneC
ancelReset
RotationPlaneLocal ROTATION_PLANE ALTERNATE Use
RotationPlaneLo
cal2
SetActiveSpindleName FEEDS_SPEEDS ALTERNATE Use
SetActiveStock
Name
SetPivotOffset TOOL_OFFSETS ALTERNATE This macro is
associated with
the old style
RTCP
SubsystemActivateTool ACTIVATION ALTERNATE Use
ActivateToolSub
system
ToolLengthCompNeg TOOL_OFFSETS ALTERNATE
ToolLengthCompOff TOOL_OFFSETS ALTERNATE
ToolLengthCompPos TOOL_OFFSETS ALTERNATE
ToolLengthCompToolNum TOOL_OFFSETS ALTERNATE
ToolLengthCompToolNumSub TOOL_OFFSETS ALTERNATE
Value
ToolLengthCompUpdate TOOL_OFFSETS ALTERNATE
ToolLengthCompValue TOOL_OFFSETS ALTERNATE
XLeadRate MOTION ALTERNATE
YLeadRate MOTION ALTERNATE
ZLeadRate MOTION ALTERNATE

ActivateSpindle ACTIVATION NOT


RECOMMENDED
ActiveTool ACTIVATION NOT Use
RECOMMENDED
ActivateToolS
ubsystem
AutoUpdatePZ PROGRAM_ZERO NOT Try using
RECOMMENDED
Gage and
Gage Pivot
Offsets
CollisionOnCutPart MISC NOT
RECOMMENDED
RotationPlaneRestoreAxis ROTATION_PLANE NOT Use Rotation
RECOMMENDED

809
macros ending
with 2
SetAxisRegisterName MISC NOT Concept is
RECOMMENDED
being tested
Added V6.0
SpindleValue ACTIVATION NOT
RECOMMENDED
ToolOffsetIndex TOOL_OFFSETS NOT Use
RECOMMENDED
GageOffsetDri
venPoint
ToolOffsetUpdate TOOL_OFFSETS NOT Use
RECOMMENDED
GageOffsetDri
venPoint

ActiveTool1 ACTIVATION OBSOLETE Use


ActivateToolSubsys
tem
ActiveTool2 ACTIVATION OBSOLETE Use
ActivateToolSubsys
tem
ActiveTool3 ACTIVATION OBSOLETE Use
ActivateToolSubsys
tem
ActiveTool4 ACTIVATION OBSOLETE Use
ActivateToolSubsys
tem
ActiveTool5 ACTIVATION OBSOLETE Use
ActivateToolSubsys
tem
ApplyGageOffset TOOL_OFFSETS OBSOLETE Use
TurnOnOffGageOff
set
ApplyGagePivotOffset TOOL_OFFSETS OBSOLETE Use
TurnOnOffGagePiv
otOffset
ApplyGagePivotOffsetCurrent TOOL_OFFSETS OBSOLETE Use
TurnOnOffGagePiv
otOffset
AutoUpdateIPZ PROGRAM_ZERO OBSOLETE Use AutoUpdatePZ
CutterCompToolNum CUTTER_COMP OBSOLETE Use
ToolCutterComp
CutterCompToolNumSubValu CUTTER_COMP OBSOLETE Use
e ToolCutterComp
CutterCompValue CUTTER_COMP OBSOLETE Use
ToolCutterComp
MazakPartLoader MISC OBSOLETE
MotionOnOffSide MOTION OBSOLETE
MotionOnSide MOTION OBSOLETE
NcodeSeqSub SUBROUTINES OBSOLETE
PartTransformation MISC OBSOLETE

810
RotationPlaneIncAngle1 ROTATION_PLANE OBSOLETE Use non
incremental angles
and
RotatonPlaneLocal
2
RotationPlaneIncAngle2 ROTATION_PLANE OBSOLETE Use non
incremental angles
and
RotatonPlaneLocal
2
RotationPlaneIncAngle3 ROTATION_PLANE OBSOLETE Use non
incremental angles
and
RotatonPlaneLocal
2
SetGageOffset TOOL_OFFSETS OBSOLETE
SetGageOffsetSubValue TOOL_OFFSETS OBSOLETE
SetMatchingGageOffset TOOL_OFFSETS OBSOLETE
ToolNoseCompApply TOOL_OFFSETS OBSOLETE As of V6.0
ToolOffsetAptAdj TOOL_OFFSETS OBSOLETE UseGageOffsetDriv
enPoint
TurretActivateTool TOOLING OBSOLETE
TurretIndex TOOLING OBSOLETE
TurretLoadTool TOOLING OBSOLETE
TurretRetract TOOLING OBSOLETE
UpdateIPZ PROGRAM_ZERO OBSOLETE
ZTranslateStockComp MISC OBSOLETE
ZTranslateValue MISC OBSOLETE

BlockSkipAnywhere BLOCK_SKIP SPECIAL


ChangeWorkCoord SHIFT_OFFSETS SPECIAL
CollisionCheckOnOff MISC SPECIAL
CollisionSpecialComp MISC SPECIAL
EndLabelLoop BRANCHING SPECIAL
Enhanced5AxisLogicOnOff MISC SPECIAL Use only if there is a
problem Added
V6.0
MaxTesselationAngle PROGRAM_ZERO SPECIAL
MotionOnOff MOTION SPECIAL
RotateMacro ROTATE_2D SPECIAL
SetMotionFlag MOTION SPECIAL
SpecialRotoTrans MISC SPECIAL
SpecialRotoTransComp MISC SPECIAL
SpindleChanger MISC SPECIAL

811
ToolLengthOffsetValue TOOL_OFFSETS SPECIAL
TripodArmLength MISC SPECIAL
TripodRodLength MISC SPECIAL
UpdatePZ PROGRAM_ZERO SPECIAL
ZWBTiltTableLength MISC SPECIAL

812
Control Settings

Control Settings window


Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window enabling you to configure how the machine control will processes
machine code data.

General tab — Features on this tab are used to configure general guidelines for how the
control processes machine code data and number equations.

813
Motion tab — Features on this tab are used to configure default NC control motion
states, and the precision used when outputting calculated values.
Circles tab — Features on this tab are used to configure how the circle center data (e.g. I
J K) is interpreted.
Cycles tab — Features on this tab are used to configure how fixed tool axis, or "canned"
cycle motion blocks are interpreted, e.g. G8n.
Tooling tab — The features on this tab are used to configure default tooling conditions
and tool change activity.
Rotary tab — Features on this tab are used to configure how rotary motion commands
are interpreted, e.g. A, B, C.

OptiPath & Curve Fit tab — Features on this tab are used to configure settings
referenced when G-code tool path files are optimized by OptiPath.
User Defined (CTL) tab — Features on this tab are used to configure user defined
control settings supplied via a custom CME file.
Sync tab — Features on this tab configure VERICUT for simulating machining with
synchronized subsystems.
Turning tab — Features on this tab configure VERICUT for lathe turning simulations.

Wire EDM tab — Features on this tab are used to configure wire EDM machining
settings.
Cutter Compensation tab — Features on this tab are used to configure how the
programmed tool path is compensated when cutter diameter compensation, or "CDC" is
used, e.g. G41-42.
Offsets tab — Features on this tab are used to configure an initial work offset, or “fixture
offset”, to be in effect at the start of tool path processing.
Subroutines tab — Features on this tab are used to configure how subroutine names are
referenced by the NC control.

OK — Applies the changes and closes the Control Settings window.


Apply — Applies the changes and leaves the Control Settings window open.
Cancel — Closes the Control Settings window without applying changes.

814
Control Settings window, General tab
Location: Configuration menu > Control Settings
Location: OptiPath menu > Control > G-Code Output Options tab

VERICUT toolbar short cut:

Opens a window to configure general guidelines for how the control processes machine
code data and number equations. (See how)

Control Type — Sets the type of NC control being used. Choosing the proper option
establishes a mode of operation consistent with how the control processes NC data.
Options are:

y Generic—Fanuc and most other controls using standard controller functions.


y NUM—French-made control. This option affects how G-code data is interpreted,
for example: how variables are initialized and processed, and how to interpret
parameters to macros that shift the location of the tool path.
y Heidenhain Conversational—Heidenhain Conversational control. This option
causes VERICUT to recognize the "L" word as an optimizable word. Also, the
"L" word is included with any cuts added during optimization.
y
Calculation Tolerance — Tolerance for rounding mathematical evaluations, such as
determining if two calculated values are equal to, greater than, or lesser than each other.

815
NOTE: The Calculation Tolerance should be adjusted to eliminate "invalid
circle" errors caused by circle calculations that produce differences larger than the
tolerance value when processing G-Code data.

Order of Math Operations — Order in which math operations are performed. Options
are:
y Rules of Precedence — Follow the basic rules of math precedence:
1. Perform exponential (power) .
2. Perform multiplication and division operations.
3. Perform addition and subtraction operations, example: 5 + 5.3 * 3 *
sin(30)= 12.95
Enclosing math operations in parenthesis causes them to be performed before
those not enclosed in parenthesis. The same rules of precedence are applied to
math operations enclosed in parenthesis.
y Left to Right — Use left to right sequence, example: 5 + 5.3 * 3 *
sin(30)= 15.45
Default Word — Word assumed by VERICUT for NC data blocks beginning with
numbers, such as NC data for some Heidenhain controls. For example, for VERICUT to
interpret blocks like “50G01X5”, set Default Word to "N". VERICUT then interprets the
block without error as “N50G01X5”.

816
Control Settings window, Motion tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure default NC control motion states, and the precision used
when outputting calculated values. (See how) These settings are in affect when the
control and machine are initially powered on.

Default Motion Type — Default motion type for the control. Options are: Rapid or
Linear.
Default Plane Selection — Default motion plane, or "cutting plane" for the control.
Options are: XY, ZX or YZ.

817
Default Control Units — Default measurement units for the control. Options are: Inch
or Metric.
Default Command Mode — Default command mode, or "input dimension mode" for
the control. Options are: Absolute or Incremental.
Default Feed Mode / Default Feedrate — Default feed rate mode and value for the
control. Feed mode options are: Feed per Minute or Feed per Revolution.
Output Initial Spindle Location — When active, causes the machine to move to its
initial spindle location at the beginning of tool path processing. Enter initial machine
location values in an Initial Machine Location table.
Rapid Motion Cancels Cycles — When active, rapid motions (e.g. G0) cancel canned
cycles (e.g. G81-89).
Linear Motion Cancels Cycles — When active, linear motions (e.g. G01) cancel canned
cycles (e.g. G81-89).
CW Motion Cancels Cycles / CCW Motion Cancels Cycles—When active, clockwise
(or counterclockwise) circular interpolation motions (e.g. G02) cancel canned cycles (e.g.
G81-89).
Output Rapid Motions as — Controls the format in which rapid motions are written to
the APT Output file during reverse post-processing. Options are:
y Rapid — Output the word “RAPID” followed by a single tool tip location.
y Feedrate — Output “FEDRAT/n” where the feed rate is calculated based on the
rapid priority of moving axes, then output the tool tip location(s). When rapid
priority causes axes to move independently, multiple tool tip positions are output.
Maximum Inverse Time Output Feedrate — Highest feedrate value which can result
from interpreting inverse time feed rate values (e.g. G93). The output feed rate is set to
this rate when in inverse time feed mode and the calculated feed rate is zero or greater
then the specified maximum.
Output Precision — Controls the accuracy used to interpret calculated values, such as:
CDC offset positions, mathematical operations, etc. Options are:
y Full Precision — Highest possible accuracy. Note that full precision output
values can result in higher accuracy than the NC control uses, which may result in
differences between simulated motion and the actual motion performed by the NC
control.
y Input Precision — Use the accuracy used in the input tool path file. For example,
when tool path file data is in 3.4 format, the precision used is also 3.4.
y Specified Precision — Use the accuracy specified via Specified Output
Precision (see below).
Specified Output Precision — When Output Precision= Specified Precision, this
value reflects the accuracy used by the NC control to perform the operations described
above for Output Precision.

818
Control Settings window, Circles tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure how the circle center data (e.g. IJK) is interpreted. (See
how) The Interpolation Tolerance determines the quantity of machine positions which
simulate arc and helical motions.

Circle Center Mode — Mode in which to interpret circle center data. Options:
y Absolute — Absolute center coordinates.
y Incremental — Incremental distances-see "Incremental Circle Center Method"
below).
y G Code Dependent — As described above, except depends on the active input
dimension mode: absolute or incremental.
Incremental Circle Center Method — When interpreting incremental circle center
values, controls how incremental circle center data is interpreted. Options:
y From Start to Center Point — Distance from circle start point to circle center.
y From Center to Start Point — Distance from circle center to circle start point.
y Unsigned — Unsigned, positive incremental distance between circle start point
and circle center). Unsigned incremental circle motion blocks are always positive
in value, and do not cut circles greater than 90 degrees.

819
Pitch Specified with IJK— This option determines if the CircleCenterX, and
CircleCenterY, and CircleCenterZ macros can be used to determine the pitch. Only the
macro which corresponds to the direction perpendicular to the current motion plane will
be used for the pitch value. The pitch is defined as depth per revolution. The default is
"No". If set to "Yes", the delta depth distance divided by the pitch will determine the
number of full loops. If set to "No", the HelicalFullLoops macro should be called, and the
pitch will be calculated based on the number of full loops, the delta depth distance, and
the starting and ending angles.
APT Output for Circular Motion — Controls the format in which circular motions are
output during conversion to an APT output file. An APT Output file is created when
Create APT Output File is active. (Ref. Process Options window : G-Code Output Files
tab)

820
Control Settings window, Cycles tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure how fixed tool axis, or "canned" cycle motion blocks are
interpreted, e.g. G8n. (See how)

Cycle Return Level — Controls where the tool tip is returned (retracted) after
processing a cycle command. Options:
y R Point — Rapid positioning or “R level”.
y Initial Point — Initial level from where the cycle motion began.
y Specified Point — Clearance distance from the workpiece as specified by an
word/address, such as G71Zn with some Okuma controls, or Clearance +
Retraction (similar to Specified Point, except a retraction clearance can be
specified).

821
Cycle Clearance Distance — Distance from the workpiece to the R level.

Cycle Rapid method — Controls how rapid positioning is performed between cycle
executions. Options:

y Clearance Plane — FANUC method-R level located at some clearance above the
workpiece, tool tip placed at the R level).
y Part Surface — Cincinnati Acramatic method-R level located on the workpiece
surface, tool tip placed .125”, or 3mm above the R level.

822
Cycle Depth Value — Controls how the cycle depth values are interpreted. Options:
y Absolute — Absolute cycle depth value.
y Incremental — Incremental distance as described by the Cycle Incremental
Depth Value below).
y G Code Dependent—As described above, except depends on the active input
dimension mode: absolute or incremental.
Cycle Incremental Depth Value — When interpreting incremental cycle depth values,
controls how incremental distances are interpreted. Options:
y Relative to Cycle Rapid Value — Incremental distance from R level.
y Relative to Cycle Initial Level — Incremental distance from initial level.
y Relative to Part Surface — Incremental distance from the part surface.
Cycle Rapid Value — Controls how cycle rapid values are interpreted to determine the
R level. Options:
y Absolute — Absolute R level position.
y Incremental — Incremental distance to the R level, as specified by the Cycle
Incremental Rapid Value.
y G Code Dependent — As described above, except depends on the active input
dimension mode: absolute or incremental.
Cycle Incremental Rapid Value — When interpreting incremental cycle rapid values,
controls how incremental distances are interpreted to determine the R level. Options:
y Relative to Cycle Initial Level — Incremental distance from the initial level.
y Relative to Part Surface — Incremental distance from the part surface.
Cycle Causes Rapid Motion — When active, sets the rapid motion mode with a cancel
cycle command (e.g. G80).
Ignore Cycles during Rotary Motion — When active, ignores canned cycles during
rotary motions. Clear this checkbox to allow cycles during rotary motions. The use of this
modal becomes more important when the Output Intermediate Points control setting is in
use.
Cycle Execute — Controls when cycle motions are executed. Options:
y On Motion — Execute cycle on cycle block and each following motion until
cancelled. (Default)
y As Commanded — Cycle definition block is for setup only; execute cycle when
commanded by a specific word/address, such as G79 with some Phillips NC
controls. Requires using the CyclesExecute macro in the NC control configuration
for the codes that command cycles to be executed.

823
Control Settings window, Tooling tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure default tooling conditions and tool change activity. (See
how)

Initial Tool Component ID — Specifies the Tool Index Number of the tool component
initially active for tool changes.
Tool Number Method — Controls how to interpret tool number word/addresses (e.g.
Tn). Options are:
y Select Only — Tool number only selects the tool. The tool is changed by a
separate command, e.g. M6)
y Select & Change — Tool number selects and changes the tool. A separate tool
change command is not used.
Tool Change Retract Method — Method of retracting for a tool change. Methods which
retract machine axes reference location values stored in a Tool Change Location table.
Options are:
y No Retract — Change the tool at its current location.
y Retract (Z-Axis only) — Retract the tool only along the Z-axis.

824
y Retract All Axes — Retract all machine motion axes to their respective tool
change locations.
y Retract Tool Side Axes — Similar to Retract All Axes, except applies only to
motion axes connected between the machine Base and Tool components.
y Use Retraction Table — Refer to the Tool Change Retraction table to determine
which machine axes to retract.
Tool Change Cancels Cycles — When active, cancels canned cycles with a tool change.
Tool Change Causes Rapid Motion — When active, sets the rapid motion mode with a
tool change.

825
Control Settings window, Rotary tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure how rotary motion commands are interpreted, e.g. A, B, C.
(See how) A "moving tool philosophy" is assumed when describing rotations.

Output Intermediate Points — When active, generates intermediate tool positions


during rotary motions. If turned off, only the final tool position of a rotary motion is
shown. Rotary intermediate points help you see the tool-to-workpiece relationship during
rotary motions, however, the simulation will be slower. The Interpolation Tolerance
determines the quantity of machine positions which simulate rotary motions. (Ref. File
menu > Properties: Tolerance tab)

826
OptiPath NOTE: Multi-axis motions are not optimized when Output
Intermediate Points is active.
A-axis Rotary Type, B-axis Rotary Type, C-axis Rotary Type — The settings control
how rotary commands are interpreted (e.g. ABC). Each axis is individually controlled.
Options:
y EIA (360 Absolute) — Refers to absolute angle positions. Absolute Rotary
Direction controls how rotation values determine the direction of rotation.

y Linear — Refers to angles on a linear axis "wrapped" around the rotary


component. In absolute input dimension mode (e.g. G90), rotary values specify
absolute locations along the linear-rotary axis, while the sign (+ / -) controls
which end of the linear axis is used. In incremental input dimension mode (e.g.
G91), rotary values specify degrees to rotate from the current position, and the
sign controls the direction of rotation: plus = CCW, minus = CW.

827
Example rotations of a B-axis linear-rotary component:
Rotary motion
Current axis Command Rotary destination
(moving tool
position
philosophy)
B0 G90B75 75 deg CCW B75
B0 G90B-75 75 deg CW B285 (B-75)
B35 G90B75 40 deg CCW B75
B35 G90B-75 110 deg CW B285 (B-75)
B150 G90B120 30 deg CW B120
B150 G90B-120 270 deg CW B240 (B-120)
N/A G91B75 75 deg CCW Current +75
N/A G91B-75 75 deg CW Current -75

A2-axis Rotary Type, B2-axis Rotary Type, C2-axis Rotary Type — The settings
control how rotary commands for secondary rotary axes are interpreted (e.g. A2,B2,C2).
Each axis is individually controlled. Options are same as described above for ABC rotary
types.
Absolute Rotary Direction — Controls how rotation values determine the direction of
rotation for EIA (360 Absolute) rotary type components. Options and examples follow.
y Positive -> CCW — Sign controls the direction of rotation: plus = CCW, minus =
CW, and absolute value of the rotation value specifies the rotary destination.
NOTE: You can configure the same behavior using Configuration menu >
Word/Address and associating the RotaryDirPosCCW macro.

Examples of rotary behavior with Absolute Rotary Direction=Positive -> CCW:


Rotary motion
Current axis Command Rotary destination
(moving tool
position
philosophy)
NA G90B0 NA B0
B0 G90B380 20 deg CCW B20
B20 G90B-90 290 deg CW B90
B90 G90B60 330 deg CCW B60

828
y Positive -> CW — Similar to Positive -> CCW, except the rotation directions are
reversed.

NOTE: You can configure the same behavior using Configuration menu >
Word/Address and associating the RotaryDirPosCW macro.

Examples of rotary behavior with Absolute Rotary Direction=Positive -> CW:


Rotary motion
Current axis Command Rotary
(moving tool
position destination
philosophy)
NA G90B0 NA B0
B0 G90B380 340 deg CW B20
B20 G90B-90 70 deg CCW B90
B90 G90B60 30 deg CW B60

y Always CCW — Rounds the rotation value to increments of 360, then subtracts
360 until the subtracted value is between 0-360. The rounded value specifies the
rotary destination. The tool always rotates in a CCW direction about the rotary
center point.

NOTE: You can configure the same behavior using Configuration menu >
Word/Address and associating the RotaryDirCCW macro.

Examples of rotary behavior with Absolute Rotary Direction=Always CCW:


Rotary motion
Current axis Command Rotary
(moving tool
position destination
philosophy)
NA G90B0 NA B0
B0 G90B380 20 deg CCW B20
B20 G90B-90 250 deg CCW B270
B270 G90B60 150 deg CCW B60

y Always CW — Similar to Always CCW, except the rotation directions are


reversed.

NOTE: You can configure the same behavior using Configuration menu >
Word/Address and associating the RotaryDirCW macro.

829
Examples of rotary behavior with Absolute Rotary Direction=Always CW:
Rotary motion
Current axis Command Rotary
(moving tool
position destination
philosophy)
NA G90B0 NA B0
B0 G90B380 340 deg CW B20
B20 G90B-90 110 deg CW B270
B270 G90B60 210 deg CW B60

y Shortest Distance — Uses the rotation value and its sign to specify the absolute
rotary position. For each rotary motion, the tool rotates the shortest distance about
the rotary center point to the rotary destination.

NOTE: You can configure the same behavior using Configuration menu >
Word/Address and associating the RotaryDirShortestDist macro.

Examples of rotary behavior with Absolute Rotary Direction=Shortest Distance:


Rotary motion
Current axis Command Rotary
(moving tool
position destination
philosophy)
NA G90B0 NA B0
B0 G90B380 20 deg CCW B20
B20 G90B-90 110 deg CW B270
B270 G90B60 150 deg CCW B60

y Linear — Rounds the rotation value to increments of 360, then subtracts 360
until the subtracted value is between 0-360. The difference between the rounded
value and the current position is the rotary destination while the sign of the
difference specifies the rotation direction. A positive difference value rotates the
tool in a CCW direction about the rotary center point, a negative value rotates the
tool in a CW direction.

NOTE: You can configure the same behavior using Configuration menu >
Word/Address and associating the RotaryDirLinear macro.

830
Examples of rotary behavior with Absolute Rotary Direction=Linear:
Rotary motion
Current axis Comman Rotary
(moving tool
position d destination
philosophy)
NA G90B0 NA B0
B0 G90B380 20 deg CCW B20
B20 G90B-90 250 deg CCW B270
B270 G90B60 210 deg CW B60

Rotary Tool Control Point — When active, with default settings, Rotary Tool Control
Point, or "RTCP" causes rotary motion about a specific control point-typically the tool
tip. When RTCP is not active, rotation occurs about the rotary component origins. This
feature is intended for use only with tilting head machines.
RTCP compensates for the gage offset (XYZ distance from tool tip to Tool component)
and pivot offset (XYZ distance from spindle face/centerline to tool side rotary
components rotation/pivot point) as tool side rotary components rotate.

Affect of using RTCP with an A-axis rotary component:

RTCP only applies to rotary components between a Tool component and the Base
component (tool side). Rotary components between a Stock component and the Base
component (part side) do not effect the orientation of the tool, and therefore do not affect
the tool side offsets.
RPCP, or Rotary Part Contol Point, is used with part side rotary components, where the
part is moved relative to the tool tip. RPCP actually rotates the workpiece coordinate
system as the part side rotary components rotate. RPCP should only be used when

831
programming in the part coordinate system. See reference information on the "RpcpOn,
RpcpOff" macros, or the "RPCP Pivot Offset table" in the Tables for Processing G-Codes
section for more information.

NOTES:
1. The default state for RTCP is set on the Rotary Settings panel. The RTCP state
can be modified via the RotaryControlPointOnOff or RtcpOn, RtcpOff macros.
2. See also: "RTCP Pivot Offset table" or "RPCP Pivot Offset table" for possible
additional configuration for correct RTCP simulation.

RTCP Contour — Use this feature to set the mode for RTCP contouring. "Yes" puts
RTCP in contouring mode (XYZ offsets are updated and applied continuously during
rotary motion). "No" puts RTCP in non-contouring mode (XYZ offsets are not updated
and applied during rotary motion). Use the RtcpContour macro to over-ride this setting.
RTCP must be active for this setting to have an effect.
RTCP With Motion — Use this feature to set the mode for RTCP with motion. "Yes"
causes the RTCP updated XYZ offsets to only take effect when the corresponding X, Y,
or Z axes are programmed in a rotary motion block. "No" causes the XYZ offsets to take
effect immediately, meaning X, Y, or Z axes do not have to be programmed in a rotary
motion block. Typically, this feature is only applicable when in non-contouring mode
(RTCP Contour = "No"). Use the RtcpWith Motion macro to over-ride this setting. RTCP
must be active for this setting to have an effect.
RTCP Uses — Use this feature to specify which type of pivot offset compensation to
use. There are two Pivot Offset compensation types: RTCP and Gage.
RTCP specifies the programmed/driven point is assumed to be the spindle
face/centerline with no tool loaded. The RTCP Pivot Offset table can be used with
this type to override the automatic calculation. The centerline of rotation for
multiple tool side rotary components must intersect.
Gage specifies the programmed/driven point is assumed to be the rotation/pivot
point of the tool side rotary component, closest to the Base component. The
PivotOffsetCompName macro can be used with this type to override where the
XYZ pivot offset distance will be measured to. The centerline of rotation for
multiple tool side rotary components do not have to intersect. The macros
TurnOnOffGageOffset and TurnOnOffGagePivotOffset can be used to turn on and
off the gage offset and the pivot offset, thereby driving either the spindle face or the
tool tip. If Programming Method is set to Tool Tip, the gage offset is always active.
RTCP must be active for this setting to have an affect.
Choose one of the following:
y Default Pivot Offset — Use the RTCP Pivot Offset compensation type. The
ApplyGagePivotOffset macro can be used to switch to the Gage Pivot Offset
compensation type.
y Gage Pivot Offset — Use the Gage Pivot Offset compensation type. This option
should be used for all new jobs.

832
NOTE: The Gage Pivot Offset might currently be turned off, or may be set to
(0,0,0).
y RTCP Pivot Offset — Use the RTCP Pivot Offset compensation type.
NOTE: The RTCP Pivot Offset might currently be turned off, or may be set to
(0,0,0).
y Only Gage Offset — Do not compensate for XYZ pivot offset. Compensate only
for the XYZ gage offset.

Tech Notes:
Traditionally, Rotary Tool Control Point (RTCP) referred to a state in which the tool
would rotate about the tool tip when a tool-side rotary was rotated.

Today this feature has a more generic definition. Rotary Tool Control Point refers to a
state in which the tool side offsets are automatically updated when a tool-side rotary
is rotated. This means that even though Rotary Tool Control Point is active, the results
might not be as described above for the following reasons:
1. The traditional definition assumed that the offsets are adjusted continually as the
rotary axis is rotated. This is not always the case. In the above diagram, an "A90"
command is being executed. If the offsets are not updated continuously, the tool
tip position will not stay fixed, but will "wander", and then end up in its original
position. The RTCP Contour flag allows for configuration of either type.
2. The traditional definition assumed that the offsets would be applied immediately
to all axes even though the corresponding linear axes were not specified on the
block. This is not always the case. If the offsets are only applied when the
corresponding linear axes are specified, then in the above case (A90), even though
RTCP was active, the machine would behave as illustrated on the left. Then when
XYZ is specified (with the original coordinates), then the updated offsets would
be applied, and the tool tip would return to its original position. The RTCP With
Motion flag allows for configuration of either type.
3. Some controls only adjust some of the 4 tool side offsets. If this is true, then the
tool tip will not return to the original position.

833
Control Settings window, Wire EDM tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure wire EDM machining settings. (See how)

Maximum Wire Angle — Maximum angle the wire can tilt in any direction from
vertical alignment. If the wire is tilted beyond this angle, an error message is issued.
Initial Voltage — When active, indicates voltage to the wire is on at the start of tool path
processing.
UV Relative to XY — When active, U and V tool path values are relative to the current
X and Y axis positions.
XY Also Moves UV — When active, X and Y tool path values also cause the
corresponding U and V axis to move. In typical wire EDM machine construction, the U
and V axes are connected such that they are slaved off the X and Y axes. In other words,
when the X and Y axes move, the corresponding U and V axes also move by default. The
XY Also Moves UV setting is intended to work with machines built such that the U and
V axes are separate from the X and Y axes.
Work Table to XY Output Plane — Distance from the top of the work table (machine
Z zero) to the XY output plane (output Z values). The XY output plane is the Z-axis level
at which X and Y values are assumed to be driven. This value is measured along the
machine Z-axis, and is usually zero.

834
Control Settings window, Cutter
Compensation tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure how the programmed tool path is compensated when cutter
diameter compensation, or "CDC" is used, e.g. G41-42. (See how) Enter CDC offset
values into a Cutter Compensation table. To apply CDC offsets to the programmed tool
path, ensure Process Cutter Comp. is active.

CDC ON/OFF Method — Controls how the offset condition is established when CDC is
turned on, and how the offset is cancelled when CDC is turned off. Options are:
y Ramp ON/OFF—Establish the offset condition with a "ramp-on" motion after
CDC is turned on. When CDC is turned off, the offset is cancelled with a "ramp-
off" motion on the next tool move.
y Immediate—Immediately establishes the offset condition when CDC is turned
on, and assumes the offset has been established by a prior data block (e.g. G43-44
as interpreted by the Phillips CNC controls). When CDC is turned off, the offset
is cancelled without a tool move.
CDC Ramp ON/OFF with — Specifies the motion types which establish/cancel the
CDC offset. Options:
y Active Plane Motion — Turn CDC on with a motion in the active cutting plane.
y Any Motion — Turn CDC on with any motion, including motion along the tool
axis.

835
Control Settings window, Offsets tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure an initial work offset, or “fixture offset”, to be in effect at


the start of tool path processing. (See how)

Initial Work Offset—When active, sets the initial work offset specified by the Initial
Work Index (see below).
Initial Work Index—Index, or offset register value, containing the initial work offset.
The offset remains effective until a different work offset (e.g. G54-59) is processed, or
until cancelled. Enter the corresponding offset values into a Work Offsets table.

836
Control Settings window, Subroutines tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure how subroutine names are referenced by the NC control.
(See how)

Type of Subroutine Names — Controls how names of subroutines are referenced.


options are:
y Numeric — Use the numeric value; leading zeros are ignored. For example,
"O0010" is interpreted the same as "O10".
y Text — Use the text string value. For example, "O0010" is not interpreted the
same as the name "O10".

837
OptiPath & Curve Fit tab
Location: Configuration menu > Control Settings
Location: OptiPath menu > Control > G-Code Output Options tab

VERICUT toolbar short cut:

Opens a window to configure settings referenced when G-code tool path files are
optimized by OptiPath. (See how)
The settings are used to control block sequencing and word/value spacing in the
optimized output tool path file. Note that by default, optimized blocks receive the same
sequence number, if any, that appears on the original block processed. This typically
results in multiple blocks having the same sequence number.

Auto Sequence Numbering — When active, re-sequences optimized tool path records in
ascending order. The Sequence Increment Value (see below) is used for the beginning
sequence number, and as the increment value for subsequent sequence numbers. Both
optimized and non-optimized blocks with sequence numbers are re-sequenced. Sequence
numbers are not added to unoptimized blocks without a sequence number.

NOTE: If the general control setting Default Word="N", then "N" does not
appear in the sequence number. The result is a sequence number without a word,
for example: “50G01X5”, such as required by Heidenhain controls.

838
Add Sequence Number to Added Blocks — When active, adds sequence numbers to
blocks added during optimization via the Add More Cuts OptiPath setting.
Sequence Increment Value — Initial value and increment value for re-sequencing
optimized G-code tool path records.

Word Value Spacing—When active, includes a space between word/value pairs in the
optimized tool path file. Unoptimized records do not receive spacing. When this feature
is not used, optimized tool path records are not spaced.

839
Control Settings window, User Defined tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Opens a window to configure user defined control settings supplied via a custom CME
file. This window will appear differently, depending on the CME file in use. CME files
are created using the Machine Developer's Kit, and specified for use in VERICUT via
Dev Kit CME in the Configuration menu > Adv. Options function.

NOTE: Developer's Kit-defined settings can also appear under Project menu >
Processing Options > G-Code > Process Options: User Defined tab, as determined
by the developer.

840
Control Settings window, Sync tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Features on this tab configure VERICUT for simulating machining with synchronized
subsystems.

4-Axis Sync Method — Controls when and how to interpret turret/head synchronization
data. When active, 4-axis turning motion synchronization codes is processed so that
motion components travel with the same timing as occurs on the actual NC machine tool.
The active choice indicates the NC control style of 4-axis synchronization, also known as
"merged turning". When synchronized tool path motions are processed, the Info menu >
NC Program window shows which blocks are being processed by the primary and
secondary axes. Options:
y None — (Default) processes blocks as they are encountered-primary axes are not
synchronized with secondary axes. Only one tool cuts at a time.
y G&L — "N" sequence numbers mark commands for the primary axes (typically
XZ), while "O" sequence numbers mark commands for secondary axes (typically
UW). "B" sets the sync code, and "M12" synchronizes primary axes with
secondary axes.
y Okuma — "G13" mode commands move the primary axes, while "G14" mode
commands move the secondary axes. "P" sets the sync code.
y Fanuc — Two independent tool path files are simulated. Tool path file #1 move
the primary axes, while Tool path file #2 moves the secondary axes. "Mnnn" sets
the sync code, and "G68" synchronizes primary axes with secondary axes.

841
y INDEX — A single tool path file contains two subroutines, one for each head. A
word/value, for example "M30", toggles between "channels" that control each
head. See the "IndexCallMainSub" macro under "Macros - listed alphabetically"
for more information.
y Gildemeister — Blocks starting with $1 will be processed by one subsystem, and
blocks starting with $2 will be processed by a second subsystem. Blocks not
beginning with either a $1 or a $2 will be processed by both subsystems.
y Mazak — "G109 L1" mode commands move the primary axes, while "G109 L2"
mode commands move the secondary axes.
y Allen-Bradley — This sync type has the following attributes:
A block can contain commands for both controls (subsystems).
Each control is processed independently.
The next block is not processed until both controls are done with the previous
block.
Although the split up of the Info Toolpath is not necessary (or possibly desirable)
for this sync type, it is still done for consistency with the way we handle sync
motion.
When "stepping", both the upper and lower Toolpath windows (controls) will
process 1 block.
The MDI window will ignore the subsystem specified, and will process the line as
stated by sending it to both controls.

The following are the basic rules for this sync type.
1. The Primary and Secondary SubSystems will read each line of the file. The
control configuration will determine whether there is anything on the line that
is pertinent to the current Subsystem.
2. If a line contains either (X or Z) and (U or W), an automatic sync will be
executed prior to AND after the motion on this block.
3. Additional SyncMacro calls can be made as needed. For example: with the
G4.

Primary SubSystem ID / Secondary SubSystem ID — 4-axis turning machines


intended to simulate synchronized motions must be configured with two subsystems: one
for the primary axes, a second for the secondary axes. These features associate the G-
codes (or tool path files) which command primary motion axes with the primary machine
subsystem, and the secondary motion axes/subsystem. Note that feature labels are
different, depending on the active 4-axis Sync Method.

842
Active 4-axis Sync Method: Primary SubSystem ID Secondary SubSystem ID
feature: feature:
None Primary SubSystem ID Secondary SubSystem ID
G&L N Block SubSystem ID O Block SubSystem ID
Okuma G13 SubSystem ID G14 SubSystem ID
Fanuc File 1 SubSystem ID File 2 SubSystem ID
INDEX Channel 1 SubSystem ID Channel 2 SubSystem ID
Gildemeister $1 SubSystem ID $2 Subsystem ID
Mazak G109L1 SubSystem ID G1109L2 SubSystem ID

843
Control Settings window, Turning tab
Location: Configuration menu > Control Settings

VERICUT toolbar short cut:

Features on this tab configure VERICUT for lathe turning simulations.

CSS Maximum RPM — When constant surface speed, or "CSS" is controlling spindle
speed, this value specifies the fastest RPM to turn the workpiece.
RPM Changes with RAPID and CSS — When selected and CSS is controlling spindle
speed, rapid motions (e.g. G0) can affect spindle speed, as well as linear and circular
motions (e.g. G1-3). Clear this checkbox to have only linear and circular motions affect
RPM.

844
Adv. Options

Advanced Control Options window


Location: Configuration menu > Adv. Options

VERICUT toolbar short cut:

Opens a window to configure advanced NC control options, such as: specify subroutines
available in the NC control, perform actions at key processing events (e.g. start of tool
path processing, start processing a block, etc.), substitute text strings, and more.

845
Subroutines tab — The features on this tab specify names of external files containing
subroutines accessible by the NC control.
Events tab — The features on this tab maintain macros called and variables set based on
key events that occur during tool path file processing.
Substitute tab — The features on this tab maintain text strings that are substituted when
specific text in the tool path file is encountered.
OptiPath Substitute tab — The features on this tab maintain text strings that are
substituted when tool path files are optimized by OptiPath and written to the Optimized
file.
Dev Kit CME tab — Features on this tab enable you to specify a custom CME file
containing custom macros that assist the NC control with processing machine code data.
OK — Saves additions/modifications and dismisses the Advanced Control Options
window.
Apply — Saves additions/modifications and leaves the Advanced Control Options
window open.
Cancel — Closes the Advanced Control Options window without saving any
additions/modifications.

846
Advanced Control Options, Subroutines tab
Location: Configuration menu > Adv. Options

VERICUT toolbar short cut:

The features on this tab specify names of external files containing subroutines accessible
by the NC control. (See how)

File Names list — List of external files containing subs accessible to VERICUT.
Tip: Right-click in the File Names list area to display a pop-up window with the
following features:
Add — Opens the Job Subroutine Files selection box enabling you to add
external subroutine files to the File Names list.
Replace — Opens the Job Subroutine Files selection box enabling you to
replace the highlighted subroutine file in the File Names list with another.
Delete — Deletes the highlighted subroutine file from the File Names list.

847
Edit — Displays the of the highlighted subroutine file in a text editing
window. Standard text editing features are provided, such as: copy/cut, paste,
search, etc. For more information on using the editing features see Edit menu
> Text File.

Add — Opens the Job Subroutine Files selection box enabling you to add external
subroutine files to the File Names list. (Same as Add in the pop-up window described
above)
Replace — Opens the Job Subroutine Files selection box enabling you to replace the
highlighted subroutine file in the File Names list with another. (Same as Replace in the
pop-up window described above)
Delete — Deletes the highlighted subroutine file from the File Names list. (same as
Delete in the pop-up window described above)
Delete All — Deletes all subroutines files from the File Names list.

848
Advanced Control Options, Events tab
Location: Configuration menu > Adv. Options

VERICUT toolbar short cut:

The features on this tab enable you to specify the macros called and/or variables set based
on key events that occur during tool path file processing. (See how) The Events tab
displays the event configurations of a particular NC control as a "tree" structure. When
you expand an "event" object, the macro calls/variable settings associated with that
particular event are displayed.

The following Events are available:


y Reset — Event occurs before the tool path file is scanned.
y Start of Processing — Event occurs after the tool path file has been scanned, but
before the tool path file is processed.

849
NOTE: The ConversionInit macro must always be the first macro listed for
this event.

y End of Processing — Event occurs after the tool path file has been processed.
NOTE: The ConversionFinish macro must always be the last macro listed
for this event.
y Start of Block Processing — Event occurs at the start of processing each G-code
data block.
NOTE: The BlockInit macro must always be the first macro listed for this
event.
y End of Block Processing — Event occurs at the end of processing each G-code
data block.
NOTE: The BlockFinish macro must always be the last macro listed for
this event.
y Start of Type II Command / End of Type II Command — Event occurs at the
start (or end) of processing a Type II data command.
Add / Modify — Opens the EventsAddMod window enabling you to add (or modify)
event-based macro calls/variable assignments.
Delete—Deletes the selected event-based macro call/variable assignment.

850
EventsAddMod window
Location: Configuration menu > Adv. Options

VERICUT toolbar short cut:

Opened by pressing Add/Modify on the Advanced Control Options window, Events tab.
The features on this window enable you to add (or modify) event-based macro
calls/variable assignments. Features in this window behave similar to those described for
word/address groups on the Add/Modify Word/Address window.

851
Event — Enables you to select the event that you want to add to or modify. Select from
the pull-down list.
Macroname/Variable — Controls calls a macro, or sets a variable. Depending on the
active choice, features are provided for specifying the macro called (select or type in
field), or the Variable Name and Variable Description of the variable to be set (enter the
variable value in the Override Value field). You can select macro names, or type them
in. Text entered is not case sensitive. Use the automatic filtering capability to help you
find macros. When you enter text characters in the Macroname field, the list of macros
is automatically filtered to show only those that match the specified text.
Override Value — This feature acts differently, depending on whether Macroname or
Variable is selected:
- With Macroname selected — Specifies a value to pass to the specified macro. If
blank, the address value accompanying the word is passed.
- With Variable selected — Specifies a value to assign to the specified Variable
Number. Use the Variable Description field to describe what Variable
Number represents.
Math expressions and variables understood by the control are supported. Enter "$"
to specify using the address value accompanying the word. Enter "#", followed
immediately by the variable name/number, followed by a space, to specify a
variable value. Multiple variables can be added, separated by a blank space. If the
override expression does not contain either of these characters, it is evaluated
immediately and only the value is retained. If the expression can not be evaluated
immediately, the full expression is retained in the control configuration and
evaluated separately for each block that activates the group.

Examples of using Override Value: (given that the variable, #2 = 3)

Text entered in What is retained in Sample G- Resulting value when


Override Value control configuration code data processed
field block
SIN(30) .5 X5 .5 (constant value- not
affected by G-code
data)
SIN(30) .5 X10 .5 (see note above)
$*10 $*10 X5 50
($+#2)*10 ($+#2)*10 X5 80

Also see "Using Equations/Expression In VERICUT" in the Using VERICUT


section for more information.

Override Text — Similar to Override Value, except specifies text to pass to the macro.
Only certain macros are designed to accept override text values. Consult "Macros - listed
alphabetically" in the Reference section for more information.
Expression(s) can be used in macro override text. If the override text contains the
sequence "{ expression }" the expression text inside the curly-braces is evaluated
and replaced with the calculated value.

852
For example, if the MessageMacro is used with the following override text:
"The spindle speed is {#speed} rpm"
The variable "#speed" is evaluated and if set to 500, the resulting
message would be:
"The spindle speed is 500 rpm"
The syntax for the expression(s) is the same as defined for override values.
Add — Select when adding a new macro or variable to the event.
Modify — Select when modifying an existing macro or variable for the event.
Close — Closes the EventsAddMod window.

853
Advanced Control Options, Substitute tab
Location: Configuration menu > Adv. Options

VERICUT toolbar short cut:

The features on this tab maintain text strings that are substituted when specific text in the
tool path file is encountered. (See how) Using substitutions lets you to alter how
VERICUT "sees" data in a block without editing the G-code tool path file. Substitutions
occur at the beginning of processing each G-code data block, prior to parsing block
words and values into "tokens". Substitutions in the list are applied in listed order.

See "About building NC controls" in the Using VERICUT section for more information
about how G-code blocks are processed by VERICUT.
Substitution (Input/Output Text) list—Lists text string substitutions that will occur
when specified input text is encountered.
Input Text / Output Text—Specifies an input text string to substitute, and the output
text that VERICUT will use in its place.

854
NOTE: Substitution input/output text is case sensitive.

Add—Adds a new substitution to the list.


Modify—Modifies an existing substitution in the list.
Delete—Deletes the selected substitution from the list.

855
Advanced Control Options, OptiPath
Substitute tab
Location: Configuration menu > Adv. Options

VERICUT toolbar short cut:

The features on this tab maintain text strings that are substituted when tool path files are
optimized by OptiPath and written to the Optimized file. Using substitutions lets you to
alter what VERICUT writes to optimized G-code tool path file(s). Substitutions occur at
the end of processing each G-code data block, prior to outputting to the optimized tool
path file.

Window features are the same as described for NC control substitutions-ref.


Configuration menu > Adv. Options: Substitute tab.

856
Advanced Control Options, Dev Kit CME tab
Location: Configuration menu > Adv. Options

VERICUT toolbar short cut:

Features on this tab enable you to specify a custom CME file, or CGTech Macro
Executable file containing custom macros that assist the NC control with processing
machine code data. This file can also supply "control settings" that allow users to further
customize how machine code data is interpreted, and provide access to custom data tables
for storing job, tool, and machine related data. A custom CME file is typically created by
CGTech or other services organization using the Machine Developer’s Kit. In this
manner, end users can customize VERICUT's ability to simulate machine code data
according to site-specific needs.

For more information about developing customer CME files, see VERICUT Machine
Simulation Developer's Guide in VERICUT Development Tools.

857
Dev Kit CME File—Opens a window to specify a custom CME file. Features on this
window are standard file selection window features that enable you to navigate through
directories, filter files, and type or select file names.

858
Analysis Tools menu

X-Caliper window

VERICUT Users:
VERICUT Location: Analysis menu > X-Caliper

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Analyze, View Files, Print page > Measure
Notebook Feature:

Cutter Grinder Users:


Cutter Grinder Location: Analyze, View Files, Print page > Measure
Notebook Feature:

Opens a window that displays measurements, historical, and mathematical information


about the VERICUT model. The appearance of the window will vary depending on the
X-Caliper option being used. X-Caliper shows what is being measured on the model area
by highlighting the "measure from" point (+) and the "measure to" point (o). Results from
X-Caliper operations are displayed in the X-Caliper window. Measurements are
described relative to the active coordinate system.

859
The X-Caliper window is also one of the dockable windows enabling you to dock it
inside the VERICUT main window if you choose.
NOTE: Machined features can only be measured in a workpiece view.
Toolbar — The features in the X-Caliper Toolbar are common to all options except as
noted below.

y Enable/Disable Mouse Picks — Toggles to enable/disable the ability pick


features in a VERICUT workpiece view. Shown here in "enable" mode.

y or Set X-Caliper Units — Toggle the icon between inch, and metric,
to specify the units that you want X-Caliper data displayed in.

y Measure — Computes measurements based on the current X-Caliper window


configuration. This feature is useful to have X-Caliper calculate measurements
based on data keyed in, or edited data. This feature is only active for
Distance/Angle, Stock Thickness, Air Distance and Closest Point options.

y Display Tool/Stock Collisions — Use to specifically highlight collisions


between the tool holder and the stock model in the graphics area. Use the
Feature/History option to obtain information about the collision (NC Program file,
Record number, Tool ID, etc.). This feature is only active when when
holder/stock collisions occurred while cutting the part.

860
Disable Holder/Stock Collisions Disable Holder/Stock Collisions
toggled "Off" toggled "On"

Notice that when toggled "Off", all collisions Notice that when toggled "On", only
(holder/stock, cutter/fixture, etc.) are displayed. holder/stock collisions are displayed.
Including the collision areas that were
cut away by subsequent cuts.

y Clear X-Caliper Report — Clears the results from the X-Caliper window.

y Print — Displays a Page Setup window enabling you to format the page,
specify the printer, and print.

y Save X-Caliper Report — Saves the results from the X-Caliper window to
a file. Use the file selection window that displays to specify the /path/filename for
the file to be created.

y Close Window — Closes the X-Caliper window.


Options — Select the desired X-Caliper option from the pull-down list. The following
options are available:
y Feature/History — When a cut on the model is selected, this option displays the
geometric description of the cut feature, and corresponding tool path history. (See
how)
y Distance Angle — Use to measure the distance and/or angle between any
combination of two points, planes, conic axes, model or component origins, or
edges formed by intersecting planes or cylinders. (See how)
y Stock Thickness — Use to measure solid stock material. (See how)
y Air Distance — Use to measure the air gap between two solid surfaces. (See
how)
y Closest Point — Use to measure the shortest distance from an XYZ point
location to the closest point on the model surface. (See how)

861
y Scallop — Use to measure the height of a scallop formed by parallel intersecting
cylinders, typically cut by cutter corner radius. (See how)
y Volume — Use to display the following volume values calculated for a selected
stock workpiece: cut stock volume (cubic units), original stock model volume
(cubic units), and volume of material removed from the original stock model. (See
how)
y Stock/Design Distance — Use to measure the distance between the cut stock and
design models. (See how)
y Highlight Same Planes — Use to display all "cut" features that lie in the same
plane.
X-Caliper window — This is where the results from X-Caliper operations are displayed.
Active Coordinate System — Displays the name of the active coordinate system.

862
X-Caliper window, Feature/History
Location: Analysis menu > X-Caliper: Feature/History option

Toolbar shortcut:

When a cut on the model is selected, the Feature/History option is used to display related
cut feature (mathematical description) and tool path history. The historical data includes:
NC program file name, record number, and tool path record text responsible for the cut.
(See how) This function is useful to spot-check machined features, and determine the
source of an error cut identified in red by VERICUT.
Sample X-Caliper window, Feature/History option :

Following are geometric features identified by VERICUT, listed alphabetically:


y Auto-diff model—(X,Y,Z value and surface normal) an uncut surface on a model
displayed after an auto-difference Solid method comparison.
y Circle—(X,Y,Z center, axis vector and radius) a surface cut by a circular motion.
y Cone—(X,Y,Z center, axis vector and side angle) a hole bottom cut by an angle
tip drill, corner cut by a tapered endmill, or chamfer cut by a turning operation.

863
y Cylinder—(X,Y,Z center, axis vector and radius) an inside corner cut by 2 linear
motions having an interior angle less then 180 degree, fillet cut by a bull or ball
endmill moving perpendicular to the tool axis, or diameter cut by a turning
operation.
y Ellipse—(X,Y,Z center, axis vector, major and minor focal distances) a ramping
or plunging surface cut by the bottom of an endmill with a flat, or partially flat
bottom.
y Fixture model—(X,Y,Z value and surface normal) an uncut surface on a fixture
model.
y Holder Collision Area—(X,Y,Z value and surface normal) a holder/stock
collision area cut stock model. Data also includes NC program file, record number
and tool ID.
y Plane—(X,Y,Z value and surface normal) a flat machined surface. Cylinders or
circles cut using linear motions can also return this identity.
y Ruled surface—(X,Y,Z value and surface normal) a surface cut by a multi-axis
motion.
y Sphere—(X,Y,Z center and radius) a surface cut by the end of a ball endmill.
y Stock model—(X,Y,Z value and surface normal) an uncut surface on a stock
model.
y Torus—(X,Y,Z center, axis vector, major and minor radius) a fillet in a corner
cut by a bull endmill, or fillet left on a diameter by a radiused cutter during a
turning operation.
y Torus sweep—(X,Y,Z center, axis vector and major radius) This feature is
typical of an angled (ramping or plunging) surface cut by a bull endmill.

864
X-Caliper, Distance/Angle
Location: Analysis menu > X-Caliper: Distance/Angle option

Toolbar shortcut:

The Distance/Angle option is used to measure the distance and/or angle between any
combination of two points, planes, conic axes, model or component origins, or edges
formed by intersecting planes or cylinders. (See how) In general, select the "From"
feature, then select the "To" feature. X-Caliper shows what is being measured on the
model by highlighting the "measure from" point (+) and the "measure to" point (o) as
well as a line representing the distance (or vectors representing the angle) between them.
Sample X-Caliper window, Distance/Angle option :

NOTE: Machined features can only be measured in a workpiece view.

865
From / To groups—Each group includes the Feature, Location and Direction used to
specify what to measure from and what to measure to. Use the From / To arrows , to
control which fields are filled in by screen pick data. You can select features on the
VERICUT model, or enter number values (separated by blank spaces) directly into the
fields. After selecting the From feature, VERICUT automatically transfers control to the
To group. After selecting the To feature the X-Caliper window displays the measurement
data.
Feature — Controls the types of features to measure between. Select the Feature
type from the pull-down list.
Feature descriptions:
Point — The X, Y, Z of the pick point or entered point coordinates.
Plane—A flat, unbounded surface. If a curved surface is selected, data retrieved
represents a plane tangent to the selected model surface at the pick point.
Axis—Centerline of a cylinder or conic.
Edge—Edge formed by two intersecting planes or parallel cylinders. Special
cases follow.
Plane/Cylinder edge - Only a cylinder with an axis parallel to the plane can
produce an edge. Tangent conditions produce 1 edge. Intersecting
conditions produce 2 possible edges, thus the one closest to the cylinder
pick-point is used.
Cylinder/Cylinder edge - Only cylinders with parallel axes can produce an
edge. Tangent conditions produce 1 edge. Intersecting conditions produce
2 edges, thus the one closest to the last cylinder pick-point is used.

y Vertex — Enables you to easily select one of the six key points associated
with the triangles representing the faces of a model. For each triangle, the
points consist of the three vertices and the midpoint of each of the triangle's
three sides. VERICUT selects the point closest to your mouse pick. If the
mouse pick is over the cut stock, Vertex works in the same way as the Point
feature described above.

866
Vertex is a useful tool for measuring the trace of tool/fixture collisions on
uncut fixtures.
y Model Origin — Origin of a selected model. Use the View menu > View
Axes function to see model origin axes.
y Component Origin — Origin of a selected component. Use the View menu >
View Axes function to see component origin axes.
y CSYS Origin — Origin of the selected coordinate system axis. Use the View
menu > View Axes function to display the coordinate systems that are
available.
y CSYS Axis — The X, Y, or Z axis of the selected coordinate system. Use the
View menu > View Axes function to display the coordinate systems that are
available.
Location — Represents the XYZ coordinates of the screen pick.
Direction — Represents IJK of the normal vector at the location of the screen pick.
Data from the screen pick fills the Location and Direction data fields in the active
From or To group. If needed, you can edit data in these fields, then press Measure
to obtain a measurement
Measurement results are displayed in the X-Caliper window. Data output includes the
From / To values input and the measured distance and/or angle.

867
X-Caliper window, Stock Thickness
Location: Analysis menu > X-Caliper: Stock Thickness option

Toolbar shortcut:

The Stock Thickness option is used to measure solid stock material. (See how)

Sample X-Caliper window, Stock Thickness option :

Location — Represents the XYZ coordinates of the point to measure from.


Direction — Represents IJK of the measurement direction vector into material.

Data from the screen pick fills the Location and Direction data fields. If needed,
you can edit data in these fields, then press Measure to obtain a measurement.

Measurement results are displayed in the X-Caliper window. Data output includes the
Location and Direction values input, the XYZ point where the direction vector exits the
material and the measured stock thickness between the Location and Exit points.

868
X-Caliper window, Air Distance
Location: Analysis menu > X-Caliper: Air Distance option

Toolbar shortcut:

The Air Distance option is used to measure air gap between two solid surfaces. (See how)

Sample X-Caliper window, Air Distance option :

Location — Represents the XYZ coordinates of the point to measure from.


Direction — Represents IJK of the measurement direction vector away from solid
material.

869
Data from the screen pick fills the Location and Direction data fields. If needed,
you can edit data in these fields, then press Measure to obtain a measurement.

Measurement results are displayed in the X-Caliper window. Data output includes the
Location and Direction vector values input, the XYZ point where the direction vector re-
enters solid material and the measured Air Distance between the Location and entry
points.

870
X-Caliper window, Closest Point
Location: Analysis menu > X-Caliper: Closest Point option

Toolbar shortcut:

The Closest Point option is used to measure the shortest distance from an XYZ point
location to the closest point on the model surface. (See how)

Sample X-Caliper window, Closest Point option :

Location — Represents the XYZ coordinates of the point to measure from. XYZ
values must be manually entered. The Closest Point, "From" Location cannot be
specified by selecting the location graphically.

Measurement results are displayed in the X-Caliper window. Data output includes the
From Location, the XYZ coordinates of the closest point on the model, and the
measured distance between the "from" point and and the closest point on the model.

871
X-Caliper, Scallop
Location: Analysis menu > X-Caliper: Scallop option

Toolbar shortcut:
The Scallop option is used to measure the height of a scallop formed by two parallel
intersecting cylinders. (See how) Select the two parallel and intersecting cylinders on the
VERICUT model that form the scallop. X-Caliper identifies the cylinders being measured
by displaying intersecting circles on the model.

Sample X-Caliper window, Scallop option :

NOTE: Machined features can only be measured in a workpiece view.

872
Cylinder 1 / Cylinder 2 — Used to define the cylinders to measure from and to. Use the
choice arrow to control which cylinder is being picked. Select parallel cylinders on
the VERICUT model. After selecting Cylinder 1, VERICUT displays a circle
representing the cylinder in the graphics area and automatically transfers control to
Cylinder 2. After selecting Cylinder 2, measurement results are displayed in the X-
Caliper window.

Data output includes center point, axis vector and radius values for each cylinder and the
scallop height measurement.

873
X-Caliper window, Volume
Location: Analysis menu > X-Caliper: Volume option

Toolbar shortcut:

The Volume option calculates and displays the following volume values for a selected
stock workpiece: current cut stock volume, original stock model volume, and volume of
material removed from the original stock model. All volumes are in cubic units. (See
how)

Sample X-Caliper window, Volume option :

Calculated volumes are displayed in the X-Caliper window. Data output includes the
Current Stock Volume, Original Volume and Removed Volume.

874
X-Caliper window, Stock/Design Distance
Location: Analysis menu > X-Caliper: Stock/Design Distance option

Toolbar shortcut:

The Stock/Design Distance option enables you to measure the distance between the cut
stock and the design models.

Sample X-Caliper window, Stock/Design Distance option :

Stock— Use to display the stock model in the workpiece view. Options are
provided to display the models as Solid or Translucent, or turn the display Off.

875
Design — Similar to Stock Display above, except applies to design model(s).
From Stock to Design / From Design to Stock — Use to specify the "From" and
"To" components for the measurement.
Direction — Use to specify the I, J, K components, separated by blank spaces, of a
vector representing the direction of measurement from Location to the "To"
component.
Location — Represents the XYZ coordinates of the point to measure from on the
"From" component.
Direction — Represents IJK of the measurement direction vector toward the "To"
component.

Pick a location on the "From" component in the workpiece view. X-caliper then
measures the distance, normal to the pick location, to the nearest point on the
"To" component. You can also enter the X, Y, and Z components, separated by
blank spaces, of the desired measurement point on the "From" component.

Data from the screen pick fills the Location and Direction data fields. If needed,
you can edit data in these fields, then press Measure to obtain a measurement.

Measurement results are displayed in the X-Caliper window. Data output includes the
measurement method, Location and Direction values related to the "From" component,
the XYZ point of contact on the "To" component, and the measured Distance between
the Location and the point of contact on the "TO" component.

876
X-Caliper window, Highlight Same Plane
Location: Analysis menu > X-Caliper: Highlight Same Plane option

Toolbar shortcut:

The Highlight Same Plane option enables you to see all "cut" features that lie in the
same plane.

Sample X-Caliper window, Highlight Same Plane option :

Color — Use to select the color to highlight the planes. Select the desired color
from the pulldown color list.
Location — Represents the XYZ coordinates of the screen pick.
Direction — Represents IJK of the plane's normal vector at the location of the
screen pick.
Data from the screen pick fills the Location and Direction data fields

877
Z Tolerance — Use to specify a tolerance value for determining "same" planes.
All planes, within +/- the tolerance value, along the normal vector will be
highlighted
using specified color

Sample Graphics display after using the X-Caliper window, Highlight Same
Plane option :

878
AUTO-DIFF

VERICUT Users:
VERICUT Location: Analysis menu > AUTO-DIFF

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Analysis and Viewing page > Compare to the Design

Notebook Feature:

Opens a window to compare design model data against the VERICUT simulated cut
model. Using AUTO-DIFF, a licensed option, clearly identifies discrepancies between
the cut model the intended design model. Errors are identified before actual machine time
is wasted machining an incorrect part. You can use AUTO-DIFF interactively, in batch
mode, or automatically via "VERICUT-COMMAND" records in the tool path file. After
using AUTO-DIFF to identify gouges and excess material, use other VERICUT functions
such as X-Caliper and Zoom (ref. View menu > Orient) to measure and help determine
the source of the errors.

879
Settings tab — Features on this tab control the AUTO-DIFF comparison, and what you
see as a result.
Options tab — Features on this tab are used to set processing and reporting options.
Compare By Region tab — Features on this tab enable you to select a region to perform
AUTO-DIFF on.
Constant Gouge Check tab — Features on this tab enable you to specify a tolerance
value for Constant Gouge Check and turn Constant Gouge Check On/Off.
Apply—Applies the current AUTO-DIFF window settings.
Compare—Compares the design model(s) specified by the AUTO-DIFF window
settings.
Restore—Restores the VERICUT model as it was before performing the AUTO-DIFF
operation.

880
Report—Opens a window containing an AUTO-DIFF Report file that identifies errors
detected by AUTO-DIFF. Information includes a listing of tool path record numbers
responsible for the errors, and amount of deviation from the design model. Selecting an
error in the list highlights the location of the error on the model. AUTO-DIFF
automatically builds the report after the comparison has been done. If you are only
interested in seeing the results (no report), you can abort report building by pressing Stop
(red VCR button) after you see the message "Creating AUTO-DIFF report".
Select any column heading to sort the report by the entries in that column.
Close—Closes the AUTO-DIFF window-does not apply window changes.

881
AUTO-DIFF, Settings tab
Location: Analysis menu > AUTO-DIFF

VERICUT toolbar short cut:

Features on this tab control the AUTO-DIFF comparison, and what you see as a result.
You can compare four types of design data with AUTO-DIFF: solid models, surface data,
inspection points and profiles. The Comparison Method controls which type of design
data is compared, while Comparison Type determines the error condition checked for.
Comparison Tolerance features set the inspection tolerances and the display colors used
for identified gouge/excess errors. The appearance of the Comparison Tolerance portion
od the Settings tab will vary depending on the Comparison Method Setting.

882
Stock Component — When multiple Stock components are defined, this option controls
which one is used in the comparison. The Design component used in the comparison is
that which is connected to, or connected to the same component as the chosen Stock
component.
Stock Display— When selected, displays the stock model in the AUTO-DIFF view.
Options are provided to display these models as Solid, Translucent, or Lines. The
available options will vary depending on the Comparison Method that is selected.
Design Display — Similar to Stock Display above, except applies to design model(s).
Comparison Method — Controls the method of comparing design model data against
the VERICUT model. The comparison method also re-configures the Settings tab to
reflect the tolerances and other data required to compare the data as requested. All
methods generate an AUTO-DIFF model that can be analyzed or saved as an In Process
file. Regardless of the method chosen, the design model must first be loaded prior to
comparison (ref. Modeling window: Model tab). Design models can be loaded at any
time. Options:
Solid — Compare a solid design model by subtracting solid models from each
other. (See how / See example) Solid models must be "watertight"-in other words,
completely enclosed surfaces.
You can check solid design model integrity by loading it as a stock model, then
select Analysis menu > X-Caliper window: Volume tab to analyze the volume of
the stock model. After checking the volume, the following problems indicate the
design model needs repair, or is suitable only for the Surface comparison method:
- small holes or gaps appear in the model
- model falls apart-is partially displayed
- model disappears completely
Surface — Compare a surface, set of surfaces, or skin of a solid design model or
VERICUT Solid by overlaying the surface on the cut model. (See how / See
example) VERICUT only compares where the design surface and cut model
overlap. Surface comparison provides multiple colors and tolerances that produce a
"rainbow" affect to show the extent of errors.
NOTE: VERICUT Solids can only be used for Standard (not FastMill)
cutting mode.
Point — Compare a set of design inspection points by overlaying the points on the
cut model. (See how / See example) VERICUT searches from each point for an
intersection with the model surface. Surface normal vectors control the direction in
which to search. Only points associated with errors are seen in the results. Points
associated with gouges have the Error color-typically Red, while points associated
with excess material have the 5th defined color in the Shade Color list (typically
Magenta).
Profile— Enables you to compare the turning profile of the cut stock with profile
of a design model. (See how / See example)
When Comparison Method is set to Profile, up to four profiles (Gouge, Excess,
Stock, Design) may be displayed in the "Profile" view. Each can be displayed in
one of two modes: Solid or Lines. The display mode for Stock and Design profiles

883
is specified using the Design Display / Stock Display features. The display mode
for Gouge and Excess is specified using the Draw Mode option in the View
Attributes window for the currently active "Profile" view.
When display mode is set to "Solid", Stock and Design profiles are displayed the
"component" color unless the "model" color is different than the "component"
color. In this case, Stock and Design profiles are displayed the color of the 1st
model. Gouge and Excess profiles are displayed in the color selected with the
Comparison Tolerance "color" feature.
When display mode is set to "Lines", the same color scheme described above is
used for "uncut" sections of the profile. "Cut" sections of the profile are displayed
in the "cut" color.
X-Caliper can be used to analyze any of the profiles ( Gouge, Excess, Design, and
Stock profiles) currently displayed in a "Profile" view. Saving an In-Process file
(IP file) stores all four profile types.
Any valid VERICUT model type can be used as a design model for an AUTO-
DIFF Profile comparison. The design profile which is compared to stock profile is
a Boolean union of the individual profiles of all Design Component models
associated with specified Stock.
If a design model is a Cone, Cylinder, SOR, or IGES Profile, and its Z-axis is
aligned with the turning axis, its profile is built directly from its definition profile
and is "exact". In all other cases, the profile is built by spinning the model about the
turning axis (as is common with other turning applications) and is an
approximation. The smaller the Cut Tolerance that is used, the better the
approximation. If the "design component" consists of multiple models, the
individual model profiles are merged into one design profile.
Comparison Type — Controls the error type(s) checked for by the AUTO-DIFF
operation. Options: Gouge, Excess, or Both.

Comparison Tolerance Features


Comparison Tolerance features are used to specify the tolerances and colors used by
AUTO-DIFF. The degree to which VERICUT can detect discrepancies is also affected by
Cutting Tolerance. For best results set cutting tolerance smaller than the smallest
tolerances used by AUTO-DIFF.
Comparison Tolerance features displayed will vary depending the on the Comparison
Method and Comparison Type settings.

884
Solid comparison tolerances

Gouge — Tolerance used when checking for gouges during a Solid


comparison. Gouges detected by AUTO-DIFF are shaded in the associated
gouge color.
Excess — Similar to Gouge above, except applies when checking for excess
material.

NOTE: "Solid" Gouge/Excess tolerance/color values are independent of


"Profile" Gouge/Excess tolerance/color values and are stored as separate
values in .VcProject file.

Surface comparison tolerances

885
Gouge Range/Color list—Range of tolerances used when checking for
gouges during a Surface comparison. Multiple tolerance values can be listed
in addition to the "Gouge Check Distance" used to limit checking. If more
than six tolerance values are listed, a scroll bar will be added to the table.
Each pair of tolerance values represents a range of gouge depths to which
the gouge color (of the lower tolerance value) will be applied. Use the Add
and Delete buttons to add/remove tolerance values.
The AUTO-DIFF model is first shaded using the "Base color" (top color in
the list associated with the "Gouge Check Distance" - see the illustration
below), then gouges detected by AUTO-DIFF are shaded in the gouge
color(s) associated with the depth of the gouge.
Excess Range/Color list—Similar to Gouge Range/Color list above, except
applies when checking for excess material.

Minimum Excess — This feature enables you to specify a value and color to
be used to represent an offset from the design surface. The Minimum Excess
value is applied to the design surface in all directions. During the compare,
any Excess value less than the Minimum Excess value is considered to be a
gouge and displayed the Minimum Excess color. Excess material is measured
from the Minimum Excess to the Range value (see below)

886
.

NOTE: The amount of gouge and excess reported is with respect to the
offset design, not the original design. In other words, zero deviation is where
the cut stock excess with respect to the original design exactly equals to the
given "Minimum Excess" value. This also is where the Excess color table
range starts from.
While in this mode, AUTO_DIFF > Report shows both gouges and excesses
with respect to the condition described above. If a cut produces both a gouge
and an excess, AUTO-DIFF reports the gouge (no matter what the value of
the excess). This is different from the Report behavior when "Comparison
Type" = "Both" where the biggest deviation would be reported.

Point comparison tolerances

Gouge Tolerance — Tolerance used when checking for gouges during a


Point comparison. Gouges detected by AUTO-DIFF are shaded in the gouge
color specified for a Solid comparison.

887
Excess Tolerance — Similar to Gouge above, except applies when checking
for excess material conditions.
Gouge Check Distance — Maximum distance to check for the cut model
surface in the gouge direction. Distance is measured from the inspection
point along direction of the normal vector used with the inspection point.
Excess Check Distance — Similar to Gouge Check Distance above, except
applies when checking for excess material.
Default Normal (IJK) — Default normal vector in which to check during a
Point comparison when vector data is not present in the Design Points file.
Enter three values separated by spaces, for example "0 0 1".
Normal Direction — Indicates if surface normal vectors associated with
design points are pointing outward (Out) or inward (In) relative to the design
model.

Profile comparison tolerances

The Profile comparison tolerances are applied "exactly", without tessellating the
stock and/or design profiles. An arc offset by the tolerance value, will also be an
arc and will be recognized by X-Caliper as such. The Profile Gouge/Excess
tolerance values are independent of the Solid Gouge/Excess tolerance values
described above, and are stored as separate values in .VcProject file.
Gouge — Tolerance used when checking for gouges during a Profile
comparison. Gouges detected by AUTO-DIFF are shaded in the associated
gouge color.
Excess — Similar to Gouge above, except applies when checking for excess
material.
NOTE: "Profile" Gouge/Excess tolerance/color values are independent
of "Solid" Gouge/Excess tolerance/color values and are stored as
separate values in .VcProject file.

888
AUTO-DIFF window, Options tab
Location: Analysis menu > AUTO-DIFF

VERICUT toolbar short cut:

The features on this tab are used to set processing and reporting options.

Design Consistency Check—When selected during a "Solid" comparison, checks


consistency of solid design models, including: check for "watertight" solid- repair
improperly trimmed surfaces (overlaps and gaps), and reconstruct insignificant missing
surfaces. This option is highly recommended for design models creating from importing
IGES data, and other model files which produce unsatisfactory results from the
comparison.
When selected during a "Profile" comparison, Design Consistency Check is applicable
when building a profile from an STL, VERICUT Polygon, or VERICUT Solid design
model.

889
While checking design model consistency can take a while, it provides the best insurance
for reliable AUTO-DIFF results. If you've used the model in VERICUT before and know
the quality is good enough, you can save time by clearing this checkbox. AUTO-DIFF
will take less time, but results may not be reliable if the solid is not water-tight.

Keep Design Solid— When selected, keeps the solid design model created by AUTO-
DIFF so it can be used in additional comparisons. This action can reduce AUTO-DIFF
time if multiple comparisons are made, but requires additional computer resources to
keep the design solid. The design solid is kept until the VERICUT model is reset, a
design model is removed or deleted, or the checkbox is cleared and Apply is pressed.
Saving an IP file also contains the kept design solid. Clear this checkbox to have AUTO-
DIFF create a new design solid for each comparison.

Disable Report— Enables you to turn off the AUTO-DIFF Report feature to reduce
AUTO-DIFF processing time. To generate the report, the processor must search through
all cut records and lists the maximum error for each bad cut record. This can take a
significant amount of time for large toolpath files. When is toggled "on", you will still see
the AUTO-DIFF results in the graphic area. Disable Report is only active when
Comparison Method is set to Solid, Surface or Profile.

Report Uncut Differences — When selected, differences between the design and uncut
stock are added to the AUTO-DIFF report.

Show Point Vectors — Displays the measurement vector associated with each point for
the "Point" Comparison Method. The Vector is drawn whether AUTO-DIFF compare is
active or not.

Save AUTO-DIFF Model— Use to save gouge or excess data as a VERICUT solid
model file (.vct). Selecting Save AUTO-DIFF Model displays a dialog enabling you to
specify a directory path and filename for the model file. If both gouge and excess models
are present, two files will be created ( gouge_filename.vct and excess_filename.vct,
where filename is the filename you entered in the Save AUTO-DIFF Model dialog.
This option is only available for use if all of the following are true (otherwise it is grayed
out):
1. Standard Cut Mode is active (not FastMill).
2. Constant Gouge Check is turned off.
3. AUTO_DIFF Comparison Method is set to Solid or Profile.
4. AUTO-DIFF Compare has been processed.

890
AUTO_DIFF window, Compare By Region
tab
Location: Analysis menu > AUTO-DIFF

VERICUT toolbar short cut:

The features on this tab enable you to select a region to perform AUTO-DIFF on.
Compare By Region is created for very large parts that would require too much memory
for AUTO-DIFF to process the entire part. Optionally, cut stock can be internally re-cut
within the region with a better Cut Tolerance before doing AUTO-DIFF. The Compare
By Region tab is not available when Comparison Method is set to "Profile".

891
On — When selected, activates the Compare by Region feature. When on, AUTO-DIFF
comparison only processes the cut stock and design volumes within the specified
"region".

Apply Regions Over Entire Stock — The check box, Apply Regions Over Entire Stock,
does the following:
y Calculates a region that can achieve the specified Comparison Tolerance within
the computer’s physical memory.
y Re-processes that region of the cut stock at a tolerance that ensures the
Comparison Tolerance can be achieved.
y Does the specified AUTO-DIFF comparison for the region.
y Repositions the region and does AUTO-DIFF multiple times over the entire cut
stock.
During AUTO-DIFF processing, the Region Box is displayed at each position over the
cut stock.
When Compare is pressed and this box is checked, a notice dialogue is displayed with the
text, “Processing may take several minutes depending on tolerance, size of the cut stock,
memory and processor speed. Press the stop button in the main window to cancel AUTO-
DIFF.”, OK.
When the Apply Regions Over Entire Stock feature is active, the Region Size features are
disabled.

Improve Cut Stock Tolerance — When selected, the Cut Stock is re-evaluated at a new
tolerance based on the specified minimum AUTO-DIFF tolerance. Having this box
checked affects the results from both the Fit to Memory and the Apply Regions Over
Entire Stock features. Typically the Comparison Tolerance is smaller than the Cut
Tolerance, so processing will take longer when Improve Cut Stock Tolerance is active.

Region Size features

Show Region Box — Click on the icon to show / not show the "region box",
representing the AUTO-DIFF comparison region, in the Workpiece View.

Minimum XYZ — Use to enter the minimum X, Y, and Z values (relative to the
workpiece coordinate system), separated by spaces. These values represent the X,
Y, Z coordinates of first corner point of the "region box".

Maximum XYZ — Use to enter the maximum X, Y, and Z values (relative to the
workpiece coordinate system), separated by spaces. These values represent the X,
Y, Z coordinates of the diagonal corner point of the "region box".

892
Maximize to Stock — Use to size the "region box" to the maximum extent of the
union of the stock and design volumes.

Fit to Box — Use to drag a 2 dimensional rectangle (similar to a "zoom" box) over
the cut stock. The rectangle is projected into 3 dimensional space to define the
"region box".

Drag Region — Enables you to grab a corner of the "region box" and drag it to re-
size the "region box". The new corner location is automatically projected onto the
cut stock in 3 dimensional space. Grab the mid-point of one of the "region box"
edges to re-size the "region box" by dragging a face. Click with the mouse pointer
in the point representing the center of the "region box" and drag around the Cut
Stock to reposition the "region box" without resizing it.

Fit to Memory — Use to automatically size the "region box" based on the
available memory for AUTO-DIFF. A short delay occurs while memory is
analyzed.

893
AUTO-DIFF window, Constant Gouge Check
tab
Location: Analysis menu > AUTO-DIFF

VERICUT toolbar short cut:

Enables you to specify a gouge check tolerance, and turn Constant Gouge Check on and
off. Gouge areas found by Constant Gouge Check during NC Program processing are
displayed in the assigned Error color. (See how).

894
On — Toggles Constant Gouge Check on and off.
Toggle Constant Gouge Check on/off to activate/deactivate Constant Gouge Check
during toolpath processing.

NOTES:
A design model must be present in the component tree for Constant
Gouge Check to detect potential gouges.
Constant Gouge Check is not compatible with FastMill. When cutting in
FastMill mode, use one of the AUTO-DIFF comparison methods
instead.
AUTO-DIFF and Constant Gouge Check are mutually exclusive. To use
the AUTO-DIFF features Constant Gouge Check must be turned
"off". If you are using AUTO-DIFF, you must click the Restore
button before you will be able to turn Constant Gouge Check "on".

Tolerance — Specify a tolerance value for Constant Gouge Check. Only gouges
greater than the specified tolerance will be displayed. You can turn Constant Gouge
Check "off", change the tolerance and re-process the toolpath at any time.

NOTE: A VERICUT Solid (.vct) file can be used for a design model when
using Constant Gouge Check to find gouges during NC Program processing.

895
AUTO-DIFF "Point" method example

896
AUTO-DIFF "Profile" method example

897
AUTO-DIFF "Solid" method example

898
AUTO-DIFF "Surface" method example

899
Comparator

VERICUT Users:
VERICUT Location: Analysis menu > Comparator

VERICUT toolbar short cut:

Cutter Grinder Users:


Cutter Grinder Location: Analyze, View Files, Print page > Comparator Grid

Notebook Feature:

Opens the Optical Comparator window enabling you to overlay a polar or rectangular
grid over a workpiece or machine view to emulate an optical comparator chart. (See how)
(See example) Use this feature to measure distance and angular relationships of features
on your part like you would with optical comparator.

900
The grid can be displayed in any view but only in one view at a time. The grid is always
displayed in the "active" view. The grid is always displayed parallel to the screen and its
center (0,0) position is related to the origin of either the workpiece coordinate system or
the machine coordinate system depending on the type of view that is active.

The grid will be displayed as long as the Optical Comparator window is open. Closing
the Optical Comparator window removes the grid from the display.

Full Polar — Displays a full polar grid .

Polar Grid With Linear Quadrant — Displays a polar grid with one
linear grid quadrant.

Half Polar / Half Linear — Displays a grid that is half polar and half
linear.

Linear Grid With Polar Quadrant — Displays a linear grid with one
polar quadrant.

Full Linear — Displays a full linear grid.

Color Pallet — Select a color from the pallet for the optical comparator
grid. The default color is VERICUT's Foreground color. Click on the x in the
upper right corner of the color pallet close it.

Use the following options to specify the size and position of the grid as well as define the
spacing between major and minor grid lines. Units are the same as the workpiece or
machine depending on the type of view that is "active".

Radius— Specify the radius of the grid that you want to display.

Center X—Specify the horizontal position of the center of the grid. Enter a value in the
text field . A negative number moves the center of the grid the specified number of units
to the left of the coordinate system origin. A positive number moves the grid to the right.
You can also move the horizontal position of the grid center by selecting one of the arrow
buttons. Selecting either the < or > button moves the center of the grid to the left or right
of its current position by the value specified for Minor Linear Spacing. Selecting either
the < < or >> button moves the center of the grid to the left or right of its current
position by the value specified for Major Linear Spacing.

Center Y— Specify the vertical position of the center of the grid. Enter a value in the
text field . A negative number moves the center of the grid the specified number of units
down from the coordinate system origin. A positive number moves the grid up.
You can also move the vertical position of the grid center by selecting one of the arrow

901
buttons. Selecting either the < or > button moves the center of the grid down or up from
its current position by the value specified for Minor Linear Spacing. Selecting either the
< < or >> button moves the center of the grid down or up from its current position by
the value specified for Major Linear Spacing.

CCW Rotation— Use to rotate the grid about its center point. Enter an angle value in the
text field. A positive number rotates the grid the specified number of degrees in a
counterclockwise direction from its default (zero)position. A negative number rotates the
grid the specified number of degrees in a clockwise direction from its default (zero)
position.
You can also rotate the grid about its center by selecting one of the arrow buttons.
Selecting either the < or > button rotates the grid clockwise or counterclockwise from
its current position by the value specified for Minor Angular Spacing. Selecting either
the << or >> button rotates the grid clockwise or counterclockwise from its current
position by the value specified for Major Angular Spacing.

Major Angular Spacing— Specify the number of degrees between the "major" grid
lines of a polar grid.

Minor Angular Spacing— Specify the number of degrees between the "minor" grid
lines of a polar grid.

Major Linear Spacing— Specify the distance between "major" grid lines of a linear
grid.

Minor Linear Spacing— Specify the distance between "minor." grid lines of a linear
grid.

Magnification— Use this option to quickly change the size of the grid by either a factor
of 2 or a factor of 10. Selecting either the < or > button reduces or enlarges the size of
the grid by a factor of 2. Selecting either the < < or >> button reduces or enlarges the
size of the grid by a factor of 10.

Snap to— Use this option to center the grid on a specific feature of the workpiece or
machine. Click on the text field so that it is highlighted. Select a feature in the graphics
area and the grid center will move to that location. You can also enter the X, Y, and Z
coordinates of the workpiece/machine coordinate system in the text field. Selecting the
Snap to button (or Enter on the keyboard) moves the grid to the specified location.

OK— Saves the current settings and dismisses the Optical Comparator window.
Apply— Applies all of the current settings to the displayed grid without dismissing the
Optical Comparator window. You can also use the Enter key after changing an individual
setting to immediately apply the change to the current grid display.
Cancel— Dismisses the Optical Comparator window without saving the settings.

902
NC Program Review
The MC Program Review feature enables you to quickly and easily view, replay and edit
a previously processed NC program (toolpath). (See how) NC Program Review can be
accessed at any point in the verification process. It does not interrupt the current
verification status, so reset or rewind of the NC program is not necessary.

Location: Analysis > NC Program Review

VERICUT toolbar short cut:

Opens the NC Program Review window enabling you to review and manually edit the
NC program.

NOTE: The following conditions must be met before a NC program can be


viewed with NC Program Review.
1. The NC program must be processed far enough in VERICUT so that a
tool has been loaded and at least one tool motion has been processed
after the tool is loaded.
2. There must be a model attached to the first "Stock" type component in
the Component Tree.
3. The first "Stock" type component must be visible in a workpiece view.
4.

903
The NC Program Review main window is composed of three distinct areas, each with
different user interaction. The window header displays the current NC program file. This
window can be moved and resized like most other windows, via dragging the window
header, sides or corners. In addition, the size of the NC Program Listing, Error Listing,
and Graphics areas can be changed within the main window by dragging the adjoining
sides of each area.
NC Program Review enables you to quickly and easily associate the NC program record,
the motion resulting from it, and any errors that may be associated with it. The three areas
of the window are linked together so that if you select a NC program record in the listing,
the tool moves to the corresponding location in the graphics area. If you select a location
in the graphics area, the corresponding NC program record is highlighted in the NC
program listing. If you select an error in the error listing, the NC program record that
caused the error becomes highlighted in the NC program listing and the tool moves to the
position where the error occurred in the graphics area.

NC Program Listing — This area displays a listing of the NC program (toolpath)


records. In this area you can manually edit, add, or delete NC program records. Save the
modified NC program file or open another NC program file associated with the current
project file. You can also set Start and End markers to define the range of NC
programrecords that you want to review. For more information about this portion of the
NC Program Review window, click on the NC program Listing heading above.
Error Listing — This area displays a list of the errors that VERICUT found while
processing the toolpath. For more information about this portion of the NC Program
Review window, click on the Error Listing heading above.
Graphics Area — This area displays a visual representation of the motion associated
with the records in the NC Program Listing. Here you can control how the tool is
displayed, the method and direction of the replayed NC program as well as the speed of
the replay. For more information about this portion of the NC Program Review window,
click on the Graphics Area heading above.

904
NC Program Listing area
The NC Program Listing area is located in the upper left portion of the Toolpath Review
window.

Main Menu:

The menu located across the top of the Toolpath Review window provide easy access to
major Toolpath Review functions. Each menu contains groups of related functions. Left-
click on any menu name to display the list of functions in that menu. Click on the
function in the menu you want to use. The name of the current toolpath file is also
displayed in this area.

File:
Save As— Save the current toolpath file under a different name.
Close— Close the Toolpath Review window

905
Edit:
Cut— Cuts the highlighted text in the toolpath listing and puts it in the paste buffer.
Copy— Copies the highlighted text in the toolpath listing to the paste buffer.
Paste— Puts the contents of the paste buffer at the location of the cursor in the toolpath
listing.
Settings:
Set Start— Sets the "Start" marker to the position specified by the cursor in the toolpath
listing or picking a location in the Graphics Area.
Set Current— Sets the "Current " marker to the position specified either by the cursor in
the toolpath listing or picking a location in the Graphics Area.
Set End— Sets the "End" marker to the position specified by the cursor in the toolpath
listing or picking a location in the Graphics Area.
Display to Box— Enables you to set "Start", "Current" and "End" markers by creating a
box around the area of interest in the graphics area. Click on Display to Box, then left
click in the Graphics Area and drag the cursor to create a box around the area of interest.
The "Start" marker will be set to the lowest record number contained within the boxed
area and the "Current" and "End" markers will be set to the highest record number
contained within the "boxed" area.
Cut Line— Displays a color pallet enabling you to specify a color for "cutting" portions
of the toolpath display in the Graphics Area.
Non-Cut Line— Displays a color pallet enabling you to specify a color for "non-cutting"
portions of the toolpath display in the Graphics Area.
Current Line— Displays a color pallet enabling you to specify a color for "current"
motion of the toolpath display in the Graphics Area.
Goto Start— Moves the cursor in the toolpath listing and positions the cutter in the
Graphics area to the position indicated by the "Start" marker.
Goto Current— Moves the cursor in the toolpath listing and positions the cutter in the
Graphics area to the position indicated by the "Current" marker.
Goto End— Moves the cursor in the toolpath listing and positions the cutter in the
Graphics area to the position indicated by the "End" marker.
Shortcut: You can also access the Settings menu by using the right mouse button in
either the Toolpath Listing area or in the Graphics Area.

Icon Bar:

The items in the Icon Bar enable you to search for specific items in the toolpath listing,
print the toolpath listing, or exit Toolpath Review. Moving the cursor over the icon will
display name of the option.
Line Number or Search Text— Use to enter a line number or a string of text to search
for.
Goto Line Number— Moves the cursor in the toolpath listing to the line number
specified in the Line Number or Search Text field.
Search Forward— Searches forward in the toolpath listing for the text string specified
in the Line Number or Search Text field.

906
Search Backward— Searches backward in the toolpath listing for the text string
specified in the Line Number or Search Text field.
Replacement Text— Use to enter a "replacement text" string.
Replace One— Replace one occurrence of text string in the Line Number or Search
Text field (or the highlighted text in the toolpath listing) with the text string in the
Replacement Text field.
Replace All—Replace all occurrences of the text string in the Line Number or Search
Text field with the text string in the Replacement Text field.
Print— Prints the toolpath listing.
Close Window— Closes the Toolpath Review window.

Toolpath Listing:
Toolpath Editing
The toolpath listing area allows you to edit the toolpath with a full function text editor.
You can use the keyboard to add, change, delete portions of the toolpath listing. You can
also use the Cut, Copy and Paste functions found under Edit in the main menu.
You can easily see the modifications that you have made to the toolpath listing. Added,
changed, and pasted text is displayed in blue and underlined. Cut and deleted text is
displayed in red with a "strike through" font. Once you save the modified toolpath, the
red and deleted text is removed and the blue added, changed, and pasted text is returned
to the original font.

Start/Current/End Markers
The Start/Current/End markers can be found along the left side of the Toolpath
Listing area. The Start marker is represented by the green triangle, the Current
marker is represented by the aquamarine arrow and the End marker is represented
by the red square. You can easily identify each marker by moving the cursor over
it.
The Start and End markers are used to define the range of toolpath records that
will be replayed when using Play to End. The Current marker moves to the
toolpath record that is currently being replayed. Set these markers by either
selecting a toolpath record in the toolpath listing or the location in the graphics area
where you want the marker placed. Then select the appropriate option (Set Start,
Set Current, Set End) from the menu displayed when using the right mouse
button in either the graphics area to the toolpath listing. The menu can also be
found under Settings in the Review Toolpath main window. You can also click on
the marker in the toolpath listing and drag it to the desired toolpath record.
The line number of the "current" record is displayed in the lower left corner of the
Toolpath Listing area.
If the user file contains more than one toolpath file, the name of the displayed
toolpath file is displayed in the lower right corner of the Toolpath Listing area.
Clicking on the button to the right of the toolpath file name displays a list of the
toolpath files contained in the user file. Click on a file name in the list to change the
toolpath displayed Toolpath Listing area.

907
NC Program Review, Error Listing area
The Error Listing area is located in the lower left portion of the Toolpath Review
window. It contains a list of the errors that were found while processing the toolpath in
VERICUT.

Selecting an error in the Error Listing causes the line in the Toolpath Listing associated
with the error to become highlighted. At the same the tool display in the Graphics Area
moves to the position where the error occurred. This enables you to quickly and easily
associate the error with the position in the toolpath.

908
NC Program Review, Graphics Area
The Graphics area is located in the right portion of the Toolpath Review window.

The graphics area displays the active workpiece view from the VERICUT main graphics
area. Also, the analysis tools found under Analysis-->X-Caliper in the VERICUT main
menu are available for use while you are in the Toolpath Review graphics area.

View Manipulation Icons:

The view manipulation icons and the X-Caliper icon perform the same function as
those found in the VERICUT toolbar. For more information on these features, see
View menu > Toolbar.

909
The Toolpath Display:
As the toolpath is replayed, a line representing the motion of the tool control point
is displayed in the graphics area. Motions that remove material are displayed as
solid lines with a default color of the foreground color. Motions that do not remove
material are displayed as dashed lines with a default color of magenta. The line
representing the motion of the current toolpath record is highlighted with a default
color of red. The tool image is displayed at the location of the current toolpath
record.
The color of the lines can be changed using the Cut Line, Non-Cut line and
Current Line options found in the menu that is displayed when using the right
mouse button in the graphics area or the toolpath listing area, or found under
Settings in the Toolpath Review main window.

Graphics Area Controls:


The current tool (tool id or APT description) and the X, Y, Z, I, J, K of the current tool
tip position are displayed in the upper right corner of this area.

Tool Display— Use to specify how the tool is displayed during the toolpath replay.
Choose Off (do not display the tool), Solid (a shaded solid) or Translucent.

Line Display— Use to specify whether or not to display the lines representing the path of
the tool end points. Choose On (display the path), Off (do not display the path).

Animation Speed Slider— Controls the speed of the toolpath replay. Move to the left to
slow down the replay of the toolpath. Move to the right to speed it up.

Simulation (VCR) Controls— The simulation controls, also known as VCR buttons,
located at the bottom-right corner of the Graphics area control interactive tool path
replay. Use these controls to start and stop the replay of the toolpath. To see what action
is associated with a Simulation control icon, simply position the cursor over the icon and
a tip appears.

Icon: Name: Function:


Play to End Replays from the Current
position to the End position.
Step Forward Replays the next toolpath
record (“single block”).
Stop Stop the replay during "Play"
(after the current record
displays)
Step Back Replays the previous
toolpath record (“single
block”).

910
Rewind Sets the Current marker to
the record with the Start
marker and clears the
toolpath display from the
Graphics area.
Reset Sets the Start and Current
markers to the first motion
record in the toolpath, sets
the End marker to the last
toolpath motion record, and
clears the toolpath display
from the Graphics area.

911
Inspection

Introduction to VERICUT Inspection


The VERICUT Inspection module, is a licensed option to VERICUT that provides the
tools enabling you to quickly and easily specify critical inspection data, then use it to
create a fully customizable inspection report.
Inspection Sequence is used to define and document inspection operations critical to the
integrity of the part. Inspection can be used to document critical dimensions to be
checked while the part is still on the machine, at various times in the machining process,
to detect and correct errors on the "in process" part so that time is not wasted on
subsequent machining operations on a part that is already out of tolerance (see example).
Inspection can also be used to define and document final inspection procedures on the
finished part.
As you use Inspection to define inspection operations, an inspectionfile (.vcinspect) is
created containing the two elements essential to creating the actual inspection report. The
first is a picture showing the features that are to be inspected, the second is a table
containing the inspection data related to each of these features. Samples of these two
elements are shown below.
Sample Inspection File Picture

Sample Inspection File Table

912
File Organization
An inspection sequence file retains all the information needed to reproduce the inspection
data table and the corresponding inspection markers on the workpiece for a single report.
The inspection sequence file is not the report itself. Once the inspection sequence file has
been created, the Inspection Report is created using the same report generation
mechanism used with the rest of VERICUT.
A report is created on demand and will typically have the extension ".htm" or ".pdf".
Unless you explicitly specify a file name when you first save an inspection sequence, the
inspection sequence file name will default to user file name, with its extension changed to
".vcinspect". If there will be several inspection sequences for a part, it is suggested that
you adjust the file names to include suffixes "1", "2", ... or "A", "B", ... or perhaps tool
identifiers.
When you request that a report be created, the report file name will be the same as the
inspection sequence file name, with the extension changed to ".htm" or ".pdf". For a PDF
file, any pictures required in the report will be embedded, which makes it trivial to pass
the report around electronically. For an HTML file, the pictures are generated as separate
GIF and JPEG files, making it more difficult to keep all the pieces together, unless you
place all inspection files and reports for a part in their own folder, perhaps named using
the part's identifier.
VERICUT reports are based on report template files, which are fully customizable. You
can either create the Inspection Report using the sample Inspection Report template
provided, or use a custom one that you have created. For more information on VERICUT
report templates and report creation, see Introduction to VERICUT Reports.

913
Inspection
The Inspection Sequence feature enables you to quickly and easily create and document
critical inspection points associated with the current user file. (See How)

Location: Analysis > Inspection

VERICUT toolbar short cut:

Opens the Inspection Sequence window enabling you to create/edit an inspection


sequence (.vcinspect) file and use it create inspection reports based on its content.

The Menu Bar:

The menu located across the top of the Inspection Sequence window provides easy access
to major Inspection Sequence functions. Each menu contains groups of related functions.
Left-click on any menu name to display the list of functions in that menu. Click on the
function in the menu you want to use.

File:
New — Start a new Inspection Sequence file.

Open — Open an existing Inspection Sequence file. Such files typically have
the extension ".VcInspect". Note that you can also open one of the ten most
recently accessed files more directly by selecting from the Recent Files list.

914
Save — Save the current inspection sequence file. You may be prompted to
select a file name if the current sequence was not derived from an existing
file.

Save As — Save the current Inspection Sequence file under a different name.

Create Report — Use to create an inspection sequence report (See How).


Choose one of the following formats:
Text — Create an inspection sequence report in text format.
HTML — Create an inspection sequence report in HTML format.
PDF — Create an inspection sequence report in PDF format.

NOTE: The picture used in the inspection report is the from the "active"
window.

Report Template — Displays the Report Template window enabling you to


select and/or modify an existing report template or create a new one.

User-Defined Tag Values — Opens the User-Defined Tags window


enabling you to assign/edit user-defined tag values used by the current
inspection sequence report template.

Rotate Picture CCW — When toggled "On", the Inspection Sequence


picture is rotated 90 degrees counterclockwise when it is used in the
Inspection Sequence report.

Recent Files — Provides a list of recently opened files. To open a file in the
list, select the desired file.

Exit — Closes the Inspection Sequence window.

Analysis:
Feature Identifier — Displays the Feature Identifier window to assist you in
locating critical part features that you want included in the inspection table.
(see window features)

Edit:
NOTE: All of the following inspection features are selected in the active
workpiece view.

Insert Wall Thickness Row — Inserts a wall thickness inspection


record to the Inspection Sequence table. You will be prompted to pick the
wall feature.

915
Insert Floor Thickness Row — Inserts a floor thickness inspection
record to the Inspection Sequence table. You will be prompted to pick the
floor feature.

Insert Hole Diameter Row — Inserts a hole diameter inspection


record to the Inspection Sequence table. You will be prompted to pick the
hole feature.

Insert Datum Plane Row — Inserts a datum plane inspection record


to the Inspection Sequence table. You will be prompted to pick the plane
feature to be used as the datum.

Insert Distance Row — Inserts a distance (from a datum plane)


inspection record to the Inspection Sequence table. You will be prompted to
pick the relevant feature. Use of this type of measurement requires a datum
plane.

Insert Angle Row — Inserts an angle ( between a selected plane and


the datum plane) inspection record to the Inspection Sequence table. The
"angle" feature can be used without a datum plane if it is obvious which
angle is to be measured.

Insert Position Rows — Inserts two or three rows in the table for the
coordinates of a position. You could use this type of feature to specify the
location of the center of a hole, relative to the currently active coordinate
system. You will be prompted to pick the hole in the active workpiece view.

Insert Hole Depth Row — Inserts a hole depth inspection record to the
Inspection Sequence table. You will be prompted to pick the hole feature.

Insert Radius Row — Inserts a radius inspection record to the


Inspection Sequence table. You will be prompted to pick the hole or cylinder
feature.

Insert Surface Finish Row — Inserts a surface finish inspection record


to the Inspection Sequence table. You will be prompted to pick the surface
feature.

916
Insert Note Row — Inserts a row in the table for a tabulated note. You
will be prompted to pick a reference location for the note.

Modify Marker Location — Reposition the highlighted feature's


inspection point marker in the active workpiece view.

Restore Default Tolerance — Restores the highlighted tolerance to its


default value.

Edit Geometric Tolerance — Opens the Geometric Tolerance window


enabling you to add geometric tolerance specifications to the Inspection
Sequence Table. (see window features)

Delete Row — Deletes the highlighted inspection record from the


Inspection Sequence table.

Refresh —

Shortcut: You can also access the Edit menu options by selecting the appropriate
icon from the Icon Bar, or by using the right mouse button in the Inspection
Sequence table and selecting from the menu that displays.

Program:

Use probe for selected feature — Changes the measuring instrument


in the currently selected (highlighted) row to "Probe".

Use probe for all features — Changes the measuring instrument in all
rows to "Probe". Typically this would be used just before the next icon.

Program probe cycles — Causes the Inspection Programming window


to be displayed, and transfers any features that have "Probe" as their
measuring instrument, to the Inspection Programming window.

Shortcut: You can also access the Program menu options by selecting the
appropriate icon from the Icon Bar or by using the right mouse button in the
Inspection Sequence table and selecting from the menu that displays.

917
Icon Bar:
The items in the Icon Bar provide quick access to the most frequently used features
described above.

New File Open File Save File


From File menu

Feature Identifier
From Analysis menu

Insert Wall Insert Floor Insert Hole Insert Datum Insert Insert Angle Insert
Thickness Thickness Diameter Plane Row Distance Row Position
Row Row Row Row Rows
From Edit menu

Insert Hole Insert Radius Insert Surface Insert Note Modify


Depth Row Row Finish Row Row Marker
Location
From Edit menu

Use probe for selected Use probe for all Program probe cycles Delete Row
feature features
From Program menu From Edit menu

Export HTML (Create Export PDF (Create Report>PDF) Close Window (Exit)
Report>HTML)
From File menu

918
Inspection Sequence Table:

Each record in the table consists of eight columns of information. The first five
columns are automatically entered by VERICUT when the record is created. Click
on any column in a row to highlight a record for editing. The order of the records in
the table can be changed by clicking on the square button at the beginning of the
record and dragging the record to the desired position. Each record in the table
consists of the following information:

Symbol — Represents the inspection record type. This column is automatically


updated when Feature, below, is edited.

Feature — Indicates the record type. With the record highlighted, click on the
record "feature" field and select the feature type from the pull-down list (Wall
Thickness, Floor Thickness, Hole Diameter, Distance, Angle, Position, Hole
Depth, Radius, Surface Finish).
You can also enter the name of a different feature type that has not already been
included. If you do so, there will be no corresponding symbol in the first column.

Identifier — Indicates the inspection record's unique identifier. VERICUT will


automatically generate a feature identifier.
If the first feature inserted in a table does not require a datum plane, its identifier
will be "A1". The next will be "A2", then "A3", etcetera. If you were to edit the last
one in this sequence, making it "B1", then subsequently appended rows would
continue the new sequence, with "B2", "B3", etcetera. If you then inserted a row
after the last "A" feature, its identifier would continue the "A" sequence.
With the record highlighted, double click on the identifier field of a record to edit
the identifier text.

Instrument — Indicates the inspection instrument to be used to measure the


inspection feature. VERICUT will initially show a suitable instrument type, such as
"Ultrasonic" for a floor thickness or "Snap Caliper" for a wall thickness, but can be
changed as follows.
With the record highlighted, click on the record "instrument" field and select the

919
instrument type from the pull-down list (Snap Caliper, Ultrasonic, Plug Gage,
Depth Gage, Comparator, Micrometer, Caliper, Height Gage, Bore Gage,
Hole Gage, Surface Tester). You can also add additional instrument types by
highlighting the text in the "instrument" field and type in a new instrument type.
When you press "Enter", the new instrument type is added to the pull-down list.
Dimension — Indicates the expected dimension of the inspection feature. For
many feature types, but not all, this column will be populated by the system. For
floor thickness for example, VERICUT uses X-Caliper's capabilities to determine
the distance through the stock from the position you picked to the next "air"
condition. The same calculation is performed for wall thickness. And if you pick a
cylinder when locating a diameter or radius feature, VERICUT can also fill in the
column easily. Things become a little more complicated when a datum plane is
involved. Whether the column is populated automatically or not, you can always
adjust the value.

Tolerance — Indicates the tolerance of the inspection feature. If the dimension


value is automatically generated by VERICUT when you insert the row, the
Tolerance column value is automatically filled in also. There are hard-coded
default tolerance values built into VERICUT.
If the tolerances generated do not reflect the values you want, at least they give you
initial entries to edit, with the advantage that you don't need to know how to
keyboard enter a plus/minus symbol. If you need non-symmetric tolerances you
could enter "+0.010/-0.008" for example, or you could employ ISO standards by
typing an "H" number. Incidentally, if you do want to type a plus/minus symbol, on
a Windows system try holding down the Alt key while you hit the numeric pad
keys 0, 1, 7 and 7, then release the Alt key. Cut and Paste is easier to remember.
You can also create, and have VERICUT use, a custom inspection tolerance file.

Geo. Tolerance — Indicates the geometric tolerance (GD&T) characteristics


associated with the inspection feature. If you do not use the widely misinterpreted
GD&T standard, you can shrink this column's width to zero in the table, and omit it
completely from your report template. But if your company uses geometric
tolerancing, select a row that requires it and select Edit Geometric Tolerance from
the Inspection Sequence, Edit menu ( or right-click on the inspection table and pick
Edit Geometric Tolerance from the pop-up menu) to display the Geometric
Tolerance window.

Measurement — Use this field to record the "actual" measurement of the


inspection feature. This will most likely occur on paper copies of the reports
generated by this module. If your company is using digital record keeping, and
VERICUT is available to your inspectors, they can enter the values directly into the
table.

920
Geometric Tolerance window
The Geometric Tolerance window, accessed using Edit > Edit Geometric Tolerance in
the Inspection Sequence window, enables you to assemble the elements of a geometric
tolerance (GD&T) specification for inclusion in the Inspection Sequence table. (See
How)

NOTE: The features in the Geometric Tolerance window provides the tools to
assemble a geometric tolerance specification but does not attempt to check the
validity of the specification created, or enforce compliance to any "standard".

In the sample window shown above, notice that one of the element boxes is highlighted
indicating that it is the "active" element. Click on an element box to make it "active"or
use the "Enter" or "Tab" keys to step to the next element box and make it "active". Use
the icon below each element to shift the elements to the right and make space for an
additional one. Use the icon below each element to delete an element and shift the
remaining elements to the left. To add text to an empty box, simply type in an "active"
element box.

Text — Click on the text button, , to change a Characteristic, Separator, or


Modifier symbol in the active element box to text.

Characteristic — Click on the appropriate characteristic symbol to add it to the "active


element box.
Tip: Hold the cursor over a characteristic symbol for a text reminder of what the
symbol represents.

Separator — Click on the separator button, , to add a separator to the "active"


element box.

Modifier — Click on the appropriate modifier symbol to add it to the "active element
box.

921
Tip: Hold the cursor over a modifier symbol for a text reminder of what the symbol
represents.

Clear — Use this feature to clear all element boxes.


OK — Adds the geometric tolerance specification to the Inspection Sequence table and
closes the Geometric Tolerance window.
Cancel — Closes the Geometric Tolerance window without adding the geometric
tolerance specification to the Inspection Sequence table.

922
Feature Identifier window
The Feature Identifier window, accessed using Analysis > Feature Identifier in the
Inspection Sequence window, assists you in locating critical part features for inclusion in
the Inspection Sequence table. (See How)

First Feature — Use (Step backward/Step forward) to step through each


feature created with the highlighted cutter, starting with the first feature and moving
toward the last feature. The current "first" feature is displayed with the "1" marker as
shown in the illustration below.

Last Feature — Use (Step backward/Step forward) to step through each


feature created with the highlighted cutter, starting with the last feature and moving
toward the first feature. The current "last" feature is displayed with the "2" marker as
shown in the illustration below.
Color Bar — Use the pull-down list of colors to specify the feature display color.

Close Window — Closes the Inspection Feature Identifier window.

Cutter Table — Contains a list of cutters used to cut the part. Each record contains the
following information:
File # — The toolpath file number.
Record Number — The line number of the tool change record.
Tool ID — The tool ID of the cutter.
Description — A description of the cutter.

923
924
Inspection Programming window
The Inspection Programming feature enables you to quickly and easily create a G-Code
program to drive an NC machine with a probe loaded to the critical inspection points
associated with the current user file. (See How)

Location: Analysis > Inspection window: Program >Program probe cycles

VERICUT toolbar short cut:

Opens the Inspection Programming window enabling you to create G-Code program to
drive an NC machine through the steps required to inspect a workpiece using one or more
probes.

The Menu Bar:

The menu located across the top of the Inspection Programming window provides easy
access to major Inspection Programming functions. Click on the function in the menu you
want to use.

925
Post-processor — Enter the /path/filename of the post-processor file to use, or use
the (Browse for Post-processor) icon and use the Post-processor file selection
box to select the Post-processor file.

Edit post-processor — Displays the Post-processor in a text edit window


enabling you to view/edit the post-processor file.
N= — Use the N= text field to enter the increment to be used for sequence numbers
in the G-Code program (i.e., N=10 results in sequence numbers N10, N20, N30, ...)

Run post to generate program — Runs the specified post processor program
to generate the probe G-Code program.

Probe program — Enter the /path/filename of the probe G-Code program to


generate, or use the (Browse for probe program) icon and use the Probe
program file selection box to select the probe G-Code program file.

Edit probe program — Displays the probe G-Code program in a text edit
window enabling you to view/edit the probe program that was created.

Simulate probe program — Displays the NC Program window enabling you


to specify the probe G-Code program and simulate the probe path in VERICUT.

Close Window — Closes the Inspection Programming window.

926
Die Sinking Simulation
Location: Analysis menu > Die Sinking Simulation

Opens the Die Sinking Simulation window enabling you to select electrodes and simulate
the die sinking process. (See How)

Simulation Display Features:


Stock — Enables you to select the Stock component that is to be used for the
simulation. Select the name of the Stock component from the pulldown list.
Display Stock — use to specify whether or not to display the Stock model during
the simulation. The stock model can be displayed as Solid or Translucent. The
stock model remains displayed during the Burn process unless Display Burned
Material is toggled on. In this case the Stock model will be turned off when you
select Burn and only the material removed by the simulated EDM burn will be
displayed at the end of the burn process.

927
Display Electrodes — use to specify whether or not to display the Electrode
model(s). Electrode models can be displayed as Solid or Translucent. Electrode
models are always toggled off after Burn is selected.
Display Burned Material — use to specify whether or not to display the material
that is removed by each electrode during the simulation. The "burned material" can
be displayed as Solid or Translucent.
Animate — use to specify whether or not to display electrode animation during the
"burn" process. Use the slider bar to control the speed of the animation. If toggled
off, displays only the result of the burn process.

Electrode Table:
Table of electrodes selected for use during Die Sinking Simulation.
On —Toggles on and off to activate/deactivate individual electrodes in the table.
Only the active electrodes will be used during the "burn" process.
Electrode — the name of the electrode component.
Overburn — this column enables you to specify an "overburn" value for each
electrode. The "overburn" value is applied as an offset to each electrode during
"burn" processing.
Volume Removed — this column displays the volume of material that was
removed by each active electrode during the burn process. The "volume removed"
value is updated in the table as each electrode completes the burn process.
Click and drag the button in the first column of each row to change position of an
electrode in the table. "Active" electrodes will be processed sequentially starting at
the top of the table.
Add — use to add additional electrodes to the table. Select the electrode to be
added from the pulldown list then select Add. The pulldown list will contain all
electrode components found in the Component Tree that are not currently in the
table.
Delete — use to remove the highlighted electrode from the table.
The Add/Delete can be accomplished by either selecting the associated button in
the Die Sinking Simulation window or selecting it from the pulldown that results
from using the right mouse button while the cursor is in the Electrode table.
Set All — use to activate "all" electrodes in the table.
Clear All — use to deactivate "all" electrodes in the table.

Die Sinking Simulation features:


Compare With Design — displays the AUTO-DIFF window enabling you to
compare the stock model at the end of the burn process with the design model.
Save Model — enables you to save the stock model that resulted from the burn
process as a VERICUT solid (.vct) file.

Apply — Use to save the current Die Sinking Simulation settings.

928
Burn — Use to start the "burn" process.
Restore — Restores the stock model to the state it was in prior to the "burn" process.
Report —Use to create a Die Sinking Simulation Report.
Close — Closes the Die Sinking Simulation window.

929
OptiPath menu

OptiPath Control window

VERICUT Users:
VERICUT Location: OptiPath menu > Control
Project menu > Output : Logs tab, Settings button

VERICUT toolbar short cut:

Mold and Die Users:


Mold and Die Location: Preview and Optimize page > Optimize Tool Path
Notebook Feature:

Opens a window to control when tool paths are optimized by OptiPath, specify the file to
receive the optimized data, choose the type of stock material and NC machine involved in
the cutting the workpiece. Feed rates and spindle speeds can be monitored via the Status
window. A summary of the cutting conditions encountered during optimization and
min/max optimized feed rates is written to the Log and available for use when creating a
report file showing an overview of the results of the
current VERICUT session.

930
Settings tab — Features on this tab enable you to control when and how tool paths are
optimized.
G-Code Output Options tab — Features on this tab enable you to configure how the
machine control will process machine code data, and configure settings referenced when
G-code tool path files are optimized.
Learn Mode Options tab — Features on this tab enable you to control how and when
OptiPath records are written to the OptiPath Library file during Learn From Toolpath
processing.
APT Output Options tab — Features on this tab enable you to configure settings
referenced when APT NC programs are optimized.

OK — Applies the changes and closes the OptiPath Control window.


Apply — Applies the changes and leaves the OptiPath Control window open.
Cancel — Closes the OptiPath Control window without applying changes.

931
OptiPath Control window, Settings tab
VERICUT Location: OptiPath menu > Control
Project menu > Output : Logs tab, Settings button

VERICUT toolbar short cut:

Features on this tab enable you to control when and how tool paths are optimized.

OptiPath Mode — Controls when and how tool paths are optimized. All OptiPath modes
can be used as with both Standard and the “new" FastMill cut modes.
Options:
y Off — Turns optimization off. Optimization is automatically turned off when the
end of the tool path file has been reached, or when the tool path has been reset or
rewound.
y On — Turns tool path optimization on and writes optimized tool path data to the
Optimized File. For optimization to occur, OptiPath records must be associated
with cutting tools in the tool path file. There are two methods of doing this:
- Tool Library association method- associate the OptiPath tool description and
number of teeth with a tool in a Tool Library file, then choose the stock material
and machine in the OptiPath Control window.
- Tool List association method- choose the stock material and machine in the

932
OptiPath Control window, then build a tool list that associates OptiPath
records with cutting tools to be optimized in the tool path file.
With either method, tools without cutting tool-to-OptiPath record associations are
not optimized. If both methods are used, associations in the tool list override
those stored with tools in the Tool Library.
y Prompt While Cutting — Turns tool path optimization on and interactively
prompts for optimization data at each tool change. As you enter data for
optimizing the cuts performed by each tool, VERICUT automatically stores this
information in a OptiPath Library file and sets tool properties to point to the new
OptiPath records.
y Learn From Toolpath — Automatically creates a new OptiPath Library file
for the current user file in the /path/filename specified by OptiPath Library. (See
how) The OptiPath library file that is created can then be manually fine-tuned
using OptiPath Manager and used to optimize the tool path.
Learn From Toolpath can be turned On/Off at any time during cut processing. Each
time Learn From Toolpath is turned on, it creates an OptiPath library file. The file
contains OptiPath settings for every tool loaded since cutting was started with
Learn From Toolpath turned "On", including the tool that was cutting at time that
Learn From Toolpath was turned "Off". These settings are based only on cutting
conditions that occurred between the time cutting was started with Learn From
Toolpath was turned on and the time when cutting stops and Learn From Toolpath
turned "Off". To get complete and accurate information for each tool, process the
whole job through Learn From Toolpath. Turning Learn From Toolpath On/Off
during cutting can be used to analyze cutting conditions for a specific group of cuts.
When Learn Mode is turned on and an existing .olb is present, any tools with
matching OP records are skipped, not "learned". Any tools without OP records are
"learned" and a new OP record is created. The old and new records are combined in
a new OP library file.
For each tool, OptiPath finds the maximum volume removal rate and chip thickness
that occurred during cutting and uses them for corresponding OptiPath settings for
the tool. The optimization mode is set to a combination of “Chip Thickness” and
“Volume Removal” for each tool. Axial Depth and Radial Width values are
determined by the cut that produces the highest volume removal rate. Default
values are used for other settings unless they have specifically been changed using
Learn Mode Options tab.
Learn From Toolpath only automatically creates the OptiPath Library file (.olb)
and an updated Tool Library file (.tls) containing the "OP Description" and "#
Teeth" values associated with the newly created OptiPath Library file. It does not
automatically optimize the tool path or produce the Optimized File. Once Learn
From Toolpath creates the Optipath Library file, you are prompted whether or not
you want to optimize the toolpath using the newly created OptiPath Library file
and Tool Library files.
OptiPath Library — If OptiPath Mode is set to Off, On, or Prompt While Cutting,
OptiPath Library represents the /path/filename of the OptiPath Library file containing the
desired OptiPath records. If OptiPath Mode is set to Learn From Toolpath, OptiPath
Library represents the /path/filename of the OptiPath Library file that will be created.

933
Optimized File — Specifies the name of the modified (optimized) tool path file to
receive optimized tool path data. The format of this file, APT vs. G-code, is the same as
the tool path file being optimized. When an APT tool path type is optimized the
programmed “FEDRAT” records are commented out using “$$” and written to the
modified path for reference. The Optimized File name must be different from that of the
original tool path file. OptiPath will not permit the original tool path file to be
overwritten.

When optimizing multiple tool path files an optimized tool path file is output for each
tool path file simulated. Each output file has an ascending sequence number appended to
the end of the base file name. For example: assume Optimized File=“part.mco” is
entered (without the quotes). Optimizing 2 tool paths outputs the following files:
part001.mco => optimized tool path from tool path 1
part002.mco => optimized tool path from tool path 2
If a dot “.” is the last character of the optimized tool path file name, then three digits are
appended to the file name as the extension. Continuing with the above example: assume
Optimized File=“part.” is entered. Optimizing the same 2 tool paths outputs the
following files:
part.001 => optimized tool path from tool path 1
part.002 => optimized tool path from tool path 2

If an asterisk “*” is used in the optimized tool path file name, the original tool path file
name is used as the output file name in place of the asterisk. If characters follow the
asterisk, the input tool path file name extension is replaced with the characters following
the asterisk.

Examples follow.
Original tool path file: Optimized File name: Output file name:
dir1/filename.tp dir2/filename.tp
dir2/*
dir1/filename.tp dir2/filename.op
dir2/*.op
dir1/filename.tp dir2/filenameop
dir2/*op
dir1/filename.tp dir2/filenameop.tp
dir2/*op.tp
filename.tp filename.op
*.op

Only a single asterisk is acted on in the optimized tool path file name, with one
exception: asterisk dot asterisk (“*.*”). This case behaves exactly like the single asterisk
file name described above. This is NOT a regular expression replacement, therefore any
characters before the asterisk are ignored and lost. When there is more than one asterisk,
only the first one is replaced.

934
Examples follow.
Original tool path file: Optimized File name: Output file name:
dir1/filename.tp dir2/filename.tp
dir2/*.*
dir1/filename.tp dir2/filename.tp
dir2/op*
dir1/filename.tp dir2/filename.ext
dir2/op*.ext
dir1/filename.tp dir2/filenameop.*
dir2/*op.*

Material — Identifies the stock material being cut. The material name is changed via
clicking the arrow and selecting from a list of available materials, or clicking in the data
field and typing a new material name.
Machine — Identifies the NC machine being used to cut the workpiece. This feature
functions similar to Material described above.

NOTE: For optimization to occur the Material and Machine names must match
those of the desired records in the OptiPath Library.

Override All Feedrates — Overrides optimized feed rates calculated for all tools
optimized. 100% uses optimized feed rates as is, 50% cuts feed rates in half, 200%”
doubles the feed rates, and so on.

935
OptiPath Control window, G-Code Output
Options tab
VERICUT Location: OptiPath menu > Control
Project menu > Output : Logs tab, Settings button

VERICUT toolbar short cut:

Enables you to configure how the machine control will processes machine code data and
configure settings referenced when G-code tool path files are optimized by OptiPath. The
G-Code Output Options tab is only available when NC Program Type is set to G-Code
Data.

OptiPath & Curve Fit tab — Features on this tab enable you to configure settings
referenced when G-code tool path files are optimized by OptiPath.
General tab — Features on this tab enable you to configure general guidelines for how
the control processes machine code data and number equations.

936
OptiPath Control window, OptiPath & Curve
Fit tab
Features on this tab enable you to configure settings referenced when G-code tool path
files are optimized by OptiPath. (See how)

The settings are used to control block sequencing and word/value spacing in the
optimized output tool path file. Note that by default, optimized blocks receive the same
sequence number, if any, that appears on the original block processed. This typically
results in multiple blocks having the same sequence number.

The features on this tab are the same as those found on the Control Settings window:
OptiPath & Curve Fit tab and are described in detail there.

937
OptiPath Control window, General tab
Features on this tab enable you to configure general guidelines for how the control
processes machine code data and number equations. (See how)

The features on this tab are the same as those found on the Control Settings window:
General tab and are described in detail there.

938
OptiPath Control window, Learn Mode
Options tab
VERICUT Location: OptiPath menu > Control
Project menu > Output : Logs tab, Settings button

VERICUT toolbar short cut:

Features on this tab enable you to control how and when OptiPath records are written to
the OptiPath Library file during Learn From Toolpath processing.

Enables you to override the default values for Minimum Feedrate Change, Clean-up
Feedrate, Minimum Cut Feedrate and Maximum Cut Feedrate without going to the
OptiPath window: Settings tab. The Learn Mode Options tab is only active when
OptiPath Mode, on the OptiPath Control window: Settings tab, is set to Learn From
Toolpath.

Append to Existing OptiPath Library — If toggled "On", Learn From Toolpath


appends OptiPath records to the existing OptiPath Library file for the current project file.
Otherwise the "OptiPath Library to be created" window will display enabling you to
specify the /path/filename for the new OptiPath library file to be created.

939
Update Optimization Settings for Existing Records — If toggled "On", existing
OptiPath records are updated with new volume, chip thickness, and spindle speed values.

NOTE: If Update Optimization Settings for Existing Records is toggled "On",


and the same tool is loaded multiple times in the toolpath, the OptiPath Library file
(.olb), produced by Learn From Toolpath, will have only one record for the tool.
The settings for the tool are based on the "worst case" cut condition of all cuts
made with the tool during the current toolpath. If toggled "Off", a record will be
added to the OptiPath Library file each time the tool is loaded. The settings will be
based on the "worst case" cut for the current "load tool" cut sequence.

Reset and Optimize after Learning — If toggled "On", VERICUT automatically resets
and optimizes the toolpath after the OptiPath Library file is created. Otherwise, you will
be prompted whether or not you want to optimize the toolpath using the newly created
OptiPath Library file and Tool Library files.

Minimum Feedrate Change—Specifies the minimum change from the current


optimized feed rate that will cause a new optimized feed rate to be output. This feature
controls the quantity of feed rates output to the optimized tool path file. A small value
causes more optimized feed rates to be output than when a larger value is entered.
y Default —When selected, sets the default Minimum Feedrate Change = 1 IPM
or 25 MMPM, whichever applies.

Clean-up Feedrate—Feed rate used when the tool is adjacent to, but not removing
material. This condition is commonly referred to as a “spring pass”.
y Default —When selected, sets the default clean-up feed rate as follows:
- G-code tool path = 50% of the Max Feed Velocity of the machine's X-axis.
- APT tool path = 50% of the Fast Feed value.

Tip: Set the Clean-up Feedrate to be less than the Air Cut Feedrate, since actual
cutting leaves small amounts of material from tool deflection.

Minimum Cut Feedrate—Specifies the minimum optimized feed rates that can be
output when removing material.
y Default option—When selected, sets the default minimum feed rate = 1 IPM or
25 MMPM, whichever applies.

Maximum Cut Feedrate—Specifies the maximum optimized feed rates that can be
output when removing material.
y Default —When selected, sets the default maximum feed rate as follows:
- G-code tool path = 45% of the Max Feed Velocity of the machine's X-axis.
- APT tool path = 45% of the Fast Feed value.

940
Air Cut Feed Rate— This option is useful for reducing time of proven tool paths,
without affecting cutting feed rates and resulting surface finishes. When the checkbox is
cleared, this feature controls the feed rate used by all other optimization methods to
optimize air cuts.
y Default —when selected, the air cut feed rate is determined as follows:
- G-code tool path = Max Feed Velocity of the machine's X-axis.
- APT tool path = Fast Feed value.
To specify an air cut feed rate value, clear the Default checkbox and enter a value in the
data field. The feed rate entered should reflect the maximum speed at which machine
axes can move simultaneously in feed mode (e.g. G01).

941
OptiPath Control window, APT Output
Options tab
VERICUT Location: OptiPath menu > Control
Project menu > Output : Logs tab, Settings button

VERICUT toolbar short cut:

Features on this tab enable you to configure settings referenced when APT NC programs
are optimized.

Output Number of Decimal Places — Use the text field to specify the number of
decimal places that are to be output when OptiPath adds records. The default value is 10.

942
OptiPath Compare Files
VERICUT Location: OptiPath menu > Compare Files

Opens a window to enabling you to select and compare the original toolpath and the
optimized toolpath.

Toolpath Type — Select APT or G-Code Data

Original Toolpath — Enter the \path\file name in the text field of the file to receive
exported model data or click on Browse and use the Original Toolpath file selection
window to specify the file.

Optimized Toolpath — Enter the \path\file name in the text field of the file to receive
exported model data or click on Browse and use the Optimized Toolpath file selection
window to specify the file.

Previous Difference — Use the icon to step back through the file to the previous
difference.

943
Next Difference — Use the icon to step forward through the file to the next
difference.

Line Number or Search Text — Use to enter a line number or a string of text to search
for.

Goto Line Number —Use the icon to move the cursor in the file listing to the line
number specified in the Line Number or Search Text field.

Search Forward — Use the icon to search forward in the file listing for the text
string specified in the Line Number or Search Text field.

Search Backward — Use the icon to search backward in the file listing for the text
string specified in the Line Number or Search Text field.

Compare — Starts the compare of the two specified toolpaths.

Close — Closes the Compare Toolpath Files window.

Stop — Use the icon to stop the compare.

944
Tables for Processing G-Codes

Tables - listed alphabetically


The following VERICUT windows provide access to tables:

y Project menu > Processing Options > G-Code > Settings window: Tables tab —
Specify "Job Tables" to store work offsets and machine locations specific to the
current tool path file(s) and "Tool Tables" to store tool-related offset and
compensation data.
y Configuration menu > Machine Settings window: Tables tab — Specify
important machine locations and detail tool change motion.

For information about using Tables window features, see "About configuring tables" in
the Using VERICUT section.

The tables available in VERICUT are listed below in alphabetical order. See the
appropriate section for details on data stored, data formats, and how to access each table.

Table name General description


Base Work Offset table Specifies the location from which work
offsets are based
Cutter Compensation table Stores cutter diameter compensation, or
"CDC" offset values
Gage Offset table Stores tool gage offset, or “gage length”
values
Initial Machine Location table Specifies where machine axes are initially
located
Input Program Zero (Special Z) table Specifies the programmed zero location of a
(formerly Input Program Zero table) G-code tool path file
Machine Reference Location table Specifies the reference location of machine
axes
Machine Zero table No longer used
(formerly Input Machine Zero table)
Part Transformation table Specifies a workpiece transformation

945
Probe Offset table Stores probe tool offset values
Program Zero table Specifies the programmed zero location of a
G-code tool path file taking Tool Length
Comp into consideration.
RPCP Pivot Offset table Specifies the offset between the Stock
component origin and the rotary table pivot
point
RTCP Pivot Offset table Specifies the offset between the Tool
component origin and the tilting head pivot
point
Tool Change Location table Specifies the location of machine axes for
changing the tool
Tool Change Retraction table Specifies which machine axes retract for
changing the tool
Tool Length Compensation table Stores the tool length compensation offset
values
Tool Nose Compensation table Stores the tool nose compensation offset
values for use with Fanuc style "imaginary
tool nose programming" for turning (e.g.
G41-42 Dn)
Work Offsets table Stores work coordinate system offset
(fixture offset) values

946
Cutter Compensation table
This table stores cutter diameter compensation, or "CDC" offset values used when
simulating cutter diameter compensation. VERICUT access this table when the "Process
Cutter Comp." feature is active (ref. G-Code Settings window: Settings tab) and CDC
data is processed, e.g. G41-42 Dn.

You can create a Cutter Compensation table via features on the G-Code Settings
window: Tables tab. Enter values to represent the CDC values entered at the NC control.
Data entry formats follow.

Data entry => register_index: val


where "register_index" specifies the NC control register number where the corresponding
CDC value offset "val" is stored.
Enter an offset value for each CDC offset register referenced by the tool path. Zero offset
values are assumed when not specified, and do not require entry. The figure below shows
a sample table to support a tool path file using CDC.
Sample NC data tool path and Cutter Compensation table entries

How cutter compensation is simulated


Assume a control has been configured to support CDC, and a tool path file was
programmed using "T1"-a zero diameter tool (sometimes known as "part edge
programming"). Also assume a .5 diameter tool is used to cut the part. If the CDC offset
programmed for use with this tool is "D1", the machine operator enters a value of .25 in
the CDC register for "D1" to offset tool 1 when G41/42 is active. To simulate how this
tool path will be compensated, a value of ".25" is entered into the Cutter Compensation
table under Index 1, since this is the index referenced when "D1" is processed.
"Look ahead" logic, similar to Fanuc type "C" compensation, applies the CDC offsets

947
during the simulation. The block activating CDC results in a "ramp-on" motion
establishing the offset condition. The block cancelling CDC results in a "ramp-off"
motion cancelling the offset condition.

NOTES:
Output Precision specifies the accuracy for calculating CDC offset tool positions.
(Ref. Control Settings window: Motion tab).
Tool paths can not be optimized by OptiPath when CDC offsets are being simulated.

948
Base Work Offset table
This table specifies the location from which work offsets are based. Use this table when
the tool path file references a base work coordinate system (e.g. G52) from which all
other work offsets are based. (Ref. "Work Offsets table" in this section). Enter values to
represent the work offset values entered at the NC control.

Data entry => 1: Xval Yval Zval Aval Bval Cval Uval Vval Wval

where linear offset values Xval-Zval and Uval-Wval are measured in the machine
coordinate system from machine zero. Rotary offset values Aval-Cval are measured from
the corresponding rotary component zero and are expressed in decimal degrees. Enter “0”
for axes that do not have a base work offset or do not exist in the machine. Zero is
assumed for unspecified machine axis offsets.

Examples that follow show table entry formats for various NC machine configurations.
Machine configuration Table entry format
3 axes - XYZ 1: Xval Yval Zval 0 0 0 0 0 0 or 1: Xval
Yval Zval (“0” assumed for axes A-W)
4 axes - XYZA 1: Xval Yval Zval Aval
4 axes - XYZB 1: Xval Yval Zval 0 Bval
4 axes - XYZC 1: Xval Yval Zval 0 0 Cval
4 axes - XZUW 1: Xval 0 Zval 0 0 0 Uval 0 Wval
5 axes - XYZAB 1: Xval Yval Zval Aval Bval
5 axes - XYZAC 1: Xval Yval Zval Aval 0 Cval
5 axes - XYZBC 1: Xval Yval Zval 0 Bval Cval
9 axes - XYZABCUVW 1: Xval Yval Zval Aval Bval Cval Uval
Vval Wval

949
Gage Offset table
This table stores tool gage offset, or "gage length" values that set the adjustment needed
to drive the tool in "Tool Tip" and "Tool Length Compensation" programming method.
These programming methods enable an NC programmer to assume the positions in the
tool path are controlling the tool, instead of NC machine axis positions. VERICUT uses
the gage offset to determine where the driven point is (aka. "control point") relative to the
gage point.

While tool gage offset values can be entered via the Tool Manager, this table must be
used when the tool path file drives a control point other than that described by Gage
Point values in the Tool Manager window, Tool Table. Missing or incorrect gage offset
values causes a tool to load incorrectly on a 3-D machine, or causes improper cutting.
You can create a Gage Offset table via features on the G-Code Settings window: Tables
tab. Data entry formats follow.

Milling data entry => register_index: 0 0 Zval

where "register_index" specifies the tool number and the gage length "Zval" is a positive
value measured from the tool's control point to the gage line.

Turning data entry => register_index: Xval 0 Zval

where "register_index" specifies the tool number and the gage offset values Xval and
Zval are measured from the tool’s control point to the machine zero. For example, on a
horizontal rear lathe the machine zero location is typically the tool turret face and
centerline.

Enter gage length values for each tool number referenced by the tool path file that
requires adjustment. Gage Offset table entries are not needed for tools that have the
same offset values as stored in the Tool Manager. The figure below shows sample table
entries for a milling tool and a turning tool.

950
Sample Gage Offset table entries:

NOTES:
Gage Offset table values override Tool Manager-defined Gage Point values for
setting the adjustment to calculate the driven control point. However, they do not
affect how the tool is loaded in the NC machine. Only Tool Manager window, Tool
Table Gage Point values affect tool loading.

When the Gage Offset table is used to adjust tool motions, the NC control must be
configured to call the ToolOffsetAptAdj macro when a tool change occurs, or when
the tool control point changes, to adjust the motions seen in Workpiece views. The
ToolOffsetAptAdj macro allows the machine simulation to be driven with multiple
tool control points, when a single tool control point was defined in the Tool
Manager.

If this macro is not called on or after the tool change command, or when the tool
control point changes, then Workpiece views may not reflect the adjustment to the
Tool Manager-defined Gage Offset.

951
Initial Machine Location table
This table specifies where machine axes are initially located. The machine is moved to
this location when the machine is first loaded, when VERICUT is reset, or the tool path is
rewound.

Data entry => 1: Xloc Yloc Zloc Aloc Bloc Cloc Uloc Vloc Wloc

where linear offset values Xval-Zval and Uval-Wval are measured in the machine
coordinate system from machine zero. Rotary values Aval-Cval are measured from the
corresponding rotary component zero and are expressed in decimal degrees. Enter "0" for
axes which start at machine zero or do not exist in the machine. Zero is assumed for axes
not having a specified initial location.

The following examples attempt to specify the initial location of a 5-axis XYZBC NC
machine to be X=20 Y=62 Z=60 B=180 C=0:

y 1: 20 62 60 0 180 0 0 0 0
Correct- specifies X=20 Y=62 Z=60 A=0 B=180 C=0 U=0 V=0 W=0, even
though AUVW are not in the machine configuration.

y 1: 20 62 60 0 180
Correct- specifies X=20 Y=62 Z=60 A=0 B=180; ACUVW are not specified and
are assumed to be machine zero.

y 1: 20 62 60 180
Incorrect- specifies X=20 Y=62 Z=60 A=180; BCUVW are assumed to be at
machine zero. B=180 has been incorrectly placed and is interpreted as A=180.

952
Machine Zero table
(formerly Input Machine Zero Table)
The Machine Zero/Input Machine Zero table is an obsolete table that has been retained
for "legacy" machine and user file purposes only. Use the Input Program Zero (Special
Z) table instead.

The Machine Zero/Input Machine Zero table is similar to the Input Program Zero
(Special Z) table except that it applies the Z offset immediately instead of after a G43. It
also does not recognize "tool length compensation".

953
Input Program Zero (Special Z) table
(formerly Input Program Zero table)

NOTE: It is recommended that the Program Zero Table be used instead of the Input
Program Zero/Input Program Zero (Special Z) table. While very similar in most respects,
it does a much better job of handling Tool Length Compensation.

This table specifies the programmed zero location of a G-code tool path file. This table is
required when the machine operator establishes a zero location other than machine zero.
This activity is also known as establishing a "floating zero" location.

Data entry => 1: Xloc Yloc Zloc Aloc Bloc Cloc Uloc Vloc Wloc

where linear axis locations Xloc-Zloc and Uloc-Wloc are measured in the machine
coordinate system from machine zero. Rotary axis locations Aloc-Cloc are measured
from the corresponding rotary component zero and are expressed in decimal degrees.
Zero is used for axes which the tool path zero is the same as the machine zero, or do not
exist in the machine configuration. Zero is assumed for axes not having a specified input
program zero value.

Values for this table are calculated differently, based on the programming method used
by the tool path file. Each programming method is listed below with an example of how
Input Program Zero (Special Z)/Input Program Zero table values are calculated for
that method.

y With Tool Tip programming method- calculate values from the Machine
reference point with no offsets in affect, such as: cutter compensation, work
offsets, etc.
y With Gage Length programming method- calculate values from the Machine
reference point with no offsets in affect, such as: cutter compensation, work
offsets, etc.
y With Tool Length Compensation programming method- calculate values from
the Machine reference point to the programmed zero when tool length
compensation is active (e.g. G43).

The figure that follows shows sample table entries which specify the programmed zero
location of tool path files run on various NC machine configurations.

954
955
Machine Reference Location table
This table specifies the reference location of machine axes. The reference location is
where the machine axes move to when a "return to reference location" command is
processed (e.g. G28), such as typically used with the "Tool Length Compensation"
programming method.

Data entry => 1: Xloc Yloc Zloc Aloc Bloc Cloc Uloc Vloc Wloc

where linear axis locations Xloc-Zloc and Uloc-Wloc are measured in the machine
coordinate system from machine zero. Rotary axis locations Aloc-Cloc are measured
from the corresponding rotary component zero and are expressed in decimal degrees.
Zero is used for axes having a reference location at machine zero or do not exist in the
machine configuration. Zero is assumed for axes not having a specified reference
location.

A return to reference point command typically cancels active offsets (tool length, work
offsets, position set, etc.) and moves specified axes to their respective reference locations.
The axis commands (e.g. X...Y...Z...A...B...C...) are processed prior to moving the
machine to the reference location. For example, the command "G28 G91 X1 Y2 Z3" first
moves the X axis by 1, Y axis by 2, and Z axes by 3, followed by moving to the X,Y,Z
reference location.

956
Part Transformation table
NOTE: The Part Transformation table is an obsolete table that has been retained
for "legacy" user file purposes only. If this table is currently defined, it will
continue to show up in the Tables Window, but this table will no longer show up in
the list of available tables on the Add/Modify window.

This table specifies a workpiece transformation. Using this table and the
PartTransformation macro, it is possible to automatically rotate and/or translate the part
workpiece, and reverse the view of the VERICUT model during G-code processing.

Data entry => index: rotX rotY rotZ posX posY posZ [1]

where "index" matches the value of the group used to access the table, rotX-rotZ rotate
the VERICUT model, posX-posZ position the model. Including "1" in the seventh
number location instructs VERICUT to reverse the model view.

To have VERICUT use the table information, use the "Process Matrix" on the APT
Settings window: Motion tab.

Example- to have "M10" rotate the model 180 degrees about the Y-axis and reverse the
view:

y In the control configuration, define a Word/Address group: Word/Range=M 10,


Condition=* *, Macroname=PartTransformation
y In the G-code settings, define a Job table- Table Name=Part Transformation,
Index=10, Values=0 180 0 0 0 0 1
y In the APT settings, set Process Matrix=Yes

957
Probe Offset table
This table stores probe tool offset values. The table is used to adjust tool motions during
simulation of part probing.

You can create a Probe Offset table via features on the G-Code Settings window: Tables
tab. Data entry formats follow.

Data entry => tool_index: posXval posYval posZval negXval negYval negZval

where the "tool_index" specifies the tool ID number of the probe tool to which the offset
values are to be applied. Offsets specify the distance from the probe driven point to the
touch surface in each axis direction. Zero is assumed for axes not having a specified
probe offset value.

Enter probe offset values for each probe tool used by the tool path file. The following
diagram shows a sample Probe Offset table entry for tool "T99", a probe tool which has
a .1 ball radius and driven at the ball center.

958
Sample Probe Offset table entries:

The Probe Offset Table is currently only used by the GLType2PRB command. The G&L
PRB command activates the probing offsets for a specific probe. The offsets are the
distance from the center of the ball to edge of the ball. The offsets are positive X, positive
Y, positive Z, negative X, negative Y, and negative Z. These values are then stored in
registers 10101-10106. The registers are then used in the probing subroutine to
determine the actual location of the surface being probed.

959
Program Zero Table
This table specifies the programmed zero location of a G-code tool path file. This table is
required when the machine operator establishes a zero location other than machine zero.
This activity is also known as establishing a "floating zero" location.

Data entry => 1: Xloc Yloc Zloc Aloc Bloc Cloc Uloc Vloc Wloc

where linear axis locations Xloc-Zloc and Uloc-Wloc are measured in the machine
coordinate system from machine zero. Rotary axis locations Aloc-Cloc are measured
from the corresponding rotary component zero and are expressed in decimal degrees.
Zero is used for axes which the tool path zero is the same as the machine zero, or do not
exist in the machine configuration. Zero is assumed for axes not having a specified input
program zero value.

Values for this table are calculated differently, based on the programming method used
by the tool path file. Each programming method is listed below with an example of how
the Program Zero table values are calculated for that method.

y With Tool Tip programming method- calculate values from the Machine
reference point with no offsets in affect, such as: cutter compensation, work
offsets, etc.
y With Gage Length programming method- calculate values from the Machine
reference point with no offsets in affect, such as: cutter compensation, work
offsets, etc.
y With Tool Length Compensation programming method- calculate values from
the Machine reference point to the programmed zero when tool length
compensation is active (e.g. G43).

NOTE: The Program Zero Table is intended to replace the use of the Input
Program Zero/Input Program Zero (Special Z) table. While very similar in most
respects, it does a much better job of handling Tool Length Compensation.

960
The figure that follows shows sample table entries which specify the programmed zero
location of tool path files run on various NC machine configurations.

961
RPCP Pivot Offset table
Rotary Part Control Point, or "RPCP", moves the part is relative to the tool tip. In
VERICUT, RPCP simulation is activated via the RotaryControlPointOnOff or RpcpOn,
RpcpOff macros. The RPCP Pivot Offset table specifies an offset between the Stock
component origin and the rotary table pivot point to be considered when RPCP logic is
active. Use this table when a rotary component located between the Stock and Base
components has an Initial Machine Location table entry other than zero.

Data entry => 1: Xval Yval Zval

where Xval-Zval are calculated by subtracting the location of the Stock component origin
from the rotary pivot point location, with all axes at their initial machine location. Enter
"0" for axes that do not have an offset or do not exist in the machine. Zero is assumed for
unspecified offsets.

962
RTCP Pivot Offset table
Rotary Tool Control Point, or "RTCP", causes rotary head motion occurs about a specific
control point-typically the tool tip. In VERICUT, RTCP simulation is activated via the
Rotary Tool Control Point control setting (ref. Control Settings window: Rotary tab), or
the RotaryControlPointOnOff or RtcpOn, RtcpOff macros. The RTCP Pivot Offset table
specifies an offset between the Tool component origin and the tilting head pivot point to
be considered when RTCP logic is active. Use this table when a rotary component
located between the Tool and Base components has an Initial Machine Location table
entry other than zero.

Data entry => 1: Xval Yval Zval

where Xval-Zval are calculated by subtracting the location of the Tool component origin
from the rotary pivot point location, with all axes at their initial machine location. Enter
"0" for axes that do not have an offset or do not exist in the machine. Zero is assumed for
unspecified offsets.

Examples of when to use this table:

y RTCP is desired with a vertical 5-axis tilting head machine that has a pivot length
of 10 and a B-axis initial location of 180. This configuration puts the tool axis in a
vertical orientation. For calculations, the location of the pivot point can be
assumed to be at (0 0 0). This would require RTCP Pivot Offset table values: 0 0
10. ((0 0 0) - (0 0 -10)) = (0 0 10)
y If the B-axis initial location was 0 (tool axis in a vertical orientation), then the
RTCP Pivot Offset table is not needed. However, if the table was to be defined,
it should contain the values: 0 0 10. ((0 0 0) - (0 0 -10)) = (0 0 10)

This table can also be used to support a machine/control where the post-processor takes
care of the offset for the pivot length, and the control handles the offset for each tool's
gage length. For this situation, set RTCP Pivot Offset table values to: 0 0 0.

963
Tool Change Location table
This table specifies the location of machine axes for changing the tool. This table is used
when machine axes are specified to retract during a tool change via the Tool Change
Retract Method feature (ref. Control Settings window: Tooling tab), or the Tool Change
Retraction table.

Data entry => tool_index: Xloc Yloc Zloc Aloc Bloc Cloc Uloc Vloc Wloc

where the "tool_index" specifies the tool component number to which the tool change
location values are to be used (typically "1" for single tool component machines). Linear
axis locations Xloc-Zloc and Uloc-Wloc are measured in the machine coordinate system
from machine zero. Rotary axis locations Aloc-Cloc are measured from the
corresponding rotary component zero and are expressed in decimal degrees. Zero is used
for axes which are located at machine zero, or do not exist in the machine configuration.
Zero is assumed for axes not having a specified location.

The following examples specify the tool change location of a 5-axis XYZBC NC
machine to be X=20 Y=62 Z=60:

y 1: 20 62 60 0 0 0 0 0 0 - specifies X=20 Y=62 Z=60 A=0 B=0 C=0 U=0 V=0


W=0, even though AUVW are not in the machine configuration
y 1: 20 62 60 - specifies X=20 Y=62 Z=60; ABCUVW are not specified and are
assumed to be at machine zero

964
Tool Change Retraction table
This table specifies which machine axes retract for changing the tool. This table is used
only with the Use Retraction Table option for the Tool Change Retract Method
feature (ref. Control Settings window: Tooling tab). The retract location of each axes is
specified via the Tool Change Location table.

Data entry => tool_index: Xval Yval Zval Aval Bval Cval Uval Vval Wval

where the "tool_index" specifies the tool component number for which the tool change
retraction values are to be used (typically "1" for single tool component machines). For
each machine axis (Xval-Wval), a value of 1 is entered when the axis is to be retracted, 0
is entered for no retract, or when the axis does not exist in the machine configuration.
Zero is assumed for axes not having a specified value.

Examples:
y 1: 1 1 1 1 1 0 0 0 0 - specifies that the XYZAB axes are to be retracted to their
tool change location while the CUVW axes (if they exist) are not to be retracted
y 1: 1 1 1 1 1 - as above, except CUVW are not specified and are assumed not to be
retracted
y 1: 0 0 1 - specifies that only the Z axis is to be retracted

965
Tool Length Compensation table
This table stores the tool length compensation offset values (e.g. G43 Hn). Using this
table is optional when simulating tool paths programmed in the "Tool Length
Compensation" programming method. VERICUT automatically calculates tool length
compensation values from the Input Program Zero (Special Z) table and machine zero
locations. Use this table to override values that are automatically calculated by
VERICUT.
You can create a Tool Length Compensation table via features on the G-Code Settings
window: Tables tab. Enter values to represent the tool length compensation values
entered at the NC control. Zero offset values need not be entered. Data entry formats
follow.

Data entry format => register_index: val

where "register_index" specifies the NC control register number where the corresponding
tool length compensation offset "val" is stored. The tool length compensation offset is
usually a negative value measured from the control point (typically the tool tip) of each
tool loaded at machine zero to the control point when the tool is positioned at the
programmed zero.

Enter an offset value for each tool length offset referenced by the tool path file. The
figure below shows a sample table to support a tool path using a tool with gage
length=7.0 in a setup where the programmed zero is 20.0 from the machine zero.

Sample Tool Length Compensation table entry:

966
Work offset note: Work offsets have the affect of moving machine zero. When work
offsets are in use, the tool length compensation offset value is calculated from the control
point of each tool loaded at its respective work offset zero, to the control point when the
tool is positioned at the tool path programmed zero.

967
Tool Nose Compensation table
This table stores the tool nose compensation offset values for use with Fanuc style
"imaginary tool nose programming" for turning (e.g. G41-42 Dn). Use this table to
simulate how the NC control will offset a tool path programmed to the "part edge" (exact
diameters, etc.) and tool nose compensation is active.

You can create a Tool Nose Compensation table via features on the G-Code Settings
window: Tables tab. Enter values to represent the offset distance and direction from the
center of the tool nose radius to the imaginary programmed control point driven on the
part geometry. Data entry format:

Data entry => register_index: Xval 0 Zval

where "register_index" specifies the NC control register number where the corresponding
tool nose compensation offset values (Xval & Zval) are stored. The "register_index" to be
referenced by a given tool is typically specified with the tool number, for example T0101
specifies tool 1 (first occurrence of "01") and offset register "01" (second occurrence of
"01"). T0102 specifies specifies tool 1 and offset register "02", etc.

Offset values are measured from the tool nose center to the imaginary driven point. For
example, the offset values for a turning insert having .060 radius would be: "-.06 0 -.06".
Zero offset values need not be entered. Each tool nose compensation register index
referenced by the tool path file should be included in the table with an associated value.

Sample Tool Nose Compensation table entry:

NOTE: For a tool value to be interpreted as two pieces of data, such as Taabb
where "aa" represents the tool number and "bb" represents the offset number, the
"T" word must be defined in the NC control configuration as a Macro word type

968
using the Composite-Numeric word value type. (Ref. Word Format window)
Then, use the Word/Address window to configure word/address groups (e.g. T1,
T2) to act on the parsed composite "T" word pieces to call the appropriate macros
to accomplish changing the tool and setting the offsets.

969
Turret Rotations table
This table stores the turret rotation angles of multiple Tool components connected to a
Turret component on a lathe machine. This table is intended for use when one or more
Tool components are not defined with tool origin Z-axis values "0 0 1". If the table is not
defined and one of these Tool components becomes active, the turret will automatically
index to its zero position. To correct this condition, the Turret Rotations table is used to
specify the rotation angle for indexing the tool into its cutting position. The table is not
required to index Tool components defined with tool origin Z-axis values "0 0 1", since
the tool origin X-axis orientation (when defined properly) causes proper turret indexing.
You can create a Turret Rotations table via features on the G-Code Settings window:
Tables tab. Data entry format follows.

Data entry => turret_index: angleval

where the "turret_index" specifies a turret index number corresponding to the Tool
component's Tool Index number. (Ref. Modeling window: Component Attributes tab),
and "angleval" specifies the absolute rotation angle to rotate the Turret component when
the corresponding Tool component becomes active.

When using multiple tools in Turret components, configure the NC control to change
tools via calling the "TurretToolChange" macro. (Ref. Word/Address window) This will
ensure proper turret indexing, and Tool component activation.

970
Work Offsets table
This table stores work coordinate system offset, or "fixture offset" values. Use this table
when simulating programming with work offsets (e.g. G53-59). Enter values to represent
the work offset values entered at the NC control. Work coordinate system offset values
that are automatically loaded using via data in the tool path file (e.g. G10L2Pn) do not
require entry.

Data entry => register_index: Xval Yval Zval Aval Bval Cval Uval Vval Wval

where "register_index" specifies the NC control register number where the corresponding
work offset values "Xval Yval Zval..." are stored. Linear offset values Xval-Zval and
Uval-Wval are measured in the machine coordinate system from machine zero. Rotary
offset values Aval-Cval are measured from the corresponding rotary component zero and
are expressed in decimal degrees. Enter "0" for axes that do not have a base work offset
or do not exist in the machine. Zero is assumed for unspecified machine axis offsets.
Enter offset values for each local work coordinate system referenced by the tool path.
The figure below shows a sample table to support a tool path file which references work
offsets: G54, 55, 56.

971
The examples that follow assume a work offset register index of "54" and show general
table entry formats for various NC machine configurations.

Machine configuration Table entry format


3 axes - XYZ 54: Xval Yval Zval 0 0 0 0 0 0 or 54: Xval
Yval Zval (“0” assumed for axes A-W)
4 axes - XYZA 54: Xval Yval Zval Aval
4 axes - XYZB 54: Xval Yval Zval 0 Bval
4 axes - XYZC 54: Xval Yval Zval 0 0 Cval
4 axes - XZUW 54: Xval 0 Zval 0 0 0 Uval 0 Wval
5 axes - XYZAB 54: Xval Yval Zval Aval Bval
5 axes - XYZAC 54: Xval Yval Zval Aval 0 Cval
5 axes - XYZBC 54: Xval Yval Zval 0 Bval Cval
9 axes - XYZABCUVW 54: Xval Yval Zval Aval Bval Cval Uval
Vval Wval

NOTES:
To specify an initial work offset to be in affect, use Control Settings window: Offsets
tab.
When a Base Work Offset table is in use, work offsets are established from the base
work offset location (method commonly used by Phillips CNC controls).

972
Automating VERICUT

Batch VERICUT
Batch processing
Running VERICUT in batch automates the verification process by loading requested
VERICUT files, processing the NC program file, and exiting VERICUT-all without
opening the VERICUT window. Other command line options are commonly used to
specify the VERICUT Project file(s) and/or IP file(s) needed for the simulation, perform
VERICUT functions, and change VERICUT variable values. See "Command line
options for VERICUT" for more information.

VERICUT is run in batch mode (unattended in the background) by including the "batch"
command line option, or via the Batch Wizard. Another form of batch processing,
"batchp", pops open the VERICUT window when finished to reveal the cut workpiece.
You can run other applications, or perform other tasks while VERICUT is processing in
batch mode.

The same CGTech security and computer resources are required to run VERICUT in
batch as required during interactive processing. Logging out after initiating a batch
session has no affect on the process, as long as the computer remains active.
The following simple examples run VERICUT as configured by the previously created
"part.VcProject" project file:
vericut batch vcp=part.VcProject (UNIX)
vericut batch “vcp=part.VcProject” (Windows)

The values stored in the Project file provide information about the stock model to
machine, tool path file(s) to process, orientations of the models and tool paths, type of
machining to simulate, etc. In this above example the following actions occur:

1. VERICUT is executed.
2. Load the "part.VcProject" project file.
3. Press Play to start the simulation. (Also writes a Log file containing errors and
other information about the simulation.)
4. When finished, exit VERICUT.
For greater automation, multiple batch execution commands can be compiled in an
executable batch script file, as described by the sections that follow.

973
Batch Wizard
The Batch Wizard grapically guides you through setting up and running CGTech
products in batch mode. Batch mode runs CGTech products unattended in the
background. Command line options and configuration files control the batch process
without opening the VERICUT window. This allows you to run other applications, or
perform other tasks while CGTech products are being productive.

Accessing the Batch Wizard


Accessing the Batch Wizard is different, depending on the environment in which it is
operated.
y Access the Batch Wizard on a Windows computer—From the Taskbar, click
Start > Programs > CGTech VERICUT 6.x > Utilities > Batch Wizard where
"6.x" is the desired VERICUT version number.
y Access the Batch Wizard on a UNIX computer—Type "bwizard". If the
command is not found, include the full path, e.g.
"/<cgtech6x>/<computertype>/commands/bwizard" where <cgtech6x> represents
the directory path to where CGTech products were installed, and <computertype>
is the type of computer on which VERICUT is being operated, for example:
hp700, rs, sgi, or solaris.
y
Sample Batch wizard window:

In general, follow the prompts-press Next to go to the next screen, Back returns to the
previous screen. Finish indicates batch session setup is complete and opens a window to
specify the name of the batch session file to save. (See How)

974
Following are general descriptions of Batch Wizard screens that guide you throught
setting up a batch session file.

y Main screen—Also known as the "Welcome screen", this screen welcomes you
to the Batch Wizard. You can start a new batch session, modify an existing
session, or run an existing session.
y Operation screen—This screen is used to add, modify, or delete batch
operations. Operations can be named as desired, and are performed in listed order.
Use Move Up / Move Down to change the order in the list.
y CGTech product screen—This screen is used to specify which CGTech product
will be run in the batch operation. Choose O.S.Command to use an operating
system command to assist with batch processing, such as: copy, move, append,
rename, and set environment variables.
y CGTech product screen—This screen is used to specify which CGTech product
will be run in the batch operation. Choose O.S.Command to use an operating
system command to assist with batch processing, such as: copy, move, append,
rename, and set environment variables.
y Command line option screen—This screen is used to choose one or more
command line options for the product being run in batch. Press the right arrow

to include the option in the batch session being configured. Use the left

arrow to remove an unwanted option. Use the file selection button to specify
files to use. Be sure to include one of the batch options (batch or batchp) to run
the CGTech product in batch mode.

After setup is finished, choose Run an existing session from the main screen to run the
batch session. Batch session files created by the Batch Wizard are computer independent,
and can be run on any computer that is capable of running VERICUT.

975
Configuring for batch process output
Output from running VERICUT in batch always includes a Log file. VERICUT can also
be configured to automatically perform many operations, or output many different types
of files. The following sections describe how to configure VERICUT for batch process
output.

To batch save IP or View Capture files:


Configure VERICUT for processing the desired Project file (models, NC Programs,
tools, etc.)
Click File menu > AutoSave to display the AutoSave window.
Click on either the In Process tab (if configuring to automatically save IP files), or the
View Capture tab (if configuring to automatically save View Capture image files).
If saving View Capture image files, then click on Properties on the View Capture
tab to display the View Capture window and use its features to configure the
desired image file format.
In either case, use the Auto Save features select the event(s) and enter supporting
data that will cause VERICUT to automatically save the file. Type the name to be
used for the file in the text field, or click on Browse and use the window that
displays to specify the /path/filename for the file.
Use the Auto Error features to have VERICUT automatically save the file when an
error is encountered. Toggle the "On" checkbox on and type the name to be used
for the file in the text field, or click on Browse and use the window that displays
to specify the /path/filename for the file.
NOTE: If using both Auto Save and Auto Error, be sure to use different file
names for each to avoid overwriting.
Press OK
Save a Project file (or IP file) to be used during the batch process, for example
"test.VcProject"
Exit VERICUT
To start batch processing use the Batch Wizard, or execute VERICUT with
vcp=<file> and batch (or batchp) command line options, for example:
vericut batch vcp=test.VcProject

To batch record VERICUT Image files:


Configure VERICUT for processing the desired project file (models, tool path, tools,
etc.)
Click File menu > Images > Record Movie to display the Image Record window.
Configure the window as desired to record snapshot or animation images.
Press Record then Stop to retain Image Record window changes.

976
Close the Image Record window.
Save a Project file (or IP file) to use during the batch process, for example
"test.VcProject"
Exit VERICUT
To start batch processing use the Batch Wizard, or execute VERICUT with
vcp=<file>, record, and batch (or batchp) command line options, for example:
vericut batch vcp=test.VcProject record
To append to an existing Image file, include the "IMRCAPDT=on" option, for
example:
vericut batch vcp=test.VcProject record IMRCAPDT=on

To batch compare design models using AUTO-DIFF:


Configure VERICUT for processing the desired project file (models, tool path, tools,
etc.)
Depending on the AUTO-DIFF comparison method to be used, ensure a Design
Solid, Surface or Point model is loaded (ref. Modeling Window).
Click Analysis menu > AUTO-DIFF to display the AUTO-DIFF window.
Configure the AUTO-DIFF features as required to compare with the design model
and show gouge, and/or excess conditions.
Press Apply, then close the AUTO-DIFF window
Save a Project file (or IP file) to use during the batch process, for example
"test.VcProject"
Exit VERICUT
To start batch processing use the Batch Wizard, or execute VERICUT with
vcp=<file>, auto-diff=<reportfilename>, and batch (or batchp) command line
options, for example:
vericut batch vcp=test.VcProject auto-diff=test.rpt

To batch optimize tool path files using OptiPath:


Configure VERICUT for processing the desired project file (models, tool path, tools,
etc.), and optimizing the desired tools.
The following steps assuming an OptiPath Library file exists containing the
desired optimization data, and that VERICUT has already been configured to
optimize tool paths. If the library does not exist or does not contain all of the
desired optimization data, use the OptiPath window to create this file. Use the
Tool Manager window, the OptiPath window, and the OptiPath Control window
features to configure VERICUT for optimization. See "About optimizing NC
programs" in the Using VERICUT section, for additional information.
Click OptiPath menu > Control to display the OptiPath Control window.

977
Ensure the window is configured as required (OptiPath Library file name,
Material, Machine, etc.) to optimize the desired tools. Do not turn optimization
On in this window to start tool path optimization, as this will be done via the
"optimize" command line option.
Press OK
Save a Project file (or IP file) to use during the batch process, for example
"test.VcProject"
Exit VERICUT
To start batch processing use the Batch Wizard, or execute VERICUT with
vcp=<file>, optimize, and batch (or batchp) command line options, for example:
vericut batch vcp=test.VcProject optimize

978
Command Line Options
Command line options configure and control VERICUT upon execution. Command line
options are particularly useful in customizing the user interface for specific site use, or
during batch processing as described in the section later in this chapter titled "Batch
processing".

Available command line options are listed below in alphabetical order. See the
appropriate section for details. Options can be arranged on the command line in any
order.

Command line option: General description:


<uservariablename>=<uservalue> Sets a user variable (value in the user
interface)
append_log Open Log file in append mode
auto-diff=<reportfilename> Perform an AUTO-DIFF model comparison
and write results to a file
batch Runs VERICUT in the background, without
opening the user interface
batchp Similar to batch, except "pops open" the
VERICUT window when finished
burn Processes the "Burn" function in a Die
Sinking Simulation
csys_file=<filename> Reads the specified CSYS File and creates a
VERICUT coordinate system.
dxf2sweep Imports DXF 2D geometry and creates a
"sweep" solid model
export Exports the VERICUT cut model
fitall Fits all open views
hres=<value> Sets the horizontal screen display resolution
IMRCAPDT=on Appends recorded images to an existing
Image file
ip=<ipfile> Loads an In Process file
LGFILNAM=<logfilename> Set the Log file name

979
ops=</path/filename> Creates an Operations file
optimize Turns OptiPath on
record Records VERICUT images to an Image file
reset_cutcolor Resets cut colors of all machine cuts
reset_log Reset the Log file
reverse Reverses the active view
vcp=<file> Loads a Project file
usr=<usrfile> Loads a User file
VericutPlayer Plays back the specified VERICUT image
file.
vres=<value> Sets the vertical screen display resolution
zoom_out[=<value>] Zooms out approximately 20% for each
"zoom_out"

NOTE: If the option you are looking is not listed above, see "Obsolete command line
options" at the end of this section.

Windows NOTE: Command line options containing an assignment (“=”) must be


surrounded with double quotes, for example: vericut “usr=part.usr”

<uservariablename>=<uservalue>
Specifies a user variable and corresponding value to be set in the user interface. Also
know as a "user variable override", user variables and values entered on the command
line are not case sensitive. However, some operating systems use case sensitivity when
reading directory paths and file names. Consult your operating system guide to determine
if case sensitivity applies.

Windows example:
vericut "FASTFEED=500"
UNIX example:
vericut FASTFEED=500

When combined with other command line options that affect project values, the options
are processed in the order listed below. Processing order is the same regardless of the
order in which they are listed on the command line.

980
Order in which command line options affecting project values are processed:
1. ip=<ipfile> - load VERICUT model
2. usr=<usrfile> - load complete set of user values
3. vcp=<file> - load complete set of project values
4. <uservariablename>=<uservalue> - load individual user values

NOTES:
Specific spelling and formats apply. To see a list of VERICUT user variable
names/values, view any User file saved from the current version of VERICUT. The
middle column lists user variables, while the right column indicates the saved user values
for corresponding user variables.

When specifying multiple word user values join the words with an underscore ("_").
Back to command line options list

append_log
When VERICUT is run and an existing Log file is detected, the Log file is opened in
"append" mode. Additional log messages are appear at the end of the file.
See also: reset_log and LGFILNAM=<logfilename>.
Back to command line options list

auto-diff=<reportfilename>
Performs an AUTO-DIFF model comparison and writes results to the specified AUTO-
DIFF Report file. The comparison method and tolerances used are controlled via the
AUTO-DIFF window. The comparison is performed when tool path processing has
finished. Immediately afterwards, VERICUT automatically restores the model to its "as
machined" state, as it was prior to differencing.
This option is commonly used during batch processing to automatically inspect the part
after machining.
Back to command line options list

batch
Runs VERICUT in the background, without opening the user interface. In this mode,
VERICUT loads specified IP, User, or Project files (in listed order), processes the tool
path file(s), and exits-without user interaction. The "batch" option can appear anywhere
on the command line. Examples follow.

Windows examples:
vericut batch "vcp=part.VcProject"
vericut "vcpr=C:\ncparts\part.VcProject" batch

981
UNIX examples:
vericut batch vcp=part.VcProject
vericut vcp=/ncparts/part.VcProject batch

For step-by-step examples of how to accomplish popular tasks via batch processing, see
"Batch processing".

NOTES:
The same CGTech security and computer resources are required to run VERICUT
in batch mode as required during interactive processing.

Logging out after initiating a batch session has no affect on the process, as long as
the computer remains active.

Another form of batch processing, batchp, "pops open" the VERICUT window
when finished to reveal the cut workpiece.

A "Batch Wizard" provides a guided, graphical method of creating and running


CGTech products in batch mode. See "Batch processing" for details.

Back to command line options list

batchp
Similar to batch, except when finished the VERICUT window "pops open" to reveal the
cut workpiece. The model can then be analyzed or saved for later use.
See "Batch processing" for details.

burn
Executes the processing of the "Burn" feature of a Die Sinking Simulation. The export
operation is performed when tool path processing has finished.
Back to command line options list

csys_file=<filename>
Reads the specified CSYS File and creates one or more VERICUT coordinate systems. If
this command line argument is used, then VERICUT does not create CSYS's when
processing the NC program file. Provides the sane funcionality as the CSYS from File
feature in the Coordinate System window.
Back to command line options list

982
dxf2sweep[argument list]
Enables you to import two dimensional geometry from files which comply with a de
facto CAD system standard, the Data eXchange Format (DXF) to define a "closed" 2-D
profile that can be "swept" a specified thickness along an axis to create solid model. The
program that takes a DXF profile, sweeps it along the positive Z-axis the specified
distance, then outputs it to a VERICUT sweep file.

Arguments:
"input=<dxf_filename>" (Required)
(where dxf_filename is a fully qualified filename, including the directory
path, of a DXF file containing at least one closed profile.
"length=(sweep model thickness)" (Required)
(where sweep model thickness is the distance to sweep the 2D DXF profile
along the positive Z axis.
["output=<sweep_filename>"] (Optional)
(where sweep_filename is a fully qualified filename, including the directory
path, of the output SWEEP file)

NOTE: If "output" not specified, the resulting output file will default to
the name of the DXF file, without the extension, with a ".swp" extension
added. If the output file already exists, it is overwritten.

["layer=<lay1_name, lay2_name, ...>"] (Optional)


(where lay1_name, lay2_name, ... is the name of the layer containing the
DXF entities)

NOTE: IF 'layer" is specified, only entities on the specified layer(s) will


be converted. If "layer is not specified, all entities will be converted

It is possible to have multiple closed profiles that represent holes in the interior of the
model. If multiple profiles exist, they must conform to the following:
y cannot intersect other profiles
y cannot self-intersect
y inner profiles must be completely contained by the outer profile
y cannot be contained by any other profile
y all entities of a closed profile must have same layer name

NOTE: This functionality is also available as a stand-alone utility on Windows. Execute


dxf2sweep.bat, located in the "commands" directory of your VERICUT installation, with
the appropriate arguments.
Back to command line options list

983
export
Exports the VERICUT cut model. The method and tolerances used are controlled via the
File menu > Save Cut Stock > CAD Model window configuration. The export operation
is performed when tool path processing has finished.
Back to command line options list

fitall
Fits all open views. Use this option to ensure models of the workpiece, holding fixtures,
and NC machine are fit completely within all open views.
Back to command line options list

hres=<value>
Sets the screen display resolution in the horizontal direction. The value entered is in
pixels. See also vres=<value>.
Back to command line options list

IMRCAPDT=on
Actually a user variable override, this option is used with the "record" option to append
images recorded via the File menu > Images > Record Movie function to an existing
Image file.
Back to command line options list

ip=<ipfile>
Loads an existing In-process file into VERICUT. The full directory path can be included
with the file name. The examples that follow assume an In-process file named “part.ip”
has been saved.

Windows examples:
vericut “ip=part.ip”
vericut “ip=C:\ncparts\part.ip”

UNIX examples:
vericut ip=part.ip
vericut ip=/ncparts/part.ip

When combined with other command line options that affect user values, the options are
processed in the order listed below. Processing order is the same regardless of the order
in which they are listed on the command line.

984
Order in which command line options affecting user values are processed:
ip=<ipfile> - load VERICUT model
usr=<usrfile> - load complete set of user values\
vcp=<file> - load complete set of project values
<uservariablename>=<uservalue> - load individual user values
Back to command line options list

LGFILNAM=<logfilename>
Actually a user variable override, this option sets the name of the Log file to receive
error, warning, and informational messages resulting from processing a tool path in
VERICUT.
See also: append_log and reset_log.
Back to command line options list

ops=</path/filename>
An Operations File, or Ops File, can be used to assemble a project with multiple setups
from several VERICUT project files, which typically have the extension ".VcProject".
This assembly process can only be triggered from the command line that invokes
VERICUT. The necessary command line syntax is;

For Windows ... "ops=D:\My\Path\MyOperationsFile.VcT


mp" ...
For Unix ... "ops=/My/Path/MyOperationsFile.VcTm
p" ...

Any extension can be used in the file name, but by convention ".VcTmp" denotes a
temporary file.
Back to command line options list

optimize
Turns OptiPath on for optimizing tool path feed rates and/or spindle speeds. Cutting tools
optimized and optimization values used are controlled via the Project menu > NC
Programs and OptiPath menu > Control window configurations.
Back to command line options list

record
Records VERICUT session images to an Image file, as specified by the File menu >
Images > Record Movie window configuration. When record is used with the
IMRCAPDT=on option, images are appended to the end of the file.
Back to command line options list

985
reset_cutcolor
Resets the cut colors of all machine cuts to be one color: the Reset Cut color. Cut colors
are reset prior to cutting.
Back to command line options list

reset_log
When VERICUT is run and an existing Log file is detected, the Log file is reset (cleared)
prior to writing new log messages.
See also: append_log and LGFILNAM=<logfilename>.
Back to command line options list

reverse
Reverse the active view prior to cutting. This option is useful when recording images and
tool motion occurs on the opposite side of the model.
See "Reverse" under View menu > Orient for more information.
Back to command line options list

usr=<usrfile>
Loads an existing into VERICUT. The full directory path can be included with the file
name. The examples that follow assume a User file named "part.usr" has been saved.

Windows examples:
vericut "usr=part.usr"
vericut "usr=C:\ncparts\part.usr"

UNIX examples:
vericut usr=part.usr
vericut usr=/ncparts/part.usr

When combined with other command line options that affect user values, the options are
processed in the order listed below. Processing order is the same regardless of the order
in which they are listed on the command line.

Order in which command line options affecting user values are processed:
1. ip=<ipfile> - load VERICUT model
2. usr=<usrfile> - load complete set of user values
3. vcp=<file> - load complete set of project values
4. <uservariablename>=<uservalue> - load individual user values
Back to command line options list

986
vcp=<file>
Loads an existing Project file into VERICUT. The full directory path can be included
with the file name. The examples that follow assume a Project file named
"part.VcProject" has been saved.

Windows examples:
vericut "vcp=part.VcProject"
vericut "vcpr=C:\ncparts\part.VcProject"

UNIX examples:
vericut vcp=part.VcProject
vericut vcp=/ncparts/part.VcProject

When combined with other command line options that affect user values, the options are
processed in the order listed below. Processing order is the same regardless of the order
in which they are listed on the command line.

Order in which command line options affecting user values are processed:
ip=<ipfile> - load VERICUT model
vcp=<file> - load complete set of project values
<uservariablename>=<uservalue> - load individual user values
Back to command line options list

VericutPlayer[argument list]
Enables you to open a "VERICUT Player" window and play back an Image file recorded
using the File menu > Images > Record function or the record command line option.

Arguments:
"filename"
(where filename is a fully qualified filename, including the directory path, of
a VERICUT Image file)
"impbfil=(filename)"
(where filename is a fully qualified filename, including the directory path, of
a second VERICUT Image file to play both Image files simultaneously)
"impbspdp=value)"
(where value, entered as a percent, controls how fast images are played back)
"impberrt=value)"
(where value is either "on" or "off"; when value=on, playback stops an error
is detected by VERICUT)
"impbchgt=value)"
(where value is either "on" or "off"; when value=on, playback stops when the
cutter changes)

987
"impbnevt=value)"
(where value is either "on" or "off"; when value=on, playback stops every
"N" events (frames). Use " impbneve=value" to specify "N")
"impbeoft=value)"
(where value is either "on" or "off"; when value=on, causes playback to stop
when the end of a toolpath file has been reached).
"impbneve=value)"
(where value is the number used to specify the number of events (frames)
that causes playback to stop when "impbnevt=on)" as described above)
"impbstop=value)"
(where value is either "on" or "off"; when value=on, playback stops at an
"inserted stop")
"impbloop=value)"
(where value is either "on" or "off"; when value=on, causes playback to loop
continuously until interactively stopped by pressing the Escape key <Esc>).
"impbssd=value)"
(where value is the number of seconds to pause after displaying a snapshot)
Back to command line options list

vres=<value>
Sets the screen display resolution in the vertical direction. The value entered is in pixels.
See also hres=<value>.
Back to command line options list

zoom_out[=<value>]
Zooms out, or decreases the viewing size of uncut stock models by approximately 20%
for each "zoom_out" listed. For example, "zoom_out" zooms out one step, while
"zoom_out=2" zooms out twice.
See "Zoom Out" under View menu > Orient for more information.
Back to command line options list

Obsolete command line options


The command line options listed below are obsolete in this version of VERICUT.
Recommended alternate command line options are recommended where possible.

y autodemo=<imgfile>—Not supported.
y batcht—"True batch", obsolete- use "batch" instead.
y OpenGL—Not supported.
y pbappend—Obsolete- use "IMRCAPDT=on" instead.
y pseudocolor—No longer applies.
y results—No longer applies.
y slice—Not supported in this release.

988
y statdisp=<computername>—Not supported.
y truecolor—No longer applies.
Back to command line options list

989
Command line options for CGTech
converters
CGTech converter products provide a way to translate a wide variety of CAD/CAM data,
primarily for use in VERICUT. All converters can be run interactively, or in batch mode.
When run in batch, command line options are used to configure the converters without
the use of the user interface.

The sections that follow describe command line options available for CGTech converter
products. See the appropriate section for details.

y Binary CL Converter command line options


y CAD Converter command line options
y IGES Converter command line options
y PolyFix Converter command line options
y Surface to Solid Converter command line options
y VDA Converter command line options

Windows note: Command line options containing an assignment (“=”) must be


surrounded with double quotes, for example: iges2v “input=inputfile.igs”

Binary CL Converter command line options

Command line options available for the Binary CL Converter are described in the table
below.

Option Description Default


batch Execute without user
interface
batcht (obsolete) Same as "batch"
input=input-file Binary CL Input File
output=output-file Output File (ASCII APT)
table=table-file APT Table File aptwords.tbl (CGTech
library)
cltype={1|2|3|4} Input File Type: 1
1=IBM,2=IBMWS,3=CAT

990
WS,4=VAXWS
circles={YES|NO} Output Circles Yes
height=value Minimum Cutter Height 0

CAD Converter command line options

Command line options available for the CAD Converter are described in the table below.

Option Description Default


batch Execute without user
interface
input=input-file CAD Input File
output=output-file Output File
dtol=value Deviation Tolerance 0.05
format={ASCII|BINARY} Output File Format BINARY
type={VERICUT|STL} Output File Type STL
dir={INWARD|OUTWARD Normal Direction OUTWARD
}

IGES Converter command line options

Command line options available for the IGES Converter are described in the table below.

Option Description Default


batch Execute without user
interface
batcht (obsolete) Same as "batch"
input=input-file IGES Input File
output=output-file Output File
dtol=value Deviation Tolerance 0.05 for in. model, 1.27 for
mm model
format={ASCII|BINARY} Output File Format BINARY
type={VERICUT|STL} Output File Type STL

991
mode={TRIMMED|BASE|A Surface Input Mode ALL
LL}
dir={INWARD|OUTWARD| Normal Direction OUTWARD
GUESS}
summary Summary of input file
contents

PolyFix Converter command line options

Command line options available for the IGES Converter are described in the table below.

Option Description Default


batch Execute without user
interface
batcht (obsolete) Same as "batch"
input=input-file Input File
intype={VERICUT|STL} Input File Type STL
output=output-file Output File
outformat={ASCII|BINARY Output File Format BINARY
}
outtype={VERICUT|STL} Output File Type STL

Surface to Solid Converter command line options

Command line options available for the Surface to Solid Converter are described in the
table below.

Option Description Default


batch Execute without user
interface
batcht (obsolete) Same as "batch"
input=input-file IGES Input File
output=output-file Output File
tol=value Tolerance

992
intype={VERICUT|STL} Input File Type
outtype={VERICUT|STL} Output File Type
format={ASCII|BINARY} format={ASCII|BINARY} BINARY
matrix=matrix-string Transformation Matrix Identity matrix
offset=value surface Offset 0
base=value Base Location 0
rectangle={NO|YES} Project Rectangle NO

VDA Converter command line options

Command line options available for the VDA Converter are described in the table below.

Option Description Default


batch Execute without user
interface
batcht (obsolete) Same as "batch"
input=input-file VDA Input File
output=output-file Output File
dtol=value Deviation Tolerance 0.05 for in. model, 1.27 for
mm model
format={ASCII|BINARY} Output File Format BINARY
type={VERICUT|STL|POIN Output File Type STL
T}
dir={INWARD|OUTWARD| Normal Direction OUTWARD
GUESS}

993
Controlling VERICUT with comment records
Comment records, for example "PPRINT/COMMENT TEXT" in APT or CLS tool paths,
or "(COMMENT TEXT)" in G-code tool paths, typically have no affect on tool motion
simulated by VERICUT. However, special "VERICUT comment" records are available
to help control the tool path simulation in VERICUT. For example, VERICUT comments
can be used to change cut colors, set VERICUT user interface values, or cause VERICUT
to perform certain actions, such as: AUTO-DIFF model comparisons, reversing the view,
etc.

Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. Some simple examples follow.

Examples of VERICUT comment records that reverse the model view:


y APT or CLS tool path => PPRINT/VERICUT-COMMAND reverse
y G-code tool paths:
- Fanuc control configured with "(" begin comment word, and ")" end comment
word => (VERICUT-COMMAND reverse)
- Cincinnati Acramatic control configured with "(MSG," begin comment word,
and ")" end comment word => (MSG,VERICUT-COMMAND reverse)
- Heidenhain control configured with ":" begin comment word (no end comment
word) => :VERICUT-COMMAND reverse

Click to see specific formats and examples:


y VERICUT-BEGINTABLE record
y VERICUT-COMMAND records
y VERICUT-CUTCOLOR record
y VERICUT-ENDTABLE record
y VERICUT-MATRIX record
y VERICUT-MODAL record
y VERICUT-MOTION record
y VERICUT-OPTIPATH record
y VERICUT-TC record
y VERICUT-TOOLID record
y VERICUT-USERTAG record

994
VERICUT-BEGINTABLE record
Special comment record that, when used with VERICUT-ENDTABLE record, enables
specifying the contents of a table, for use in a VERICUT report, from PPRINT statements
within the toolpath file. The general format is PPRINT/VERICUT-BEGINTABLE
“tagname”, for APT or CLS tool paths, or (VERICUT-BEGINTABLE “tagname”) for
G-code tool paths.

Example of use:
Use to specify the contents for a "Table" type User-Defined Tag:

(VERICUT-BEGINTABLE "setup_info")
( 1ST OP, METALDYNE PUNCH SLEEVE BODY )
( PART #,H0070-0243 )
( REV.,"A" )
( NC Program File,L1H0070-0243.TXT)
( DATE ORIGINALLY PROGRAMMED,10/24/03 )
( PROGAMMED BY,CHARLIE WILSON )
( STOCK,6-1/2" H-13 CUT +.150 )
(- ,CHUCK ON STOCK DIA. 3.00" DEEP )
(- ,WITH FULL CHUCK PRESSURE )
(- ,UNDERCUT YOUR JAWS FOR A GOOD GRIP )
(VERICUT-ENDTABLE)

where setup_info is the User-Defined Tag name, the remaining statements


represent the content of the table, with the exception if the VERICUT-ENDTABLE
statement which indicates the end of the table data. Each comment record
represents a row in the table and the "," character is used to separate the column
entries. (see Using PPRINT info from an NC program in a report, in the Using
VERICUT section for additional information)

NOTE: See VERICUT-USERTAG record for information on populating a


table in a VERICUT report using the a text file.

995
VERICUT-COMMAND records
Special comment records that perform VERICUT commands or operations. The
commands available via comment records are listed below with examples of use.
Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
some examples.

auto-diff
Performs an AUTO-DIFF comparison, then restores the cut model.
Examples of use:
- APT/CLS => PPRINT/VERICUT-COMMAND auto-diff
- G-code (Fanuc) => (VERICUT-COMMAND auto-diff)

display
Updates the display of a FastMill cut model with current cuts.
Examples of use:
- APT/CLS => PPRINT/VERICUT-COMMAND display
- G-code (Fanuc) => (VERICUT-COMMAND display)

display_fixtures
Displays all defined fixture models. (See also "remove_fixtures".)
Examples of use:
- APT/CLS => PPRINT/VERICUT-COMMAND display_fixtures
- G-code (Fanuc) => (VERICUT-COMMAND display_fixtures)

load_model_by_name "<modelname>"
Loads a model referenced by its name. (See also "remove_model_by_name")
Examples of use- load the model named “Model 2” from the sample models list:
Model Definition List
---------------------
Model 1 (Stock)
Model 2 (Fixture)
Model 3 (Design Solid)
- APT/CLS => PPRINT/VERICUT-COMMAND load_model_by_name
“Model 2”
- G-code (Fanuc) => (VERICUT-COMMAND load_model_by_name
“Model 2”)

996
load_fixture_by_seq <n>
Loads the fixture referenced in the sequential order of defined fixtures. (See also
"remove_fixture_by_seq")
Examples of use- load the second fixture model (Model 3) in the sample models
list:
Model Definition List
---------------------
Model 1 (Stock)
Model 2 (Fixture)
Model 3 (Fixture)
- APT/CLS => PPRINT/VERICUT-COMMAND load_model_by_seq 2
- G-code (Fanuc) => (VERICUT-COMMAND load_model_by_seq 2)

pause n
Adds “n” seconds of delay to an Image file being recorded. (See Record Movie
function)
Examples of use- add 5 seconds of pause:
- APT/CLS => PPRINT/VERICUT-COMMAND pause 5
- G-code (Fanuc) => (VERICUT-COMMAND pause 5)

repaint
Repaints solid objects with colors assigned via the Edit menu > Colors: Assign
tab.
Examples of use:
- APT/CLS => PPRINT/VERICUT-COMMAND repaint
- G-code (Fanuc) => (VERICUT-COMMAND repaint)

reset_cutcolor
Resets all of the model colors to the "Reset Cut Color" color. (Ref. Edit menu >
Colors: Assign tab)
Examples of use:
- APT/CLS => PPRINT/VERICUT-COMMAND reset_cutcolor
- G-code (Fanuc) => (VERICUT-COMMAND reset_cutcolor)

reverse
Reverses the view of the VERICUT model. (Ref. View menu > Orient: Reverse)
Examples of use:
- APT/CLS => PPRINT/VERICUT-COMMAND reverse
- G-code (Fanuc) => (VERICUT-COMMAND reverse)

997
remove_fixtures
Removes all displayed fixture models. (See also "display_fixtures".)
Examples of use:
- APT/CLS => PPRINT/VERICUT-COMMAND remove_fixtures
- G-code (Fanuc) => (VERICUT-COMMAND remove_fixtures)

remove_model_by_name "<modelname>"
Removes a model referenced by its name. (See also "load_model_by_name")
Examples of use- remove the model named "Model 2":
- APT/CLS => PPRINT/VERICUT-COMMAND remove_model_by_name
“Model 2”
- G-code (Fanuc) => (VERICUT-COMMAND remove_model_by_name
“Model 2”)

remove_fixture_by_seq <n>
Removes the fixture referenced in the sequential order of defined fixtures. (See
also "load_model_by_seq")
Examples of use- remove the second fixture model in the models list:
- APT/CLS => PPRINT/VERICUT-COMMAND remove_model_by_seq 2
- G-code (Fanuc) => (VERICUT-COMMAND remove_model_by_seq 2)

998
VERICUT-CUTCOLOR record
Special comment records that assign the cut color for the active tool. Cut colors are
referenced via an index corresponding to the colors defined for use via the "Shade Color
list" on the Edit menu > Colors: Define tab. Color index numbers range from 0-n where
“0” refers to the first color in the list-typically assigned to be the Error color. “1” refers
to the second listed color, and so on. The index number is always 1 less than the index
seen in the user interface. Examples follow.

Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
simple examples.

Examples of use:
Set the cut color to "Light Steel Blue", as referenced in the sample Color window below:
APT/CLS => PPRINT/VERICUT-CUTCOLOR 2
G-code (Fanuc) => (VERICUT-CUTCOLOR 2)

999
VERICUT-ENDTABLE record
Special comment record that, when used with VERICUT-BEGINTABLE record, enables
specifying the contents of a table, for use in a VERICUT report, from PPRINT statements
within the toolpath file. The general format is PPRINT/VERICUT-ENDTABLE, for APT
or CLS tool paths, or (VERICUT-ENDTABLE) for G-code tool paths.

Example of use:
Use to specify the contents for a "Table" type User-Defined Tag:
(VERICUT-BEGINTABLE "setup_info")
( 1ST OP, METALDYNE PUNCH SLEEVE BODY )
( PART #,H0070-0243 )
( REV.,"A" )
( NC Program File,L1H0070-0243.TXT)
( DATE ORIGINALLY PROGRAMMED,10/24/03 )
( PROGAMMED BY,CHARLIE WILSON )
( STOCK,6-1/2" H-13 CUT +.150 )
(- ,CHUCK ON STOCK DIA. 3.00" DEEP )
(- ,WITH FULL CHUCK PRESSURE )
(- ,UNDERCUT YOUR JAWS FOR A GOOD GRIP )
(VERICUT-ENDTABLE)

where the VERICUT-BEGINTABLE statement indicates the start of the


table data, setup_info is the User-Defined Tag name, the remaining
statements represent the content of the table, and the VERICUT-
ENDTABLE statement indicates the end of the table data. Each comment
record represents a row in the table and the "," character is used to separate
the column entries. (see Using PPRINT info from an NC program in a report,
in the Using VERICUT section for additional information)

NOTE: See VERICUT-USERTAG record for information on populating a


table in a VERICUT report using a text file.

1000
VERICUT-MATRIX record
Special comment records that specify a twelve parameter tool path transformation matrix:
i1,j1,k1,d1,i2,j2,k2,d2,i3,j3,k3,d3. This record is processed regardless of the Process
Matrix setting. The transformation matrix is similar to the matrix used in programming
APT tool paths. Its twelve parameters reveal the geometrical attributes of the local
(transformed) coordinate system in terms of the workpiece origin.

The format of the matrix is as follows:


i j k d
X i1 j1 k1 d1
Y i2 j2 k2 d2
Z i3 j3 k3 d3

The first three columns represent the axes of the local system: i1, i2, i3 as the positive X-
axis vector; j1, j2, j3 as the positive Y-axis vector; and k1, k2, k3 as the positive Z-axis
vector. The fourth column d1, d2, d3 is the origin point of the local system. The active
matrix is reset to an identity matrix (no rotation or translation) each time a new tool path
file is processed.

Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
simple examples.

Examples of use:
Translate the tool path 2 units in X, 3 in Y, and -1 in Z.
APT/CLS => PPRINT/VERICUT-MATRIX 1,0,0,2,0,1,0,3,0,0,1,-
1
G-code (Fanuc) => (VERICUT-MATRIX 1,0,0,2,0,1,0,3,0,0,1,-1)

As above, except in APT/CLS multi-line record format using the "$" continuation:
PPRINT/VERICUT-MATRIX 1,0,0,2,$
PPRINT/VERICUT-MATRIX 0,1,0,3,$
PPRINT/VERICUT-MATRIX 0,0,1,-1

1001
Rotate the tool path 180 degrees about the Y axis:
APT/CLS => PPRINT/VERICUT-MATRIX -1,0,0,0,0,1,0,0,0,0,-
1,0
G-code (Fanuc) => (VERICUT-MATRIX -1,0,0,0,0,1,0,0,0,0,-
1,0)

1002
VERICUT-MODAL record
Special comment records that specify a user interface value, such as a data field entry or
an option choice. One user variable/value can be set per record. Most user variables
found in a Project file can be set or modified in this way.

Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
simple examples.

Examples of use:

Set the Fast Feed data field value to "100":


APT/CLS => PPRINT/VERICUT-MODAL FASTFEED=100
G-code (Fanuc) => (VERICUT-MODAL FASTFEED=100)

Choosing the Machining Type option for simulation of milling or turning operations:
APT/CLS milling mode => PPRINT/VERICUT-MODAL
MACHTYPE=milling
APT/CLS turning mode => PPRINT/VERICUT-MODAL
MACHTYPE=turning
G-code (Fanuc) milling mode => (VERICUT-MODAL
MACHTYPE=milling)
G-code (Fanuc) turning mode => (VERICUT-MODAL
MACHTYPE=turning)

1003
VERICUT-MOTION record
Special comment records that control when tool motions and cutting are simulated. When
off, motion commands and tool positions are processed, but simulation, cutting, collision
detection, and axis overtravel detection are suspended (ignored) during subsequent
moves. When motion is turned on, the tool and/or NC machine "jumps" to its current
position. The motion "on" condition is automatically set when a reset is done.
Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
simple examples.

Examples of use:

Turn motion off:


APT/CLS => PPRINT/VERICUT-MOTION off
G-code (Fanuc) => (VERICUT-MOTION off)

Turn motion on:


APT/CLS => PPRINT/VERICUT-MOTION on
G-code (Fanuc) => (VERICUT-MOTION on)

1004
VERICUT-OPTIPATH record
Special comment records that control when tool motions are optimized via the OptiPath.
When off, optimization is suspended (ignored) during subsequent moves-tool path
records are written to the Optimized file as they were programmed. Optimization remains
off until the next OptiPath "On" record is encountered. Optimization must be turned on
prior to the next tool change. A format also exists for specifying which OptiPath library
record to use:

VERICUT-OPTIPATH DESC="my_optipath_tool_description"
TEETH=<n>

where "my_optipath_tool_description" is an optimization record description which could


contain any characters, including delimiters. The description must be enclosed in double
quotes. "N" is the number of cutting teeth. This record specifies two of the four values
needed to identify which optimization record to use. The other two values come from
Material and Machine on the OptiPath Control window. If an optimization record
matching the four values is not found, VERICUT continues to write unoptimized tool
path records to the optimized tool path file.
Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
simple examples.

Examples of use:

Turn optimization off:


APT/CLS => PPRINT/VERICUT-OPTIPATH off
G-code (Fanuc) => (VERICUT-OPTIPATH off)
NOTE: "OPTIPATH off" turns off OptiPath until the next "OPTIPATH on" is
encountered.

Turn optimization on:


APT/CLS => PPRINT/VERICUT-OPTIPATH on
G-code (Fanuc) => (VERICUT-OPTIPATH on)

Specify an OptiPath library record for use with the current tool:
APT/CLS => PPRINT/VERICUT-OPTIPATH DESC=".5 Dia Ball EM,
Carbide" TEETH=4
G-code (Fanuc) => (VERICUT-OPTIPATH DESC=".5 Dia Ball EM, Carbide"
TEETH=4)

1005
VERICUT-TC record
Special comment records that define the shapes of cutters, shanks or holders in a tool
assembly. Interpreted like a CUTTER record, anything allowed to follow "CUTTER/" is
also allowed to follow "VERICUT-TC". Like "CUTTER", this record is processed by
default via Tool Change By set to: "Cutter Desc." or "VERICUT TC".

Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
simple examples.

Examples of use:

Defines an APT-type seven parameter cutter shape- 1.0 diameter x .125 corner radius x
3.0 height:
APT/CLS => PPRINT/VERICUT-TC 1.0,.125,0,0,0,0,3.0
G-code (Fanuc) => (VERICUT-TC 1.0,.125,0,0,0,0,3.0)

Defines a profile cutter shape:


APT/CLS => PPRINT/VERICUT-TC
XCUT,PTS,0,0,.5,0,ARC,1,0,.5,PTS,1,.5,1,1
G-code (Fanuc) => (VERICUT-TC
XCUT,PTS,0,0,.5,0,ARC,1,0,.5,PTS,1,.5,1,1)

As above, except in APT/CLS multi-line record format using the "$" continuation:
PPRINT/VERICUT-TC XCUT,PTS,0,0,.5,0,$
PPRINT/VERICUT-TC ARC,1,0,.5,PTS,1,.5,$
PPRINT/VERICUT-TC 1,1

Defines a profile shank shape:


APT/CLS => PPRINT/VERICUT-TC SHANK,PTS,0,0,.5,0,.5,1,0,1
G-code (Fanuc) => (VERICUT-TC SHANK,PTS,0,0,.5,0,.5,1,0,1)

Defines a profile holder shape:


APT/CLS => PPRINT/VERICUT-TC
HOLDER,PTS,0,0,1,0,1.5,.5,1.5,3,0,3
G-code (Fanuc) => (VERICUT-TC
HOLDER,PTS,0,0,1,0,1.5,.5,1.5,3,0,3)

1006
Incorrect examples:

Continuation record missing "VERICUT-TC":


PPRINT/VERICUT-TC XCUT,PTS,0,0,.5,0,ARC,$
PPRINT/1,0,.5,PTS,1,.5,1,1,0,1

The word "ARC" split between lines:


PPRINT/VERICUT-TC XCUT,PTS,0,0,.5,0,AR$
PPRINT/VERICUT-TC C,1,0,.5,PTS,1,.5,1,1,0,1

Continuation record does not have the same keyword "TC":


PPRINT/VERICUT-TC XCUT,PTS,0,0,.5,0,1,.5,1,1 $
PPRINT/VERICUT-COMMAND reverse

1007
VERICUT-TOOLID record
Special comment records that specify the ID of a tool to use from a VERICUT Tool
Library file. This record is acted on only when VERICUT is configured to retrieve tools
from a Tool Library, for example: Tool Change By set to: "Tool Number".

Note that for G-code tool paths, the NC control must be configured to interpret the
comment record format for that control, for example "begin comment" word, "end
comment" word (if present), etc. See "Controlling VERICUT with comment records" for
simple examples.

Examples of use:

Use tool in the library having ID #100002:


APT/CLS => PPRINT/VERICUT-TOOLID 100002
G-code (Fanuc) => (VERICUT-TOOLID 100002)

1008
VERICUT-USERTAG record
Special comment record that enables specifying User-Defined Tag values, for use in a
VERICUT report, from within the toolpath file. The general format is
PPRINT/VERICUT-USERTAG “tagname”=”tagvalue”, for APT or CLS tool paths, or
(VERICUT-USERTAG “tagname”=”tagvalue”) for G-code tool paths.

Examples of use:

Use to specify the value for a "Text" type User-Defined Tag:


PPRINT/VERICUT-USERTAG "text_entry"="This is the text that will
appear in the VERICUT report.")
(VERICUT-USERTAG "text_entry"="This is the text that will appear in the
VERICUT report.")
where text_entry is the User-Defined Tag name, and This is the text that
will appear in the VERICUT report., is what will be written out in the
report. (see Using PPRINT info from an NC program in a report, in the
Using VERICUT sectionfor additional information)

Use to specify the value for a "Table" type User-Defined Tag:


PPRINT/VERICUT-USERTAG "table_name"="/path/filename")
(VERICUT-USERTAG "table_name"="/path/filename")
where table_name is the User-Defined Tag name, and /path/filename
represents the path and file name of the text file containing the data for the
table. (see Using data from a file in a report, in the Using VERICUT section
for additional information)

NOTE: See VERICUT-BEGINTABLE record and VERICUT-


ENDTABLE record for information on populating a table in a VERICUT
report using the PPRINT statements in the toolpath file.

Use to specify the value for a "Picture From File" type User-Defined Tag:
PPRINT/VERICUT-USERTAG "picture"="/path/filename")
(VERICUT-USERTAG "picture"="/path/filename")
where picture is the User-Defined Tag name, and /path/filename represents
the path and file name of the image file containing picture for the report. (see
Using PPRINT info from an NC program in a report, in the Using VERICUT
section for additional information)

1009
CNC Machine Probing

CNC Machine Probe Simulation


Introduction
CNC Machine Probe Simulation enables you to simulate the use of probing devices on a
CNC machining center and detect errors that could break the probe. The simulation
feature can also be used to simulate any machine model stopping when it contacts
another, such as moving a stock until it contacts a bar stop or moving steady-rest rollers
until they contact the stock. Tool length setting and checking is not addressed directly at
this time.
CNC Machine Probing is a licensed add-on module to Verification. You do not need a
probe license to create a probe tool in Tool Manager or to use a probe tool in VERICUT.
You do need a probe license to make the motion stop when the probe tip contacts
something. Without a probe license, and without configuring the control for probe
motion, you will get collision errors when the probe tool collides with something it
should not, as described below.

Probe tool
A new probe tool type is added to Tool Manager for use when probing. The probe tip
consists of a spherical "tip" of specified diameter, a shank/stem with a specified diameter,
and an overall length. The probe tool can also have holder components used for collision
detection.
A probe tool does not cut. In fact, VERICUT's material removal logic is never used for a
probe tool. This is mainly because a probe tool, unlike a milling tool, does not have to be
symmetric about an axis of rotation. Thus VERICUT can support multiple tip probe tool
configurations like a "star" probes. This design also positions us to be able to support
asymmetric probe tips in some future release.
VERICUT's collision logic for a probe tool is more like a turning tool. As with a turning
tool, a probe tool uses machine simulation's collision algorithm to detect collisions. No
material is removed, but errors are reported in the logger and log file, and the error
counter is incremented. If a machine simulation view is open and simulation and collision
checking is on, you will see the usual error color display.

Probe motion
The G-Code macro Probe turns on probing for the current block. This macro is associated
with the active tool component, and the corresponding tool must be a Probe Tool. Probe
motion causes VERICUT to calculate the location where the probing component
encounters an object between the start and the end point of the motion. The machine then
moves to the probe contact location, or if no contact is made, to the end point of the
motion.

1010
Probing with a "Probe" Tool
When probing with a Probe Tool, the end of the motion is calculated as follows:
The spherical probe tip(s) are processed through a special algorithm that computes an
accurate "hit" location. The location is based on the "great circle" of the sphere which lies
in the motion plane.

The axes are moved to that location. If the spherical probe tip makes contact at any other
location other than the "great circle", a warning message is output and motion stops at the
alternate location. If no contact is detected, motion continues to the programmed location.
Standard collision logic is used to determine if the probe tip hits any other component
during the probe motion, but the motion continues to the probe's destination.

Stop Motion On Contact with Any Component


While not technically "probe" motion, this feature uses the same logic and can be used
for moving a component, such as a steady rest roller, into contact with another
component, such as the stock, or for moving the stock component into a bar stop. The G-
Code macro Touch turns on "move until you touch" for the current block. The default
"touch" component is the active tool. Use the G-Code macro TouchComponentName to
specify a component other than the active tool.

When any portion of the touch component contacts any other component, the axes are

1011
moved to that location. The axes move until the touch component arrives at the
programmed location, or until the object contacts something. Standard collision logic is
used to determine if any other component hits something during the "touch" motion, but
the motion continues to the touch component's destination.

When probing with something other than a Probe tool-type, VERICUT approximates the
contact location. When any portion of the touch component contacts any other
component, the axes are moved to that location and stop.

Collision Detection during Probe Motion


Machine Simulation and collision checking do not need to be "on" to detect collisions. As
with turning tool holders, if the "Display Holders in Workpiece View" box is checked
"on", then collisions between the holder and "workpiece visible" components are detected
using the same algorithm used by machine simulation. A probe "holder" error states that
a collision occurred between the "Probe Body" and workpiece components (typically
Stock or Fixture).

During "Probe" motion, collision checking only looks at the "stem" portion of the Probe
Tip, treating it as part of the holder. There is no collision checking applied to the
spherical portion of the probe tip since motion stops when it contacts anything. Collisions
between the Probe Tip and any "workpiece visible" component generates an error stating
that the "Probe Tip" and the workpiece components collided.

If a Probe tool is used during normal (not Probe) motion, collision checking also looks at
the spherical Probe Tip and reports any collisions.

Position Feedback and Logic


NC program probe logic often uses feedback of axis positions when the probe contacts.
VERICUT supports this using the current ability to assign axis positions to variables.

1012

You might also like