Program example: motor controller with visualization

Program example: motor controller with visualization 1:

EtherCAT XML Device Description

The display matches that of the CoE objects from the EtherCAT XML Device Description. We recommend downloading the latest XML file from the download area of the Beckhoff website and installing it according to installation instructions.

Program example: motor controller with visualization 2: Download (example file)

Used Master: TwinCAT 2.11 (for older versions the control loop has to be programmed manually; in this case it is already implemented in the NC).
This application example demonstrates movement of a motor to any position or in continuous mode with the aid of visualization. The velocity, the starting acceleration and the deceleration can be specified.

The example program consists of two files. On the one hand the PLC file and on the other System Manager file.

First open the PLC file and compile it so that you have the *.tpy file available that is required for the System Manager.

Please note that you may have to adjust the target platform in the PLC program (default: PC or CX 8x86). If required, you can select the target platform under Resources -> Controller configuration.

Program example: motor controller with visualization 3:
Selection of the target platform

Please note the following for the System Manager file:

The PLC program is configured as follows. The libraries TcMC.lib and TcNC.lib must be integrated (see Fig. Required libraries).

Program example: motor controller with visualization 6:
Required libraries

Once this is done, certain global variables are declared (see Fig. Global variables). The data types PLCTONC_AXLESTRUCT and NCTOPLC_AXLESTRUCT deal with the communication between the PLC and the NC.

Program example: motor controller with visualization 7:
Global variables

Once the global variables have been declared, programming can commence. Start with declaring local variables (see Fig. Local variables).
MC_Direction is an enumeration type that specifies the direction of travel for the block MC_MoveVelocity, which in turn initiates continuous travel of the motor.
An axis reset is carried out with the function block MC_Reset. Absolute positioning is carried out with the function block MC_MoveAbsolute. The current axis position can be read with the function block MC_ActualPosition.
MC_Power enables the axis; MC_Stop is required for stopping the axis.

Program example: motor controller with visualization 8:
Local variables

The program can then be programmed as follows (see Fig. Program code):

Program example: motor controller with visualization 9:
Program code

The motor can then be operated with the aid of the following visualization (see Fig. Visualization).

Press Enable to enable the axis. You now have the choice. You can press the Left or Right button in free run mode and the motor will turn at the velocity defined in fbMoveVelocity_Axis_1 in the selected direction. Or you can specify in Absolute mode velocity, acceleration, deceleration and the position to be driven to and start the drive with Start Job. If no values are entered for acceleration and deceleration the default value of the NC is used.

Program example: motor controller with visualization 10:
Visualization
Program example: motor controller with visualization 11:

Information on function blocks and data types

Further information on the function blocks and data types used can be found in the Beckhoff Information System.