SET_JOINT_ABS (ID: 0x01)¶
- Message Type:
0x01
- Use the message type SET_JOINT_ABS to command the robot to move to an absolute position in joint space.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Point Sequence Number | Approach Mode | Approach Velocity | Approach Acceleration | Number of Joints |
Data Type | Unsigned Int | Unsigned Int | Unsigned Int | Unsigned Int | Unsigned Int |
5 | 6 | 7 | 8 | … | … |
Value Joint 0 | … | Value Joint n | |||
Signed Int | Signed Int | Signed Int |
- Point Sequence Number is an arbitrary sequence number for identifying the waypoint specified in this message.
- Approach Mode specifes how to approach the waypoint specified in this
message. Available values are
1
for a point-to-point motion and2
for a linear motion. - Approach Velocity specifies the permitted velocit for approaching the
waypoint specified in this message where
0
equals 0% of the maximum available velocity and255
equals 100% of it. - Approach Acceleration specifies the permitted acceleration for approaching
the waypoint specified in this message where
0
equals 0% of the maximum available acceleration and255
equals 100% of it. - Number of Joints specifies how many joint values are transmitted in this message.
- Value Joint x is the desired absolute joint value for robot joint x. Counting starts at the joint mounted closest to the robot base. The encoding of joint values follows the schemes given in sections Angular Values and Linear Values, respectively.
Note
The value in Number of Joints doesn’t necessarily have to equal the number of joints present in the actual robot. Excess joint values will be ignored. Joints above Number of Joints will keep their positions.
GET_JOINT_ABS (ID: 0x02)¶
- Message Type:
0x02
- Messages of type GET_JOINT_ABS provide information on the current absolute position of the robot in joint space.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Number of Joints | Value Joint 0 | |||
Data Type | Unsigned Int | Signed Int |
… | … |
… | Value Joint n |
Signed Int | Signed Int |
- Number of Joints specifies how many joint values are transmitted in this message.
- Value Joint x is the current actual absolute joint value of robot joint x. Counting starts at the joint mounted closest to the robot base. The encoding of joint values follows the schemes given in sections Angular Values and Linear Values, respectively.
SET_JOINT_OFFS (ID: 0x03)¶
- Message Type:
0x03
- Use the message type SET_JOINT_OFFS to command the robot to move relatively in joint space by a given offset.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Number of Joints | Offset Joint 0 | |||
Data Type | Unsigned Int | Signed Int |
… | … |
… | Offset Joint n |
Signed Int | Signed Int |
- Number of Joints specifies how many joint value offsets are transmitted in this message.
- Offset Joint x is the desired relative joint value offset for robot joint x. Counting starts at the joint mounted closest to the robot base. The encoding of joint value offsets follows the schemes given in sections Angular Values and Linear Values, respectively.
Warning
This message type is intended to be used for jogging. Do not use messages of this type for approaching predefined absolute positions. Depending on the robot state, individual messages of this type may be ignored or discarded at any time.
Note
The robot follows requested offsets very directly. Requesting too large offsets in a single message may result in jerky movement of the robot or may trigger safety mechanisms due to exceeded limits. Send messages frequently with only small offsets in each message to acheive smooth movements of the robot. The ideal frequency is at 100 Hz.
Note
The value in Number of Joints doesn’t necessarily have to equal the number of joints present in the actual robot. Excess joint value offsets will be ignored. Joints above Number of Joints will keep their positions.
SET_POSE_ABS (ID: 0x05)¶
- Message Type:
0x05
- Use the message type SET_POSE_ABS to command the robot to move its endeffector to an absolute pose in Cartesian space.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Point Sequence Number | Approach Mode | Approach Velocity | Approach Acceleration | Number of Dimensions |
Data Type | Unsigned Int | Unsigned Int | Unsigned Int | Unsigned Int | Unsigned Int |
5 | 6 | 7 | 8 | 9 | 10 |
Value Position x | Value Position y … | ||||
Signed Int | Signed Int … |
11 | 12 | 13 | 14 | 15 | 16 |
… Value Position y | Value Position z | ||||
… Signed Int | Signed Int |
17 | 18 | 19 | 20 | 21 | 22 |
Value Orientation z | Value Orientation y … | ||||
Signed Int | Signed Int … |
23 | 24 | 25 | 26 | 27 | 28 |
… Value Orientation y | Value Orientation x | ||||
… Signed Int | Signed Int |
- Point Sequence Number is an arbitrary sequence number for identifying the waypoint specified in this message.
- Approach Mode specifes how to approach the waypoint specified in this
message. Available values are
1
for a point-to-point motion and2
for a linear motion. - Approach Velocity specifies the permitted velocit for approaching the
waypoint specified in this message where
0
equals 0% of the maximum available velocity and255
equals 100% of it. - Approach Acceleration specifies the permitted acceleration for approaching
the waypoint specified in this message where
0
equals 0% of the maximum available acceleration and255
equals 100% of it. - Number of Dimensions specifies how many dimnesional values are transmitted in this message. Currently onyl fully specified cartesian waypoints with values given for all 6 dimensions are supported so set this to 6.
- Value Position x is the x-component of the desired absolute Cartesian position. The encoding of position values follows the scheme given in section Linear Values.
- Value Position y is the y-component of the desired absolute Cartesian position.
- Value Position z is the z-component of the desired absolute Cartesian position.
- Value Orientation z is the z-component of the desired absolute Cartesian orientation given in zyx Euler angles. The encoding of orientation values follows the scheme given in section Angular Values.
- Value Orientation y is the y-component of the desired absolute Cartesian orientation given in zyx Euler angles.
- Value Orientation x is the x-component of the desired absolute Cartesian orientation given in zyx Euler angles.
GET_POSE_ABS (ID: 0x06)¶
- Message Type:
0x06
- Messages of type GET_POSE_ABS provide information on the current absolute pose of the robot’s endeffector in Cartesian space.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Number of Dimensions | Value Position x | |||
Data Type | Unsigned Int | Signed Int |
5 | 6 | 7 | 8 | 9 | 10 |
Value Position y | Value Position z … | ||||
Signed Int | Signed Int … |
11 | 12 | 13 | 14 | 15 | 16 |
… Value Position z | Value Orientation z | ||||
… Signed Int | Signed Int |
17 | 18 | 19 | 20 | 21 | 22 |
Value Orientation y | Value Orientation x … | ||||
Signed Int | Signed Int … |
23 | 24 |
… Value Orientation x | |
… Signed Int |
- Number of Dimensions specifies how many dimnesional values are transmitted in this message. Currently onyl fully specified cartesian waypoints with values given for all 6 dimensions are supported so set this to 6.
- Value Position x is the x-component of the current actual absolute Cartesian position. The encoding of position values follows the scheme given in section Linear Values.
- Value Position y is the y-component of the current actual absolute Cartesian position.
- Value Position z is the z-component of the current actual absolute Cartesian position.
- Value Orientation z is the z-component of the current actual absolute Cartesian orientation given in zyx Euler angles. The encoding of orientation values follows the scheme given in section Angular Values.
- Value Orientation y is the y-component of the current actual absolute Cartesian orientation given in zyx Euler angles.
- Value Orientation x is the x-component of the current actual absolute Cartesian orientation given in zyx Euler angles.
SET_POSE_OFFS (ID: 0x03)¶
- Message Type:
0x07
- Use the message type SET_POSE_OFFS to command the robot to move relatively in Cartesian space by a given offset.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Number of Dimensions | Offset Position x | |||
Data Type | Unsigned Int | Signed Int |
5 | 6 | 7 | 8 | 9 | 10 |
Offset Position y | Offset Position z … | ||||
Signed Int | Signed Int … |
11 | 12 | 13 | 14 | 15 | 16 |
… Offset Position z | Offset Orientation z | ||||
… Signed Int | Signed Int |
17 | 18 | 19 | 20 | 21 | 22 |
Offset Orientation y | Offset Orientation x … | ||||
Signed Int | Signed Int … |
23 | 24 |
… Offset Orientation x | |
… Signed Int |
- Number of Dimensions specifies how many dimensional values are transmitted in this message. Currently onyl fully specified cartesian waypoints with values given for all 6 dimensions are supported so set this to 6.
- Offset Position x is the x-component of the desired Cartesian position offset. The encoding of position offsets follows the scheme given in section Linear Values.
- Offset Position y is the y-component of the desired Cartesian position offset.
- Offset Position z is the z-component of the desired Cartesian position offset.
- Offset Orientation z is the z-component of the desired Cartesian orientation offset given in zyx Euler angles. The encoding of orientation offsets follows the scheme given in section Angular Values.
- Offset Orientation y is the y-component of the desired Cartesian orientation offset given in zyx Euler angles.
- Offset Orientation x is the x-component of the desired Cartesian orientation offset given in zyx Euler angles.
Warning
This message type is intended to be used for jogging. Do not use messages of this type for approaching predefined absolute positions. Depending on the robot state, individual messages of this type may be ignored or discarded at any time.
Note
The robot follows requested offsets very directly. Requesting too large offsets in a single message may result in jerky movement of the robot or may trigger safety mechanisms due to exceeded limits. Send messages frequently with only small offsets in each message to acheive smooth movements of the robot. The ideal frequency is at 100 Hz.
GET_MOTION_DONE (ID: 0x11)¶
- Message Type:
0x11
- A Messages of type GET_MOTION_DONE provides information that a waypoint the robot was previously commanded to move to has been reached.
Byte | 0 |
Meaning | Point Sequence Number |
Data Type | Unsigned Int |
- Point Sequence Number is the sequence number associated with the waypoint that has been reached.
SET_OUTPUT (ID: 0x20)¶
- Message Type:
0x20
- Use the message type SET_OUTPUT to command the robot to set an (analog or digital) output to a given value.
Byte | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
Meaning | Address | Value | ||||||
Data Type | Unsigned Int | (Unsigned) Int |
- Address specifies the address of the output to be set.
- Value is the value to be set for the addressed output signal.
Note
The value field may be interpreted as singed or unsigned depending on the type of the addressed output.
Note
For digital outputs the value 0
equals inactive whereas values of 1
and above are interpreted as active.
GET_INPUT (ID: 0x21)¶
- Message Type:
0x21
- A Messages of type GET_INPUT provides information on the values of all (analog and digital) inputs of the robot.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Number of Values | Value Input 0 | |||
Data Type | Unsigned Int | (Unsigned) Int |
… | 5 | 6 | 7 | 8 |
… | Value Input n | |||
… | (Unsigned) Int |
- Number of Values specifies how many input values are transmitted in this message.
- Value Input x is the current value present at input x.
Note
Each value field may be interpreted as singed or unsigned depending on the type of the corresponding input.
Note
For digital inputs the value 0
equals inactive whereas values of 1
and above are interpreted as active.
GET_OUTPUT (ID: 0x23)¶
- Message Type:
0x23
- A Messages of type GET_OUTPUT provides information on the values of all (analog and digital) outputs of the robot.
Byte | 0 | 1 | 2 | 3 | 4 |
Meaning | Number of Values | Value Output 0 | |||
Data Type | Unsigned Int | (Unsigned) Int |
… | 5 | 6 | 7 | 8 |
… | Value Output n | |||
… | (Unsigned) Int |
- Number of Values specifies how many output values are transmitted in this message.
- Value Output x is the current value present at output x.
Note
Each value field may be interpreted as singed or unsigned depending on the type of the corresponding output.
Note
For digital outputs the value 0
equals inactive whereas values of 1
and above are interpreted as active.
SET_G_COMPENSATION (ID: 0x41)¶
- Message Type:
0x41
- Use the message type SET_G_COMPENSATION to command the robot to temporarily enter gravity compensation mode where the robot can be moved by external force.
Byte | 0 |
Meaning | Mode |
Data Type | Unsigned Int |
- Mode determines the desired mode of gravity compensation.
As of now, the only valid value for this field is
0
. In this mode the robot is freely moveable while repsecting joint limits.
Note
Gravity compensation mode is volatile by implementation.
Send messages frequently to keep gravity compensation enabled.
The ideal frequency is at 100 Hz.
To disable gravity compensation mode again just stop sending messages of type
0x41
.
GET_STATUS (ID: 0x50)¶
- Message Type:
0x50
- Messages of type GET_STATUS provide information on the current status and operating condition of the robot and carry additional user-mapped information.
Byte | 0 | 1 | 2 | 3 |
Meaning | Status | Rx Sequcence No. | Rx Result | Last Reached Waypoint |
Data Type | Signed Int | Unsigned Int | Signed Int | Unsigned Int |
4 | 5 | 6 |
Last Error Status Sequence No. | Last Error Status | Mapped Data ID |
Unsigned Int | Signed Int | Unsigned Int |
7 | 8 | … |
Mapped Data Length | Mapped Data | |
Unsigend Int | … |
- Status provides information on the current status and operating conditions. Positive values indicate ordinary operation while negative values indicate error conditions. See section Status Codes for further details.
- Rx Sequence No. is the sequence number associated with the last message that has been received.
- Rx Result is the processing status of the message specified by Rx Sequence No.. Negative values indixate an error while positive values indicate success.
- Last Reached Waypoint is the sequence number associated with the waypoint that has been reached.
- Last Error Status Sequence No. is a sequence number that changes every time a new error status appears.
- Last Error Status carries the last error status that appeared. Formatting is the same as for the field Status.
- Mapped Data ID determines what information is transported in the Mapped Data field and how to interpret it. See Mapped Data for valid ID values and their meanings.
- Mapped Data Length determines the length of the Mapped Data field following in this message.
- Mapped Data contains the actual mapped data. The format of this field depends on the information mapped to this field in accordance to the contents of the field Mapped Data ID and is given in section Mapped Data.
SET_MAPPED_STATUS_DATA (ID: 0x55)¶
- Message Type:
0x55
- Use the message type SET_MAPPED_STATUS_DATA to modify which information is transported in the Mapped Data fields of messages of the type GET_STATUS.
Byte | 0 | 1 |
Meaning | Mapped Data Slot | Mapped Data ID |
Data Type | Unsigned Int | Unsigned Int |
- Mapped Data Slot specifies the data slot of the messagign cycle to be
modified. There are currently
4
slots per messaging cycle. Counting of the slots starts from0
. - Mapped Data ID specifies which data are mapped to the data slot specified in the field Mapped Data Slot. Valid values are given in section Mapped Data.
Note
See section Messaging Procedure for more details on the messaging cycle.
SET_STOP (ID: 0xEE)¶
- Message Type:
0xEE
- Use the message type SET_STOP to command the robot to stop all current and pending actions.
Byte | 0 |
Meaning | RFU |
Data Type | Unsigned Int |
- RFU — reserved for future usage. Set to
0
for for consistent behavior with future versions.