nb_task = arg[1];
comp_size = arg[2];
comm_size = arg[3];
-slave_count = arg[4]
-
+slave_count = arg[4];
if (#arg ~= 4) then
error("Argc should be 4");
simgrid.info("Master: Everything's done.");
end
+--end_of_master
+
-- Slave Function ---------------------------------------------------------
function Slave(...)
simgrid.info("Slave '" ..my_mailbox.."': I'm Done . See You !!");
-end -- function ----------------------------------------------------------
+end
+-- end_of_slave
+
+-- Simulation Core ----------------------------------------------------------
--]]
require "simgrid"
-
- --first we save the host number ( since we'll first save them into a C table )
- simgrid.Host.setNumber(5);
+
+ --create new routing model
+ --simgrid.AS.new(AS_id,AS_mode)
+ simgrid.AS.new{id="AS0",mode="Full"};
--simgrid.Host.new(host_id,power)
- simgrid.Host.new("Tremblay",98095000);
- simgrid.Host.new("Jupiter",76296000);
- simgrid.Host.new("Fafard",76296000);
- simgrid.Host.new("Ginette",48492000);
- simgrid.Host.new("Bourassa",48492000);
-
- -- set Number of links
- simgrid.Link.setNumber(12);
+ simgrid.Host.new{id="Tremblay",power=98095000};
+ simgrid.Host.new{id="Jupiter",power=76296000};
+ simgrid.Host.new{id="Fafard",power=76296000};
+ simgrid.Host.new{id="Ginette",power=48492000};
+ simgrid.Host.new{id="Bourassa",power=48492000};
+
-- create Links
- for i=0,11 do
- simgrid.Link.new(i,252750+ i*768,0.000270544+i*0.087); -- let's create link !! with crazy values ;)
+ for i=10,0,-1 do
+ --simgrid.Link.new{id=i,bandwidth=252750+ i*768,latency=0.000270544+i*0.087};
+ simgrid.Link.new{id=i,bandwidth=252750+ i*768,latency=0.000270544+i*0.087};
end
-
- -- set number of route ( 5 hosts >> 5*5 = 25 )
- simgrid.Route.setNumber(20);
-
-- simgrid.Route.new(src_id,des_id,links_nb,links_list)
- simgrid.Route.new("Tremblay","Jupiter",1,{"1"});
- simgrid.Route.new("Tremblay","Fafard",6,{"0","1","2","3","4","8"});
- simgrid.Route.new("Tremblay","Ginette",3,{"3","4","5"});
- simgrid.Route.new("Tremblay","Bourassa",7,{"0","1","3","2","4","6","7"});
-
- simgrid.Route.new("Jupiter","Tremblay",1,{"1"});
- simgrid.Route.new("Jupiter","Fafard",7,{"0","1","2","3","4","8","9"});
- simgrid.Route.new("Jupiter","Ginette",4,{"3","4","5","9"});
- simgrid.Route.new("Jupiter","Bourassa",8,{"0","1","2","3","4","6","7","9"});
+ simgrid.Route.new{src="Tremblay",dest="Jupiter",links="1"};
+ simgrid.Route.new{src="Tremblay",dest="Fafard",links="0,1,2,3,4,8"};
+ simgrid.Route.new{src="Tremblay",dest="Ginette",links="3,4,5"};
+ simgrid.Route.new{src="Tremblay",dest="Bourassa",links="0,1,3,2,4,6,7"};
+
+ simgrid.Route.new{src="Jupiter",dest="Tremblay",links="1"};
+ simgrid.Route.new{src="Jupiter",dest="Fafard",links="0,1,2,3,4,8,9"};
+ simgrid.Route.new{src="Jupiter",dest="Ginette",links="3,4,5,9"};
+ simgrid.Route.new{src="Jupiter",dest="Bourassa",links="0,1,2,3,4,6,7,9"};
- simgrid.Route.new("Fafard","Tremblay",6,{"0","1","2","3","4","8"});
- simgrid.Route.new("Fafard","Jupiter",7,{"0","1","2","3","4","8","9"});
- simgrid.Route.new("Fafard","Ginette",5,{"0","1","2","5","8"});
- simgrid.Route.new("Fafard","Bourassa",3,{"6","7","8"});
+ simgrid.Route.new{src="Fafard",dest="Tremblay",links="0,1,2,3,4,8"};
+ simgrid.Route.new{src="Fafard",dest="Jupiter",links="0,1,2,3,4,8,9"};
+ simgrid.Route.new{src="Fafard",dest="Ginette",links="0,1,2,5,8"};
+ simgrid.Route.new{src="Fafard",dest="Bourassa",links="6,7,8"};
- simgrid.Route.new("Ginette","Tremblay",3,{"3","4","5"});
- simgrid.Route.new("Ginette","Jupiter",4,{"3","4","5","9"});
- simgrid.Route.new("Ginette","Fafard",5,{"0","1","2","5","8"});
- simgrid.Route.new("Ginette","Bourassa",6,{"0","1","2","5","6","7"});
-
- simgrid.Route.new("Bourassa","Tremblay",7,{"0","1","3","2","4","6","7"});
- simgrid.Route.new("Bourassa","Jupiter",8,{"0","1","2","3","4","6","7","9"});
- simgrid.Route.new("Bourassa","Fafard",3,{"6","7","8"});
- simgrid.Route.new("Bourassa","Ginette",6,{"0","1","2","5","6","7"});
+ simgrid.Route.new{src="Ginette",dest="Tremblay",links="3,4,5"};
+ simgrid.Route.new{src="Ginette",dest="Jupiter",links="3,4,5,9"};
+ simgrid.Route.new{src="Ginette",dest="Fafard",links="0,1,2,5,8"};
+ simgrid.Route.new{src="Ginette",dest="Bourassa",links="0,1,2,5,6,7"};
+
+ simgrid.Route.new{src="Bourassa",dest="Tremblay",links="0,1,3,2,4,6,7"};
+ simgrid.Route.new{src="Bourassa",dest="Jupiter",links="0,1,2,3,4,6,7,9"};
+ simgrid.Route.new{src="Bourassa",dest="Fafard",links="6,7,8"};
+ simgrid.Route.new{src="Bourassa",dest="Ginette",links="0,1,2,5,6,7"};
--Save Platform
- simgrid.register_platform();
+ --simgrid.info("start registering platform");
+ simgrid.msg_register_platform();
+ --simgrid.info("platform registered");
--Set Application
-
- --simgrid.Host.setFunction(host_id,function_name,args_nb,args_list)
- simgrid.Host.setFunction("Tremblay","Master",4,{"20","550000000","1000000","4"});
- simgrid.Host.setFunction("Bourassa","Slave",1,{"0"});
- simgrid.Host.setFunction("Jupiter","Slave",1,{"1"});
- simgrid.Host.setFunction("Fafard","Slave",1,{"2"});
- simgrid.Host.setFunction("Ginette","Slave",1,{"3"});
+ simgrid.Host.setFunction{host="Tremblay",fct="Master",args="20,550000000,1000000,4"};
+ simgrid.Host.setFunction{host="Bourassa",fct="Slave",args="0"};
+ simgrid.Host.setFunction{host="Jupiter",fct="Slave",args="1"};
+ simgrid.Host.setFunction{host="Fafard",fct="Slave",args="2"};
+ simgrid.Host.setFunction{host="Ginette",fct="Slave",args="3"};
--Save Application
- simgrid.register_application();
-
--- Run The Application
+ simgrid.msg_register_application();
+ --Run The Application
simgrid.run()
simgrid.info("Simulation's over.See you.")
- simgrid.clean()
\ No newline at end of file
+ simgrid.clean()
+