Browse Source

fixed freezing Dispatcher

master
Tom Krüger 4 years ago
parent
commit
7e76b12b65
1 changed files with 12 additions and 3 deletions
  1. +12
    -3
      al2/experiment.py

+ 12
- 3
al2/experiment.py View File

@ -51,21 +51,23 @@ class Dispatcher (threading.Thread):
worker.start() worker.start()
def wait_to_continue(workers, stop_called): def wait_to_continue(workers, stop_called):
any_worker_alive = any(map(lambda w: w.is_alive(), workers))
any_worker_alive = lambda: any(map(lambda w: w.is_alive(), workers))
while any_worker_alive and not stop_called.is_set():
while any_worker_alive() and not stop_called.is_set():
time.sleep(0) time.sleep(0)
waiter = threading.Thread(target=wait_to_continue, waiter = threading.Thread(target=wait_to_continue,
args=(self.__workers, args=(self.__workers,
self.__stop_called)) self.__stop_called))
waiter.start() waiter.start()
waiter.join() waiter.join()
if self.__stop_called.is_set(): if self.__stop_called.is_set():
for worker in self.__workers: for worker in self.__workers:
worker.terminate() worker.terminate()
for worker in self.__workers: for worker in self.__workers:
worker.join() worker.join()
@ -73,6 +75,13 @@ class Dispatcher (threading.Thread):
def stop(self): def stop(self):
self.__stop_called.set() self.__stop_called.set()
def num_active_workers(self):
count = 0
for worker in self.__workers:
count += 1 if worker.is_alive() else 0
return count
class Worker (multiprocessing.Process): class Worker (multiprocessing.Process):
def __init__(self, exp_mod, exp_plan): def __init__(self, exp_mod, exp_plan):
multiprocessing.Process.__init__(self) multiprocessing.Process.__init__(self)


Loading…
Cancel
Save