Example #1
0
int main(int argc, char **argv)
{
  /* initialisation of SD */

  SD_workstation_t w1, w2;
  const SD_workstation_t *workstations;
  const SD_link_t *route;
  const char *name1;
  const char *name2;
  int route_size, i, j, k;
  int list_size;

#ifdef _XBT_WIN32
  setbuf(stderr, NULL);
  setbuf(stdout, NULL);
#else
  setvbuf(stdout, NULL, _IOLBF, 0);
#endif

  SD_init(&argc, argv);

  /* creation of the environment */
  SD_create_environment(argv[1]);
  printf("Workstation number: %d, link number: %d\n",
         SD_workstation_get_number(), SD_link_get_number());

  if (argc >= 3) {
    if (!strcmp(argv[2], "ONE_LINK")) {
      workstations = SD_workstation_get_list();
      w1 = workstations[0];
      w2 = workstations[1];
      name1 = SD_workstation_get_name(w1);
      name2 = SD_workstation_get_name(w2);

      printf("Route between %s and %s\n", name1, name2);
      route = SD_route_get_list(w1, w2);
      route_size = SD_route_get_size(w1, w2);
      printf("Route size %d\n", route_size);
      for (i = 0; i < route_size; i++) {
      printf("  Link %s: latency = %f, bandwidth = %f\n",
           SD_link_get_name(route[i]),
           SD_link_get_current_latency(route[i]),
           SD_link_get_current_bandwidth(route[i]));
      }
      printf("Route latency = %f, route bandwidth = %f\n",
         SD_route_get_current_latency(w1, w2),
         SD_route_get_current_bandwidth(w1, w2));
    }
    if (!strcmp(argv[2], "FULL_LINK")) {
      workstations = SD_workstation_get_list();
      list_size = SD_workstation_get_number();
      for (i = 0; i < list_size; i++) {
      w1 = workstations[i];
      name1 = SD_workstation_get_name(w1);
      for (j = 0; j < list_size; j++) {
        w2 = workstations[j];
        name2 = SD_workstation_get_name(w2);
        printf("Route between %s and %s\n", name1, name2);
        route = SD_route_get_list(w1, w2);
        route_size = SD_route_get_size(w1, w2);
        printf("  Route size %d\n", route_size);
        for (k = 0; k < route_size; k++) {
        printf("  Link %s: latency = %f, bandwidth = %f\n",
             SD_link_get_name(route[k]),
             SD_link_get_current_latency(route[k]),
             SD_link_get_current_bandwidth(route[k]));
        }
        printf("  Route latency = %f, route bandwidth = %f\n",
           SD_route_get_current_latency(w1, w2),
           SD_route_get_current_bandwidth(w1, w2));
      }
      }
    }
    if (!strcmp(argv[2], "PROP")) {
      printf("SG_TEST_mem: %s\n",
          SD_workstation_get_property_value(SD_workstation_get_by_name("host1"),
          "SG_TEST_mem")
          );
      printf("Author: %s\n", SD_as_router_get_property_value("AS0", "author"));
      printf("AS1: %s\n", SD_as_router_get_property_value("AS1", "name"));
      printf("AS2: %s\n", SD_as_router_get_property_value("AS2", "name"));
    }
  }

  SD_exit();
  return 0;
}
Example #2
0
int main(int argc, char **argv)
{
  SD_task_t task;
  double computation_amount[1];
  double communication_amount[2] = { 0 };
  SD_workstation_t workstation_list[1];
  xbt_dynar_t ret;

  /* initialization of SD */
  SD_init(&argc, argv);

  /* creation of the environment */
  SD_create_environment("./faulty_host.xml");
 
  /* creation of a single task that will poorly fail when the workstation
   * will stop */
  XBT_INFO("First test: COMP_SEQ task");
  task = SD_task_create_comp_seq("Poor task", NULL, 2e10);
  SD_task_watch(task, SD_FAILED);
  SD_task_watch(task, SD_DONE);

  XBT_INFO("Schedule task '%s' on workstation 'Faulty Host'",
           SD_task_get_name(task));

  SD_task_schedulel(task, 1, SD_workstation_get_by_name("Faulty Host"));

  ret = SD_simulate(-1.0);
  xbt_dynar_free(&ret);

  SD_task_dump(task);

  XBT_INFO("Task '%s' has failed. %.f flops remain to be done",
           SD_task_get_name(task),
           SD_task_get_remaining_amount(task));

  XBT_INFO("let's unschedule task '%s' and reschedule it on the 'Safe Host'",
           SD_task_get_name(task));
  SD_task_unschedule(task);
  SD_task_schedulel(task, 1, SD_workstation_get_by_name("Safe Host"));

  XBT_INFO("Run the simulation again");
  ret = SD_simulate(-1.0);
  xbt_dynar_free(&ret);

  SD_task_dump(task);
  XBT_INFO("Task '%s' start time: %f, finish time: %f",
      SD_task_get_name(task),
      SD_task_get_start_time(task),
      SD_task_get_finish_time(task));

  SD_task_destroy(task);
  task=NULL;

  XBT_INFO("Second test: NON TYPED task");

  task = SD_task_create("Poor parallel task", NULL, 2e10);
  SD_task_watch(task, SD_FAILED);
  SD_task_watch(task, SD_DONE);

  computation_amount[0] = 2e10;

  XBT_INFO("Schedule task '%s' on workstation 'Faulty Host'",
             SD_task_get_name(task));

  workstation_list[0] = SD_workstation_get_by_name("Faulty Host");
  SD_task_schedule(task, 1, workstation_list,
          computation_amount, communication_amount,-1);

  ret = SD_simulate(-1.0);
  xbt_dynar_free(&ret);

  SD_task_dump(task);

  XBT_INFO("Task '%s' has failed. %.f flops remain to be done",
            SD_task_get_name(task),
            SD_task_get_remaining_amount(task));

  XBT_INFO("let's unschedule task '%s' and reschedule it on the 'Safe Host'",
           SD_task_get_name(task));
  SD_task_unschedule(task);

  workstation_list[0] = SD_workstation_get_by_name("Safe Host");

  SD_task_schedule(task, 1, workstation_list,
                   computation_amount, communication_amount,-1);

  XBT_INFO("Run the simulation again");
  ret = SD_simulate(-1.0);
  xbt_dynar_free(&ret);

  SD_task_dump(task);
  XBT_INFO("Task '%s' start time: %f, finish time: %f",
           SD_task_get_name(task),
           SD_task_get_start_time(task),
           SD_task_get_finish_time(task));

  SD_task_destroy(task);
  SD_exit();
  return 0;
}