View Single Post
  #4   Spotlight this post!  
Unread 27-01-2008, 18:43
Daniel_LaFleur's Avatar
Daniel_LaFleur Daniel_LaFleur is offline
Mad Scientist
AKA: Me
FRC #2040 (DERT)
Team Role: Engineer
 
Join Date: Apr 2005
Rookie Year: 2003
Location: Peoria, IL
Posts: 1,964
Daniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond reputeDaniel_LaFleur has a reputation beyond repute
Send a message via MSN to Daniel_LaFleur
Re: Help with Steering?

Quote:
Originally Posted by interfect View Post
Hello,
We have our robot set up with two independent steering wheels, tracked with encoders and run by globe motors geared down at about a 3:1 ratio. It has fallen to me to program this rig, and convince it to do something useful. I am trying to get the wheels to point in a certain direction, but I am having trouble with the position seeking algorithm.
Running the wheels right when they're turned too far left, and left when they are too far right, just makes them oscillate about the target (I didn't add a dead zone. I could try that, but I want them to seek exactly.)
I tried implementing full PID control, but tuning it has already consumed more time than it's really worth, and no matter what I do it either oscillates or doesn't get to the target, or sometimes both.
I think the underlying problem may be that, because of the motors and the gearing, the wheels don't perceptibly move unless the motor is set to more than about 20 units off of idle (127). Once the motor revs up, it's hard to stop on target. PID ought to be able to deal with this, but it isn't.
What sort of control schemes have other people used for this sort of problem? How do you tune your PID loops (if you use them)?

What's the simple & effective solution that I am ignoring?
PID is really the way to go.

One of the things you'll need to do is slow down the turning motor as it gets closer to the target direction. If you dont do this you will end up hunting around your target (also caled classic occillation).

Also, if your wheels start to turn right when you are turning left then you are probably manipulating the input number such that it goes over 255 or below 0 and thus "wraps around". You need to check (Printf) what your numbers are when you are sending them, as a PWM, to the motor.

I would also suggest using a pot, rather than an encoder, to give you positional feedback. That should avoid 'wrapping around' with your PWM numbers.
__________________
___________________
"We are not now that strength which in old days moved earth and heaven; that which we are, we are;
One equal temper of heroic hearts, Made weak by time and fate, but strong in will
To strive, to seek, to find, and not to yield. "
- Tennyson, Ulysses