Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Adding Louis-Claude Canon's tests.
[simgrid.git] / teshsuite / simdag / canon / sd_test1.c
diff --git a/teshsuite/simdag/canon/sd_test1.c b/teshsuite/simdag/canon/sd_test1.c
new file mode 100644 (file)
index 0000000..0652547
--- /dev/null
@@ -0,0 +1,37 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include "simdag/simdag.h"
+
+int main(int argc, char **argv) {
+    /* initialisation of SD */
+    SD_init(&argc, argv);
+
+    /* creation of the environment */
+    SD_create_environment(argv[1]);
+
+    /* creation of the tasks and their dependencies */
+    SD_task_t taskInit = SD_task_create(NULL,NULL,1.0);
+    SD_task_t taskA = SD_task_create("Task Comm A", NULL, 1.0);
+    SD_task_t taskB = SD_task_create("Task Comm B", NULL, 1.0);
+
+
+    /* scheduling parameters */
+
+    const SD_workstation_t* workstation = SD_workstation_get_list();
+    double communication_amount1 = 1000000000;
+    double communication_amount2 = 1000000000;
+    double no_cost = 0.0;
+
+    /* let's launch the simulation! */
+    SD_task_schedule(taskInit, 1, SD_workstation_get_list(), &no_cost, &no_cost, -1.0);
+    SD_task_schedule(taskA, 1, &workstation[0], &no_cost, &communication_amount1, -1.0);
+    SD_task_schedule(taskB, 1, &workstation[1], &no_cost, &communication_amount2, -1.0);
+
+    SD_task_dependency_add(NULL, NULL, taskInit, taskA);
+    SD_task_dependency_add(NULL, NULL, taskInit, taskB);
+    
+    SD_simulate(-1.0);
+
+    SD_exit();
+    return 0;
+}