# Simulation analysis

2025-07-19

### **Experiments**

- Variants
  - Linear Leios, linear
  - Linear Leios with tx references, linear-with-tx-references
  - o Stracciatella, full-without-ibs
- 100 tx/s for first 900 seconds
- Simulation ends at 1200th second
- 1400 B/tx

https://github.com/input-output-hk/ouroboros-leios/tree/bwbush/ll3/analysis/sims/2025w29b

sim-cli @ 631d24a3

## 100 tx/s with 1400 B/tx

| Transaction size [B/tx] | Time to full EB [s] | Demand [Mb/s] | Demand [MB/s] | Demand [tx/s] | Max EB size | Stage length | Variant                   |
|-------------------------|---------------------|---------------|---------------|---------------|-------------|--------------|---------------------------|
| <dbl></dbl>             | <dbl></dbl>         | <dbl></dbl>   | <dbl></dbl>   | <dbl></dbl>   | <fct></fct> | <fct></fct>  | <fct></fct>               |
| 1400                    | 35.83653            | 1.11618       | 0.1395224     | 99.65889      | 5.0 MB/EB   | 5 slot/stage | full-without-ibs          |
| 1400                    | 71.67306            | 1.11618       | 0.1395224     | 99.65889      | 10.0 MB/EB  | 5 slot/stage | full-without-ibs          |
| 1400                    | 143.34611           | 1.11618       | 0.1395224     | 99.65889      | 20.0 MB/EB  | 5 slot/stage | full-without-ibs          |
| 1400                    | 35.83653            | 1.11618       | 0.1395224     | 99.65889      | 5.0 MB/EB   | 8 slot/stage | full-without-ibs          |
| 1400                    | 71.67306            | 1.11618       | 0.1395224     | 99.65889      | 10.0 MB/EB  | 8 slot/stage | full-without-ibs          |
| 1400                    | 143.34611           | 1.11618       | 0.1395224     | 99.65889      | 20.0 MB/EB  | 8 slot/stage | full-without-ibs          |
| 1400                    | 35.83653            | 1.11618       | 0.1395224     | 99.65889      | 5.0 MB/EB   | 5 slot/stage | linear                    |
| 1400                    | 71.67306            | 1.11618       | 0.1395224     | 99.65889      | 10.0 MB/EB  | 5 slot/stage | linear                    |
| 1400                    | 143.34611           | 1.11618       | 0.1395224     | 99.65889      | 20.0 MB/EB  | 5 slot/stage | linear                    |
| 1400                    | 35.83653            | 1.11618       | 0.1395224     | 99.65889      | 5.0 MB/EB   | 8 slot/stage | linear                    |
| 1400                    | 71.67306            | 1.11618       | 0.1395224     | 99.65889      | 10.0 MB/EB  | 8 slot/stage | linear                    |
| 1400                    | 143.34611           | 1.11618       | 0.1395224     | 99.65889      | 20.0 MB/EB  | 8 slot/stage | linear                    |
| 1400                    | 35.83653            | 1.11618       | 0.1395224     | 99.65889      | 5.0 MB/EB   | 5 slot/stage | linear-with-tx-references |
| 1400                    | 71.67306            | 1.11618       | 0.1395224     | 99.65889      | 10.0 MB/EB  | 5 slot/stage | linear-with-tx-references |
| 1400                    | 143.34611           | 1.11618       | 0.1395224     | 99.65889      | 20.0 MB/EB  | 5 slot/stage | linear-with-tx-references |
| 1400                    | 35.83653            | 1.11618       | 0.1395224     | 99.65889      | 5.0 MB/EB   | 8 slot/stage | linear-with-tx-references |
| 1400                    | 71.67306            | 1.11618       | 0.1395224     | 99.65889      | 10.0 MB/EB  | 8 slot/stage | linear-with-tx-references |
| 1400                    | 143.34611           | 1.11618       | 0.1395224     | 99.65889      | 20.0 MB/EB  | 8 slot/stage | linear-with-tx-references |

# Efficiency

| Time to reach ledger [s] | Time to reach EB [s] <dbl></dbl> | Space efficiency [%] <dbl></dbl> | Max EB size<br><fct></fct> | Stage length <fct></fct> | Variant<br><fct></fct>    |
|--------------------------|----------------------------------|----------------------------------|----------------------------|--------------------------|---------------------------|
| <dbl></dbl>              |                                  |                                  |                            |                          |                           |
| 56.87735                 | 5.948086                         | 88.019663                        | 5.0 MB/EB                  | 5 slot/stage             | full-without-ibs          |
| 57.00624                 | 5.901681                         | 87.145579                        | 10.0 MB/EB                 | 5 slot/stage             | full-without-ibs          |
| 56.98086                 | 5.901895                         | 87.140163                        | 20.0 MB/EB                 | 5 slot/stage             | full-without-ibs          |
| 69.21801                 | 8.259793                         | 92.630722                        | 5.0 MB/EB                  | 8 slot/stage             | full-without-ibs          |
| 68.99397                 | 8.161247                         | 92.639798                        | 10.0 MB/EB                 | 8 slot/stage             | full-without-ibs          |
| 69.11355                 | 8.156960                         | 92.689345                        | 20.0 MB/EB                 | 8 slot/stage             | full-without-ibs          |
| 76.27580                 | 43.759517                        | 47.263229                        | 5.0 MB/EB                  | 5 slot/stage             | linear                    |
| 47.19447                 | 133.379196                       | 5.412314                         | 10.0 MB/EB                 | 5 slot/stage             | linear                    |
| 47.18600                 | 110.316553                       | 2.808371                         | 20.0 MB/EB                 | 5 slot/stage             | linear                    |
| 159.23294                | 112.196650                       | 42.014002                        | 5.0 MB/EB                  | 8 slot/stage             | linear                    |
| 63.71906                 | 19.189494                        | 49.915335                        | 10.0 MB/EB                 | 8 slot/stage             | linear                    |
| 62.31809                 | 17.715550                        | 51.593285                        | 20.0 MB/EB                 | 8 slot/stage             | linear                    |
| 89.45720                 | 50.349183                        | 93.970815                        | 5.0 MB/EB                  | 5 slot/stage             | linear-with-tx-references |
| 61.40164                 | 21.697992                        | 93.988888                        | 10.0 MB/EB                 | 5 slot/stage             | linear-with-tx-references |
| 62.86204                 | 21.509128                        | 93.488622                        | 20.0 MB/EB                 | 5 slot/stage             | linear-with-tx-references |
| 149.21241                | 107.221641                       | 93.111219                        | 5.0 MB/EB                  | 8 slot/stage             | linear-with-tx-references |
| 64.90414                 | 22.127230                        | 93.358883                        | 10.0 MB/EB                 | 8 slot/stage             | linear-with-tx-references |
| 63.61299                 | 20.527595                        | 93.459876                        | 20.0 MB/EB                 | 8 slot/stage             | linear-with-tx-references |

# Spatial efficiency

Spatial efficiency (size of txs on ledger / size of non-tx persisted data) Rust simulator, mini-mainnet, 100 tx/s, 1400 B/tx



### Data volume





### EB diffusion

Arrival delay for EB



### Vote diffusion

Arrival delay for VT



### **RB** diffusion

Arrival delay for RB



### TX diffusion

Arrival delay for TX



# Network (mean)

#### Mean nodal ingress



## Network (1-second peak)

#### Peak nodal ingress Rust simulator, mini-mainnet, 100 tx/s, 1400 B/tx



# CPU (mean)

Mean CPU load among all nodes Rust simulator, mini-mainnet, 100 tx/s, 1400 B/tx



# CPU (1-second peak)

#### Peak CPU load among all nodes



# Mempool to EB

Time for transaction to reach an EB



# Mempool to RB (certified)

#### Time for transaction to reach the ledger Rust simulator, mini-mainnet, 100 tx/s, 1400 B/tx



### Transactions reaching ledger in under 300 slots



### EB size distribution

Size of transactions in EBs



### RB size distribution

Size of transactions in RBs Rust simulator, mini-mainnet, 100 tx/s, 1400 B/tx



## Disposition of blocks

Disposition of transactions in blocks Rust simulator, mini-mainnet, 100 tx/s, 1400 B/tx



## **Findings**

- 1. 5 slot/stage is too short for Linear Leios at 100 tx/s.
- Including transactions in EBs (instead of references) results in congestion and delays at 100 tx/s.
- 3. 10 MB/EB is sufficient for 100 tx/s but 5 MB/EB is not.
- 4. EB-sortition unluckiness in Stracciatella can lengthen the transaction lifecycle, but this could be remedied by increasing the EB production rate.
- 5. CPU and network usage peak high when transactions are included in EBs.
- 6. *Caveat:* this conclusion may change when better transaction validation times are used in the simulator configuration.