-
Notifications
You must be signed in to change notification settings - Fork 45
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
[ZeroErr eRob] Joint not moving using EcCia402Drive + Joint trajectory position #87
Comments
EDIT: the config file is correct and I'm able to set the OP state. For some reason the config file it was being launched wasn't updated. Anyway now when I send a new position the controller doesn't work and the motor doesn't move. I am able to move the motor, and the communication is ok as if I set the default position to a value different then zero it moves there. Therefore, the problem is when using the trajectory controller, any help would be appreciated. |
Hi, can you include the log of your terminal running ros2_control ? |
Which operation mode is used? |
Hi, I have the same problem with the erob ZeroErr. I can't reach OP state. Can you describe how you reached the OP state? |
You must include the operation mode in the tpdo, otherwise your position isn't forwarded. I searched long after this.. I will try to open a PR which falls back to the setup operation mode if there is no config in tpdo. |
Hi there, the working configuration file for me was: zeroerror_config.yaml
One thing was that the default position couldn't be set to .nan but works with zero. Of course this produces another error, if the motor is powered on when its position is not near zero the OP state won't be set to ready but in fault. This is the ros2_control config file:
Sorry if I didn't answer earlier but I didn't have the motor to make any test for a while. I'll try in the next days to make it work with ros2 control, if anyone else has attempted and succeeded let us know! |
I would also be interested in the solution for these motors. I can talk to them and also set and read the values for example the position and write the control words eta. But I still can't move the motors and have them all hooked up to a ros2 controller, as I can print the desired position. Any input on how you managed to get them to work would be good. |
The main problem is that the mode of operation display is set to 0 -> ModeOfOperation::MODE_NO_MODE Line 50 in 9657cf3
This should initially be set to the operation mode given in de config mapping. Temporary work around is to add example from above: # Configuration file for ZERO ERR drive
vendor_id: 0x5A65726F
product_id: 0x00029252
assign_activate: 0x003c
auto_fault_reset: true
rpdo:
- index: 0x1600
channels:
- {index: 0x607a, sub_index: 0, type: int32, command_interface: position, default: .nan}
- {index: 0x60fe, sub_index: 0, type: int32, default: 0}
- {index: 0x6040, sub_index: 0, type: uint16, default: 0}
tpdo:
- index: 0x1A00
channels:
- {index: 0x6064, sub_index: 0, type: int32, state_interface: position}
- {index: 0x6061, sub_index: 0, type: uint8 } # Mode of operation
- {index: 0x60fd, sub_index: 0, type: int32}
- {index: 0x6041, sub_index: 0, type: uint16}
sm:
- {index: 0, type: output, pdo: ~, watchdog: disable}
- {index: 1, type: input, pdo: ~, watchdog: disable}
- {index: 2, type: output, pdo: rpdo, watchdog: enable}
- {index: 3, type: input, pdo: tpdo, watchdog: disable} This wil set the vallue correctly here: Line 78 in 9657cf3
|
Hi @JensVanhooydonck! I tried adding the Mode of operation using - {index: 0x6061, sub_index: 0, type: uint8 } as you suggested, but this makes the motor go into preop error state. Did you manage to use it on the Zero err? ethercat slaves returns: @mcbed when i launch it with the configuration that i published in previous comments the ros2_control returns:
|
@JensVanhooydonck by hardcoding 8 as mode_of_operation_display_ i am able to move it. What's a clean way to solve this? 😅 |
That was my next possible try.. I wanted to add a PR which fills in the inital value of mode_of_operation_display_ with the value defined here: <ros2_control name="ec_single_axis" type="system">
<hardware>
<plugin>ethercat_driver/EthercatDriver</plugin>
<param name="master_id">0</param>
<param name="control_frequency">100</param>
</hardware>
<joint name="joint_0">
<state_interface name="position"/>
<state_interface name="velocity"/>
<state_interface name="effort"/>
<command_interface name="position"/>
<command_interface name="reset_fault"/>
<ec_module name="MAXON">
<plugin>ethercat_generic_plugins/EcCiA402Drive</plugin>
<param name="alias">0</param>
<param name="position">0</param>
<param name="mode_of_operation">8</param>
<param name="slave_config">/path/to/maxon.yaml</param>
</ec_module>
</joint>
</ros2_control> Currently not had the time for this. I guess this can easily be done in: Line 131 in 9657cf3
So we also set display instead of only mode_of_operation_ Haven't tested this yet.. Could you let me know if this works? |
Ok never mind, I wrote too soon ahah. I am able to set it from the tpdo config but CiA402D_TPDO_MODE_OF_OPERATION_DISPLAY is a uint16! For whoever is watching, the correct config file, in order to move the motor using ros2_control is the following:
|
I think this is dependend on the mapping of the drive. On my drive this was a uint8 (: Line 131 in 9657cf3
But good that it works now! EDIT |
Thanks again for your help 😁 Time permitting I'll also try a more robust approach! |
Hi, I've have the drives sort of working with ros2 control at the moment, but there aren't that robust e.g. you have to restart them a couple of times before they are working all together properly. I made some minor changes to the code that might not be needed but made my life easier:
I removed the factor / offset so we can get the raw values from the motors
And then set the factor and offset here. This way I can get the raw motor position to set as the initial position for the motors. Then in the drive file I just made this change:
I change it to this:
The thinking behind it. We initial the last_position as a nan in the header so check to make sure we have a value from the motor and then to make sure we have a none zero, as the motor position flickers +- 2 raw position values. I also had to add this as the first compel of readings I get from the motor are zero. This is my working yaml:
|
@alesof Where did you find this value:
I've looked in the data sheet and can't find it any where? |
@brennand, I initially started with a configuration file I had written for another Chinese actuator (Maxon and others share the same address). I subsequently modified it to suit the new actuator and left it there even if I didn't actually find a reference in the datasheet. I'm just experimenting with them during my free time and not actively working on them. Nonetheless, I've created a public repository for the automatic setup and usage, I'll share any update there. I'll take a look at your solution. Thanks! |
@brennand @alesof Hello. I'm also trying to make a ZeroErr eRob motor work with ethercat in ROS2. I try with the configuration file discussed early and it worked, at least once. It generally loops through the following states:
Sometimes it says it has reached the OP state, but it doesn't work. Some other times it reaches the SAFEOP+ERROR, or just the PREOP+ERROR state. I also notice, checking the eTunner software, that the operation mode never changes to 8, it's always at 3. The yaml file is missing the corresponding rpdo (i guess, I'm new to Ethercat), but adding it didn't change anything. Apart from that, in the monitor it shows the 33792 error: The velocity error exceeds the limit value, although I've never modify any velocity value. Have you made any progress to a more robust solution? Maybe it would be better to open a separate issue for this particular motor. |
Hi there, I'll be updating the public repo on my profile as soon I'll be able to work again on it. In the meantime I can tell you that I experienced the same error (velocity ecxeeds...) and it should be related to the current position beeing too far away from the commanded one. Using .nan (instead of zero) as default value removed the issue for me. But again, i didn't make many test! Probably @brennand solution using last_value is solving the same issue. As the issue is related to this specific motor I edited the title. |
A little update: I did the changes you suggested and I managed to get it into de OP state every time by launching the "joint trajectory controller" a little after everything else. It seems like, as you said, the current position was too far away from the target position. I let the motor get to the OP state and then I launch the "joint trajectory controller" (so far manually, I've been only doing tests). It still doesn't work perfectly with MoveIt2, but I didn't modify many configurations parameters yet. It starts moving but reaches the target before the final position, and then brakes, or it diverges too much, and brakes. Some other notes:
|
If you do not map the tpdo:
The operation mode will not be altered. You must add this to the tpdo. That should change the operating mode to 8 instead of 3.. |
This is what I learned about the velocity limit error. When we first connect to the motors, we do not get a valid position from the motor. So ROS2 control thinks the initial position is Zero and sets that the the desired position, that will course the motor to try and turn at great speed. I hack my version of this code to add:
after the I still find it very hard to startup 7 motors and they all start with no errors. normally takes a couple of attempts. I need to really write some code to clear the errors and try booting again. |
Streamline your eRob integration with our latest open-source software, drivers, and examples now available on GitHub: github.com/ZeroErrControl |
I am closing this, as there is an official repo now from @ZeroErrControl. I have opensourced the code I've been using too. |
@alejomancinelli I am very interested in this comment of yours Could you please provide some more detail about how you were able to first allow the drive to reach OP state and then start the trajectory controller? Thanks |
I'm just giving how I work around this. I'm starting the controllers after a timed delay: RegisterEventHandler(
event_handler=OnProcessStart(
target_action=ros2_control_node,
on_start=[
TimerAction(
period=90.0,
actions=load_controllers,
),
],
)
), Where load controllers is a list of the controllers which you would like to launch. I have around 30 ethercat clients, so it takes a while before they are all in OP (+- 70 seconds, I've added an extra 20seconds just to be sure). To prepare the load_controllers array i use the following: if len(load_controllers) == 0:
load_controllers.append(node)
else:
load_controllers += [
RegisterEventHandler(
event_handler=OnProcessExit(
target_action=(
load_controllers[-1]
if isinstance(load_controllers[-1], Node)
else load_controllers[
-1
].event_handler._OnActionEventBase__actions_on_event[-1]
),
on_exit=[node],
)
)
] So each one is started after the other. |
Thanks @JensVanhooydonck I'll implement that and test it out. |
Hi there!
I am trying to move an actuator using the generic plugin EcCiA402Drive. The device cannot switch to OP state due to a configuration error, can someone provide any help?
The error i get is: AL status message 0x001E: "Invalid input configuration".
The actuator name is: erob ZeroErr
sudo dmseg:
zeroerr_config.yaml
$ ethercat cstruct
Thank you!
The text was updated successfully, but these errors were encountered: