-class NetworkCm02Model : public NetworkModel {
-private:
- void initialize();
-public:
- NetworkCm02Model(int /*i*/) : NetworkModel("network") {
- f_networkSolve = lmm_solve;
- m_haveGap = false;
- };//FIXME: add network clean interface
- NetworkCm02Model(const char *name) : NetworkModel(name) {
- this->initialize();
- }
- NetworkCm02Model() : NetworkModel("network") {
- this->initialize();
- }
- ~NetworkCm02Model() {
+
+namespace simgrid {
+ namespace surf {
+
+ class NetworkCm02Model : public NetworkModel {
+ public:
+ NetworkCm02Model();
+ explicit NetworkCm02Model(void (*solve_fun)(lmm_system_t self));
+ virtual ~NetworkCm02Model() = default;
+ LinkImpl* createLink(const char* name, double bandwidth, double latency,
+ e_surf_link_sharing_policy_t policy) override;
+ void updateActionsStateLazy(double now, double delta) override;
+ void updateActionsStateFull(double now, double delta) override;
+ Action* communicate(s4u::Host* src, s4u::Host* dst, double size, double rate) override;
+ virtual void gapAppend(double size, const LinkImpl* link, NetworkAction* action);
+
+ protected:
+ bool haveGap_ = false;
+ };
+
+ /************
+ * Resource *
+ ************/
+
+ class NetworkCm02Link : public LinkImpl {
+ public:
+ NetworkCm02Link(NetworkCm02Model* model, const char* name, double bandwidth, double latency,
+ e_surf_link_sharing_policy_t policy, lmm_system_t system);
+ virtual ~NetworkCm02Link() = default;
+ void apply_event(tmgr_trace_event_t event, double value) override;
+ void setBandwidth(double value) override;
+ void setLatency(double value) override;
+ virtual void gapAppend(double size, const LinkImpl* link, NetworkAction* action);
+ };
+
+
+ /**********
+ * Action *
+ **********/
+ class NetworkCm02Action : public NetworkAction {
+ friend Action* NetworkCm02Model::communicate(s4u::Host* src, s4u::Host* dst, double size, double rate);
+ friend NetworkSmpiModel;
+ public:
+ NetworkCm02Action(Model *model, double cost, bool failed)
+ : NetworkAction(model, cost, failed) {};
+ virtual ~NetworkCm02Action() = default;
+ void updateRemainingLazy(double now) override;
+ protected:
+ double senderGap_;
+ };
+