documenting
This commit is contained in:
parent
2e25a03d13
commit
f1f88610dd
|
@ -66,7 +66,20 @@ class DADF5():
|
||||||
|
|
||||||
|
|
||||||
def __manage_visible(self,datasets,what,action):
|
def __manage_visible(self,datasets,what,action):
|
||||||
"""Manages the visibility of the groups."""
|
"""
|
||||||
|
Manages the visibility of the groups.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
datasets : list of str or Boolean
|
||||||
|
name of datasets as list, supports ? and * wildcards.
|
||||||
|
True is equivalent to [*], False is equivalent to []
|
||||||
|
what : str
|
||||||
|
attribute to change (must be in self.visible)
|
||||||
|
action : str
|
||||||
|
select from 'set', 'add', and 'del'
|
||||||
|
|
||||||
|
"""
|
||||||
# allow True/False and string arguments
|
# allow True/False and string arguments
|
||||||
if datasets is True:
|
if datasets is True:
|
||||||
datasets = ['*']
|
datasets = ['*']
|
||||||
|
@ -74,7 +87,7 @@ class DADF5():
|
||||||
datasets = []
|
datasets = []
|
||||||
choice = [datasets] if isinstance(datasets,str) else datasets
|
choice = [datasets] if isinstance(datasets,str) else datasets
|
||||||
|
|
||||||
valid = [e for e_ in [glob.fnmatch.filter(getattr(self,what) ,s) for s in choice] for e in e_]
|
valid = [e for e_ in [glob.fnmatch.filter(getattr(self,what),s) for s in choice] for e in e_]
|
||||||
existing = set(self.visible[what])
|
existing = set(self.visible[what])
|
||||||
|
|
||||||
if action == 'set':
|
if action == 'set':
|
||||||
|
@ -94,19 +107,60 @@ class DADF5():
|
||||||
|
|
||||||
|
|
||||||
def set_by_time(self,start,end):
|
def set_by_time(self,start,end):
|
||||||
|
"""
|
||||||
|
Sets active time increments based on start and end time.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
start : float
|
||||||
|
start time (included)
|
||||||
|
end : float
|
||||||
|
end time (exclcuded)
|
||||||
|
|
||||||
|
"""
|
||||||
self.__manage_visible(self.__time_to_inc(start,end),'increments','set')
|
self.__manage_visible(self.__time_to_inc(start,end),'increments','set')
|
||||||
|
|
||||||
|
|
||||||
def add_by_time(self,start,end):
|
def add_by_time(self,start,end):
|
||||||
|
"""
|
||||||
|
Adds to active time increments based on start and end time.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
start : float
|
||||||
|
start time (included)
|
||||||
|
end : float
|
||||||
|
end time (exclcuded)
|
||||||
|
|
||||||
|
"""
|
||||||
self.__manage_visible(self.__time_to_inc(start,end),'increments','add')
|
self.__manage_visible(self.__time_to_inc(start,end),'increments','add')
|
||||||
|
|
||||||
|
|
||||||
def del_by_time(self,start,end):
|
def del_by_time(self,start,end):
|
||||||
|
"""
|
||||||
|
Delets from active time increments based on start and end time.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
start : float
|
||||||
|
start time (included)
|
||||||
|
end : float
|
||||||
|
end time (exclcuded)
|
||||||
|
|
||||||
|
"""
|
||||||
self.__manage_visible(self.__time_to_inc(start,end),'increments','del')
|
self.__manage_visible(self.__time_to_inc(start,end),'increments','del')
|
||||||
|
|
||||||
|
|
||||||
def iter_visible(self,what):
|
def iter_visible(self,what):
|
||||||
"""Iterates over visible items by setting each one visible."""
|
"""
|
||||||
|
Iterates over visible items by setting each one visible.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
what : str
|
||||||
|
attribute to change (must be in self.visible)
|
||||||
|
|
||||||
|
"""
|
||||||
datasets = self.visible[what]
|
datasets = self.visible[what]
|
||||||
last_datasets = datasets.copy()
|
last_datasets = datasets.copy()
|
||||||
for dataset in datasets:
|
for dataset in datasets:
|
||||||
|
@ -120,14 +174,50 @@ class DADF5():
|
||||||
|
|
||||||
|
|
||||||
def set_visible(self,what,datasets):
|
def set_visible(self,what,datasets):
|
||||||
|
"""
|
||||||
|
Sets active groups.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
datasets : list of str or Boolean
|
||||||
|
name of datasets as list, supports ? and * wildcards.
|
||||||
|
True is equivalent to [*], False is equivalent to []
|
||||||
|
what : str
|
||||||
|
attribute to change (must be in self.visible)
|
||||||
|
|
||||||
|
"""
|
||||||
self.__manage_visible(datasets,what,'set')
|
self.__manage_visible(datasets,what,'set')
|
||||||
|
|
||||||
|
|
||||||
def add_visible(self,what,datasets):
|
def add_visible(self,what,datasets):
|
||||||
|
"""
|
||||||
|
Adds to active groups.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
datasets : list of str or Boolean
|
||||||
|
name of datasets as list, supports ? and * wildcards.
|
||||||
|
True is equivalent to [*], False is equivalent to []
|
||||||
|
what : str
|
||||||
|
attribute to change (must be in self.visible)
|
||||||
|
|
||||||
|
"""
|
||||||
self.__manage_visible(datasets,what,'add')
|
self.__manage_visible(datasets,what,'add')
|
||||||
|
|
||||||
|
|
||||||
def del_visible(self,what,datasets):
|
def del_visible(self,what,datasets):
|
||||||
|
"""
|
||||||
|
Removes from active groupse.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
datasets : list of str or Boolean
|
||||||
|
name of datasets as list, supports ? and * wildcards.
|
||||||
|
True is equivalent to [*], False is equivalent to []
|
||||||
|
what : str
|
||||||
|
attribute to change (must be in self.visible)
|
||||||
|
|
||||||
|
"""
|
||||||
self.__manage_visible(datasets,what,'del')
|
self.__manage_visible(datasets,what,'del')
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -205,6 +205,14 @@ class return_message():
|
||||||
"""Object with formatted return message."""
|
"""Object with formatted return message."""
|
||||||
|
|
||||||
def __init__(self,message):
|
def __init__(self,message):
|
||||||
|
"""
|
||||||
|
Sets return message.
|
||||||
|
|
||||||
|
Parameters
|
||||||
|
----------
|
||||||
|
message : str or list of str
|
||||||
|
message for output to screen
|
||||||
|
"""
|
||||||
self.message = message
|
self.message = message
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
|
@ -468,45 +476,56 @@ def curve_fit_bound(f, xdata, ydata, p0=None, sigma=None, bounds=None, **kw):
|
||||||
|
|
||||||
return (popt, pcov, infodict, errmsg, ier) if return_full else (popt, pcov)
|
return (popt, pcov, infodict, errmsg, ier) if return_full else (popt, pcov)
|
||||||
|
|
||||||
class Worker(Thread):
|
|
||||||
|
class ThreadPool:
|
||||||
|
"""Pool of threads consuming tasks from a queue."""
|
||||||
|
|
||||||
|
class Worker(Thread):
|
||||||
"""Thread executing tasks from a given tasks queue."""
|
"""Thread executing tasks from a given tasks queue."""
|
||||||
|
|
||||||
def __init__(self, tasks):
|
def __init__(self, tasks):
|
||||||
Thread.__init__(self)
|
""" Worker for tasks."""
|
||||||
self.tasks = tasks
|
Thread.__init__(self)
|
||||||
self.daemon = True
|
self.tasks = tasks
|
||||||
self.start()
|
self.daemon = True
|
||||||
|
self.start()
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
while True:
|
while True:
|
||||||
func, args, kargs = self.tasks.get()
|
func, args, kargs = self.tasks.get()
|
||||||
try:
|
try:
|
||||||
func(*args, **kargs)
|
func(*args, **kargs)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
# An exception happened in this thread
|
# An exception happened in this thread
|
||||||
print(e)
|
print(e)
|
||||||
finally:
|
finally:
|
||||||
# Mark this task as done, whether an exception happened or not
|
# Mark this task as done, whether an exception happened or not
|
||||||
self.tasks.task_done()
|
self.tasks.task_done()
|
||||||
|
|
||||||
|
|
||||||
class ThreadPool:
|
def __init__(self, num_threads):
|
||||||
"""Pool of threads consuming tasks from a queue."""
|
"""
|
||||||
|
Thread pool.
|
||||||
|
|
||||||
def __init__(self, num_threads):
|
Parameters
|
||||||
self.tasks = Queue(num_threads)
|
----------
|
||||||
for _ in range(num_threads):
|
num_threads : int
|
||||||
Worker(self.tasks)
|
number of threads
|
||||||
|
|
||||||
def add_task(self, func, *args, **kargs):
|
"""
|
||||||
"""Add a task to the queue."""
|
self.tasks = Queue(num_threads)
|
||||||
self.tasks.put((func, args, kargs))
|
for _ in range(num_threads):
|
||||||
|
self.Worker(self.tasks)
|
||||||
|
|
||||||
def map(self, func, args_list):
|
def add_task(self, func, *args, **kargs):
|
||||||
"""Add a list of tasks to the queue."""
|
"""Add a task to the queue."""
|
||||||
for args in args_list:
|
self.tasks.put((func, args, kargs))
|
||||||
self.add_task(func, args)
|
|
||||||
|
|
||||||
def wait_completion(self):
|
def map(self, func, args_list):
|
||||||
"""Wait for completion of all the tasks in the queue."""
|
"""Add a list of tasks to the queue."""
|
||||||
self.tasks.join()
|
for args in args_list:
|
||||||
|
self.add_task(func, args)
|
||||||
|
|
||||||
|
def wait_completion(self):
|
||||||
|
"""Wait for completion of all the tasks in the queue."""
|
||||||
|
self.tasks.join()
|
||||||
|
|
Loading…
Reference in New Issue