mirror of
https://github.com/mimblewimble/grin.git
synced 2025-01-21 11:31:08 +03:00
1e93b7fe65
* Markdown formating
77 lines
No EOL
2.1 KiB
Markdown
77 lines
No EOL
2.1 KiB
Markdown
# Dandelion Simulation
|
|
|
|
This document describes a network of node using the Dandelion protocol with transaction aggregation.
|
|
|
|
In this scenario, we simulate a successful aggregation.
|
|
|
|
This document also helps visualizing all the timers in a simple way.
|
|
|
|
## T = 0 - Initial Situation
|
|
|
|
![t = 0](images/t0.png)
|
|
|
|
## T = 5
|
|
|
|
A sends grins to B. A adds the transaction to its stempool and starts the embargo timer for this transaction.
|
|
|
|
![t = 5](images/t5.png)
|
|
|
|
## T = 10
|
|
|
|
A waits until he runs out of patience.
|
|
|
|
![t = 10](images/t10.png)
|
|
|
|
## T = 30
|
|
|
|
A runs out of patience, flips a coin and broadcasts the stem transaction to its Dandelion relay G.
|
|
G receives the stem transaction, add it to its stempool and starts the embargo timer for this transaction.
|
|
|
|
![t = 30](images/t30.png)
|
|
|
|
## T = 40
|
|
|
|
G sends grins to E.
|
|
G adds the transaction it to its stempool and starts the embargo timer for this transaction.
|
|
|
|
![t = 40](images/t40.png)
|
|
|
|
## T = 45
|
|
|
|
G runs out of patience, flips a coin and broadcasts the stem transaction to its Dandelion relay D.
|
|
|
|
![t = 45](images/t45.png)
|
|
|
|
## T = 50
|
|
|
|
B spends B1 to D.
|
|
B add it to its stempool and starts the embargo timer for this transaction.
|
|
|
|
![t = 55](images/t55.png)
|
|
|
|
## T = 55
|
|
|
|
B runs out of patience, flips a coin and broadcasts the stem transaction to its Dandelion relay H.
|
|
D runs out of patience, flips a coin and broadcasts the aggregated stem transaction to its Dandelion relay E.
|
|
E receives the stem transaction, add it to its stempool and starts the embargo timer for this transaction.
|
|
|
|
![t = 55](images/t55.png)
|
|
|
|
## T = 60
|
|
|
|
H runs out of patience, flips a coin broadcasts the stem transaction to its Dandelion relay E.
|
|
E receives the stem transaction, add it to its stempool and starts the embargo timer for this transaction.
|
|
|
|
![t = 60](images/t60.png)
|
|
|
|
## T = 70 - Step 1
|
|
|
|
E runs out of patience, flips a coin and decide to broadcast the transaction to all its peers (fluff in the mempool).
|
|
|
|
![t = 70_1](images/t70_1.png)
|
|
|
|
## T = 70 - Step 2
|
|
|
|
All the nodes add this transaction to their mempool and remove the related transactions from their stempool.
|
|
|
|
![t = 70_2](images/t70_2.png) |