Conta il numero di fronti di salita per ciascun bit
Questa istruzione FP conta il numero di fronti di salita di ciascun bit nell'area dati specificata dall'indirizzo iniziale s1_Start e il numero di bit n_Bits. I risultati del conteggio vengono salvati negli elementi n_Bits del tipo di dato DINT o UDINT a partire da d_Start.
Ingresso
Indirizzo iniziale dell'area dati per bit da valutare.
Utilizzare la seguente formula per determinare la dimensione minima di quest'area dati:
Tutte le posizioni decimali nel risultato di questa divisione intera devono essere rimosse.
n_Bits da 1–16 => la dimensione è 1 word.
n_Bits da 17–32 => la dimensione è 2 word...
Indirizzo iniziale dell'area di lavoro. La sua dimensione deve essere identica a quella di s1_Start.
Numero di bit (intervallo utilizzabile: 1–65535)
Uscita
Indirizzo iniziale dell'area dati contenente i risultati del conteggio della durata composto da un ARRAY con numero minimo di elementi pari a n_Bits del tipo di dato DINT o UDINT. Utilizzare le istruzioniAdr_Of_Var_I (LD/FBD) o Adr_Of_Var (ST) per accedere all'indirizzo iniziale di quest’area dati.
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
bStart: BOOL:=FALSE;
iTestIndex: INT:=0;
iWorkAreaCount: INT:=0;
arrCountEvents: ARRAY [0..5] of dint:=[6(0)];
END_VAR
Quando la variabile bStart è impostata su 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_F,FP_EVENTS_COUNT!,,12,0,22,6,,?DEN?Ds1_Start?Ds2_WorkArea?Dn_Bits?AENO?Cd_Start);
B(B_VARIN,,iTestIndex,10,2,12,4,);
B(B_VARIN,,iWorkAreaCount,10,3,12,5,);
B(B_VARIN,,6,10,4,12,6,);
B(B_VAROUT,,arrCountEvents[0],33,2,35,4,);
B(B_CONTACT,,bStart,3,1,5,3,);
B(B_F,Adr_Of_Var_O!,,25,2,33,4,,?D?C);
L(1,2,3,2);
L(5,2,12,2);
L(22,3,25,3);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF (bStart) then
FP_EVENTS_COUNT(s1_Start := iTestIndex,
s2_WorkArea := iWorkAreaCount,
n_Bits := 6,
d_Start => Adr_Of_Var(arrCountEvents[0]));
END_IF;