sc_hypervisor_lp.h 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010-2013 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. #ifndef SCHED_CTX_HYPERVISOR_LP_H
  17. #define SCHED_CTX_HYPERVISOR_LP_H
  18. #include <sc_hypervisor.h>
  19. #include <starpu_config.h>
  20. #ifdef __cplusplus
  21. extern "C"
  22. {
  23. #endif
  24. /*
  25. * GNU Linear Programming Kit backend
  26. */
  27. #ifdef STARPU_HAVE_GLPK_H
  28. #include <glpk.h>
  29. #endif //STARPU_HAVE_GLPK_H
  30. struct sc_hypervisor_policy_task_pool;
  31. /* returns tmax, and computes in table res the nr of workers needed by each context st the system ends up in the smallest tmax*/
  32. double sc_hypervisor_lp_get_nworkers_per_ctx(int nsched_ctxs, int ntypes_of_workers, double res[nsched_ctxs][ntypes_of_workers], int total_nw[ntypes_of_workers]);
  33. /* returns tmax of the system */
  34. double sc_hypervisor_lp_get_tmax(int nw, int *workers);
  35. /* the linear programme determins a rational number of ressources for each ctx, we round them depending on the type of ressource */
  36. void sc_hypervisor_lp_round_double_to_int(int ns, int nw, double res[ns][nw], int res_rounded[ns][nw]);
  37. /* redistribute the ressource in contexts by assigning the first x available ressources to each one */
  38. void sc_hypervisor_lp_redistribute_resources_in_ctxs(int ns, int nw, int res_rounded[ns][nw], double res[ns][nw]);
  39. /* make the first distribution of ressource in contexts by assigning the first x available ressources to each one */
  40. void sc_hypervisor_lp_distribute_resources_in_ctxs(int* sched_ctxs, int ns, int nw, int res_rounded[ns][nw], double res[ns][nw], int *workers, int nworkers);
  41. /* place resources in contexts dependig on whether they already have workers or not */
  42. void sc_hypervisor_lp_place_resources_in_ctx(int ns, int nw, double w_in_s[ns][nw], int *sched_ctxs, int *workers, unsigned do_size);
  43. /* dichotomy btw t1 & t2 */
  44. double sc_hypervisor_lp_find_tmax(double t1, double t2);
  45. /* execute the lp trough dichotomy */
  46. unsigned sc_hypervisor_lp_execute_dichotomy(int ns, int nw, double w_in_s[ns][nw], unsigned solve_lp_integer, void *specific_data,
  47. double tmin, double tmax, double smallest_tmax,
  48. double (*lp_estimated_distrib_func)(int ns, int nw, double draft_w_in_s[ns][nw],
  49. unsigned is_integer, double tmax, void *specifc_data));
  50. #ifdef STARPU_HAVE_GLPK_H
  51. /* linear program that returns 1/tmax, and computes in table res the nr of workers needed by each context st
  52. the system ends up in the smallest tmax*/
  53. double sc_hypervisor_lp_simulate_distrib_flops(int nsched_ctxs, int ntypes_of_workers, double velocity[nsched_ctxs][ntypes_of_workers],
  54. double flops[nsched_ctxs], double res[nsched_ctxs][ntypes_of_workers], int total_nw[ntypes_of_workers]);
  55. /* linear program that simulates a distribution of tasks that minimises the execution time of the tasks in the pool */
  56. double sc_hypervisor_lp_simulate_distrib_tasks(int ns, int nw, int nt, double w_in_s[ns][nw], double tasks[nw][nt],
  57. double times[nw][nt], unsigned is_integer, double tmax, int *in_sched_ctxs,
  58. struct sc_hypervisor_policy_task_pool *tmp_task_pools);
  59. #endif // STARPU_HAVE_GLPK_H
  60. #ifdef __cplusplus
  61. }
  62. #endif
  63. #endif