delay.py 1.2 KB

123456789101112131415161718192021222324252627282930
  1. # StarPU --- Runtime system for heterogeneous multicore architectures.
  2. #
  3. # Copyright (C) 2020 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
  4. #
  5. # StarPU is free software; you can redistribute it and/or modify
  6. # it under the terms of the GNU Lesser General Public License as published by
  7. # the Free Software Foundation; either version 2.1 of the License, or (at
  8. # your option) any later version.
  9. #
  10. # StarPU is distributed in the hope that it will be useful, but
  11. # WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  13. #
  14. # See the GNU Lesser General Public License in COPYING.LGPL for more details.
  15. #
  16. from starpu import starpupy
  17. import starpu
  18. import asyncio
  19. from functools import partial
  20. def delayed(f=None,*, name=None, synchronous=0, priority=0, color=None, flops=None, perfmodel=None):
  21. # add options of task_submit
  22. if f is None:
  23. return partial(delayed, name=name, synchronous=synchronous, priority=priority, color=color, flops=flops, perfmodel=perfmodel)
  24. def submit(*args):
  25. fut = starpu.task_submit(name=name, synchronous=synchronous, priority=priority,\
  26. color=color, flops=flops, perfmodel=perfmodel)(f, *args)
  27. return fut
  28. return submit