- Better chunks function, option for both number of chunks or size of chunks.

This commit is contained in:
Wim Pomp
2021-05-24 18:19:14 +02:00
parent 5d57081713
commit 95ae325028
2 changed files with 24 additions and 10 deletions

View File

@@ -116,16 +116,30 @@ def dumps(obj, protocol=None, byref=None, fmode=None, recurse=True, **kwds):
return file.getvalue() return file.getvalue()
def chunks(n, *args): def chunks(*args, **kwargs):
""" Yield successive n-sized chunks from lists. """ """ Yield successive chunks from lists.
Usage: chunks(s, list0, list1, ...)
chunks(list0, list1, ..., s=s)
chunks(list0, list1, ..., n=n)
s: size of chunks, might change to optimize devision between chunks
n: number of chunks, coerced to 1 <= n <= len(list0)
both s and n are given: use n, unless the chunk size would be bigger than s
"""
N = len(args[-1])
if 's' in kwargs and 'n' in kwargs:
n = kwargs['n'] if N < kwargs['s'] * kwargs['n'] else round(N / kwargs['s'])
elif 's' in kwargs: # size of chunks
n = round(N / kwargs['s'])
elif 'n' in kwargs: # number of chunks
n = kwargs['n']
else: # size of chunks in 1st argument
s, *args = args
n = round(N / s)
A = len(args) == 1 A = len(args) == 1
N = len(args[0]) n = max(1, min(N, n))
n = int(round(N/max(1, round(N/n)))) for i in range(n):
for i in range(0, N, n) if N else []: p, q = (i * N // n), ((i + 1) * N // n)
if A: yield args[0][p:q] if A else [a[p:q] for a in args]
yield args[0][i:i+n]
else:
yield [a[i:i+n] for a in args]
class tqdmm(tqdm): class tqdmm(tqdm):

View File

@@ -5,7 +5,7 @@ with open("README.md", "r") as fh:
setuptools.setup( setuptools.setup(
name="parfor", name="parfor",
version="2021.3.2", version="2021.5.0",
author="Wim Pomp", author="Wim Pomp",
author_email="wimpomp@gmail.com", author_email="wimpomp@gmail.com",
description="A package to mimic the use of parfor as done in Matlab.", description="A package to mimic the use of parfor as done in Matlab.",