本文整理匯總了Python中concurrent.futures.ProcessPoolExecutor方法的典型用法代碼示例。如果您正苦於以下問題:Python futures.ProcessPoolExecutor方法的具體用法?Python futures.ProcessPoolExecutor怎麽用?Python futures.ProcessPoolExecutor使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類concurrent.futures
的用法示例。
在下文中一共展示了futures.ProcessPoolExecutor方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: main
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def main():
t1 = timeit.default_timer()
with ProcessPoolExecutor(max_workers=4) as executor:
for number, prime in zip(PRIMES, executor.map(is_prime, PRIMES)):
print('%d is prime: %s' % (number, prime))
print("{} Seconds Needed for ProcessPoolExecutor".format(timeit.default_timer() - t1))
t2 = timeit.default_timer()
with ThreadPoolExecutor(max_workers=4) as executor:
for number, prime in zip(PRIMES, executor.map(is_prime, PRIMES)):
print('%d is prime: %s' % (number, prime))
print("{} Seconds Needed for ThreadPoolExecutor".format(timeit.default_timer() - t2))
t3 = timeit.default_timer()
for number in PRIMES:
isPrime = is_prime(number)
print("{} is prime: {}".format(number, isPrime))
print("{} Seconds needed for single threaded execution".format(timeit.default_timer()-t3))
示例2: test_smoke_one_file
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def test_smoke_one_file(self):
db_path = "test.sqlite"
runner = CliRunner()
with runner.isolated_filesystem():
fifo_name = "jsonl_fifo"
os.mkfifo(fifo_name)
with ProcessPoolExecutor() as executor:
executor.submit(fifo_writer, fifo_name)
result = runner.invoke(cmd, ["-o", db_path, "file", fifo_name, "--format", "jsonl"])
print_traceback(result)
assert result.exit_code == ExitCode.SUCCESS, fifo_name
assert SimpleSQLite(db_path).fetch_num_records("jsonl_fifo") == 8
示例3: launch
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def launch(experiment: str, num_workers: int = 1, seed: tp.Optional[int] = None,
cap_index: tp.Optional[int] = None, output: tp.Optional[PathLike] = None) -> Path:
"""Launch experiment with given names and selection modulo
max_index can be specified to provide a limited number of settings
"""
# create the data
csvpath = Path(experiment + ".csv") if output is None else Path(output)
if num_workers == 1:
df = core.compute(experiment, cap_index=cap_index, seed=seed)
else:
with futures.ProcessPoolExecutor(max_workers=num_workers) as executor:
df = core.compute(experiment, seed=seed, cap_index=cap_index, executor=executor, num_workers=num_workers)
# save data to csv
try:
core.save_or_append_to_csv(df, csvpath)
except Exception: # pylint: disable=broad-except
csvpath = Path(experiment + ".csv")
print(f"Failed to save to {output}, falling back to {csvpath}")
core.save_or_append_to_csv(df, csvpath)
else:
print(f"Saved data to {csvpath}")
return csvpath
示例4: build_from_path
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def build_from_path(in_dir, out_dir, num_workers=1, tqdm=lambda x: x):
'''Preprocesses the LJ Speech dataset from a given input path into a given output directory.
Args:
in_dir: The directory where you have downloaded the LJ Speech dataset
out_dir: The directory to write the output into
num_workers: Optional number of worker processes to parallelize across
tqdm: You can optionally pass tqdm to get a nice progress bar
Returns:
A list of tuples describing the training examples. This should be written to train.txt
'''
# We use ProcessPoolExecutor to parallize across processes. This is just an optimization and you
# can omit it and just call _process_utterance on each input if you want.
executor = ProcessPoolExecutor(max_workers=num_workers)
futures = []
index = 1
with open(os.path.join(in_dir, 'metadata.train'), encoding='utf-8') as f:
for line in f:
parts = line.strip().split('|')
wav_path = os.path.join(in_dir, 'wavs', '%s.wav' % parts[0])
text = parts[1]
futures.append(executor.submit(partial(_process_utterance, out_dir, index, wav_path, text)))
index += 1
results = [future.result() for future in tqdm(futures)]
return [r for r in results if r is not None]
示例5: build_from_path
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def build_from_path(in_dir, out_dir, num_workers=1, tqdm=lambda x: x):
executor = ProcessPoolExecutor(max_workers=num_workers)
futures = []
index = 1
for book in books:
with open(os.path.join(in_dir, book, 'sentence_index.txt')) as f:
for line in f:
parts = line.strip().split('\t')
if line[0] is not '#' and len(parts) == 8 and float(parts[3]) > _min_confidence:
wav_path = os.path.join(in_dir, book, 'wav', '%s.wav' % parts[0])
labels_path = os.path.join(in_dir, book, 'lab', '%s.lab' % parts[0])
text = parts[5]
task = partial(_process_utterance, out_dir, index, wav_path, labels_path, text)
futures.append(executor.submit(task))
index += 1
results = [future.result() for future in tqdm(futures)]
return [r for r in results if r is not None]
示例6: __init__
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def __init__(self, config: Config = None) -> None:
if config is None:
config = Config(**DEFAULT, TOKEN='asdf', CHANNELS={}, USERS={})
Namespace._bot = self
self.loop = asyncio.get_event_loop()
self.call_queue: List[Call] = []
self.api = SlackAPI(self)
self.channels: List[PublicChannel] = []
self.ims: List[DirectMessageChannel] = []
self.groups: List[PrivateChannel] = []
self.mc = aiomcache.Client(
host=config.CACHE['HOST'], port=config.CACHE['PORT'],
)
self.cache: CacheMock = CacheMock(self.mc, 'YUI_TEST_')
self.users: List[User] = [User(id='U0', team_id='T0', name='system')]
self.responses: Dict[str, Callable] = {}
self.config = config
self.process_pool_executor = ProcessPoolExecutor()
self.thread_pool_executor = ThreadPoolExecutor()
示例7: par_crop
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def par_crop(args):
"""
Dataset curation,crop data and transform the format of a label
"""
crop_path = os.path.join(args.download_dir, './crop{:d}'.format(args.instance_size))
if not os.path.isdir(crop_path): makedirs(crop_path)
VID_base_path = os.path.join(args.download_dir, './ILSVRC')
ann_base_path = os.path.join(VID_base_path, 'Annotations/DET/train/')
sub_sets = ('a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i')
for sub_set in sub_sets:
sub_set_base_path = os.path.join(ann_base_path, sub_set)
if 'a' == sub_set:
xmls = sorted(glob.glob(os.path.join(sub_set_base_path, '*', '*.xml')))
else:
xmls = sorted(glob.glob(os.path.join(sub_set_base_path, '*.xml')))
n_imgs = len(xmls)
sub_set_crop_path = os.path.join(crop_path, sub_set)
with futures.ProcessPoolExecutor(max_workers=args.num_threads) as executor:
fs = [executor.submit(crop_xml, args, xml, sub_set_crop_path, args.instance_size) for xml in xmls]
for i, f in enumerate(futures.as_completed(fs)):
printProgress(i, n_imgs, prefix=sub_set, suffix='Done ', barLength=80)
示例8: par_crop
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def par_crop(args, ann_base_path):
"""
Dataset curation, crop data and transform the format of label
Parameters
----------
ann_base_path: str, Annotations base path
"""
crop_path = os.path.join(args.download_dir, './crop{:d}'.format(int(args.instance_size)))
if not os.path.isdir(crop_path):
makedirs(crop_path)
sub_sets = sorted({'a', 'b', 'c', 'd', 'e'})
for sub_set in sub_sets:
sub_set_base_path = os.path.join(ann_base_path, sub_set)
videos = sorted(os.listdir(sub_set_base_path))
n_videos = len(videos)
with futures.ProcessPoolExecutor(max_workers=args.num_threads) as executor:
fs = [executor.submit(crop_video, args, sub_set, video, crop_path, ann_base_path) for video in videos]
for i, f in enumerate(futures.as_completed(fs)):
# Write progress to error so that it can be seen
printProgress(i, n_videos, prefix=sub_set, suffix='Done ', barLength=40)
示例9: __init__
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def __init__(self, threads: int = None) -> None:
try: # get or create loop (threads don't have one)
#: our asyncio loop
self.loop = asyncio.get_event_loop()
except RuntimeError:
self.loop = asyncio.new_event_loop()
asyncio.set_event_loop(self.loop)
#: number of threads to use
self.threads = threads or threads_to_use()
#: semaphore to limit io parallelism
self.io_sem: asyncio.Semaphore = asyncio.Semaphore(1)
#: must never run more than one conda at the same time
#: (used by PyPi when running skeleton)
self.conda_sem: asyncio.Semaphore = asyncio.Semaphore(1)
#: the filters successively applied to each item
self.filters: List[AsyncFilter] = []
#: executor running things in separate python processes
self.proc_pool_executor = ProcessPoolExecutor(self.threads)
self._shutting_down = False
示例10: run
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def run(self) -> bool:
"""Enters the asyncio loop and manages shutdown."""
# We need to handle KeyboardInterrupt "manually" to get clean shutdown
# for the ProcessPoolExecutor
self.loop.add_signal_handler(signal.SIGINT,
lambda: asyncio.ensure_future(self.shutdown(signal.SIGINT)))
try:
task = asyncio.ensure_future(self._async_run())
self.loop.run_until_complete(task)
logger.warning("Finished update")
except asyncio.CancelledError:
pass
except EndProcessing:
logger.error("Terminating...")
self.loop.run_until_complete(self.shutdown())
for filt in self.filters:
filt.finalize()
示例11: preprocess
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def preprocess(wav_dirs, out_dir, num_workers, params):
audio_out_dir = os.path.join(out_dir, "audio")
mel_out_dir = os.path.join(out_dir, "mels")
os.makedirs(out_dir, exist_ok=True)
os.makedirs(audio_out_dir, exist_ok=True)
os.makedirs(mel_out_dir, exist_ok=True)
executor = ProcessPoolExecutor(max_workers=num_workers)
futures = []
wav_paths = chain.from_iterable(glob.iglob("{}/*.wav".format(dir), recursive=True) for dir in wav_dirs)
for wav_path in wav_paths:
fid = os.path.basename(wav_path).replace(".wav", ".npy")
audio_path = os.path.join(audio_out_dir, fid)
mel_path = os.path.join(mel_out_dir, fid)
futures.append(executor.submit(partial(process_wav, wav_path, audio_path, mel_path, params)))
metadata = [future.result() for future in tqdm(futures)]
write_metadata(metadata, out_dir, params)
示例12: __init__
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def __init__(self, eggroll_session):
self.data_dir = os.path.join(file_utils.get_project_base_directory(), 'data')
self.session_id = eggroll_session.get_session_id()
self.meta_table = _DTable('__META__', '__META__', 'fragments', 10)
self.pool = Executor()
Standalone.__instance = self
self.eggroll_session = eggroll_session
self.unique_id_template = '_EggRoll_%s_%s_%s_%.20f_%d'
eggroll_session.set_gc_table(self)
eggroll_session.add_cleanup_task(eggroll_session.clean_duplicated_table)
# todo: move to eggrollSession
try:
self.host_name = socket.gethostname()
self.host_ip = socket.gethostbyname(self.host_name)
except socket.gaierror as e:
self.host_name = 'unknown'
self.host_ip = 'unknown'
示例13: convert_dataset
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def convert_dataset(path, filemap, name, num_processes, max_num_support, max_tokens, is_web=True):
with open(path, 'rb') as f:
dataset = pickle.load(f)
if num_processes == 1:
instances = process((dataset, filemap, max_num_support, max_tokens, is_web), True)
else:
chunk_size = 1000
executor = ProcessPoolExecutor(num_processes)
instances = []
i = 0
for processed in executor.map(
process, [(dataset[i * chunk_size:(i + 1) * chunk_size], filemap, max_num_support, max_tokens, is_web)
for i in range(len(dataset) // chunk_size + 1)]):
instances.extend(processed)
i += chunk_size
print("%d/%d done" % (min(len(dataset), i), len(dataset)))
return {"meta": {"source": name}, 'instances': instances}
示例14: simulate_walks
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def simulate_walks(self,num_walks,walk_length):
# for large graphs, it is serially executed, because of memory use.
if(len(self.G) > 500000):
with ProcessPoolExecutor(max_workers=1) as executor:
job = executor.submit(generate_random_walks_large_graphs,num_walks,walk_length,self.workers,self.G.keys())
job.result()
else:
with ProcessPoolExecutor(max_workers=1) as executor:
job = executor.submit(generate_random_walks,num_walks,walk_length,self.workers,self.G.keys())
job.result()
return
示例15: main
# 需要導入模塊: from concurrent import futures [as 別名]
# 或者: from concurrent.futures import ProcessPoolExecutor [as 別名]
def main():
print("Starting ThreadPoolExecutor")
with ProcessPoolExecutor(max_workers=3) as executor:
future = executor.submit(task, (2))
future = executor.submit(task, (3))
future = executor.submit(task, (4))
print("All tasks complete")