Newer
Older
import java.util.List;
import java.util.ArrayList;
import java.util.ListIterator;
import java.util.Arrays;
public class TestNloc {
public static void main(String[] args) {
//Nloc nlSX = new Nloc(getNlocS1());
//Nloc nlSX = new Nloc(getNlocS2());

Peter Wagenhuber
committed
//Nloc nlSX = new Nloc(getNlocS6());
//Nloc nlSX = new Nloc(getNlocS7());
Nloc nlSX = new Nloc(getNlocS8());
//try {
// List<Channel> chlist = nlSX.getModulesByName(Arrays.asList("ch1","ch3"));
// List<Channel> chlist = nlSX.getModulesByName(Arrays.asList("ch1"));
// System.out.println(nlSX.getHeaderPathlength(chlist));
//} catch(Exception e) {
// System.out.println( e.getMessage());
//}
String[] mtv = {"m4","d1","m1","m3","h0","m5"};
List<List<SequenceTuple>> sequences = nlSX.getPossibleSequences(mtv);

Peter Wagenhuber
committed
printSequences(sequences);
} catch(Exception e) {
System.out.println( e.getMessage());
}

Peter Wagenhuber
committed
public static void printSequence(List<SequenceTuple> seq) {
for (SequenceTuple stup: seq) {
if (seq.indexOf(stup) == (seq.size() - 1)) {

Peter Wagenhuber
committed
System.out.print(stup.getDroplet().getName() + ": " + stup.getMinPos() +
":" + stup.getMaxPos());
} else {
System.out.print(stup.getDroplet().getName() + ": " + stup.getMinPos() +
":" + stup.getMaxPos() + " -> ");
}
}
System.out.println("\n");
}

Peter Wagenhuber
committed
public static void printSequences(List<List<SequenceTuple>> sequences) {
System.out.println("##################");
System.out.println("# " + sequences.size() + " Sequences Found");
System.out.println("##################");
System.out.println("");
for (List<SequenceTuple> sl: sequences) {
printSequence(sl);
}
}
public static void printPath(List<Channel> path) {
System.out.println("Pathlength Payload: " + Nloc.getPayloadPathlength(path));
System.out.println("Pathlength Header: " + Nloc.getHeaderPathlength(path));
for (Channel ch : path) {
if (path.indexOf(ch) == (path.size() - 1)) {
System.out.print(ch.getName());
} else {
System.out.print(ch.getName() + " -> ");
}
}
System.out.println("");
System.out.println("");
}
public static void printPaths(List<List<Channel>> pathlist) {
System.out.println("");
System.out.println("#############################");
System.out.println("# Number of paths found: " + pathlist.size());
System.out.println("#############################");
for (List<Channel> p : pathlist) {
printPath(p);
}
}
public static List<Channel> getNlocS1() {
// channel(name, psteps, hsteps)
Channel ch1 = new Channel("ch1",1,1);
Channel ch2 = new Channel("ch2",1,1);
Channel ch3 = new Channel("ch3",1,1);
Channel ch4 = new Channel("ch4",1,1);
Channel ch5 = new Channel("ch5",1,1);
Channel ch6 = new Channel("ch6",1,1);
Channel ch7 = new Channel("ch7",1,1);
Channel ch8 = new Channel("ch8",1,1);
Channel ch9 = new Channel("ch9",1,1);
Channel ch10 = new Channel("ch10",1,1);
Channel ch11 = new Channel("ch11",3,3);
Channel ch12 = new Channel("ch12",1,1);
Channel ch13 = new Channel("ch13",1,1);
Channel ch14 = new Channel("ch14",1,1);
Channel ch15 = new Channel("ch15",1,1);
Module m0 = new Module("m0", 5,1);
Module m1 = new Module("m1", 5,1);
Module m2 = new Module("m2", 5,1);
Module d1 = new Module("d1", 5,1);
Module d2 = new Module("d2", 5,1);
Module h1 = new Module("h1", 5,1);
Module h2 = new Module("h2", 5,1);
Module f2 = new Module("f2", 5,1);
Pump p0 = new Pump();
Sink s0 = new Sink();
List<Channel> chlist = Arrays.asList(ch1, ch2, ch3, ch4, ch5, ch6, ch7,
ch8, ch9, ch10, ch11, ch12, ch13, ch14, ch15, m0, m1, m2, d1, d2, h1,
h2, f2, p0, s0);
p0.addChild(ch1);
p0.addChild(ch2);
p0.addChild(ch3);
ch1.addChild(m2);
m2.addChild(ch4);
ch4.addChild(d2);
d2.addChild(ch6);
ch2.addChild(h2);
h2.addChild(ch5);
ch6.addChild(ch7);
ch5.addChild(ch7);
ch3.addChild(ch7);
ch7.addChild(m1);
m1.addChild(ch8);
ch8.addChild(f2);
f2.addChild(ch9);
ch9.addChild(ch11);
ch9.addChild(ch10);
ch11.addChild(h1);
h1.addChild(ch12);
ch12.addChild(ch13);
ch10.addChild(ch13);
ch13.addChild(m0);
m0.addChild(ch14);
ch14.addChild(d1);
d1.addChild(ch15);

Peter Wagenhuber
committed
public static List<Channel> getNlocS2() {
// channel(name, psteps, hsteps)
Channel ch1 = new Channel("ch1",1,1);
Channel ch2 = new Channel("ch2",1,1);
Channel ch3 = new Channel("ch3",1,1);
Channel ch4 = new Channel("ch4",1,1);
Channel ch5 = new Channel("ch5",1,1);
Channel ch6 = new Channel("ch6",3,3);
Channel ch7 = new Channel("ch7",1,1);
Channel ch8 = new Channel("ch8",1,1);
Channel ch9 = new Channel("ch9",1,1);
Channel ch10 = new Channel("ch10",1,1);
Channel ch11 = new Channel("ch11",1,1);
Channel ch12 = new Channel("ch12",3,3);
Channel ch13 = new Channel("ch13",1,1);
Channel ch14 = new Channel("ch14",1,1);
Channel ch15 = new Channel("ch15",1,1);
Channel ch16 = new Channel("ch16",1,1);
Channel ch17 = new Channel("ch17",3,3);
Channel ch18 = new Channel("ch18",1,1);
Channel ch19 = new Channel("ch19",1,1);
Channel ch20 = new Channel("ch20",1,1);
Channel ch21 = new Channel("ch21",3,3);
Channel ch22 = new Channel("ch22",1,1);
Channel ch23 = new Channel("ch23",1,1);
Channel ch24 = new Channel("ch24",1,1);
Channel ch25 = new Channel("ch25",3,3);
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
Channel ch26 = new Channel("ch26",1,1);
Channel ch27 = new Channel("ch27",1,1);
Channel ch28 = new Channel("ch28",1,1);
Channel ch29 = new Channel("ch29",1,1);
Channel ch30 = new Channel("ch30",1,1);
Module m0 = new Module("m0", 5,1);
Module m1 = new Module("m1", 5,1);
Module m2 = new Module("m2", 5,1);
Module m3 = new Module("m3", 5,1);
Module m4 = new Module("m4", 5,1);
Module m5 = new Module("m5", 5,1);
Module h0 = new Module("h0", 5,1);
Module h3 = new Module("h3", 5,1);
Module d1 = new Module("d1", 5,1);
Module f2 = new Module("f2", 5,1);
Pump p0 = new Pump();
Sink s0 = new Sink();
List<Channel> chlist = Arrays.asList(ch1, ch2, ch3, ch4, ch5, ch6, ch7,
ch8, ch9, ch10, ch11, ch12, ch13, ch14, ch15, ch16, ch17, ch18, ch19,
ch20, ch21, ch22, ch23, ch24, ch25, ch26, ch27, ch28, ch29, ch30, m0,
m1, m2, m3, m4, m5, h0, h3, d1, f2, p0, s0);
p0.addChild(ch1);
p0.addChild(ch2);
p0.addChild(ch3);
p0.addChild(ch4);
ch1.addChild(m4);
m4.addChild(ch8);
ch8.addChild(ch11);
ch8.addChild(ch12);

Peter Wagenhuber
committed
ch12.addChild(d1);
d1.addChild(ch15);
ch2.addChild(ch9);

Peter Wagenhuber
committed
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
ch3.addChild(m2);
m2.addChild(ch5);
ch5.addChild(ch6);
ch5.addChild(ch7);
ch6.addChild(ch9);
ch9.addChild(h3);
h3.addChild(ch13);
ch4.addChild(ch10);
ch7.addChild(ch10);
ch10.addChild(f2);
f2.addChild(ch14);
ch14.addChild(ch16);
ch14.addChild(ch17);
ch11.addChild(ch18);
ch15.addChild(ch18);
ch13.addChild(ch18);
ch16.addChild(ch18);
ch18.addChild(m1);
m1.addChild(ch19);
ch19.addChild(ch20);
ch19.addChild(ch21);
ch21.addChild(ch22);
ch17.addChild(ch22);
ch22.addChild(m3);
m3.addChild(ch23);
ch23.addChild(ch24);
ch23.addChild(ch25);
ch20.addChild(ch26);
ch24.addChild(ch26);
ch26.addChild(m0);
m0.addChild(ch28);

Peter Wagenhuber
committed
ch25.addChild(h0);
h0.addChild(ch27);
ch28.addChild(ch29);
ch27.addChild(ch29);
ch29.addChild(m5);
m5.addChild(ch30);
ch30.addChild(s0);
return chlist;
}
public static List<Channel> getNlocS6() {
// channel(name, psteps, hsteps)
Channel ch1 = new Channel("ch1",1,1);
Channel ch2 = new Channel("ch2",1,1);
Channel ch3 = new Channel("ch3",1,1);
Channel ch4 = new Channel("ch4",1,1);
Channel ch5 = new Channel("ch5",3,3);
Channel ch6 = new Channel("ch6",1,1);
Channel ch7 = new Channel("ch7",1,1);
Channel ch8 = new Channel("ch8",1,1);
Channel ch9 = new Channel("ch9",1,1);
Channel ch10 = new Channel("ch10",3,3);
Channel ch11 = new Channel("ch11",1,1);
Channel ch12 = new Channel("ch12",1,1);
Channel ch13 = new Channel("ch13",1,1);
Channel ch14 = new Channel("ch14",3,3);
Channel ch15 = new Channel("ch15",1,1);
Channel ch16 = new Channel("ch16",1,1);
Channel ch17 = new Channel("ch17",1,1);
Channel ch18 = new Channel("ch18",1,1);
Channel ch19 = new Channel("ch19",1,1);
Channel ch20 = new Channel("ch20",1,1);
Module m0 = new Module("m0", 5,1);
Module m1 = new Module("m1", 5,1);
Module m3 = new Module("m3", 5,1);
Module m4 = new Module("m4", 5,1);
Module m5 = new Module("m5", 5,1);
Module h0 = new Module("h0", 5,1);
Module h3 = new Module("h3", 5,1);
Module d1 = new Module("d1", 5,1);

Peter Wagenhuber
committed
Pump p0 = new Pump();
Sink s0 = new Sink();
List<Channel> chlist = Arrays.asList(ch1, ch2, ch3, ch4, ch5, ch6, ch7,
ch8, ch9, ch10, ch11, ch12, ch13, ch14, ch15, ch16, ch17, ch18, ch19,
ch20, m0, m1, m3, m4, m5, h0, h3, d1, p0, s0);

Peter Wagenhuber
committed
p0.addChild(ch1);
p0.addChild(ch2);

Peter Wagenhuber
committed
ch2.addChild(h3);
h3.addChild(ch4);
ch1.addChild(m4);
m4.addChild(ch3);
ch3.addChild(ch5);
ch3.addChild(ch6);
ch5.addChild(d1);
d1.addChild(ch7);
ch7.addChild(ch8);
ch6.addChild(ch8);
ch4.addChild(ch8);
ch8.addChild(m1);
m1.addChild(ch9);
ch9.addChild(ch10);
ch9.addChild(ch11);
ch10.addChild(ch12);
ch12.addChild(m3);
m3.addChild(ch13);
ch13.addChild(ch14);
ch13.addChild(ch15);

Peter Wagenhuber
committed
ch14.addChild(h0);
h0.addChild(ch16);

Peter Wagenhuber
committed
ch15.addChild(ch17);
ch11.addChild(ch17);
ch17.addChild(m0);
m0.addChild(ch18);
ch16.addChild(ch19);
ch18.addChild(ch19);

Peter Wagenhuber
committed
ch19.addChild(m5);
m5.addChild(ch20);

Peter Wagenhuber
committed

Peter Wagenhuber
committed
}

Peter Wagenhuber
committed
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
public static List<Channel> getNlocS7() {
// channel(name, psteps, hsteps)
Channel ch1 = new Channel("ch1",1,1);
Channel ch2 = new Channel("ch2",1,1);
Channel ch3 = new Channel("ch3",1,1);
Channel ch4 = new Channel("ch4",1,1);
Channel ch5 = new Channel("ch5",1,1);
Channel ch6 = new Channel("ch6",1,1);
Channel ch7 = new Channel("ch7",1,1);
Channel ch8 = new Channel("ch8",3,3);
Channel ch9 = new Channel("ch9",1,1);
Channel ch10 = new Channel("ch10",1,1);
Channel ch11 = new Channel("ch11",1,1);
Channel ch12 = new Channel("ch12",3,3);
Channel ch13 = new Channel("ch13",1,1);
Channel ch14 = new Channel("ch14",1,1);
Channel ch15 = new Channel("ch15",1,1);
Channel ch16 = new Channel("ch16",1,1);
Channel ch17 = new Channel("ch17",1,1);
Channel ch18 = new Channel("ch18",1,1);
Module m0 = new Module("m0", 5,1);
Module m1 = new Module("m1", 5,1);
Module m3 = new Module("m3", 5,1);
Module m4 = new Module("m4", 5,1);
Module m5 = new Module("m5", 5,1);
Module h0 = new Module("h0", 5,1);
Module h3 = new Module("h3", 5,1);
Module d1 = new Module("d1", 5,1);
Pump p0 = new Pump();
Sink s0 = new Sink();
List<Channel> chlist = Arrays.asList(ch1, ch2, ch3, ch4, ch5, ch6, ch7,
ch8, ch9, ch10, ch11, ch12, ch13, ch14, ch15, ch16, ch17, ch18,
m0, m1, m3, m4, m5, h0, h3, d1, p0, s0);
p0.addChild(ch1);
p0.addChild(ch2);
ch2.addChild(h3);
h3.addChild(ch4);
ch1.addChild(m4);
m4.addChild(ch3);
ch3.addChild(d1);
d1.addChild(ch5);
ch5.addChild(ch6);
ch4.addChild(ch6);
ch6.addChild(m1);
m1.addChild(ch7);
ch7.addChild(ch8);
ch7.addChild(ch9);
ch8.addChild(ch10);
ch10.addChild(m3);
m3.addChild(ch11);
ch11.addChild(ch12);
ch11.addChild(ch13);
ch13.addChild(ch15);
ch9.addChild(ch15);
ch12.addChild(h0);
h0.addChild(ch14);
ch15.addChild(m0);
m0.addChild(ch16);
ch14.addChild(ch17);
ch16.addChild(ch17);
ch17.addChild(m5);
m5.addChild(ch18);
ch18.addChild(s0);
return chlist;
}
public static List<Channel> getNlocS8() {
// channel(name, psteps, hsteps)
Channel ch1 = new Channel("ch1",1,1);
Channel ch2 = new Channel("ch2",7,7);
Channel ch3 = new Channel("ch3",4,4);

Peter Wagenhuber
committed
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
Channel ch4 = new Channel("ch4",1,1);
Channel ch5 = new Channel("ch5",1,1);
Channel ch6 = new Channel("ch6",1,1);
Channel ch7 = new Channel("ch7",1,1);
Channel ch8 = new Channel("ch8",1,1);
Channel ch9 = new Channel("ch9",3,3);
Channel ch10 = new Channel("ch10",1,1);
Channel ch11 = new Channel("ch11",1,1);
Channel ch12 = new Channel("ch12",1,1);
Channel ch13 = new Channel("ch13",3,3);
Channel ch14 = new Channel("ch14",1,1);
Channel ch15 = new Channel("ch15",1,1);
Channel ch16 = new Channel("ch16",1,1);
Channel ch17 = new Channel("ch17",1,1);
Channel ch18 = new Channel("ch18",1,1);
Channel ch19 = new Channel("ch19",1,1);
Module m0 = new Module("m0", 5,1);
Module m1 = new Module("m1", 5,1);
Module m3 = new Module("m3", 5,1);
Module m4 = new Module("m4", 5,1);
Module m5 = new Module("m5", 5,1);
Module h0 = new Module("h0", 5,1);
Module h3 = new Module("h3", 5,1);
Module d1 = new Module("d1", 5,1);
Pump p0 = new Pump();
Sink s0 = new Sink();
List<Channel> chlist = Arrays.asList(ch1, ch2, ch3, ch4, ch5, ch6, ch7,
ch8, ch9, ch10, ch11, ch12, ch13, ch14, ch15, ch16, ch17, ch18, ch19,
m0, m1, m3, m4, m5, h0, h3, d1, p0, s0);
p0.addChild(ch1);
ch1.addChild(ch2);
ch1.addChild(ch3);
ch2.addChild(m4);
m4.addChild(ch4);
ch4.addChild(d1);
d1.addChild(ch6);
ch3.addChild(h3);
h3.addChild(ch5);
ch6.addChild(ch7);
ch5.addChild(ch7);
ch7.addChild(m1);
m1.addChild(ch8);
ch8.addChild(ch9);
ch8.addChild(ch10);
ch9.addChild(ch11);
ch11.addChild(m3);
m3.addChild(ch12);
ch12.addChild(ch13);
ch12.addChild(ch14);
ch13.addChild(h0);
h0.addChild(ch15);
ch10.addChild(ch16);
ch14.addChild(ch16);
ch16.addChild(m0);
m0.addChild(ch17);
ch15.addChild(ch18);
ch17.addChild(ch18);
ch18.addChild(m5);
m5.addChild(ch19);
ch19.addChild(s0);
return chlist;
}