Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RobotWare 6.13 EGM UdpUc error #132

Open
Luc90 opened this issue Feb 11, 2022 · 18 comments
Open

RobotWare 6.13 EGM UdpUc error #132

Luc90 opened this issue Feb 11, 2022 · 18 comments

Comments

@Luc90
Copy link

Luc90 commented Feb 11, 2022

Hello,

I work with the Yumi and EGM.
I upgraded the RobotWare version from 6.12 to 6.13. My Rapid code worked when I was using version 6.12 but with version 6.13, when I run the Rapid code I get the following two errors:

  • 41830, Error sending EGM UdpUc message.
  • 41822, No data from the UdpUc device.

I also updated the RobotWare to version 6.13 of the ABB1200 in our lab and tried to run the same Rapid EGM code. This works on the ABB1200 with RobotWare version 6.13.

I tried with the Yumi by simulating RobotWare versions 6.11 and 6.12 and it works.

Do you know why I get these errors with RobotWare 6.13 on the Yumi ?

My Rapid code is

`MODULE TRob1Main

!***********************************************************
! Program data
!***********************************************************
! Home position.
 LOCAL CONST jointtarget home:=[[0,-130,30,0,40,0],[135,9E+09,9E+09,9E+09,9E+09,9E+09]];

! Identifier for the EGM correction.
LOCAL VAR egmident egm_id;

! Limits for convergance.
LOCAL VAR egm_minmax egm_condition := [-0.1, 0.1];
        
!***********************************************************
!
! Procedure main
!
!   This RAPID code exemplify how to run EGM joint position
!   motions.
!
!   Note: Update the UCDevice "ROB_1" with correct
!         values for the remote address and port
!         (i.e. to the EGM server).
!
!         Update via RobotStudio:
!         Controller tab -> Configuration ->
!         Communication -> Transmission Protocol
!
!***********************************************************
PROC main()
    
    MoveAbsJ home, v100, fine, tool0;
    
    WHILE TRUE DO
                                
        ! Register an EGM id.
        EGMGetId egm_id;
        
        ! Setup the EGM communication.
        EGMSetupUC rob_L, egm_id, "default", "ROB_1", \Joint;
        
        ! Prepare for an EGM communication session.
        EGMActJoint egm_id
                    \J1:=egm_condition
                    \J2:=egm_condition
                    \J3:=egm_condition
                    \J4:=egm_condition
                    \J5:=egm_condition
                    \J6:=egm_condition
                    \J7:=egm_condition
                    \MaxSpeedDeviation:=180.0;
                    
        ! Start the EGM communication session.
        EGMRunJoint egm_id, EGM_STOP_HOLD\J1\J2\J3\J4\J5\J6\J7\CondTime:=5\RampOutTime:=1;
        
        ! Release the EGM id.
        EGMReset egm_id;
        
        WaitTime 5;
    ENDWHILE
    
ERROR
    IF ERRNO = ERR_UDPUC_COMM THEN
        TPWrite "Communication timedout";
        TRYNEXT;
    ENDIF
ENDPROC

ENDMODULE`

@gavanderhoorn
Copy link
Member

I would check whether the remote IP setting of the UdpUc device is still correct.

@Luc90
Copy link
Author

Luc90 commented Feb 14, 2022

I have checked and the remote IP setting is correct.

@madelinegannon
Copy link

madelinegannon commented Apr 27, 2022

I experienced this as well after an upgrade. I was able to receive the initial message back from the robots, indicating a successful connection, but then was sent the timeout error. I believe there was a change to the EGM protobuf in 6.13 (in looking through the RobotWare changelogs).
I ended up reverting back to 6.11

@gavanderhoorn
Copy link
Member

Thanks for reporting.

Could you perhaps quote the relevant part of the changelog you mention?

@madelinegannon
Copy link

madelinegannon commented Apr 27, 2022

Revision E of the EGM Applications Manual (Page 8) mentions that 2 new fields were added to the protocol message. My guess is that if you're using an emg.pb.h built for 6.XX, that the new protobuf message format is not backwards compatible. That's my best guess...

@gavanderhoorn
Copy link
Member

I'm somewhat confused.

You mention RW6, but the application manual you link is for RW7.

@enricovillagrossi
Copy link

Hi all,

we are also dealing with the "41822, No data from the UdpUc device" we are using RobotWare 6.12. In our case, EGM is working fine, but sometimes we get the error 41822 and need to restart the EGM. Looking at the ABB Actions (see the attached image), we are in case 3. We can improve the \CommTimeout, but 1 second of timeout seems reasonable.
I noticed that the error happens when the PC that hosts the abb_robot_driver is dealing with ros_control activities, which can overload the system. My guess is when the host PC of the EGM server has somehow overloaded, the communication with the robot controller is slowed down, and the robot goes into a timeout. Does anyone notice the same error? I'll try to keep the abb_robot_driver under a separete PC.

Event_Message_41822

@gavanderhoorn
Copy link
Member

gavanderhoorn commented Jun 9, 2022

I'll try to keep the abb_robot_driver under a separete PC.

It could be abb_robot_driver's threads are starved, leading to the timeout.

For abb_robot_driver specifically, you could perhaps see whether installing an PREEMPT_RT kernel and then using chrt (with suitable parameters (something like --fifo -p 99 as a first test) and run by a user with the required permissions) helps mitigate this.

If your ros_control controller is taking too long, changing priorities like this likely won't help, but for other 'random' scheduling events or other thread-starvation out of the sphere of influence of abb_robot_driver, it could help.


Edit: you should be able to use chrt as a launch-prefix command, if using ROS 1 .launch files.

@gavanderhoorn
Copy link
Member

Any luck @enricovillagrossi?

@enricovillagrossi
Copy link

We didn't try yet, we had to fix the problem quickly, we moved the abb_robot_driver on a dedicated PC, and the problem disappeared. I'll keep you informed once we will try the PREEMPT_RT kernel.

@Working-Zhang

This comment was marked as off-topic.

@gavanderhoorn

This comment was marked as off-topic.

@Working-Zhang

This comment was marked as off-topic.

@gavanderhoorn

This comment was marked as off-topic.

@xiaopocheyituijiuzou
Copy link

@Luc90
Hello,

I am working with a physical ABB IRB1600 and EGM to connect them with moveit2 recently.
The Robotware version of the physical IRB1600 is 6.14.00.01.
The Rapid code worked when I simulated the connection through whether Robotstudio 6.08 or Robotstudio 2023.1 with the Robotware version 6.08 and 6.14.00.01 verified correctly.
When I ran the same code I also got the followig two errors:

  • 41830, Error sending EGM UpdUc message.
  • 41822, No data from the UdpUc device.

Here I wonder whether the Robotware version influnces the EGM connection. And how have you overcome your bug mentioned on Feb 11, 2022. Did the Robotware version trully affect?

PS:

  • The Ip and other communication configurations have been checked. (Just Controller Tab--> Configuration --> Communication-->Add a new UdpUc transmission protocol).
  • Are there any extra steps necessary when I change a simulated Robot to a physical one?

Here is my RAPID for EGM connection:
`MODULE TRob1Main
!======================================================================================================
! Copyright (c) 2018, ABB Schweiz AG
! All rights reserved.
!
! Redistribution and use in source and binary forms, with
! or without modification, are permitted provided that
! the following conditions are met:
!
! * Redistributions of source code must retain the
! above copyright notice, this list of conditions
! and the following disclaimer.
! * Redistributions in binary form must reproduce the
! above copyright notice, this list of conditions
! and the following disclaimer in the documentation
! and/or other materials provided with the
! distribution.
! * Neither the name of ABB nor the names of its
! contributors may be used to endorse or promote
! products derived from this software without
! specific prior wrSitten permission.
!
! THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
! AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
! IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
! ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
! LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
! DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
! SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
! CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
! OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
! THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
!======================================================================================================

!***********************************************************
! Program data
!***********************************************************
! Home position.
LOCAL CONST jointtarget home := [[0, 0, 0, 0, 30, 0], [9E9, 9E9, 9E9, 9E9, 9E9, 9E9]];

! Identifier for the EGM correction.
LOCAL VAR egmident egm_id;

! Limits for convergance.
LOCAL VAR egm_minmax egm_condition := [-0.1, 0.1];

!***********************************************************
!
! Procedure main
!
!   This RAPID code exemplify how to run EGM joint position
!   motions.
!
!   Note: Update the UCDevice "ROB_1" with correct
!         values for the remote address and port
!         (i.e. to the EGM server).
!
!         Update via RobotStudio:
!         Controller tab -> Configuration ->
!         Communication -> Transmission Protocol
!
!***********************************************************
PROC main()
    MoveAbsJ home, v200, fine, tool0;


    ! Register an EGM id.
    EGMGetId egm_id;

    ! Setup the EGM communication.
    EGMSetupUC ROB_1, egm_id, "default", "ROB_1", \Joint;

    ! Prepare for an EGM communication session.
    EGMActJoint egm_id
                \J1:=egm_condition
                \J2:=egm_condition
                \J3:=egm_condition
                \J4:=egm_condition
                \J5:=egm_condition
                \J6:=egm_condition
                \MaxSpeedDeviation:=20.0;
    WHILE TRUE DO
        ! Start the EGM communication session.
        EGMRunJoint egm_id, EGM_STOP_HOLD, \J1 \J2 \J3 \J4 \J5 \J6 \CondTime:=5 \RampOutTime:=5;
    ENDWHILE
    ! Release the EGM id.
    EGMReset egm_id;


ERROR
    IF ERRNO = ERR_UDPUC_COMM THEN
        TPWrite "Communication timedout";
        TRYNEXT;
    ENDIF
ENDPROC

ENDMODULE`

And my reference url is: https://github.com/PickNikRobotics/abb_ros2/blob/rolling/docs/README.md

I am sincerely looking forward to your precious advice.

@enricovillagrossi
Copy link

Hi,

when you add the new UdpUc transmission protocol which IP address have you used? The IP must be the one of the PC running the EGM server, so your external PC.

@xiaopocheyituijiuzou
Copy link

@enricovillagrossi

Thanks for your comment.
I am trying to connect the physical IRB1600 (one click connected to PC1) to the Moveit2 operated on PC2 (also external PC).
So the new UdpUc transmission protocol IP address is that of the PC2 (also external PC ).
This worked when I simulated using a simulated IRB1600 but failed when I changed to a physical one.
https://github.com/PickNikRobotics/abb_ros2/blob/rolling/docs/README.md

图片

The PC1 IP address is set when I run the ros2 launch file on the PC2
ros2 launch abb_bringup abb_control.launch.py description_package:=abb_irb1600_support description_file:=irb1600_10_12.xacro launch_rviz:=false moveit_config_package:=abb_irb1600_10_12_moveit_config use_fake_hardware:=false rws_ip:=10.196.140.54
So I wonder whether the Robotware version matters.

Thanks for your precious comment again and may you happy day.

@FabPrez
Copy link

FabPrez commented Jan 22, 2025

Hi, I’m also working with YuMi using EGM with RobotWare version 6.13.00.00, utilizing the ABB robot driver repository (https://github.com/ros-industrial/abb_robot_driver) and the State Machine 1.1 as RAPID code.
I set the UDP connection by assigning the UcDevice ip and the ip of the two mechanical units as that of my pc, which is the EGM server. I can launch EGM through EGMRunJoint in the state machine, but the communication times out, giving me the following errors:

  • 41830: Error sending EGM UdpUc message.
  • 41822: No data from the UdpUc device.

These are the same errors reported by @Luc90 , who opened this issue. Has anyone managed to confirm over the years if the RobotWare 6.13 version is indeed the root cause of this problem?

I’m posting here because this issue seems identical to Luca’s EGM problem and unrelated to the other repositories I’ve mentioned.

Thank you!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

No branches or pull requests

7 participants