software:qview:qview_6:qview60

Differenze

Queste sono le differenze tra la revisione selezionata e la versione attuale della pagina.

Link a questa pagina di confronto

Entrambe le parti precedenti la revisione Revisione precedente
Prossima revisione
Revisione precedente
Prossima revisioneEntrambe le parti successive la revisione
software:qview:qview_6:qview60 [2015/04/20 14:59] – [19. Appendice D: Parole chiave] qem207software:qview:qview_6:qview60 [2015/04/28 14:21] – [Variabili Statiche] qem207
Linea 533: Linea 533:
  
 ===== - Le variabili DATAGROUP ===== ===== - Le variabili DATAGROUP =====
 +Le variabili Datagroup sono una particolare struttura di dati, memorizzate in una zona ritentiva. Esse vengono dichiarate nella unit di configurazione e sono idonee per rappresentare un archivio di ricette. \\ Le variabili Datagroup contengono due tipologie di variabili:
 +
 +==== Variabili Statiche ====
 +<code QCL>
 +DATAGROUP
 +  <DataGroup Name>
 +  DATAPROGRAM
 +    <number of recipes>
 +;Static variables declaration
 +    <variable name> <F/B/W/L/S>
 +    <variable name> <F/B/W/L/S>
 +    <variable name> <F/B/W/L/S>
 +</code>
 +Le variabili statiche risiedono nel sottosettore di DATAGROUP nominato come DATAPROGRAM. Il primo valore di questo settore è un numero o una costante intera, e indica il numero di ricette dell'archivio. Le variabili statiche sono da considerarsi come contenitori di un determinato valore per ogni ricetta, e sono accessibili come un array, dove l'indice è il numero di ricetta desiderata. Esempio:
 +<code QCL>
 +DATAGROUP
 +  Name
 +  DATAPROGRAM
 +    100
 +;Static variables declaration
 +    Variable1     L
 +    Variable2     S
 +    Variable3     F
 +</code>
 +Per far riferimento alla variabile //Variable3// della ricetta 5, viene usato il codice:
 +<code QCL>
 +Variable3[5]
 +</code>
 +
 +Possiamo immaginare la struttura della memoria di una variabile DATAGROUP, nel nostro esempio con variabili statiche, come la seguente tabella:
 +^ ^  Variable1  ^  Variable2  ^  Variable3  ^
 +^Ricetta 1| | | |
 +^Ricetta 2| | | |
 +^Ricetta 3| | | |
 +^...| | | |
 +^Ricetta 100| | | |
 +
 +==== Variabili Indicizzate ==== 
 +<code QCL>
 +DATAGROUP
 +  <DataGroup Name>
 +  DATAPROGRAM
 +    <number of recipes>
 +  STEP
 +    <number of steps>
 +;Indexed variables declaration
 +    <variable name> <F/B/W/L/S>
 +    <variable name> <F/B/W/L/S>
 +    <variable name> <F/B/W/L/S>
 +</code>
 +Le variabili indicizzate risiedono nel sottosettore di DATAGROUP nominato come STEP. La loro funzione è quella di introdurre per ogni ricetta, il concetto di passo. Il primo valore di questo settore è un numero o una costante intera, e indica in numero di passi per ogni ricetta dell'archivio. Le variabili indicizzate sono da considerarsi come contenitori di una lista di valori per ogni ricetta, e sono accessibili come un array a 2 dimensioni, dove il primo valore è il numero di ricetta, il secondo, il passo desiserato. Esempio:
 +<code QCL>
 +DATAGROUP
 +  Name
 +  DATAPROGRAM
 +    100
 +;Static variables declaration
 +    Variable1     L
 +    Variable2     S
 +    Variable3     F
 +  STEP
 +    10
 +;Indexed variables declaration
 +    Variable4     W
 +    Variable5     B
 +</code>
 +Per far riferimento alla variabile //Variable4// della ricetta 5 al passo 9, viene usato il codice:
 +<code QCL>
 +Variable4[5, 9]
 +</code>
 +
 +Possiamo immaginare la memoria di una variabile DATAGROUP, nel nostro esempio con variabili STATICHE e INDICIZZATE, come la seguente tabella:
 +^ ^  Variable1  ^  Variable2  ^  Variable3  ^  Variable4  ^^^^^  Variable5  ^^^^^
 +^Ricetta 1| | | | | | | | | | | | | |
 +^:::|:::|:::|:::| | | | | | | | | | |
 +^Ricetta 2| | | | | | | | | | | | | |
 +^:::|:::|:::|:::| | | | | | | | | | |
 +^Ricetta 3| | | | | | | | | | | | | |
 +^:::|:::|:::|:::| | | | | | | | | | |
 +^...| | | | | | | | | | | | | |
 +^:::|:::|:::|:::| | | | | | | | | | |
 +^Ricetta 100| | | | | | | | | | | | | |
 +^:::|:::|:::|:::| | | | | | | | | | |
 +
 +Altre informazioni:
 +  * In un DATAGROUP tutte le variabili, sia statiche che indicizzate, sono ritentive (mantengono il valore allo spegnimento).
 +  * Le variabili Datagroup possono essere più di una, in questo caso è necessario inserire più settori di tipo DATAGROUP.
 +  * La sottosezione DATAPROGRAM è obbligatoria, mentre quella STEP è opzionale.
 +  * Il numero massimo di ricette impostabile è 65534.
 +  * Il numero massimo di passi impostabile è 65534.
 +  * Rispetto a un comune array, le variabili statiche possono supportare anche un dato di tipo Flag (F).
 +===== - Le variabili DATAGROUP old =====
 +
 Le variabili Datagroup sono una particolare struttura di dati. Quando si dichiara un datagroup, si organizza una parte della memoria come una tabella formata da righe e colonne. Le colonne sono chiamate //programmi// o //ricette//, mentre le righe //passi// (in inglese //step//).\\ Le variabili Datagroup sono una particolare struttura di dati. Quando si dichiara un datagroup, si organizza una parte della memoria come una tabella formata da righe e colonne. Le colonne sono chiamate //programmi// o //ricette//, mentre le righe //passi// (in inglese //step//).\\
 Ogni programma (colonna) contiene due tipologie di variabili: Ogni programma (colonna) contiene due tipologie di variabili:
Linea 638: Linea 731:
  
 //num_prog// e //num_step// possono essere un numero (non SINGLE), una costante, una variabile o un’espressione complessa. Nel caso di numero o di costante, viene eseguito il controllo durante la compilazione che l’indice non superi la dimensione massima dichiarata in configurazione (rispettivamente per il numero programmi e il numero step); gli altri indici - //num_prog e num_step// - partono (in valore) da uno. //num_prog// e //num_step// possono essere un numero (non SINGLE), una costante, una variabile o un’espressione complessa. Nel caso di numero o di costante, viene eseguito il controllo durante la compilazione che l’indice non superi la dimensione massima dichiarata in configurazione (rispettivamente per il numero programmi e il numero step); gli altri indici - //num_prog e num_step// - partono (in valore) da uno.
- 
- 
 ===== - Sezione BUS ===== ===== - Sezione BUS =====
 La sezione BUS nell’unità di configurazione è indispensabile per dichiarare quale modello hardware di QMOVE il programmatore ha a disposizione.\\ La sezione BUS nell’unità di configurazione è indispensabile per dichiarare quale modello hardware di QMOVE il programmatore ha a disposizione.\\
Linea 1451: Linea 1542:
 <code QCL> <code QCL>
   glValue = RMULDIV(a, b, c)   glValue = RMULDIV(a, b, c)
 +</code>
 +
 +==== - Arrotondamenti all'intero più vicino ====
 +|ROUND|Esegue un arrotondamento di un valore in floating point all'intero più vicino.|
 +|TRUNC|Esegue un arrotondamento di un valore in floating point all'intero più vicino non maggiore di grandezza rispetto al valore dato.|
 +|FLOOR|Esegue un arrotondamento di un valore in floating point all'intero più vicino non superiore al valore dato.|
 +|CEIL|Esegue un arrotondamento di un valore in floating point all'intero più vicino non inferiore al valore dato.|
 +La sintassi è:\\
 +<code QCL>
 +  ROUND(<variable>)
 +  TRUNC(<variable>)
 +  FLOOR(<variable>)
 +  CEIL(<variable>)
 +</code>
 +Esempio:
 +<code QCL>
 +  gsValue = ROUND(2.7)     ;risulta 3.0
 +  gsValue = ROUND(-2.7)    ;risulta -3.0
 +  gsValue = TRUNC(2.7)     ;risulta 2.0
 +  gsValue = TRUNC(-2.7)    ;risulta -2.0
 +  gsValue = FLOOR(2.7)     ;risulta 2.0
 +  gsValue = FLOOR(-2.7)    ;risulta -3.0
 +  gsValue = CEIL(2.7)      ;risulta 3.0
 +  gsValue = CEIL(-2.7)     ;risulta -2.0
 +</code>
 +
 +==== - Operatori di classificazione ====
 +|ISFINITE|Controlla se il numero dato ha valore finito.|
 +|ISINF|Controlla se il numero dato ha valore infinito.|
 +|ISNAN|Controlla se il numero dato ha valore NaN.|
 +|ISNORMAL|Controlla se il numero dato ha valore normale.|
 +La sintassi è:\\
 +<code QCL>
 +  ISFINITE(<variable>)
 +  ISINF(<variable>)
 +  ISNAN(<variable>)
 +  ISNORMAL(<variable>)
 +</code>
 +Esempio:
 +<code QCL>
 +  gfValue = ISFINITE(gsValue)     ;risulta 1 se gsValue è un valore finito, altrimenti 0
 +  gfValue = ISINF(gsValue)        ;risulta 1 se gsValue è un valore infinito, altrimenti 0
 +  gfValue = ISNAN(gsValue)        ;risulta 1 se gsValue è un NaN (Not a Number), altrimenti 0
 +  gfValue = ISNORMAL(gsValue)     ;risulta 1 se gsValue è un valore normale (non zero, non infinito, non NaN), altrimenti 0
 </code> </code>
 ===== - Funzioni trigonometriche ===== ===== - Funzioni trigonometriche =====
Linea 3503: Linea 3638:
 ^ CALL         | chiamata subroutine                                 | ^ CALL         | chiamata subroutine                                 |
 ^ CASE         | istruzione SWITCH-CASE                              | ^ CASE         | istruzione SWITCH-CASE                              |
 +^ CEIL         | arrotondamento a intero non inferiore a quello dato |
 ^ CONST        | sezione file di configurazione                      | ^ CONST        | sezione file di configurazione                      |
 ^ COS          | coseno                                              | ^ COS          | coseno                                              |
Linea 3521: Linea 3657:
 ^ EXTDEVICE    | sezione file di configurazione                      | ^ EXTDEVICE    | sezione file di configurazione                      |
 ^ F            | flag                                                | ^ F            | flag                                                |
 +^ FLOOR        | arrotondamento a intero non superiore a quello dato |
 ^ FOR          | istruzione FOR                                      | ^ FOR          | istruzione FOR                                      |
 ^ FPROG        | istruzione FPROG                                    | ^ FPROG        | istruzione FPROG                                    |
Linea 3530: Linea 3667:
 ^ INPUT        | sezione file di configurazione                      | ^ INPUT        | sezione file di configurazione                      |
 ^ INTDEVICE    | sezione file di configurazione                      | ^ INTDEVICE    | sezione file di configurazione                      |
 +^ ISFINITE     | controlla se il valore è finito                     |
 +^ ISINF        | controlla se il valore è infinito                   |
 +^ ISNAN        | controlla se il valore è Nan (Not a Number)         |
 +^ ISNORMAL     | controlla se il valore è normale                    |
 ^ JUMP         | istruzione JUMP                                     | ^ JUMP         | istruzione JUMP                                     |
 ^ LE           | minore o uguale                                     | ^ LE           | minore o uguale                                     |
Linea 3552: Linea 3693:
 ^ RETURN       | istruzione di return (su subroutine)                | ^ RETURN       | istruzione di return (su subroutine)                |
 ^ RMULDIV      | resto di moltiplicazione e divisione                | ^ RMULDIV      | resto di moltiplicazione e divisione                |
 +^ ROUND        | arrotondamento a intero più vicino                  |
 ^ S            | single                                              | ^ S            | single                                              |
 ^ SETOUT       | setta uscita                                        | ^ SETOUT       | setta uscita                                        |
Linea 3565: Linea 3707:
 ^ TAN          | tangente                                            | ^ TAN          | tangente                                            |
 ^ TIMER        | sezione file di configurazione                      | ^ TIMER        | sezione file di configurazione                      |
 +^ TRUNC        | arrotondamento a intero non maggiore di grandezza   |
 ^ W            | word                                                | ^ W            | word                                                |
 ^ WAIT         | istruzione di wait                                  | ^ WAIT         | istruzione di wait                                  |
  • Ultima modifica: 2024/03/22 14:06