Chief Delphi

Chief Delphi (http://www.chiefdelphi.com/forums/index.php)
-   Technical Discussion (http://www.chiefdelphi.com/forums/forumdisplay.php?f=22)
-   -   fine control of robot with mecanum wheels (http://www.chiefdelphi.com/forums/showthread.php?t=84344)

efoote868 17-03-2010 10:00

Re: fine control of robot with mecanum wheels
 
My team is using mecanum wheels, I believe we are using the same setup or something similar.


One thing to keep in mind is that everything has a slight polarity, and a deadband. You can work to figure out where the motors start spinning, and then account for it in code.

Also, another thing my team has found useful is separating the rotation component from the XY joystick to another one - we found it was nearly impossible to spin without moving off axis until we did this.


After this season's competition I think I'll write a whitepaper on how I got the students to approach mecanum drive, our setup this year is very easy to control and I'd like them to be able to use it easily in future years (without having to worry about cheating).

Ether 17-03-2010 11:03

Re: fine control of robot with mecanum wheels
 
Quote:

Originally Posted by efoote868 (Post 938552)
My team is using mecanum wheels, I believe we are using the same setup or something similar.

Could I ask you to check with your lead programmer to find out if your bot using using closed-loop wheel speed control ?

Thank you.


~

efoote868 17-03-2010 11:05

Re: fine control of robot with mecanum wheels
 
There is no wheel feedback.

Ether 17-03-2010 11:20

Re: fine control of robot with mecanum wheels
 
Hi Team 868,

Thanks for your reply. I have a bunch of questions, I hope you don't mind. Any answers you are willing to provide would be much appreciated:

My team is using mecanum wheels, I believe we are using the same setup or something similar.

Are you using 8" AndyMark mecanums? Are the wheels direct-driven, or chain-driven? If chain, what are the sprocket teeth counts? Are you using the KoP AndyMark 12.75:1 toughbox? If not, what is your gear ratio? Are you using Victor or Jag motor controllers?

One thing to keep in mind is that everything has a slight polarity, and a deadband. You can work to figure out where the motors start spinning, and then account for it in code.

Yes, we are aware of this. Nothing we have tried so far is able to achieve fine control at low speeds, given our gear ratio and open-loop control.


Also, another thing my team has found useful is separating the rotation component from the XY joystick to another one - we found it was nearly impossible to spin without moving off axis until we did this.

We have no trouble spinning in-place, with the rotation command on the "twist" axis of a 3-axis joystick.


~

Mr. Lim 17-03-2010 11:48

Re: fine control of robot with mecanum wheels
 
Ether,

It sounds like you're running a setup very similar to ours. I can't say we've "mastered" fine motor control with our mecanum wheels, but I'm happy to answer any questions you have. Here's a video of our practice robot, showing what we can/can't do:

http://www.youtube.com/watch?v=apcy5naz5TE

Quote:

Are you using 8" AndyMark mecanums?
Yes.

Quote:

Are the wheels direct-driven, or chain-driven? If chain, what are the sprocket teeth counts?
They are chain-driven. 19 tooth on the ToughBox output shaft, kit supplied 22 tooth on the Mecanum wheel hubs.

Quote:

Are you using the KoP AndyMark 12.75:1 toughbox? If not, what is your gear ratio?
Yes we are using the KoP AndyMark ToughBoxes, unmodified.

Quote:

Are you using Victor or Jag motor controllers?
We are using Jaguar motor controllers, using PWM control.

Our setup also uses the US Digital optical encoders, and the WPILib PIDController object. We are using closed loop I-only motor control, and we cube our joystick inputs before sending them to our control loop.

We also implemented a "slow-down" button, which scales both our translational and angular velocities to about 1/3 of max when held down. You can see it used in the video just prior to when our robot meets the ball - the robot seems to abruptly slow down.

Boommaster713 17-03-2010 11:55

Re: fine control of robot with mecanum wheels
 
Something to be aware of is that during testing my team found that in order to control the robot at low speeds the motors must be given 40% of maximum voltage (to overcome the robots moment of inertia) and then once the robot is moving the power can lower slightly.
Other issues that could impact fine control is the lag time between control system and robot.

My Team's robot uses a near identical setup, 8in andymark Mechanums wheels(with black mini wheels), andy mark toughboxes, chains connecting them with andymark wheel tensioners (Fiddly to the extreme to get right, but once right they havent failed through 13+ matches)
all done open loop with no feedback, with jaguars on PWMs, and joystick mapping for fine control

Robot control is a 3 axis joystick

Ether 17-03-2010 12:39

Re: fine control of robot with mecanum wheels
 
Quote:

Originally Posted by Mr. Lim (Post 938605)
Our setup also uses the US Digital optical encoders, and the WPILib PIDController object. We are using closed loop I-only motor control

What made you decide to use closed-loop wheel speed control ? Was the performance less than satisfactory without it ?


~

Mr. Lim 17-03-2010 12:55

Re: fine control of robot with mecanum wheels
 
Quote:

Originally Posted by Ether (Post 938631)
What made you decide to use closed-loop wheel speed control ? Was the performance less than satisfactory without it ?


~

The performance was far less than satisfactory without it IMHO.

The vector math behind mecanums isn't that complicated, but it depends on the ability to get a wheel turning at precisely the velocity you want it to.

Ether 17-03-2010 13:05

Re: fine control of robot with mecanum wheels
 
Quote:

Originally Posted by Mr. Lim (Post 938637)
The performance was far less than satisfactory without it IMHO.

OK. I think that's our problem. We are using open loop.

Quote:

The vector math behind mecanums isn't that complicated
Agreed. We did our own:
http://www.chiefdelphi.com/forums/sh...83&postcount=1

Quote:

, but it depends on the ability to get a wheel turning at precisely the velocity you want it to.
OK. That's what I figured.

~

efoote868 17-03-2010 14:08

Re: fine control of robot with mecanum wheels
 
I think the only difference is the wheel size, 6 inch versus 8.
I understand that might provide a difference in the "low speed" handling.

For the drive, we're using Jaguars via PWM.


Sorry I don't have all the information... all of this is from memory.

Ether 17-03-2010 14:15

Re: fine control of robot with mecanum wheels
 
Quote:

Originally Posted by efoote868 (Post 938682)
I think the only difference is the wheel size, 6 inch versus 8.
I understand that might provide a difference in the "low speed" handling.

Yes. It could definitely make a difference, depending on other factors of course.

Quote:

Sorry I don't have all the information... all of this is from memory.
I understand. But if I may ask without being too much of a pest, would you be willing to ask your lead engineer whether you have encoders on the wheels/gearboxes, and what the other details of your drivetrain are (gear ratio of transmission and tooth count on sprockets if using chain drive).

Thanks


~

Jared Russell 17-03-2010 14:29

Re: fine control of robot with mecanum wheels
 
The holonomic drivebases that we have used (in 2007 and 2008) had similar kinematics to mecanum drives, and we were also dissatisfied (at first) with the controllability of the drive at all speeds, and especially at low speeds.

The following solutions helped to get us under control, and each of the aforementioned robots managed to win a regional:

1. Make absolutely sure that all wheels are always touching the ground. Ideally, you should have some sort of suspension or at least a non-rigid frame that lets you deal with non-flat carpet.

2. Use a gyro to help the robot drive straight. We used a proportional-only controller with a feed forward component (meaning we did the holonomic drive kinematics to generate the command, and then added the output of a P controller with "yaw command" as setpoint and gyro rate as input). In general, we found that encoders on the wheels did help, but not nearly as much as the gyro (because of wheel slip, non-level surfaces, etc.) Also, this was back in the IFI era, so CAN speed control was not an option.

3. Limit each joystick to a maximum of two axes. We tried using a 3 axis (X,Y,Twist) joystick with our holonomic drive, but despite plenty of practice our drivers always seemed to do better with a two stick setup without a twist axis (one stick for X/Y and another that just uses the X axis for twist, or one stick for Y and twist - e.g. tank drive - and the other for strafing). Simply put, we found that too often the driver would accidentally use the twist axis when they didn't mean to.

4. Making sure that weight is distributed evenly! The vector math assumes all wheels have equal normal force - if your robot is far off from this assumption, your mileage will vary.

efoote868 17-03-2010 14:35

Re: fine control of robot with mecanum wheels
 
I know for a fact there are no sensors on individual wheels.
I'll ask tomorrow at BMR what our reduction is.

Ether 17-03-2010 15:00

Re: fine control of robot with mecanum wheels
 
Quote:

Originally Posted by Jared341 (Post 938693)

2. Use a gyro to help the robot drive straight.

4. Making sure that weight is distributed evenly!

Weight distribution! Yes, I can see where that might be a factor with our design.

Gyro. Interesting. How difficult was this to implement (develop and tune the algorithm)? Were all your gyro implementations on bots with closed-loop wheelspeed? Or did you try it without closed-loop?

Thanks!


~

Jared Russell 17-03-2010 15:08

Re: fine control of robot with mecanum wheels
 
Quote:

Originally Posted by Ether (Post 938707)
Weight distribution! Yes, I can see where that might be a factor with our design.

Gyro. Interesting. How difficult was this to implement (develop and tune the algorithm)? Did you have success using gyro without closed-loop wheelspeed control?

Thanks!


~

Using the gyro was very simple - the algorithm was just:

Code:

for each motor
  motorCommand = <result of holonomic drive calculations>;
  if we are trying to go straight (e.g. yaw command is zero)
    motorCommand += Kp * getGyroRate();
  end if
  Tell motor to go "motorCommand"
end for

As you can see, we didn't need encoders for this to work well for us. We determined "Kp" by having it read from a potentiometer (the throttle on our joystick) - we played with it until it seemed like there was a good balance between staying straight and being smooth (if Kp is too high, the robot will oscillate wildly). You can also use integral or derivative terms (e.g. PI, PD, or PID) in your controller if you aren't satisfied that this is fixing things for you.

We put encoders on our drive, but ended up only using them for distance tracking in autonomous mode rather than for velocity control (the gyro by itself was fine and was 4 less things that could fail).


All times are GMT -5. The time now is 01:14.

Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi