XBT_INFO("Goodbye now!");
}
-/* This actor tests the ongoing execution until its completion, and don't wait before it's terminated. */
-static void monitor()
-{
- double computation_amount = simgrid::s4u::this_actor::get_host()->get_speed();
- XBT_INFO("Execute %g flops, should take 1 second.", computation_amount);
- simgrid::s4u::ExecPtr activity = simgrid::s4u::this_actor::exec_init(computation_amount);
- activity->start();
-
- while (not activity->test()) {
- XBT_INFO("Remaining amount of flops: %g (%.0f%%)", activity->get_remaining(),
- 100 * activity->get_remaining_ratio());
- simgrid::s4u::this_actor::sleep_for(0.3);
- }
-
- XBT_INFO("Goodbye now!");
-}
-
-/* This actor cancels the ongoing execution after a while. */
-static void canceller()
-{
- double computation_amount = simgrid::s4u::this_actor::get_host()->get_speed();
-
- XBT_INFO("Execute %g flops, should take 1 second.", computation_amount);
- simgrid::s4u::ExecPtr activity = simgrid::s4u::this_actor::exec_async(computation_amount);
- simgrid::s4u::this_actor::sleep_for(0.5);
- XBT_INFO("I changed my mind, cancel!");
- activity->cancel();
-
- XBT_INFO("Goodbye now!");
-}
-
int main(int argc, char* argv[])
{
simgrid::s4u::Engine e(&argc, argv);
while (activity->get_remaining() > 0) {
XBT_INFO("Remaining amount of flops: %g (%.0f%%)", activity->get_remaining(),
100 * activity->get_remaining_ratio());
- e.run_until(e.get_clock() + 1);
+ e.run_until(simgrid::s4u::Engine::get_clock() + 1);
}
XBT_INFO("Simulation time %g", simgrid::s4u::Engine::get_clock());
e.load_deployment(argv[2]);
// Add a new host programatically, and attach a state profile to it
- auto* root = e.get_netzone_root();
- auto* lilibeth = root->create_host("Lilibeth", 1e15);
- sg4::LinkInRoute link = sg4::LinkInRoute(e.link_by_name("10"));
+ auto* root = e.get_netzone_root();
+ auto* lilibeth = root->create_host("Lilibeth", 1e15);
+ auto link = sg4::LinkInRoute(e.link_by_name("10"));
root->add_route(e.host_by_name("Tremblay")->get_netpoint(), lilibeth->get_netpoint(), nullptr, nullptr, {link}, true);
lilibeth->set_state_profile(simgrid::kernel::profile::ProfileBuilder::from_string("lilibeth_profile", R"(
4 0
// Comms have only one predecessor
auto pred_pred = *(pred->get_dependencies().begin());
if (std::none_of(pred_pred->get_successors().begin(), pred_pred->get_successors().end(),
- [](const simgrid::s4u::ActivityPtr& a) { return not a->is_marked(); }))
+ [](const simgrid::s4u::ActivityPtr& act) { return not act->is_marked(); }))
next.push_back(pred_pred);
} else {
if (std::none_of(pred->get_successors().begin(), pred->get_successors().end(),
- [](const simgrid::s4u::ActivityPtr& a) { return not a->is_marked(); }))
+ [](const simgrid::s4u::ActivityPtr& act) { return not act->is_marked(); }))
next.push_back(pred);
}
}