-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflow.h
56 lines (44 loc) · 1.41 KB
/
flow.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#ifndef FLOW_H
#define FLOW_H
#include <vector>
#include <string>
#include <list>
#include <set>
#include <iostream>
#include <map>
#include <random>
using namespace std;
class Flow
{
int id;
int source_domain;
int destination_domain;
string start_rate_function; // begin flow rate function name
string path_calc_type;
bool malware_flag;
int malware_id; // -1 if - NOT malware, malware id in other case
set<string> tag_cloud; // tag cloud of this flow
vector<int> flow_path; // sequence of domain ids, that flow needs to go
float * begin_point_flow_rate; // pointer to begin flow rate function
struct Flow_state_struct // flow state is calc in every domain it come throught
{
float rate;
float loss;
float delay;
};
map <int,Flow_state_struct> flow_state; // map flow parametrs on domain
public:
Flow();
Flow(int flow_id, int sd, int dd, string srf, string pct,vector<int> fp, set<string> tc, bool mf, int mid);
int change_state(int d_id, float f_r, float f_l, float f_d);
int change_path(vector<int> new_flow_path); // TO DO
set<string> get_flow_tags();
vector<int> get_flow_path();
int get_domain_type_for_this_flow(int domain_id);
int get_prev_domain_in_flow_path(int domain_id);
int get_flow_malware_id();
bool is_malware();
float start_rate_generator();
void get_flow_info();
};
#endif // FLOW_H