Steering.core Defines the basic reactive behavior of an Agent Calculates the "cost" of a given velocity which are used to decide which velocity an agent should actually choose. There are multiple things this method needs to consider: Target Where does the agent want to move to? Speed How fast does the agent want to travel? Time of impact There are velocities which will lead to collisions with obstacles in the future Side It's often usful to prefer a "side" on which an agent avoids obstacles because it can help to reduce oscillations Based on those the function should calculate the cost for a given velocity. To to this it should somehow combine different weighted scores. The agent for which the cost should be evaluated The velocity which should be evaluated Normalized time of impact (between 0 and 1) for the velocity. A value of 0 means we are already colliding and a value of 1 means that a collision will occure earliest at the . The cost for the given velocity which should be between 0 and 1 [GET / SET] The preferred speed of the agent. [GET] The maximum speed of the agent. An agent is the basic component you want to attach to computer-controlled characters. It contains functionallity to avoid collisions with other agents/obstacles and tries to get to some defined target-location. The avoidance is only local therefore it's possible that the agent get stuck in local minima. For more complex navigation you need a high-level pathfinding layer on top of the local avoidance. [GET / SET] The Agents target velocity, i.e. the one which it tries to acquire. This is a convenience property that automatically sets and to the appropriate values. [GET / SET] The Agents target velocity, i.e. the one which it tries to acquire. This is a convenience property that automatically sets and to the appropriate values. [GET / SET] The target speed this Agent attempts to acquire unless distracted by other Agents. [GET / SET] The radius of the agent (an agent is always representet as circle) [GET / SET] The maximum time of impact wich the agent will react on. If you set this too high your agent will oscillate alot in crowded situations and if you set it too low your agent will avoid very late which looks artificial. [GET] The calculated velocity which the agent calculated as optimum. Implementation of which offers parameters which are closely related to the algorithms used. Those might be hard to configure if one doens't have background knownledge about the implementation. In that case you should use . [GET/SET] Factor between 0 and 1 which defines how much velocity-consistency should be weighted [GET/SET] Factor between 0 and 1 which defines how much the difference from the optimal direction should be weighted [GET/SET] Factor between 0 and 1 which defines how much the difference from the optimal speed should be weighted [GET/SET] Factor between 0 and 1 which defines how much the time of impact with other obstacles should be weighted [GET/SET] Value between 0 and infinity which defines the exponent applied to the TOI-penality. Can be used to make the agent avoid other obstacles earlier/later. [GET/SET] The speed which the agent should use if possible. Implementation of which offers parameters which are intuitve for end users. The purpose of this implementation is to hide implementation details as much as possible. If you need more control you can either use or use a custom implementation. This Component assigns the objects RigidBody radius (taken from its first circle shape) directly to its Agent radius, and applies the Agents suggested velocity back to the RigidBody. The sole purpose if this Component is to visualize Agent behavior. This static class contains constant string representations of certain resource names. This interface should but doesn't need to be used by implementations of . It defines which directions of velocities an agent preferes aka in which direction is the target of the agent Evaluates the cost function for a given velocity direction. The agent for which the cost should be evaluated The direction for which the cost should be evaluated This NOT the velocity but only the direction (vector is normalized) of it. Cost for the given velocity which should be between 0 and 1 Creates velocity samples which are going to get tested with . If the samples are poorly chosen or if there are simply not enough samples the agent won't be able to choose "good" velocities which lead to a bad steering quality. If on the other hand to many samples are generated the performance will suffer because for every sample the agent needs to calculate time of imapacts with obstacles. This method is called in every time step for every agent before the sampling starts. If your implementation is adaptive you should throw away your old state here and start over. Get the current sample velocity. The implementation is free to use internal information gathered from previous calls to . You should make sure that your implementation samples the zero-velocity. Velocity which should be evaluated Feeds the evaluated cost back into the sampler. The cost value can be used to adapt and intelligent choose the next velocities. The cost which was returned from with the current velocity as parameter true if more velocities should be sampled and false if no new velocities should be sampled. Simple brute force implementation of . Velocities are equally distributed in all directions independent of the costs which are fed back. Samples velocities based on the velocity the agent chose. The sampling density is higher velocities close to the last best velocity. This reduces samples needed massively compared to but can potentially lead to undesired behavior.