S_PEXT: Parametrizar y arrancar temporizador como impulso prolongado (S7-300, S7-400) - STEP 7

SCL (S7-300, S7-400)

ft:publication_title
SCL (S7-300, S7-400)
Product
STEP 7
Version
V20
Publication date
11/2024
Language
es-ES
S_PEXT: Parametrizar y arrancar temporizador como impulso prolongado

Descripción

La instrucción "Parametrizar y arrancar temporizador como impulso prolongado" arranca el temporizador programado cuando se detecta un flanco de señal ascendente en el parámetro S. El temporizador deja de contar el tiempo programado TV aunque el estado lógico del parámetro S cambie a "0". Mientras el temporizador está contando, el parámetro Q devuelve el estado lógico "1".

Una vez transcurrido el tiempo, el parámetro Q adopta el valor lógico "0". Si el estado lógico del parámetro S cambia de "0" a "1" mientras el temporizador está contando, el temporizador se inicia de nuevo con el tiempo programado en el parámetro TV.

El tiempo se compone internamente de un valor de tiempo y una base de tiempo y se programa en el parámetro TV. Cuando se inicia la instrucción, el valor de tiempo programado se cuenta hacia atrás hasta cero. La base de tiempo indica con qué periodo de tiempo se modifica el valor de tiempo. El valor actual de tiempo se deposita en el parámetro BI.

Si el temporizador está contando y el estado lógico del parámetro R cambia a "1", el valor actual de tiempo y la base de tiempo también se ponen a cero. Si el temporizador no está contando, el estado lógico "1" en el parámetro R no tiene ningún efecto.

Los datos de la instrucción se actualizan con cada acceso. Por este motivo es posible que una consulta de datos al principio del ciclo devuelva valores diferentes en comparación con el fin del ciclo.

Nota

En la célula de temporización, el sistema operativo reduce el valor de tiempo en una unidad respectivamente, y en un intervalo definido por la base de tiempo, hasta que el valor de tiempo sea "0". La reducción se realiza de modo asíncrono respecto al programa de usuario. De este modo el tiempo resultante es menor que el valor de tiempo deseado, como máximo hasta un intervalo de la base de tiempo.

Encontrará un ejemplo de la estructura de una célula de temporización en: Consulte también "L: Cargar valor del temporizador".

Parámetro

La tabla siguiente muestra los parámetros de la instrucción:

Parámetros

Declaración

Tipo de datos

Área de memoria

Descripción

T_NO

Input

TIMER, INT

T

Temporizador que arranca.

El número de temporizadores depende de la CPU.

S

Input

BOOL

I, Q, M, D, L

Entrada de arranque

TV

Input

S5TIME, WORD

I, Q, M, D, L

Valor de tiempo predeterminado

R

Input

BOOL

I, Q, M, D, L, P

Entrada de reset

Q

Output

BOOL

I, Q, M, D, L, P

Estado del temporizador

BI

Output

WORD

I, Q, M, D, L, P

Valor actual de tiempo en código dual

Valor de función

S5TIME

I, Q, M, D, L

Valor de tiempo actual

Encontrará más información sobre los tipos de datos válidos en "Consulte también".

Cronograma de impulsos

La imagen siguiente muestra el cronograma de impulsos de la instrucción "Parametrizar y arrancar temporizador como impulso prolongado":

Ejemplo

El siguiente ejemplo muestra el funcionamiento de la instrucción:

SCL Copia el código de programa siguiente en el portapapeles.

"Tag_Result" := S_PEXT(T_NO := "Timer_1",

                       S := "Tag_1",

                       TV := "Tag_Number",

                       R := "Tag_Reset",

                       Q := "Tag_Status",

                       BI := "Tag_Value");

Cuando el estado lógico del operando "Tag_1" cambia de "0" a "1", el temporizador "Timer_1" se pone en marcha. Mientras el temporizador está en marcha, el operando "Tag_Status" devuelve el estado lógico "1". Una vez transcurrido el tiempo, el operando "Tag_Status" adopta el valor lógico "0". Si el estado lógico de la entrada S cambia de "0" a "1" mientras el temporizador está contando, el temporizador se inicia de nuevo con el tiempo "Tag_Number".

El valor actual de tiempo se guarda en código dual en el operando "Tag_Value" y se devuelve como valor de función.