This function activates overload monitoring in the axis i_stAxisId.
Overload detection is used to monitor the deviation of the torque (relative to the motor shaft) from the expected torque (feed forward). When the monitoring system is enabled, the drive is stopped (overload stop). The power supply must be parameterized so that the expected torque is calculated.
i_lrTorque indicates the threshold of the deviation from the expected torque. The deviation can be detected via the FeedbackCurrent. The FeedbackCurrent can be converted into the deviation from the expected torque using the TorqueConstant.
Torque deviations are caused for instance by:
Friction (if not taken into account in the parameters StaticFriction and ViscousFriction)
External torques (for example, moving against limit stop)
Variable moment of inertia
Oscillations in the system (for example, mechanical resonances)
Transient response of the controller (especially at strong jerks)
Monitoring is only active in a specific position range. This position range is defined by i_lrLowLimit (low position limit) and i_lrHighLimit (high position limit).
If the threshold i_lrTorque is exceeded within the position range, an internal timer is incremented. If the threshold is undershot during the time i_uiOverloadTime, the internal timer is decremented. If the internal timer reaches the value i_uiOverloadTime, the monitoring system is enabled. The following diagram illustrates this behavior.
If an overload occurs, the position of the axis i_stAxisId is kept in an internal parameter after the time i_uiOverloadTime has elapsed. This position is used as reference position. The drive remains in position control.
The state of the monitoring system can be read using the function FC_OverloadDetectionGetState.
The threshold i_lrTorque is exceeded if the overall torque is greater than the expected torque plus the parameterized threshold of the deviation.
Current oscillation and high noise in the current signal (FeedbackCurrent) may cause mistripping. You can avoid this by using smooth motions.
Input |
Data type |
Description |
---|---|---|
i_stAxisId |
ST_LogicalAddress |
Logical address of the axis |
i_lrTorque |
LREAL |
Maximum permitted deviation from the expected torque (in Nm) |
i_lrLowLimit |
LREAL |
Lower position limit (in user-defined units) |
i_lrHighLimit |
LREAL |
Upper position limit (in user-defined units) |
i_uiOverloadTime |
UINT |
Time after which the axis is stopped in an overload case (in ms) |
Data type |
Description |
---|---|
DINT |
0: OK -1: Logical address of the servo amplifier or motor invalid -2: LowLimit greater or equal to HighLimit -3: Torque exceeds maximum torque -4: Value i_uiOverloadTime is out of the range (>1000) -5: Firmware version of the servo amplifier is not supported |
The following program example moves an axis with two positioning instructions. Torque monitoring (FC_Overload) is activated during the procedure.
PROGRAM PLC_PRG
VAR
lState: DINT:=1;
lResult: DINT;
END_VAR
CASE lState OF
1:
FC_CycleCheckTimeSet(100, 200);
FC_ControllerEnableSet(Axis.stLogicalAddress);
lResult:=FC_OverloadDetectionSet(i_stAxisId:= Axis.stLogicalAddress, i_lrTorque :=0.08,
i_lrLowLimit:=10, i_lrHighLimit:=350, i_uiOverloadTime:=500);
lState:=lState+1;
2:
IF Axis.AxisState = 3 THEN
FC_PosStartSmooth(Axis.stLogicalAddress,0, 250, 0, 1000, 1000, 0, 0,
ET_PosMode.Absolute, 0);
lState:=lState+1;
END_IF;
3:
IF Axis.AxisState = 3 THEN
FC_PosStartSmooth(Axis.stLogicalAddress,360, 250, 0, 1000, 1000, 0, 0, ET_PosMode.Absolute, 0);
lState:=2;
END_IF;
END_CASE;
The axis (motor shaft) was braked to test the function, resulting in a rise in current and an increase in torque. The figure shows the current increase (or torque increase) and the triggering of the diagnostic message (vertical dotted line).