Faster, O(n) implementation of -[ShipEntity findNearestPlanet].
This method is called every frame for every ship through checkForAegis. The previous implementation was taking about 9% of -[Universe update] time in a vanilla Lave; rewrite takes < 1% and scales better. git-svn-id: http://svn.berlios.de/svnroot/repos/oolite-linux/trunk@5323 127b21dd-08f5-0310-b4b7-95ae10353056
This commit is contained in:
parent
97d909d8ed
commit
8c4a8dfeda
@ -6430,29 +6430,27 @@ NSComparisonResult ComparePlanetsBySurfaceDistance(id i1, id i2, void* context)
|
||||
|
||||
- (OOPlanetEntity *) findNearestPlanet
|
||||
{
|
||||
OOPlanetEntity *result = nil;
|
||||
NSArray *planets = nil;
|
||||
/* Performance note: this method is called every frame by every ship, and
|
||||
has a significant profiler presence.
|
||||
*/
|
||||
OOPlanetEntity *planet = nil, *bestPlanet = nil;
|
||||
float bestRange = INFINITY;
|
||||
Vector myPosition = [self position];
|
||||
|
||||
planets = [UNIVERSE planets];
|
||||
if ([planets count] == 0) return nil;
|
||||
foreach (planet, [UNIVERSE planets])
|
||||
{
|
||||
// Ignore miniature planets.
|
||||
if ([planet planetType] == STELLAR_TYPE_MINIATURE) continue;
|
||||
|
||||
planets = [planets sortedArrayUsingFunction:ComparePlanetsBySurfaceDistance context:self];
|
||||
result = [planets objectAtIndex:0];
|
||||
|
||||
// ignore miniature planets when determining nearest planet - Nikos 20090313
|
||||
if ([result planetType] == STELLAR_TYPE_MINIATURE)
|
||||
float range = SurfaceDistanceSqaredV(myPosition, planet);
|
||||
if (range < bestRange)
|
||||
{
|
||||
if ([UNIVERSE sun]) // if we are not in witchspace give us the next in the list, else nothing
|
||||
{
|
||||
result = [planets objectAtIndex:1];
|
||||
}
|
||||
else
|
||||
{
|
||||
result = nil;
|
||||
bestPlanet = planet;
|
||||
bestRange = range;
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
return bestPlanet;
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user