FUNCTION BLOCKS of basic machine elements


Below you can download example function blocks that can be used to model the behavior of basic device elements.
How to download and install a function block for your own project? (course - part 1, watch the clip from 6:25 min.)


1-axis rotary module with positioner
get function block
application example



function block inputs:
ENABLE - enabling the module operation
DEMAND POS - set position of the module in [deg./sec]
MAX VEL - maximum speed in [deg./sec]
% VEL - movement speed as a% of maximum speed
MAX ALPHA - maximum position of the module in [degrees]
MIN ALPHA - minimum position of the module in [degrees]
RV_no - register number in which the current position of the module is stored.
You must provide this register and it must be different for each linear module in a given project.
FREQ - simulation frequency in [Hz] - frequency should be calculated as the reciprocal of the simulation period, which can be set and checked in the top menu -> settings -> simulation in window. For an exemplary period value of 2000 [microseconds], the frequency value is 500 [Hz], because 1 / (2000 [microseconds]) = 500 [Hz].

function block outputs:
POS ALPHA - current position of the output element of the rotary module
MAX_Limit - limit switch MAX position signal - sensor range: 1 [deg.]
MIN_Limit - limit switch MIN position signal - sensor range: 1 [deg.]
IN POSITION - signal active when set position is equal to the current position (DEMAND POS = POSITION) with the accuracy of +/- 0.5 [st]

Single-axis linear module with positioner:
get function block
application example

 

function block inputs:
ENABLE - enabling the module operation
DEMAND POS - set position of the module in [deg./sec]
MAX VEL - maximum speed in [deg./sec]
% VEL - movement speed as a% of maximum speed
MAX - maximum module position in [mm]
MIN - minimum module position in [mm]
RV_no - register number in which the current position of the module is stored.
You must provide this register and it must be different for each linear module in a given project.
FREQ - simulation frequency in [Hz] - frequency should be calculated as the reciprocal of the simulation period, which can be set and checked in the top menu -> settings -> simulation in window . For an exemplary period value of 2000 [microseconds], the frequency value is 500 [Hz], because 1 / (2000 [microseconds]) = 500 [Hz].

function block outputs:
POSITION - current position of the linear module block
MAX_Limit - limit switch MAX position signal - sensor range: 1 [mm]
MIN_Limit - limit switch MIN position signal - sensor range: 1 [mm]
IN POSITION - signal active when set position is equal to the current position (DEMAND POS = POSITION) with the accuracy of +/- 0.5 [st]

The function block can be freely modified.

Double-acting pneumatic cylinder
get function block
application example



function block inputs:
ENABLE - activation of the actuator block
'MOVE +' - when the signal is active, the piston rod extends
'MOVE -' - when the signal is active, the piston rod retracts
MAX VEL - maximum speed in [mm / sec]
% VEL - movement speed as a% of maximum speed
MAX - maximum position of the actuator stroke in [mm]
MIN - minimum position of the actuator stroke in [mm]
RV_no - register number where the current position of the piston rod is stored. You must provide this register and it must be different for each actuator in a given project.
FREQ - simulation frequency in [Hz] - frequency should be calculated as the reciprocal of the simulation period, which can be set and checked in the top menu -> settings -> simulation in window . For an exemplary period value of 2000 [microseconds], the frequency value is 500 [Hz], because 1 / (2000 [microseconds]) = 500 [Hz].

function block outputs:
POSITION - current position of the piston rod
MAX_Limit - limit switch MAX position signal - sensor range: 1 [mm]
MIN_Limit - limit switch MIN position signal - sensor range: 1 [mm]

The function block can be freely modified.

Single-acting pneumatic cylinder with self-extension
get function block
application example



function block inputs:
ENABLE - activation of the actuator block
'MOVE -' - when the signal is active, the piston rod retracts
MAX VEL - maximum speed in [mm / sec]
% VEL - movement speed as a% of maximum speed
MAX - maximum position of the actuator stroke in [mm]
MIN - minimum position of the actuator stroke in [mm]
RV_no - register number where the current position of the piston rod is stored. You must provide this register and it must be different for each actuator in a given project.
FREQ - simulation frequency in [Hz] - frequency should be calculated as the reciprocal of the simulation period, which can be set and checked in the top menu -> settings -> simulation in window . d, which can be set and checked in the top menu -> settings -> simulation in window. For an exemplary period value of 2000 [microseconds], the frequency value is 500 [Hz], because 1 / (2000 [microseconds]) = 500 [Hz].

function block outputs:
POSITION - current position of the piston rod
MAX_Limit - limit switch MAX position signal - sensor range: 1 [mm]
MIN_Limit - limit switch MIN position signal - sensor range: 1 [mm]

The function block can be freely modified.

Single-acting pneumatic cylinder with self-retraction
get function block
application example



function block inputs:
ENABLE - activation of the actuator block
'MOVE +' - when the signal is active, the piston rod extends
MAX VEL - maximum speed in [mm / sec]
% VEL - movement speed as a% of maximum speed
MAX - maximum position of the actuator stroke in [mm]
MIN - minimum position of the actuator stroke in [mm]
RV_no - register number where the current position of the piston rod is stored. You must provide this register and it must be different for each actuator in a given project.
FREQ - simulation frequency in [Hz] - frequency should be calculated as the reciprocal of the simulation period, which can be set and checked in the top menu -> settings -> simulation in window . For an exemplary period value of 2000 [microseconds], the frequency value is 500 [Hz], because 1 / (2000 [microseconds]) = 500 [Hz].

function block outputs:
POSITION - current position of the piston rod
MAX_Limit - limit switch MAX position signal - sensor range: 1 [mm]
MIN_Limit - limit switch MIN position signal - sensor range: 1 [mm]

The function block can be freely modified.

Rotary servo drive with positioner
get function block
application example



function block inputs:
ENABLE - activation of the servo drive
DEMAND POS - set position in [pulses]
MAX VEL - maximum speed in [rpm]
% VEL - movement speed as a% of maximum speed
MAX - maximum position of the motor shaft in [imp.]
MIN - minimum position of the motor shaft in [imp.]
RV_no - register number in which the current position of the servo drive shaft is stored in [imp.].
You must provide this register, and it must be different for each block in a given project.
FREQ - simulation frequency in [Hz] - frequency should be calculated as the reciprocal of the simulation period, which can be set and checked in the top menu -> settings -> simulation in window. For an exemplary period value of 2000 [microseconds], the frequency value is 500 [Hz], because 1 / (2000 [microseconds]) = 500 [Hz]. 
IMP_ROT - motor resolution in [pulses per revolution]

function block outputs:
IMP - current position of the servo drive in [pulses]
RAD - current position of the servo drive in [radians]
MAX_Limit - limit switch MAX position signal - sensor range: 1 [imp.]
MIN_Limit - limit switch MIN position signal - sensor range: 1 [imp.] 
IN POSITION - signal active when the set position is equal to the current position (DEMAND POS = POSITION) with the accuracy of +- 0.5 [imp.]