MC_GrpReadActVel

PLCopen motion icon Pipe Network motion icon

 Function BlockClosed A function block groups an algorithm and a set of private data. It has inputs and outputs. - Reads the actual velocityClosed For a group of axes this means: In ACS the velocities of the different axes. In MCS and PCS it provides the velocity of the TCP of the group and the axes in the group.

Inputs

Input

Data Type

Range

Unit

Default

Description

EnableClosed Enable signal for the drive, Hardware-Enable with 24V signal to X8, Software-Enable command by setup Software, fieldbus or permanently set. Both are required for enabling the drive.

BOOL

FALSE, TRUE

N/A

No default

If TRUE, this functionClosed A function calculates a result according to the current value of its inputs. A function has no internal data and is not linked to declared instances. block reads the current actual velocity of the group and the axes in the group.

AxesGroup

AXES_GROUP_REF

N/A

N/A

No default

The axes group the actual velocity is read from.

CoordSystem

SINT

One of these enumeration values:

N/A

No default

The coordinate system used when reading the actual velocity.

Velocity[ ]

LREAL

No range

User unit/sec

No default

An array where the velocity data is written.

  • The length of the array must equal the maximum number of axes allowed in the group.
  • The maximum number of axes is an argument to the MC_CreateAxesGrp function block used to create axes groups.

Outputs

Output

Data Type

Range

Unit

Description

Valid

BOOL

FALSE, TRUE

N/A

If TRUE, the velocities were read without error.

Error

BOOL

FALSE, TRUE

N/A

If TRUE, an error has occurred.

ErrorID

INT

No range

N/A

Indicates the error if Error output is TRUE.

See PLCopen Function Block ErrorIDs.

PathVelocity

LREAL

No range

User unit/sec

The current measured pathClosed Set of continuous positions and orientation information in multi-dimensional space. Geometrical description of a space curve that the TCP of an axesgroup moves along. velocity of the group.

This is measured by taking the square root of the sum of the squared velocities of each axis.

Remarks

  • See Coordinated Motion, the top-level topic for Coordinated Motion.
  • See Function Blocks - General Rules about how inputs and outputs work.
  • The MC_GrpReadActVel function block fills the array specified by the Velocity argument with the actual velocity of the system in the coordinate system specified by the CoordSystem argument.
    • The measured path velocity is also calculated and reported by the PathVelocity output.
  • This function or function block does not generate any motion.

    • The actual velocity is smoothed over the last 10 samples.
      This reduces the error in velocity estimation but introduces a small amount of phase delay in the reported velocities.
    • Only the ACS coordinate system is supported.
      See Coordinate Systems.

  • There is a one-to-one correspondence between the axes in the Axes Group and the velocity values in the Velocity Array.
  • Each element in the Velocity Array corresponds to the axis element in the Axis Group array.
  • If a indexClosed Zero pulse (zero signal) of a hardware pin such as digital input or feedback pin. in the Axes Group is unassigned, the velocity value for that array element in the Velocity array is 0 (zero).
  • If the element does contain an axis, the velocity value is filled with the current actual velocity for that axis.
    • This is an example of how this works:

Figure 1: MC_GrpReadActVel

FBD Language Example

FFLD Language Example

IL Language Example

            BEGIN_ILClosed Instruction list - This is a low-level language and resembles assembly.
     CAL Inst_MC_GrpReadActVel(DoRead, Group, CoordsSys, VelList)
END_IL

ST Language Example

Inst_MC_GrpReadActVel(DoRead, Group, CoordSys, VelList);

See Also