Тестирование протокола отката
Я работаю над школьным проектом, в котором мне необходимо разработать и протестировать протокол Backoff. Я должен игнорировать параллелизм и, с определенным количеством узлов, проверить требуемую задержку так, чтобы каждый узел отправлял свой единственный пакет.
Я начинаю со 100 узлов и тестирую 4 различных типа отката. Я использую slotChosen, чтобы выбрать случайный интервал окна, если два узла выбирают один и тот же слот, чем у меня коллизия, и эти два узла должны отправить пакет снова. Каждый раз, когда у меня есть несколько узлов, которые все еще должны отправить свой пакет, я увеличиваю окно и увеличиваю задержку.
Это мой код:
public class myBackoff {
public static void main(String[] args) throws IOException {
int n; // number of devices
int times;
int latency = 0;
int[] slotChosen;
int[] status;
boolean success;
BufferedWriter linearFile = new BufferedWriter (new FileWriter("linearLatency.txt"));
BufferedWriter binaryFile = new BufferedWriter (new FileWriter("binaryLatency.txt"));
BufferedWriter trinaryFile = new BufferedWriter (new FileWriter("trinaryLatency.txt"));
BufferedWriter loglogFile = new BufferedWriter (new FileWriter("loglogLatency.txt"));
for ( n = 100 ; n <= 1000 ; n += 100) {
// linearLatency
slotChosen = new int [n];
status = new int[n];
success = false;
times = 0;
latency = 0;
while ( times < 10) {
Initialize(slotChosen, n);
Initialize(status, n);
latency += Latency(success, status, slotChosen, 2, n, 1);
times++;
}
linearFile.write(latency/10 + " ");
// binaryLatency
success = false;
times = 0;
latency = 0;
while ( times < 10) {
Initialize(slotChosen, n);
Initialize(status, n);
latency += Latency(success, status, slotChosen, 2, n, 2);
times++;
}
binaryFile.write(latency/10 + " ");
// trinaryLatency
success = false;
times = 0;
latency = 0;
while ( times < 10) {
Initialize(slotChosen, n);
Initialize(status, n);
latency += Latency(success, status, slotChosen, 3, n, 3);
times++;
}
trinaryFile.write(latency/10 + " ");
//loglogLatency
success = false;
times = 0;
latency = 0;
while ( times < 10) {
Initialize(slotChosen, n);
Initialize(status, n);
latency += Latency(success, status, slotChosen, 4, n, 4);
times++;
}
loglogFile.write(latency/10 + " ");
}
linearFile.close();
binaryFile.close();
trinaryFile.close();
loglogFile.close();
}
public static int Latency(boolean success, int[] status, int[] slotChosen, int window, int n, int type){
int latency = 0;
while (success == false) {
success = true;
System.out.println(window + " " + n);
for ( int t = 0 ; t < n ; t++ ) { // choosing a random slot for each node
if (status[t] == 0) {
Random r = new Random();
slotChosen[t] = r.nextInt(window) + 1;
System.out.println(slotChosen[t]);
status[t] = 1;
} else {
System.out.println("success");
slotChosen[t] = 0;
}
}
for ( int t = 0 ; t < n ; t++ ) {
for ( int i = 0 ; i < n ; i++ ) { // searching for collision
if (slotChosen[t] == slotChosen[i] && t != i) {
status[t] = status[i] = 0; //collision detected
}
}
}
for ( int t = 0 ; t < n ; t++ ) { // still node unsuccessful
if (status[t] == 0) {
success = false;
break;
}
}
if (success == true) {
int max = 0;
for ( int t = 0 ; t < n ; t++ ) { // last latency addition
if (slotChosen[t] != 0 && slotChosen[t] > max) {
max = slotChosen[t];
}
}
latency += max;
} else {
latency += window;
}
switch(type) {
case 1: window ++;
break;
case 2: window = window * 2;
break;
case 3: window = window * 3;
break;
case 4: window = (int) Math.floor(((1+1/(Math.log(Math.log(window))))*window));
break;
}
}
return latency;
}
public static void Initialize (int[] array, int n) {
for ( int t = 0 ; t < n ; t++ ) {
array[t] = 0;
}
}
}
Дело в том, что я позволил своему коду работать более 10 минут без вывода. Я думаю, что что-то не так, но не могу понять, что.