X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b51a4211effefa29ee060101107f5152ad12c30c..94e3b6ccac06f8bb1f6ab5d9c5d7e5bd8e861a8a:/src/surf/network_wifi.hpp diff --git a/src/surf/network_wifi.hpp b/src/surf/network_wifi.hpp index 509db17025..51f566b486 100644 --- a/src/surf/network_wifi.hpp +++ b/src/surf/network_wifi.hpp @@ -25,20 +25,20 @@ 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: @@ -47,14 +47,15 @@ public: 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 refresh_decay_bandwidths(); bool toggle_decay_model(); + int get_host_count() const; }; class NetworkWifiAction : public NetworkCm02Action { @@ -62,6 +63,7 @@ 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)