Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Fix bugs...
[simgrid.git] / src / surf / gtnets / gtnets_simulator.h
1 /*      $Id$     */
2 /* Copyright (c) 2007 Kayo Fujiwara. All rights reserved.                  */
3
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. */
6
7 #ifndef _GTNETS_SIM_H
8 #define _GTNETS_SIM_H
9
10 #ifdef __cplusplus
11 #include "gtnets_topology.h"
12
13 #include <iostream>
14 #include <sys/wait.h>
15 #include <map>
16
17 //GTNetS include files
18 #include "simulator.h"      // Definitions for the Simulator Object
19 #include "node.h"           // Definitions for the Node Object
20 #include "linkp2p.h"        // Definitions for point-to-point link objects
21 #include "ratetimeparse.h"  // Definitions for Rate and Time objects
22 #include "application-tcpserver.h" // Definitions for TCPServer application
23 #include "application-tcpsend.h"   // Definitions for TCP Sending application
24 #include "tcp-tahoe.h"      // Definitions for TCP Tahoe
25 #include "tcp-reno.h"
26 #include "tcp-newreno.h"
27 #include "validation.h"
28 #include "event.h"
29 #include "routing-manual.h"
30
31 using namespace std;
32
33 //Simulator s;
34 class GTSim {
35
36 public:
37   GTSim();
38   ~GTSim();
39 public:   
40   int add_link(int id, double bandwidth, double latency);
41   int add_onehop_route(int src, int dst, int link);
42   int add_route(int src, int dst, int* links, int nlink);
43   int add_router(int id);
44   int create_flow(int src, int dst, long datasize, void* metadata);
45   double get_time_to_next_flow_completion();
46   int run_until_next_flow_completion(void*** metadata, int* number_of_flows);
47   int run(double deltat);
48
49   void create_gtnets_topology();
50 private:
51   void add_nodes();
52   void node_connect();
53
54   bool node_include(int);
55   bool link_include(int);
56   Simulator* sim_;
57   GTNETS_Topology* topo_;
58   RoutingManual* rm_;
59   int nnode_;
60   int is_topology_;
61   int nflow_;
62
63   map<int, Linkp2p*>   gtnets_links_;
64   map<int, Node*>      gtnets_nodes_;
65   map<int, TCPServer*> gtnets_servers_;
66   map<int, TCPSend*>   gtnets_clients_;
67
68   map<int, void*>      gtnets_metadata_;
69 };
70
71 #endif /* __cplusplus */
72
73 #endif
74
75