FB_SoEReadAmplifierTemperature
With the FB_SoEReadAmplifierTemperature function block the temperature of the drive (S-0-0384) can be read.
Inputs
VAR_INPUT
sNetId : T_AmsNetId := '';
bExecute : BOOL;
tTimeout : TIME := DEFAULT_ADS_TIMEOUT;
END_VAR
Name | Type | Description |
---|---|---|
sNetId | T_AmsNetId | String, which contains the AMS Network ID of the PC (type: T_AmsNetId). |
bExecute | BOOL | The function block is enabled via a positive edge at this input. |
tTimeout | TIME | Maximum time allowed for the execution of the function block. |
Inputs/outputs
VAR_IN_OUT
Axis : NCTOPLC_AXIS_REF;(* reference to NC axis *)
END_VAR
Name | Type | Description |
---|---|---|
Axis | Axis data structure of the type NCTOPLC_AXIS_REF |
Outputs
VAR_OUTPUT
bBusy : BOOL;
bError : BOOL;
iAdsErrId : UINT;
iSercosErrId : UINT;
fAmplifierTemperature : REAL;
dwAttribute : DWORD;
END_VAR
Name | Type | Description |
---|---|---|
bBusy | BOOL | This output is set when the function block is activated, and remains set until a feedback is received. |
bError | BOOL | This output is set after the bBusy output has been reset when an error occurs in the transmission of the command. |
iAdsErrId | UINT | Returns the ADS error code of the last executed command when the bError output is set. |
iSercosErrId | UINT | In the case of a set bError output returns the Sercos error of the last executed command. |
fAmplifierTemperature | REAL | Returns the drive temperature (e.g. 26.2 corresponds to 26.2 °C). |
dwAttribute | DWORD | Returns the attributes of the Sercos parameter. |
Sample
fbReadAmplifierTemp :
FB_SoEReadAmplifierTemperature;
bReadAmplifierTemp : BOOL;
fAmplifierTemperature : REAL;
(* NcAxis *)
NcToPlc AT %I* : NCTOPLC_AXIS_REF;
IF bReadAmplifierTemp THEN
fbReadAmplifierTemp(
Axis := NcToPlc,
bExecute := TRUE,
tTimeout := DEFAULT_ADS_TIMEOUT,
fAmplifierTemperature=>fAmplifierTemperature
);
IF NOT fbReadAmplifierTemp.bBusy THEN
fbReadAmplifierTemp(Axis := NcToPlc, bExecute := FALSE);
bReadAmplifierTemp := FALSE;
END_IF
END_IF