- XBT_INFO("Initial Battery: SoC: %f SoH: %f Capacity (Total): %fWh Capacity (Usable): %fWh P: %fW",
- sg_battery_get_state_of_charge(battery), sg_battery_get_state_of_health(battery),
- sg_battery_get_capacity(battery),
- sg_battery_get_capacity(battery) *
- (sg_battery_get_state_of_charge_max(battery) - sg_battery_get_state_of_charge_min(battery)),
- sg_battery_get_power(battery));
+ battery->schedule_handler(
+ 0.2, simgrid::plugins::Battery::DISCHARGE, simgrid::plugins::Battery::Handler::PERSISTANT,
+ [&battery, &host1, &host2, &host3]() {
+ XBT_INFO("Handler -> Battery low: SoC: %f SoH: %f Energy stored: %fJ Energy provided: %fJ Energy consumed %fJ",
+ battery->get_state_of_charge(), battery->get_state_of_health(), battery->get_energy_stored(),
+ battery->get_energy_provided(), battery->get_energy_consumed());
+ XBT_INFO("Disconnecting hosts %s and %s", host1->get_cname(), host2->get_cname());
+ battery->connect_host(host1, false);
+ battery->connect_host(host2, false);
+ XBT_INFO("Energy consumed this far by: %s: %fJ, %s: %fJ, %s: %fJ", host1->get_cname(),
+ sg_host_get_consumed_energy(host1), host2->get_cname(), sg_host_get_consumed_energy(host2),
+ host3->get_cname(), sg_host_get_consumed_energy(host3));
+ });