-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();
+ ~NetworkCm02Model() { }
+ Link* createLink(const char *name, double bandwidth, double latency, e_surf_link_sharing_policy_t policy,
+ xbt_dict_t properties) override;
+ void updateActionsStateLazy(double now, double delta) override;
+ void updateActionsStateFull(double now, double delta) override;
+ Action *communicate(NetCard *src, NetCard *dst, double size, double rate) override;
+ bool next_occuring_event_isIdempotent() override {return true;}
+ virtual void gapAppend(double /*size*/, const Link* /*link*/, NetworkAction * /*action*/) {};
+ protected:
+ bool haveGap_ = false;
+ };
+
+ /************
+ * Resource *
+ ************/
+
+ class NetworkCm02Link : public Link {
+ public:
+ NetworkCm02Link(NetworkCm02Model *model, const char *name, xbt_dict_t props,
+ lmm_system_t system,
+ double constraint_value, double bandwidth, double latency,
+ e_surf_link_sharing_policy_t policy);
+
+ void apply_event(tmgr_trace_iterator_t event, double value) override;
+ void updateBandwidth(double value) override;
+ void updateLatency(double value) override;
+ virtual void gapAppend(double /*size*/, const Link* /*link*/, NetworkAction * /*action*/) {};
+ };
+
+
+ /**********
+ * Action *
+ **********/
+ class NetworkCm02Action : public NetworkAction {
+ friend Action *NetworkCm02Model::communicate(NetCard *src, NetCard *dst, double size, double rate);
+ friend NetworkSmpiModel;
+
+ public:
+ NetworkCm02Action(Model *model, double cost, bool failed)
+ : NetworkAction(model, cost, failed) {};
+ void updateRemainingLazy(double now);
+ protected:
+ double senderGap_;
+ };
+