Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge lmm into base to avoid diamond inheritance
[simgrid.git] / src / surf / network_cm02.hpp
1 #include "network_interface.hpp"
2 #include "xbt/fifo.h"
3 #include "xbt/graph.h"
4
5 #ifndef SURF_NETWORK_CM02_HPP_
6 #define SURF_NETWORK_CM02_HPP_
7
8 /***********
9  * Classes *
10  ***********/
11 class NetworkCm02Model;
12 typedef NetworkCm02Model *NetworkCm02ModelPtr;
13
14 class NetworkCm02Link;
15 typedef NetworkCm02Link *NetworkCm02LinkPtr;
16
17 class NetworkCm02Action;
18 typedef NetworkCm02Action *NetworkCm02ActionPtr;
19
20 /*********
21  * Tools *
22  *********/
23
24 void net_define_callbacks(void);
25
26 /*********
27  * Model *
28  *********/
29 class NetworkCm02Model : public NetworkModel {
30 private:
31   void initialize();
32 public:
33   NetworkCm02Model(int /*i*/) : NetworkModel("network") {
34         f_networkSolve = lmm_solve;
35         m_haveGap = false;
36   };//FIXME: add network clean interface
37   NetworkCm02Model(const char *name) : NetworkModel(name) {
38     this->initialize();
39   }
40   NetworkCm02Model() : NetworkModel("network") {
41     this->initialize();
42   }
43   ~NetworkCm02Model() {
44   }
45   NetworkLinkPtr createResource(const char *name,
46                                    double bw_initial,
47                                    tmgr_trace_t bw_trace,
48                                    double lat_initial,
49                                    tmgr_trace_t lat_trace,
50                                    e_surf_resource_state_t state_initial,
51                                    tmgr_trace_t state_trace,
52                                    e_surf_link_sharing_policy_t policy,
53                                    xbt_dict_t properties);
54   void updateActionsStateLazy(double now, double delta);
55   ActionPtr communicate(RoutingEdgePtr src, RoutingEdgePtr dst,
56                                            double size, double rate);
57 };
58
59 /************
60  * Resource *
61  ************/
62
63 class NetworkCm02Link : public NetworkLink {
64 public:
65   NetworkCm02Link(NetworkCm02ModelPtr model, const char *name, xbt_dict_t props,
66                                    lmm_system_t system,
67                                    double constraint_value,
68                                    tmgr_history_t history,
69                                    e_surf_resource_state_t state_init,
70                                    tmgr_trace_t state_trace,
71                                    double metric_peak,
72                                    tmgr_trace_t metric_trace,
73                                    double lat_initial,
74                                    tmgr_trace_t lat_trace,
75                                e_surf_link_sharing_policy_t policy);
76   void updateState(tmgr_trace_event_t event_type, double value, double date);
77 };
78
79
80 /**********
81  * Action *
82  **********/
83
84 class NetworkCm02Action : public NetworkAction {
85   friend ActionPtr NetworkCm02Model::communicate(RoutingEdgePtr src, RoutingEdgePtr dst, double size, double rate);
86
87 public:
88   NetworkCm02Action(ModelPtr model, double cost, bool failed)
89  : NetworkAction(model, cost, failed) {};
90   void updateRemainingLazy(double now);
91   void recycle();
92 };
93
94 #endif /* SURF_NETWORK_CM02_HPP_ */