FB_AxisPlsPosNoModulo

PLCopen motion icon Pipe Network motion icon

 Function BlockClosed A function block groups an algorithm and a set of private data. It has inputs and outputs. - Used for any position of a non-modulo axis in both directions.

Inputs

Input

Data Type

Range

Unit

Default

Description

ibExecute

BOOL

 

 

 

Enable PLS.

iPosition

LREAL

 

 

 

Any position of a non-modulo axis.

iStartPos

LREAL

 

 

 

Start position of PLS.

iEndPos

LREAL

 

 

 

End position of PLS.

iDelayTime

TIME

 

 

 

Delay time for compensation.

iHysteresis

LREAL

 

 

 

Hysteresis.

ibForce

BOOL

 

 

 

Force PLS.

Outputs

Output

Data Type

Range

Unit

Description

oPLS

BOOL

 

N/A

Position limit switch.

Remarks

  • The Boolean output oPLS is set to:
    • TRUE if the position has crossed the start position.
    • FALSE if the position has crossed the end position.
  • The function block has the possibility to compensate a delay time of the connected device (e.g., glue nozzles).
  • It is possible to define a hysteresis for switching on and off of the PLS.

Example

Timing

Hysteresis

FBD Language Example

FFLD Language Example

IL Language Example

Not available.

ST Language Example

//PLSOutput is True when position input is between 180 and 270 with a T#2ms delay
//Can also force the output to be true with ForceOuput variable
//Hysteresis is on for 3 user units in case direction changes around start point

Inst_FB_AxisPlsPosNoModulo( EnablePLS, ActualPosition, 180, 270, T#2ms, 3, ForcePLS );

PLSOutput := Inst_FB_AxisPlsPosNoModulo.oPLS;