Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

I want to evaluate a very complicated (and possibly slow) function for N different input values.

def f(x):
   # do something very complicated
   return out

Via multiprocessing I want to parallelize the calculation on a cluster with N cores, so I do

import multiprocessing  
pool = Pool(N)
results = pool.map(f, xlist)
pool.close()
pool.join()

with 'xlist' being a list (or numpy array) that contains all input values. My question is the following: There might be values of x, where the solution of f does not converge, but I don't want to occupy the whole cluster, just because one data point does not finish. So how can I time each process, and if the time's up, return None, or some different placeholder instead of the usual output of f?

question from:https://stackoverflow.com/questions/65928485/stop-processes-from-python-multiprocessing-that-take-too-long

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
1.3k views
Welcome To Ask or Share your Answers For Others

1 Answer

Waitting for answers

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...