Sottrazione BCD a 4 cifre
Sottrae la costante equivalente BCD a 4 cifre o area a 16 bit per dati BCD a 4 cifre specificata da s dall'area a 16 bit per dati BCD a 4 cifre specificata da d se il trigger EN è in stato TRUE. Il risultato viene memorizzato in d.
Ingresso
Sottraendo, area a 16 bit per dati BCD a 4 cifre o costante equivalente
Uscita
Minuendo e risultato, area a 16 bit per dati BCD a 4 cifre
Anziché utilizzare questa istruzione F, si consiglia di utilizzare l'istruzione FP7 corrispondente: FP_SUB_BCD Sottrazione fra dati BCD
se il risultato del calcolo è 0.
se il risultato eccede l'intervallo di dati BCD a 4 cifre (overflow).
Tutte le variabili di ingresso e uscita utilizzate per programmare questa funzione sono state dichiarate nell'intestazione del POU. La stessa intestazione del POU è utilizzata per tutti i linguaggi di programmazione.
VAR
start: BOOL:=FALSE;
(*activates the function*)
subtrahend: WORD:=16#0011;
(*this value will be subtracted
from the output_value*)
output_value: WORD:=16#2111;
(*result after 0->1 leading
edge from start: 16#2100*)
END_VAR
Quando la variabile start passa da FALSE a TRUE, la funzione viene eseguita.
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
B(B_CONTACT,,start,3,1,5,3,R);
B(B_VARIN,,subtrahend,10,2,12,4,);
B(B_VAROUT,,output_value,18,2,20,4,);
B(B_F,F45_BSUB!,Instance,12,0,18,4,,?DEN?D@'s'?AENO?Cd);
L(1,2,3,2);
L(5,2,12,2);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF DF(start) then
F45_BSUB(subtrahend, output_value);
END_IF;