X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9ca5b959b0e1b164dec1c6872785df7f91c646c7..19e1048a7009c4144b0f361ad85fb9dff44761ea:/src/surf/network_wifi.hpp diff --git a/src/surf/network_wifi.hpp b/src/surf/network_wifi.hpp index 87234920e6..6f5ad3596f 100644 --- a/src/surf/network_wifi.hpp +++ b/src/surf/network_wifi.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2019-2020. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2019-2021. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -25,36 +25,36 @@ class NetworkWifiLink : public LinkImpl { /** @brief Hold every rates association between host and links (host name, rates id) */ std::map host_rates_; - /** @brief A link can have several bandwith attach to it (mostly use by wifi model) */ + /** @brief A link can have several bandwidths attached to it (mostly use by wifi model) */ std::vector bandwidths_; /** @brief Should we use the decay model ? */ bool use_decay_model_=false; - /** @brief Wifi ns-3 802.11n average bit rate */ - const double wifi_max_rate_=54*1e6 / 8; - /** @brief ns-3 802.11n minimum bit rate */ - const double wifi_min_rate_=41.70837*1e6 / 8; - /** @brief Decay model calibration */ + /** @brief Wifi maximal bit rate according to the ns-3 802.11n standard */ + const double wifi_max_rate_ = 54 * 1e6 / 8; + /** @brief minimum bit rate observed with ns3 during our calibration experiments */ + const double wifi_min_rate_ = 41.70837 * 1e6 / 8; + /** @brief Amount of stations used in the reference point to rescale SimGrid predictions to fit ns-3 ones */ const int model_n_=5; - /** @brief Decay model calibration: bitrate when using model_n_ stations */ + /** @brief Bit rate observed on ns3 at the reference point used for rescaling */ const double model_rate_=42.61438*1e6 / 8; - /** @brief Decay model bandwidths */ + /** @brief The bandwidth to use for each SNR level, corrected with the decay rescale mechanism */ std::vector decay_bandwidths_; public: - NetworkWifiLink(NetworkCm02Model* model, const std::string& name, std::vector bandwidths, - lmm::System* system); + NetworkWifiLink(const std::string& name, std::vector bandwidths, lmm::System* system); void set_host_rate(const s4u::Host* host, int rate_level); /** @brief Get the AP rate associated to the host (or -1 if not associated to the AP) */ - double get_host_rate(const s4u::Host* host); + double get_host_rate(const s4u::Host* host) const; - s4u::Link::SharingPolicy get_sharing_policy() override; + s4u::Link::SharingPolicy get_sharing_policy() const override; void apply_event(kernel::profile::Event*, double) override { THROW_UNIMPLEMENTED; } void set_bandwidth(double) override { THROW_UNIMPLEMENTED; } - void set_latency(double) override { THROW_UNIMPLEMENTED; } + void set_latency(double) override; void refresh_decay_bandwidths(); bool toggle_decay_model(); + int get_host_count() const; }; class NetworkWifiAction : public NetworkCm02Action { @@ -62,11 +62,13 @@ class NetworkWifiAction : public NetworkCm02Action { NetworkWifiLink* dst_wifi_link_; public: + NetworkWifiAction() = delete; NetworkWifiAction(Model* model, s4u::Host& src, s4u::Host& dst, double cost, bool failed, NetworkWifiLink* src_wifi_link, NetworkWifiLink* dst_wifi_link) : NetworkCm02Action(model, src, dst, cost, failed) , src_wifi_link_(src_wifi_link) - , dst_wifi_link_(dst_wifi_link){}; + , dst_wifi_link_(dst_wifi_link) + {} NetworkWifiLink* get_src_link() const { return src_wifi_link_; } NetworkWifiLink* get_dst_link() const { return dst_wifi_link_; }