1 /* Copyright (c) 2013-2014. The SimGrid Team.
2 * All rights reserved. */
4 /* This program is free software; you can redistribute it and/or modify it
5 * under the terms of the license (GNU LGPL) which comes with this package. */
7 #include "network_interface.hpp"
11 #ifndef SURF_NETWORK_CM02_HPP_
12 #define SURF_NETWORK_CM02_HPP_
17 class NetworkCm02Model;
18 typedef NetworkCm02Model *NetworkCm02ModelPtr;
20 class NetworkCm02Link;
21 typedef NetworkCm02Link *NetworkCm02LinkPtr;
23 class NetworkCm02Action;
24 typedef NetworkCm02Action *NetworkCm02ActionPtr;
30 void net_define_callbacks(void);
35 class NetworkCm02Model : public NetworkModel {
39 NetworkCm02Model(int /*i*/) : NetworkModel("network") {
40 f_networkSolve = lmm_solve;
42 };//FIXME: add network clean interface
43 NetworkCm02Model(const char *name) : NetworkModel(name) {
46 NetworkCm02Model() : NetworkModel("network") {
51 NetworkLinkPtr createNetworkLink(const char *name,
53 tmgr_trace_t bw_trace,
55 tmgr_trace_t lat_trace,
56 e_surf_resource_state_t state_initial,
57 tmgr_trace_t state_trace,
58 e_surf_link_sharing_policy_t policy,
59 xbt_dict_t properties);
61 void updateActionsStateLazy(double now, double delta);
62 void updateActionsStateFull(double now, double delta);
63 ActionPtr communicate(RoutingEdgePtr src, RoutingEdgePtr dst,
64 double size, double rate);
71 class NetworkCm02Link : public NetworkLink {
73 NetworkCm02Link(NetworkCm02ModelPtr model, const char *name, xbt_dict_t props,
75 double constraint_value,
76 tmgr_history_t history,
77 e_surf_resource_state_t state_init,
78 tmgr_trace_t state_trace,
80 tmgr_trace_t metric_trace,
82 tmgr_trace_t lat_trace,
83 e_surf_link_sharing_policy_t policy);
84 void updateState(tmgr_trace_event_t event_type, double value, double date);
85 void updateBandwidth(double value, double date=surf_get_clock());
86 void updateLatency(double value, double date=surf_get_clock());
94 class NetworkCm02Action : public NetworkAction {
95 friend ActionPtr NetworkCm02Model::communicate(RoutingEdgePtr src, RoutingEdgePtr dst, double size, double rate);
98 NetworkCm02Action(ModelPtr model, double cost, bool failed)
99 : NetworkAction(model, cost, failed) {};
100 void updateRemainingLazy(double now);
104 #endif /* SURF_NETWORK_CM02_HPP_ */