tengo un poco de código Python que tiene este aspecto:excepción hallado en pitón multiprocesamiento
procs = cpu_count()-1
if serial or procs == 1:
results = map(do_experiment, experiments)
else:
pool = Pool(processes=procs)
results = pool.map(do_experiment, experiments)
Funciona muy bien cuando me puse la bandera serial
, pero da el siguiente error cuando se utiliza el Pool
. Cuando intento imprimir algo desde do_experiment
, no aparece nada, así que no puedo intentar capturarlo e imprimir un seguimiento de la pila.
Exception in thread Thread-2:
Traceback (most recent call last):
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/threading.py", line 530, in __bootstrap_inner
self.run()
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/threading.py", line 483, in run
self.__target(*self.__args, **self.__kwargs)
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/multiprocessing/pool.py", line 285, in _handle_tasks
put(task)
TypeError: 'NoneType' object is not callable
¿Cuál es una buena manera de proceder a la depuración de esto?
Probablemente esto no importe, pero ¿cuál es el valor de retorno de 'cpu_count()'? – mgilson
Depende del sistema. 2 en mi computadora portátil. 8 en el servidor. De cualquier manera, si 'pool.map' se usa en lugar de 'map', las cosas se rompen. – noio