Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Various sonar cleanups
[simgrid.git] / examples / cpp / solar-panel-simple / s4u-solar-panel-simple.cpp
1 /* Copyright (c) 2003-2023. The SimGrid Team. All rights reserved.          */
2
3 /* This program is free software; you can redistribute it and/or modify it
4  * under the terms of the license (GNU LGPL) which comes with this package. */
5
6 #include "simgrid/plugins/solar_panel.hpp"
7 #include "simgrid/s4u.hpp"
8 #include <simgrid/s4u/Actor.hpp>
9
10 XBT_LOG_NEW_DEFAULT_CATEGORY(solar_panel_simple, "Messages specific for this s4u example");
11
12 static void manager()
13 {
14   auto solar_panel = simgrid::plugins::SolarPanel::init("Solar Panel", 10, 0.9, 10, 0, 1e3);
15   simgrid::s4u::this_actor::sleep_for(1);
16   XBT_INFO("%s: area: %fm² efficiency: %f irradiance: %fW/m² power: %fW", solar_panel->get_cname(),
17            solar_panel->get_area(), solar_panel->get_conversion_efficiency(), solar_panel->get_solar_irradiance(),
18            solar_panel->get_power());
19
20   solar_panel->set_area(20);
21   simgrid::s4u::this_actor::sleep_for(1);
22   XBT_INFO("%s: area: %fm² efficiency: %f irradiance: %fW/m² power: %fW", solar_panel->get_cname(),
23            solar_panel->get_area(), solar_panel->get_conversion_efficiency(), solar_panel->get_solar_irradiance(),
24            solar_panel->get_power());
25
26   solar_panel->set_conversion_efficiency(0.8);
27   simgrid::s4u::this_actor::sleep_for(1);
28   XBT_INFO("%s: area: %fm² efficiency: %f irradiance: %fW/m² power: %fW", solar_panel->get_cname(),
29            solar_panel->get_area(), solar_panel->get_conversion_efficiency(), solar_panel->get_solar_irradiance(),
30            solar_panel->get_power());
31
32   solar_panel->set_solar_irradiance(20);
33   simgrid::s4u::this_actor::sleep_for(1);
34   XBT_INFO("%s: area: %fm² efficiency: %f irradiance: %fW/m² power: %fW", solar_panel->get_cname(),
35            solar_panel->get_area(), solar_panel->get_conversion_efficiency(), solar_panel->get_solar_irradiance(),
36            solar_panel->get_power());
37 }
38
39 int main(int argc, char* argv[])
40 {
41   simgrid::s4u::Engine e(&argc, argv);
42   e.load_platform(argv[1]);
43   simgrid::s4u::Actor::create("manager", e.host_by_name("Tremblay"), manager);
44   e.run();
45   return 0;
46 }