34 PeerGroup a = sim.createGroup(1);
35 PeerGroup b = sim.createGroup(1);
36 PeerGroup c = sim.createGroup(1);
37 PeerGroup d = sim.createGroup(1);
38 PeerGroup e = sim.createGroup(1);
39 PeerGroup f = sim.createGroup(1);
40 PeerGroup g = sim.createGroup(1);
42 a.trustAndConnect(a + b + c + g, delay);
43 b.trustAndConnect(b + a + c + d + e, delay);
44 c.trustAndConnect(c + a + b + d + e, delay);
45 d.trustAndConnect(d + b + c + e + f, delay);
46 e.trustAndConnect(e + b + c + d + f, delay);
47 f.trustAndConnect(f + d + e + g, delay);
48 g.trustAndConnect(g + a + f, delay);
50 PeerGroup
const network = a + b + c + d + e + f + g;
54 sim.collectors.add(sc);
56 for (TrustGraph<Peer*>::ForkInfo
const& fi : sim.trustGraph.forkablePairs(0.8))
58 std::cout <<
"Can fork " << PeerGroup{fi.unlA} <<
" "
59 <<
" " << PeerGroup{fi.unlB} <<
" overlap " << fi.overlap <<
" required "
60 << fi.required <<
"\n";
66 PeerGroup byzantineNodes = a + b + c + g;
68 for (
Peer* peer : network)
73 if (byzantineNodes.contains(peer))
75 peer->txInjections.emplace(peer->lastClosedLedger.seq(), Tx{42});
79 std::cout <<
"Branches: " << sim.branches() <<
"\n";