Skip to content

Commit

Permalink
Hotfix/walk to pokestop and refactor to walker (#1193)
Browse files Browse the repository at this point in the history
* some nice refactoring to StepWalker to avoid repetition

* removing sleep in navigator (bot should only sleep after walk and in workers)

* fixing walk to pokestop

* removing personal debug log from step walker

* removing empty line

* added random_lat_long_delta again to StepWalker (my bad)

* completely removed walking progress bar (log trimming is required)

* better log color when exchanging pokemon (red)

* less sleep after spinning pokestop

* spiral navigator shouldn't reuse step walker instance
  • Loading branch information
douglascamata authored Jul 27, 2016
1 parent 70e8d50 commit 3a18aa5
Show file tree
Hide file tree
Showing 7 changed files with 47 additions and 70 deletions.
1 change: 0 additions & 1 deletion pokemongo_bot/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,6 @@ def start(self):
random.seed()

def take_step(self):
location = self.navigator.take_step()
self.process_cells(work_on_forts=True)

def process_cells(self, work_on_forts=True):
Expand Down
2 changes: 1 addition & 1 deletion pokemongo_bot/cell_workers/evolve_all_worker.py
Original file line number Diff line number Diff line change
Expand Up @@ -109,7 +109,7 @@ def _release_evolved(self, release_cand_list_ids):
# Transfering Pokemon
self.transfer_pokemon(pokemon_id)
logger.log(
'[#] {} has been exchanged for candy!'.format(pokemon_name), 'green')
'[#] {} has been exchanged for candy!'.format(pokemon_name), 'red')

def _sort_by_cp_iv(self, inventory_items):
pokemons1 = []
Expand Down
8 changes: 6 additions & 2 deletions pokemongo_bot/cell_workers/initial_transfer_worker.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,12 @@ def work(self):
pokemon_data = pokemon_groups[id][pokemon_cp]
pokemon_potential = self.get_pokemon_potential(pokemon_data)
if self.should_release_pokemon(pokemon_name, pokemon_cp, pokemon_potential):
logger.log('Exchanging {} [CP {}] [Potential {}]'.format(
pokemon_name, pokemon_cp, pokemon_potential))
message = 'Exchanging {} [CP {}] [Potential {}]'.format(
pokemon_name,
pokemon_cp,
pokemon_potential
)
logger.log(message, 'red')
self.api.release_pokemon(
pokemon_id=pokemon_data['id'])
response_dict = self.api.call()
Expand Down
27 changes: 11 additions & 16 deletions pokemongo_bot/cell_workers/move_to_fort_worker.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,14 @@
from pokemongo_bot.worker_result import WorkerResult

class MoveToFortWorker(object):

def __init__(self, fort, bot):
self.bot = bot
self.fort = fort
self.api = bot.api
self.config = bot.config
self.navigator = bot.navigator
self.position = bot.position
self._step_walker = None

def work(self):
lat = self.fort['latitude']
Expand All @@ -23,26 +23,21 @@ def work(self):
dist = distance(self.position[0], self.position[1], lat, lng)

# print('Found fort {} at distance {}m'.format(fortID, dist))
logger.log('Found fort {} at distance {}'.format(
logger.log('[x] Found fort {} at distance {}'.format(
fortID, format_dist(dist, unit)))

if dist > 10:
logger.log('Need to move closer to Pokestop')
position = (lat, lng, 0.0)

if self._step_walker == None:
self._step_walker = StepWalker(
self.bot,
self.config.walk,
self.api._position_lat,
self.api._position_lng,
position[0],
position[1]
)
logger.log('[x] Need to move closer to Pokestop')

step_walker = StepWalker(
self.bot,
self.config.walk,
lat,
lng
)

if not self._step_walker.step():
if not step_walker.step():
return WorkerResult.RUNNING

logger.log('Arrived at Pokestop')
logger.log('[o] Arrived at Pokestop')
return WorkerResult.SUCCESS
2 changes: 1 addition & 1 deletion pokemongo_bot/cell_workers/seen_fort_worker.py
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ def work(self):
logger.log('Possibly searching too often - taking a short rest :)', 'yellow')
self.bot.fort_timeouts[self.fort["id"]] = (time.time() + 300) * 1000 # Don't spin for 5m
return 11
sleep(8)
sleep(2)
return 0

@staticmethod
Expand Down
23 changes: 9 additions & 14 deletions pokemongo_bot/spiral_navigator.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ def __init__(self, bot):
self.ptr = 0
self.direction = 1
self.cnt = 0
self._step_walker = None

# Source: https://github.com/tejado/pgoapi/blob/master/examples/spiral_poi_search.py
@staticmethod
Expand Down Expand Up @@ -55,15 +54,12 @@ def take_step(self):
# Scan location math

if self.config.walk > 0:
if not self._step_walker:
self._step_walker = StepWalker(
self.bot,
self.config.walk,
self.api._position_lat,
self.api._position_lng,
point['lat'],
point['lng']
)
step_walker = StepWalker(
self.bot,
self.config.walk,
point['lat'],
point['lng']
)

dist = distance(
i2f(self.api._position_lat),
Expand All @@ -77,8 +73,8 @@ def take_step(self):
self.api._position_lng))) + " to " + str([point['lat'], point['lng']]) + " " + format_dist(dist,
self.config.distance_unit))

if self._step_walker.step():
self._step_walker = None
if step_walker.step():
step_walker = None
else:
self.api.set_position(point['lat'], point['lng'])

Expand All @@ -87,11 +83,10 @@ def take_step(self):
i2f(self.api._position_lng),
point['lat'],
point['lng']
) <= 1 or (self.config.walk > 0 and self._step_walker == None):
) <= 1 or (self.config.walk > 0 and step_walker == None):
if self.ptr + self.direction == len(self.points) or self.ptr + self.direction == -1:
self.direction *= -1
self.ptr += self.direction
self.cnt = 0

sleep(1)
return [point['lat'], point['lng']]
54 changes: 19 additions & 35 deletions pokemongo_bot/step_walker.py
Original file line number Diff line number Diff line change
@@ -1,30 +1,22 @@
from math import sqrt

from pokemongo_bot import logger
from cell_workers.utils import distance, i2f
from human_behaviour import random_lat_long_delta, sleep
import sys


def progress_bar(percentage):
percentage = min(100, max(0, percentage))
if not sys.stdout.isatty():
return
sys.stdout.write('\r')
# http://www.fileformat.info/info/unicode/char/003D/index.htm
msg = (u"[%-40s] %d%%" % (u"\u003D"*int(percentage*2//5), percentage))
sys.stdout.write(msg)
sys.stdout.flush()


class StepWalker(object):

def __init__(self, bot, speed, initLat, initLng, destLat, destLng):
def __init__(self, bot, speed, destLat, destLng):
self.bot = bot
self.api = bot.api

dist = distance(
i2f(initLat),
i2f(initLng),
self.initLat, self.initLng = self.bot.position[0:2]

self.dist = distance(
self.initLat,
self.initLng,
destLat,
destLng
)
Expand All @@ -33,52 +25,44 @@ def __init__(self, bot, speed, initLat, initLng, destLat, destLng):

self.destLat = destLat
self.destLng = destLng
self.totalDist = max(1, dist)
self.totalDist = max(1, self.dist)

self.steps = (dist + 0.0) / (speed + 0.0)
self.steps = (self.dist + 0.0) / (speed + 0.0)

if dist < speed or self.steps < 1:
if self.dist < speed or int(self.steps) <= 1:
self.dLat = 0
self.dLng = 0
self.magnitude = 0;
else:
self.dLat = (destLat - i2f(initLat)) / self.steps
self.dLng = (destLng - i2f(initLng)) / self.steps
self.dLat = (destLat - self.initLat) / int(self.steps)
self.dLng = (destLng - self.initLng) / int(self.steps)
self.magnitude = self._pythagorean(self.dLat, self.dLng)

def step(self):
dist = distance(
i2f(self.api._position_lat),
i2f(self.api._position_lng),
self.destLat,
self.destLng
)

progress_bar(int(100 * (1 - dist/self.totalDist)))

if (self.dLat == 0 and self.dLng == 0) or dist < self.speed:
if (self.dLat == 0 and self.dLng == 0) or self.dist < self.speed:
if sys.stdout.isatty():
sys.stdout.write('\n')
self.api.set_position(self.destLat, self.destLng, 0)
return True

totalDLat = (self.destLat - i2f(self.api._position_lat))
totalDLng = (self.destLng - i2f(self.api._position_lng))
totalDLat = (self.destLat - self.initLat)
totalDLng = (self.destLng - self.initLng)
magnitude = self._pythagorean(totalDLat, totalDLng)
unitLat = totalDLat / magnitude
unitLng = totalDLng / magnitude

scaledDLat = unitLat * self.magnitude
scaledDLng = unitLng * self.magnitude

cLat = i2f(self.api._position_lat) + scaledDLat + random_lat_long_delta()
cLng = i2f(self.api._position_lng) + scaledDLng + random_lat_long_delta()
cLat = self.initLat + scaledDLat + random_lat_long_delta()
cLng = self.initLng + scaledDLng + random_lat_long_delta()

self.api.set_position(cLat, cLng, 0)
self.bot.heartbeat()

sleep(1) # sleep one second plus a random delta
# self._work_at_position(
# i2f(self.api._position_lat), i2f(self.api._position_lng),
# self.initLat, self.initLng,
# alt, False)

def _pythagorean(self, lat, lng):
Expand Down

0 comments on commit 3a18aa5

Please sign in to comment.