-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.c
158 lines (142 loc) · 4.62 KB
/
main.c
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
#include <stdio.h>
#include "Symbol.h"
#include "Sender.h"
#include "Receiver.h"
// 打印symbol内容
void printSymbol(Symbol* symbol) {
if(!symbol) return;
printf("esi: ");
int i,j;
for(i=0; i<symbol->esi.size; i++) {
printf("%d, ",symbol->esi.arr[i]);
}
printf("nbytes=%d bytes, \"", symbol->nbytes);
for(j=0; j<symbol->nbytes/4; j++) {
printf("%d ",symbol->data[j]); // 0x33323130 转成10进制为858927408
}
printf("\"\n");
}
// 分配内存并初始化SFM矩阵
int** initSFM(int revers_num, int K) {
int** sfm = (int**)malloc(revers_num * sizeof(int*));
for (int i = 0; i < revers_num; ++i) {
sfm[i] = (int*)malloc(K * sizeof(int));
}
return sfm;
}
//生成SFM矩阵
void formSFM(int** SFM, Receiver* receivers, int n) {
for(int i=0; i<n; i++) {
if (rand()/(RAND_MAX + 1.0) > 0.1) {
for(int j=0; j<receivers[i].rev_status.size; j++) {
SFM[i][j] = receivers[i].rev_status.arr[j];
}
}
}
}
int main() {
int roundCount = 1;
int i,j,K,T;
double lossrate;
K = 32;
T = 4;
lossrate = 0.3;
int** SFM; //全局变量
char** source = (char**)malloc(K * sizeof(char*));
for(i=0; i<K; i++) {
source[i] = (char*)malloc(T * sizeof(char));
for(j=0; j<T; j++) {
source[i][j] = (char)(j + '0');
}
}
// 初始化Sender结构体
VectorSymbol packets = createPackets((char**)source, K, T);
int pkt_num = packets.size;
printf("source symbol is :\n");
for(i=0; i<pkt_num; i++) {
Symbol* sym = packets.symbols[i];
printSymbol(sym);
}
//构造receiver
int num_rsver=4; //接收者个数
Receiver *rcvers = (Receiver*) malloc(sizeof(Receiver) * num_rsver);
for(i=0; i<num_rsver; i++) {
rcvers[i] = initReceiver(K);
}
//发送原始包,生成SFM矩阵
//初始时,sender发送原始包给每个接受者
for (i=0; i< K; i++) { //逐包发给每个接收者
for(j=0; j<num_rsver; j++) {
if (rand()/(RAND_MAX + 1.0) > lossrate) {
rcvers[j] = receiveSymbol(rcvers[j], packets.symbols[i]);
}
}
}
//打印收包状态
for(i=0; i<num_rsver; i++) {
//cout<<"receiver "<<r.id<<" receive pkts num is "<<r.pkt_recv<<endl;
printf("receiver %d receive pkts num is %d\n",i,rcvers[i].pkt_recv);
}
// 打印receiver当前收到的原始包
for(j=0; j<num_rsver; j++) {
printf("receiver%d receive %d source pkts:\n", j, rcvers[j].pkt_recv);
for(i=0; i<rcvers[j].symbol_map.size; i++) {
if(rcvers[j].symbol_map.pktid[i] != -1) {
printSymbol(rcvers[j].symbol_map.symbols[i]);
}
}
printf("\n");
}
//初始化SFM, K为包个数
SFM = initSFM(num_rsver, K);
formSFM(SFM,rcvers, num_rsver);
printf("Round %d SFM matrix is:\n", roundCount);
for(i=0; i<num_rsver; i++) {
for(j=0; j<K; j++) {
printf("%d ", SFM[i][j]);
}
printf("\n");
}
while(!isSFMAllzero(SFM, num_rsver, K)) {
//clique算法进行包配对
int limit = 2;
partition_result pairs = func_limit_partition(SFM, num_rsver, K, limit);
//生成编码包列表
VectorSymbol symbolVec = encode(pairs, packets.symbols);
printf("print encoded pkts:\n");
for(i=0; i<symbolVec.size; i++) {
printSymbol(symbolVec.symbols[i]);
}
printf("\n");
//发送编码包到接收方,接收方收包并解码
for (i=0; i< symbolVec.size; i++) { //逐包发给每个接收者
for(j=0; j<num_rsver; j++) {
if (rand()/(RAND_MAX + 1.0) > lossrate) {
rcvers[j] = receiveSymbol(rcvers[j], symbolVec.symbols[i]);
}
}
}
// 打印receiver当前收到的原始包
for(j=0; j<num_rsver; j++) {
printf("receiver%d receive %d source pkts:\n", j, rcvers[j].pkt_recv);
for(i=0; i<rcvers[j].symbol_map.size; i++) {
if(rcvers[j].symbol_map.pktid[i] != -1) {
printSymbol(rcvers[j].symbol_map.symbols[i]);
}
}
printf("\n");
}
// 重新生成SFM矩阵
formSFM(SFM,rcvers, num_rsver);
roundCount++;
printf("Round %d SFM matrix is:\n", roundCount);
for(i=0; i<num_rsver; i++) {
for(j=0; j<K; j++) {
printf("%d ", SFM[i][j]);
}
printf("\n");
}
}
printf("end");
return 0;
}