FP_MOVE_BLOCK

Mover un bloque de datos

Estas instrucciones FP mueven el bloque de datos del área de datos especificada por s1_Start y por s2_End al bloque que comienza desde el área de datos especificada por d_Start si la entrada de trigger EN es TRUE.

Parámetros

Entrada

s1_Start (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

Dirección de inicio del área de datos fuente.

s2_End (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

Dirección final del área de datos fuente

Salida

d_Start (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

Dirección de inicio del área de datos de destino.

Observaciones

  • Se aplican las siguientes condiciones:

    • Las variables de entrada y salida tiene que ser del mismo tipo de datos.

    • Los operandos s1_Start y s2_End tienen que estar en la misma área de memoria, p. ej., DT, WR, FL, LD ...

    • s1_Start£s2_End

  • Siempre que s1_Start, s2_End y d_Start estén en el mismo área de datos:

    • s1_Start=d_Start: Esta instrucción no se ejecutará.

Banderas de error

sys_bIsOperationErrorHold (pasa a TRUE y permanece TRUE)
  • si el área especificada utilizando el modificador índice supera el límite.
  • si s1_Start > s2_End

  • si el rango de destino está fuera del rango accesible.

sys_bIsOperationErrorNonHold (pasa a TRUE para un ciclo de scan)
  • si el área especificada utilizando el modificador índice supera el límite.
  • si s1_Start > s2_End

  • si el rango de destino está fuera del rango accesible.

Temas relacionados

Ejemplo

Cabecera de la POU

Todas las variables de entrada y de salida utilizadas para la programación de esta función han sido declaradas en la Cabecera de la POU. Se utiliza la misma cabecera de la POU para todos los lenguajes de programación.

	VAR
		bStart: BOOL:=FALSE;
			(*activates the function*)
		aiSource_Array: ARRAY [0..4] OF INT:=[1,2,3,4,5];
		aiTarget_Array: ARRAY [0..2] OF INT:=[3(0)];
			(*result after a 0->1 leading edge
from start: [2,3,4]*)
	END_VAR

Cuerpo de la POU

Cuando la variable bStart se encuentra a TRUE, se ejecuta la función.

Cuerpo LD

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,,bStart,6,2,8,4,);
B(B_VARIN,,aiSource_Array[1],11,3,13,5,);
B(B_VARIN,,aiSource_Array[3],11,4,13,6,);
B(B_VAROUT,,aiTarget_Array[0],23,3,25,5,);
B(B_F,FP_MOVE_BLOCK!,,13,1,23,6,,?DEN?Ds1_Start?Ds2_End?AENO?Cd_Start);
L(1,3,6,3);
L(8,3,13,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

Cuerpo en ST

If (bStart) then
    FP_MOVE_BLOCK(s1_Start := aiSource_Array[0], s2_End := aiSource_Array[3], d_Start => aiTarget_Array[0]);
End_if;

Modificado el: 2019-11-07Comentarios sobre esta páginaLínea directa de Panasonic