2012-06-21 22:00:04 -04:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
import initExample ## Add path to library (just for examples; you do not need this)
|
2015-05-19 09:29:55 -04:00
|
|
|
|
|
|
|
import time
|
2012-06-21 22:00:04 -04:00
|
|
|
import numpy as np
|
|
|
|
import pyqtgraph.multiprocess as mp
|
|
|
|
import pyqtgraph as pg
|
2015-05-19 09:29:55 -04:00
|
|
|
from pyqtgraph.python2_3 import xrange
|
2012-06-21 22:00:04 -04:00
|
|
|
|
2013-01-12 14:35:32 -05:00
|
|
|
print( "\n=================\nParallelize")
|
2012-06-21 22:00:04 -04:00
|
|
|
|
|
|
|
## Do a simple task:
|
|
|
|
## for x in range(N):
|
|
|
|
## sum([x*i for i in range(M)])
|
|
|
|
##
|
|
|
|
## We'll do this three times
|
|
|
|
## - once without Parallelize
|
|
|
|
## - once with Parallelize, but forced to use a single worker
|
|
|
|
## - once with Parallelize automatically determining how many workers to use
|
|
|
|
##
|
|
|
|
|
|
|
|
tasks = range(10)
|
|
|
|
results = [None] * len(tasks)
|
|
|
|
results2 = results[:]
|
|
|
|
results3 = results[:]
|
|
|
|
size = 2000000
|
|
|
|
|
|
|
|
pg.mkQApp()
|
|
|
|
|
|
|
|
### Purely serial processing
|
|
|
|
start = time.time()
|
|
|
|
with pg.ProgressDialog('processing serially..', maximum=len(tasks)) as dlg:
|
|
|
|
for i, x in enumerate(tasks):
|
|
|
|
tot = 0
|
|
|
|
for j in xrange(size):
|
|
|
|
tot += j * x
|
|
|
|
results[i] = tot
|
|
|
|
dlg += 1
|
|
|
|
if dlg.wasCanceled():
|
|
|
|
raise Exception('processing canceled')
|
2013-01-12 14:35:32 -05:00
|
|
|
print( "Serial time: %0.2f" % (time.time() - start))
|
2012-06-21 22:00:04 -04:00
|
|
|
|
|
|
|
### Use parallelize, but force a single worker
|
|
|
|
### (this simulates the behavior seen on windows, which lacks os.fork)
|
|
|
|
start = time.time()
|
|
|
|
with mp.Parallelize(enumerate(tasks), results=results2, workers=1, progressDialog='processing serially (using Parallelizer)..') as tasker:
|
|
|
|
for i, x in tasker:
|
|
|
|
tot = 0
|
|
|
|
for j in xrange(size):
|
|
|
|
tot += j * x
|
|
|
|
tasker.results[i] = tot
|
2013-01-12 14:35:32 -05:00
|
|
|
print( "\nParallel time, 1 worker: %0.2f" % (time.time() - start))
|
|
|
|
print( "Results match serial: %s" % str(results2 == results))
|
2012-06-21 22:00:04 -04:00
|
|
|
|
|
|
|
### Use parallelize with multiple workers
|
|
|
|
start = time.time()
|
|
|
|
with mp.Parallelize(enumerate(tasks), results=results3, progressDialog='processing in parallel..') as tasker:
|
|
|
|
for i, x in tasker:
|
|
|
|
tot = 0
|
|
|
|
for j in xrange(size):
|
|
|
|
tot += j * x
|
|
|
|
tasker.results[i] = tot
|
2013-01-12 14:35:32 -05:00
|
|
|
print( "\nParallel time, %d workers: %0.2f" % (mp.Parallelize.suggestedWorkerCount(), time.time() - start))
|
|
|
|
print( "Results match serial: %s" % str(results3 == results))
|
2012-06-21 22:00:04 -04:00
|
|
|
|