***********/
namespace simgrid {
-namespace surf {
+ namespace surf {
-class XBT_PRIVATE NetworkCm02Model;
-class XBT_PRIVATE NetworkCm02Action;
-class XBT_PRIVATE NetworkSmpiModel;
+ class XBT_PRIVATE NetworkCm02Model;
+ class XBT_PRIVATE NetworkCm02Action;
+ class XBT_PRIVATE NetworkSmpiModel;
-}
+ }
}
-/*********
- * Tools *
- *********/
-
-XBT_PRIVATE void net_define_callbacks(void);
-
/*********
* Model *
*********/
namespace simgrid {
-namespace surf {
-
-class NetworkCm02Model : public NetworkModel {
-public:
- NetworkCm02Model();
- ~NetworkCm02Model() { }
- Link* createLink(const char *name,
- double bw_initial,
- tmgr_trace_t bw_trace,
- double lat_initial,
- tmgr_trace_t lat_trace,
- int initiallyOn,
- tmgr_trace_t state_trace,
- 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 m_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,
- int initiallyOn,
- tmgr_trace_t state_trace,
- double metric_peak,
- tmgr_trace_t metric_trace,
- double lat_initial,
- tmgr_trace_t lat_trace,
- e_surf_link_sharing_policy_t policy);
- void apply_event(tmgr_trace_iterator_t event_type, 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 m_senderGap;
-};
-
-}
+ 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,
+ double bandwidth, double latency, e_surf_link_sharing_policy_t policy,
+ lmm_system_t system);
+
+ 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_;
+ };
+
+ }
}
#endif /* SURF_NETWORK_CM02_HPP_ */