MC_StepAbsoluteSwitch
This function block searches for an absolutely positioned, external physical switch.
In general, an absolute switch has two "off" areas and one "on" area.

If the absolute switch cannot be overcrossed, then it has only one "off" area and one "on" area.

 Inputs
 Inputs
VAR_INPUT
    Execute             : BOOL; 
    Direction           : MC_Home_Direction; 
    SwitchMode          : MC_Switch_Mode; 
    ReferenceSignal     : MC_Ref_Signal_Ref; 
    Velocity            : LREAL; 
    Acceleration        : LREAL; 
    Deceleration        : LREAL; 
    Jerk                : LREAL; 
    SetPosition         : LREAL; 
    TimeLimit           : TIME; 
    DistanceLimit       : LREAL; 
    TorqueLimit         : LREAL; 
    PositiveLimitSwitch : BOOL; 
    NegativeLimitSwitch : BOOL; 
    BufferMode          : MC_BufferMode; 
    Options             : ST_Home_Options4; 
END_VAR | Name | Type | Description | 
|---|---|---|
| Execute | BOOL | The command is executed with a rising edge at the Execute input. | 
| Direction | Enumeration that defines the initial direction of movement for the search procedure. | |
| SwitchMode | Enumeration that defines the final condition for the search procedure. | |
| ReferenceSignal | This structure defines the source of the reference cam signal. | |
| Velocity | LREAL | Maximum travel velocity (>0). | 
| Acceleration | LREAL | Acceleration (≥0). If the value is 0, the standard acceleration from the axis configuration applies. | 
| Deceleration | LREAL | Deceleration (≥0). If the value is 0, the standard deceleration from the axis configuration applies. | 
| Jerk | LREAL | Jerk (≥0). If the value is 0, the standard jerk from the axis configuration applies. | 
| SetPosition | LREAL | Position value that the axis position will be set to. | 
| TimeLimit | TIME | Exceeding this time leads to the search procedure being aborted. | 
| DistanceLimit | LREAL | Exceeding this distance in relation to the start position leads to the search procedure being aborted. | 
| TorqueLimit | LREAL | The motor torque is limited to this value in order to avoid mechanical damage. | 
| PositiveLimitSwitch | BOOL | Signal of the hardware limit switch in the logically positive direction of movement (PositiveLimitSwitch = FALSE within the permissible travel range). | 
| NegativeLimitSwitch | BOOL | Signal of the hardware limit switch in the logically negative direction of movement (NegativeLimitSwitch = FALSE within the permissible travel range). | 
| BufferMode | MC_BufferMode | Not implemented | 
| Options | DisableDriveAccess: Set to FALSE for Beckhoff drives, usually to TRUE for third-party drives (see info). EnableLagErrorDetection: In the step functions, the lag error detection is switched off in order to ensure a smooth referencing process. If it would be purposeful to keep the lag error detection active in an application, this can be achieved by setting this flag. | 
|  | If DisableDriveAccess = TRUE, the user is responsible for modifying and reconstructing required drive parameters. The parameters required for the intended homing sequence must be agreed with the manufacturer of the third-party drive. | 
 /
/ Inputs/Outputs
 Inputs/Outputs
VAR_IN_OUT
    Axis      : AXIS_REF;
    Parameter : MC_HomingParameter;
END_VAR| Name | Type | Description | 
|---|---|---|
| Axis | Axis data structure of the type AXIS_REF, which uniquely addresses an axis in the system. Among other parameters it contains the current axis status, including position, velocity or error state. | |
| Parameter | MC_HomingParameter | Data structure of the type MC_HomingParameter, which must be transferred from function block to function block over the entire homing sequence. | 
 Outputs
 Outputs
VAR_OUTPUT
    Done           : BOOL;
    Busy           : BOOL;
    Active         : BOOL;
    CommandAborted : BOOL;
    Error          : BOOL;
    ErrorID        : UDINT;
END_VAR| Name | Type | Description | 
|---|---|---|
| Done | BOOL | Becomes TRUE, if the command was completed successfully. | 
| Busy | BOOL | The Busy output becomes TRUE when the command is started with Execute and remains TRUE as long as the command is processed. If Busy becomes FALSE again, the function block is ready for a new order. At the same time one of the outputs, Done, CommandAborted or Error, is set. | 
| Active | BOOL | Indicates that the command is executed. | 
| CommandAborted | BOOL | Becomes TRUE, if the command could not be fully executed. | 
| Error | BOOL | Becomes TRUE, as soon as an error occurs. | 
| ErrorID | UDINT | If the error output is set, this parameter supplies the error number. |