В Python модуль multiprocessing
может использоваться для параллельной работы функции над диапазоном значений. Например, это дает список первых 100000 оценок f.
def f(i):
return i * i
def main():
import multiprocessing
pool = multiprocessing.Pool(2)
ans = pool.map(f, range(100000))
return ans
Можно ли сделать подобное, если f принимает несколько входов, но меняется только одна переменная? Например, как бы вы распараллеливали это:
def f(i, n):
return i * i + 2*n
def main():
ans = []
for i in range(100000):
ans.append(f(i, 20))
return ans