- Better chunks function, option for both number of chunks or size of chunks.
This commit is contained in:
@@ -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):
|
||||||
|
|||||||
2
setup.py
2
setup.py
@@ -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.",
|
||||||
|
|||||||
Reference in New Issue
Block a user