Yes, it's very exciting the first time, isn't it ? You'll experience both
bouts of extreme frustration and big smiling (even evil, devilish sounding
laughter) attacks in turn in the future :-)
>I have noticed some annoying jittering on the wheels when at low
This is an age old problem that even today engineers are still developing new
methods to eliminate. Ruud pointed out a paper that has an excellent solution,
probably the best one any of us here have seen, although you might need to drop
him or Gregor a note for help (sorry guys ;-)). It's confusing to say the
least, although rather brilliant. Thanks can go to Chris West for pointing it
our way.
The problem you're having is (we all have this problem), the tires tend to
overshoot their "ideal" slip ratio by a small amount, then fall back the next
step, and continue oscillating. At higher speeds, since the rotational speed
of the wheel and theoretical free rolling speed are high, the oscillation in
slip ratio isn't enough to notice or cause an instability. However, since slip
ratio is essentially (TrueRotVel / TheoreticalRotVel), once the car slows down
enough, even a small change in true rotational velocity causes a large change
in slip ratio, which causes a really big torque back the other direction. This
goes back and forth, and gets worse the slower you go. This is why I sometimes
cringe when people here at r.a.s. occasionally get frustrated at some low speed
behavi***"quirk" in one of their various racing sims, and immediately dub it
"arcade" instead of "*** super realistic simulation." They don't
understand how the situation is completely different when it moves to high
speed racing modelling.
The paper Ruud talks about treats slip ratio (and slip angle) as a state
variable. Meaning you calculate what it "should" be the same way you're doing
it now, but then you only let it increase/decrease a little bit towards this
value each time step, depending on the speed of wheel rotation and linear
motion. It slowly gains on the slip ratio (and angle) while the wheel rotates
according to a somewhat arbitrarily defined "relaxation length" the wheel
moves/rotates through, and eventually arrives at the slip ratio you're
currently calculating. This lets the slip ratio and slip angle slowly build
up, and when stopping on a hill (a problem you'll soon discover that will rear
it's ugly head, causing a massive hair pulling episode), the slip ratio and
angle settle at some non-zero value, even though the wheel isn't rotating,
keeping the forces right where they should be. It's elegent and beautiful, IMO
:-)
I haven't included this in my system yet, although I've played around a
little with the gain effect in a seperate program as an experiment to see
how/why/if it worked.
Anyway, since I didn't know about this relaxation approach when I first
encountered the problem, I did two things:
1. I decoupled the rotational velocity/acceleration of the tires from the
main system and let it operate at its own frequency. This lets me set the
sampling frequency of the tires and differential to a really high value without
doing every single body motion calculation and ground intersection 10-100 times
as often (actually, it's adjustable on the fly, I should experiment with that
come to think of it.) To see what I mean, increase the main frequency
(decrease your timestep) and you'll notice that the speed where instabilities
start to occur drops. This lessens the problem, but you'd need an infinite
frequency to completely eliminate it this way. Perhaps there will be an
Infinite HZ holographic laser/time warp operated CPU someday :-) (Inside joke:
Would Papy make a CPU patch for this as quickly as they did for the 1.4 GHz if
it didn't work right away? WOW, was that fast! ;-))
2. I wrote something similar to a "rigid-ring" tire model for low
speed/stationary movement. This treats the tire and wheel as two seperate
things that can rotate around each other like a torsion spring. The angular
difference between the two "rings" is multiplied by a spring rate, which
provides a forward/aft force and torque, and is damped by the difference in
rotational velocity. It works great for slow motion stuff, although it's
tricky to adjust it so you don't notice the sudden change between the low and
regular (high speed) model. It also doesn't deal well in certain situations
with my differential gear code if the diff unlocks, so it isn't perfect, but it
lets you stop on hills or move slowly up and down them with no stability
problems and without resorting to absurdly high sampling frequencies.
As far as the lateral (slip angle) stuff goes, my experience is the same
as what Ruud mentioned in that letting the slip angle oscillate quickly between
high negative and positive slip angles is usually unnoticeable, even at low
speeds, and lets the car stop sideways on embankments. I haven't put anything
special in my system to handle this, and you can only see the oscillations when
I've got extremely high grip tires on a really light car, then it shakes just
like it has a big engine, so maybe it's not all bad ;-)
Still, if you've got a few bucks to pay SAE for the paper Ruud mentioned
and are mathematically inclined enough to work it, it's the best solution I've
seen for all the low speed problems. I'm planning on using it as a basis when
it's time to get back into my tire model.
Thanks for the slip ratio equation, I've currently got an IF block to handle
the different forward/aft movement vs. rotation combinations to make sure the
slip ratio is calculated correctly. That's ugly and slow compared to Brian
Beckman's equation :-)
I believe it's because the amount of longitudinal stretching in the tire is
dependent on slip ratio, rather than slip velocity (that's kind of circular
reasoning, but what the heck). Imagine a piece of *** moving through the
contact patch from front to rear (ignoring distortion from tire radius change.)
Imagine it's moving rearwards 1 m/s quicker than it would be in a free rolling
tire:
1. In a tire that had a free rolling velocity of only 1 m/s, the piece of
*** would leave the contact patch twice as quickly as it would if it was
rolling freely. If the contact patch was 1 meter long (big tire!), it would
have stretched out of place .5 meters from where it should be in a free rolling
situation. If a longitudinal tire spring rate could be estimated at
1000N/meter, you'd now have 500 N of force. The tire acts like a big ***
band, so the amount of stretching (.5 meters in this case) is what causes the
force.
2. In a tire that had a free rolling velocity of 100 m/s, the piece of ***
would leave the contact patch only 1/100th more quickly than it should. That
would only amount to a tiny amount of stretching in the print (.01 * .5 meter
print = .05 meters ahead, instead of .5 meters ahead.) Multiply that by our
1000N/meter spring rate and you'd only have 50 N of force.
Anyway, I don't know if my math is quite right there, but maybe the reason
is apparant now anyway. The slip "velocity" in both cases is identical at 1
m/s slip. If you tried to find the amount of stretching using different
velocities calculated from a constant slip ratio, the amount of stretching
would probably be constant. Therefore, since the "***band" is stretched out
of shape the same amount, it'd make the same force. Make sense?
Todd Wasson
---
Performance Simulations
Drag Racing and Top Speed Prediction
Software
http://www.racesimcentral.net/