Topic: DMD0523 CTAXLIMT - CTRIO2 Axis Run Trapezoid with Limits |
|
This instruction can only be used with the CTRIO2 module.
The CTRIO2 Axis Run Trapezoid with Limits (CTAXLIMT) instruction is used to define and initiate a single move referenced to a limit, typically a limit switch connected to an input of the CTRIO2. This instruction is useful for creating a homing routine or for registration. The position move is specified in terms of Limits, not absolute or relative position values. Limits can be inputs that are hard wired to the CTRIO2 module - this requires the CTRIO2 module be configured to have one or more of its inputs as Limits, or they can be bit locations. The moves will execute using the parameters defined by a previously executed Axis Configuration (CTAXCFG) instruction.
|
|
Parameters:Note: Use the F9 key or click the 'three dot box' at the right edge of the parameter field to open the Default Element Selection Tool (the Element Picker or the Element Browser) or use the Down-Arrow key (Auto-Complete) on any parameter field to see a complete list of the memory locations that are valid for that parameter of the instruction.
Pulse Output Device - selects which preconfigured CTRIO Pulse Output device to use. Before this instruction can select a Pulse Output device, a CTRIO Device must be configured with at least one of its output channels setup for Pulse / Direction or CW / CCW pulse output mode.
Pulse Output Structure - this field displays the name of the Pulse Output Structure that will be used by this instruction. This structure was created when the CTRIO module was configured during the Module Configuration phase.
Limit 1 Type - this option defines the first Limit.
Termination Condition - this option defines the action to take once the Limit is reached.
Reset Output Position - this option defines the action to take after the termination Condition is completed:
Alternate Maximum Frequency - enable this option to specify the frequency (in pulses per second) that the pulse output will ramp towards that is different from what is specified in the Axis Configuration (CTAXCFG) instruction. This can be any positive constant value or any readable numeric location. The value is only read when the E/R input initially comes ON.
The On Success and On Error parameters specify what action to perform when this instruction completes. You do not have to use the same type of selection for both On Success and On Error.
If the Set Bit selection is used for either On Success or On Error, the specified BIT location will be SET OFF when the instruction is first enabled and will remain OFF until the instruction completes. Once complete, the appropriate Success or Error bit location ON. The specified Bit location is enabled with a SET (Latch) operation meaning that it will remain ON even if the input logic for the instruction goes OFF.
If the JMP to Stage selection is used for either On Success or On Error the target Stage must be in the same Program code-block as this instruction, you cannot specify a target Stage that exists in a different Program code-block. When the operation finishes, the target Stage will be enabled the same way as a standalone Jump to Stage (JMP) instruction would do it. The JMP to Stage option will only be available if this instruction is placed in a Program code-block.
On Success selects which of the following actions to perform if the operation is successful:
On Error selects which of
the following actions to perform if the operation is unsuccessful:
If either the On Success or On Error selections are set to JMP to Stage, Automatically create the SG box for any NEW stage number will be enabled which will automatically create any target stage that does not already exist.
Note: any time the On Error condition occurs, the CTRIO generates an Error Code that can be read in the <Module Name>.ErrorCode (Module Name is the name assigned to the CTRIO in the Module Configuration). The List of Error Code values (in decimal) follows:
|
|
Instruction Inputs:
The first input (E/R) in the Enable / Reset input. When this input logic is ON the specified Pulse Output will be enabled (.OutputEnabled = ON) and the Pulse Output Device will begin to move in the direction specified by the DIR input toward Limit 1.
The second input is the Direction (DIR) input. The state of this input determines the direction of the position move. If this input logic is OFF when the E/R input logic comes ON, a clockwise (positive) move is performed. If this logic is ON when the E/R input logic comes ON, a counter-clockwise (negative) move is performed.
The third input (SUS) is the Suspend input. When this input logic transitions ON, the
CTRIO2 will ramp down to zero using the Deceleration
Rate specified in the Axis Configuration (CTAXCFG) instruction.
No additional pulses will be emitted as long as this input remains ON.
|
|
Status Display:
The status display of the instruction shows Values: .OutputPosition, Termination Condition - Position Offset from Limit 1 (if configured), Alternate Maximum Frequency (if configured), and Termination Condition - Limit Creep Frequency (if configured), and the Highlights: .OutputEnabled, .OutputActive, .Direction, .OutputSuspended, and .OutputStalled bits.
The red triangle in the upper left corner of the status display indicates this is a Fully Asynchronous instruction.
|
|
CTRIO2 Structure Field Care-Abouts:The following is a list of the"dot" fields of each Pulse Output Structure that are programmatically used with the CTRIO2 Axis Run Trapezoid w/Limits (CTAXLIMT) instruction. To see a complete listing of all CTRIO structures and members, go to the Project Browser --> Configuration --> Memory --> I/O --> Specialty.
COLOR KEY Blue: CTRIO2 Input Maroon: CTRIO2 Output Black: CTRIO2 Module Silver: Not used for this instruction
Note: The red "x" is the digit 0, 1, 2, or 3.
NOTES: (1)This structure member only available for CTRIO2 (not CTRIO). For CTRIO this remains zero.
|
|
See Also:
CTRIO2 Axis Run Dynamic Position Mode
CTRIO2 Axis Run Dynamic Velocity Mode
CTRIO2 Axis Run Trapezoid w/ Limits
|
|
Example 1 of 2:Description of a Typical CTRIO2 Axis Run Trapezoid w/Limits (CTAXLIMT) Stage Diagram:This is a stage diagram of a simple sequence control that would use a stepper motor to move to a position.
Initially the Config stage waits for Configure to come ON. When it does the CTRIO2 axis is defined and the process transitions to the Move stage.
The Move stage remains enabled until the limit defined by the CTAXLIMT is reached. When it is reached transition is made to the Stop stage.
The Stop stage simply exits the Program code block.
Description of a Typical CTRIO2 Axis Run Trapezoid w/Limits (CTAXLIMT) Stage Ladder:This is the ladder equivalent of the above stage diagram that uses the CTAXLIMT instruction to move to a position.
This example presupposes the existence of the following System Configuration in the CTRIO2 (PLC --> System Configuration --> Module Configuration(s) --> CTRIO_000 -->):
Config is the initial stage and waits for the input Configure bit to come ON. When it does the CTRIO2 axis is configured using the CTAXCFG instruction. If there is an error then transition is made to the ErrorStage stage where ladder logic should exist (not shown here) that would properly handle the error (e.g. to process the $CTRIO_000.ErrorCode value). If the configuration was successful, then transition is made to the Move stage. Since the CTAXCFG is configured to Do Not Initialize Output Position then $CTRIO_000_Out0.OutputPosition is not zeroed.
Move is the main CTAXLIMT instruction stage and will remain enabled for the move. When Run2Limit comes ON it causes the following to happen:
If during the execution of this move, the Suspend bit comes ON then the CTRIO2 output will decelerate to zero. When Suspend bit goes back OFF it will accelerate back to the Alternate Maximum Frequency.
The Stop stage exits this Program code block. Example 2 of 2:
|
|