WRENCH  1.10
Cyberinfrastructure Simulation Workbench
Overview Installation Getting Started WRENCH 101 WRENCH 102
NetworkProximityDaemon.h
1 
10 #ifndef WRENCH_NETWORKDAEMONS_H
11 #define WRENCH_NETWORKDAEMONS_H
12 
13 #include <random>
14 #include "wrench/services/Service.h"
15 #include "wrench/services/network_proximity/NetworkProximityServiceProperty.h"
16 #include "wrench/services/network_proximity/NetworkProximityServiceMessagePayload.h"
17 
18 namespace wrench {
19 
20  /***********************/
22  /***********************/
23 
24  class Simulation;
25 
30  public:
31 
33  std::string network_proximity_service_mailbox,
34  double message_size,double measurement_period,
35  double noise, std::map<std::string, double> messagepayload_list);
36 
37  private:
38 
39  friend class Simulation;
40 
42  std::string network_proximity_service_mailbox,
43  double message_size,double measurement_period,
44  double noise, std::map<std::string, double> messagepayload_list, std::string suffix);
45 
46 
47  double message_size;
48  double measurement_period;
49  double max_noise;
50 
51  std::string suffix;
52  std::string next_mailbox_to_send;
53  std::shared_ptr<NetworkProximityDaemon> next_daemon_to_send;
54  std::string next_host_to_send;
55  std::string network_proximity_service_mailbox;
56 
57  int main() override;
58  void cleanup(bool has_returned_from_main, int return_value) override;
59 
60 
61  double getTimeUntilNextMeasurement();
62 
63  bool processNextMessage(double timeout);
64  };
65 
66  /***********************/
68  /***********************/
69 }
70 
71 
72 #endif //WRENCH_NETWORKDAEMONS_H
wrench::NetworkProximityDaemon::NetworkProximityDaemon
NetworkProximityDaemon(Simulation *simulation, std::string hostname, std::string network_proximity_service_mailbox, double message_size, double measurement_period, double noise, std::map< std::string, double > messagepayload_list)
Constructor.
Definition: NetworkProximityDaemon.cpp:35
wrench
Definition: Alarm.cpp:20
wrench::Service::messagepayload_list
std::map< std::string, double > messagepayload_list
The service's messagepayload list.
Definition: Service.h:112
wrench::S4U_Daemon::hostname
std::string hostname
The name of the host on which the daemon is running.
Definition: S4U_Daemon.h:51
wrench::Simulation
A class that provides basic simulation methods. Once the simulation object has been explicitly or imp...
Definition: Simulation.h:46
wrench::NetworkProximityDaemon
A daemon used by a NetworkProximityService to run network measurements (proximity is computed between...
Definition: NetworkProximityDaemon.h:29
wrench::Service
A service that can be added to the simulation and that can be used by a WMS when executing a workflow...
Definition: Service.h:26
wrench::S4U_Daemon::simulation
Simulation * simulation
a pointer to the simulation object
Definition: S4U_Daemon.h:105