From Valve Developer Community
Revision as of 14:19, 14 September 2009 by TomEdwards (talk | contribs) (Absolute, local and base: for some reason CBaseEntity swallows base velocity into abs :s)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search

Velocity is a measure of speed and direction. In Source, it is a Vector that an entity will try to move the length of once per second: a velocity of (0,0,-200) means that you are falling at 200 units per second.

Absolute, local and base

There are actually three different velocity vectors:

  1. Local velocity: generated by the entity
  2. Base velocity: applied to the entity from other sources
  3. Absolute velocity: the sum of the local and base velocities; the actual value used to move
Note.png Note: The next paragraph only appears to apply to players! Base velocity is "swallowed" by other entities.

Having separate local and base velocities allows for the proper handling of inertia. If an NPC is standing on a fast-moving train, the motion of the carriage is stored in its base velocity while the motion the NPC creates itself when walking up and down is stored in its local velocity. There is no danger of either value overwriting the other, or of the NPC thinking it's walking at 150MPH.

Warning.png Warning: Don't try to change another entity's local or absolute velocity, as it will likely overwrite both values when it next tries to move. Instead, add to the existing base value with SetBaseVelocity().


When an entity moves, the code looks a little like this:

SetLocalVelocity( vecSomeValue );

SetAbsVelocity( GetLocalVelocity() + GetBaseVelocity() );

// frametime is in seconds, e.g. 0.033
SetAbsOrigin( GetAbsOrigin() + (GetAbsVelocity() * gpGlobals->frametime) );

Notice how:

  1. Objects don't so much travel through space as teleport a very small distance each frame.
    Note.png Note: Beware an object moving so fast that it doesn't pass through intervening space, which can happen unexpectedly if the server's framerate dips too far. To do: How can this be best avoided?
  2. gpGlobals->frametime is used to regulate the entity's speed regardless of how long each frame takes to calculate. (See Vector for more detail on this operation.)


  • GetLocalVelocity(), SetLocalVelocity()
  • GetBaseVelocity(), SetBaseVelocity()
  • GetAbsVelocity(), SetAbsVelocity()

See also