das-research/README.md

73 lines
2.7 KiB
Markdown

# DAS Research
This repository hosts research on DAS for the collaboration between Codex and the EF.
The goal of the DAS Simulator is to study the problem of Data Availability Sampling, both as it is
currently proposed and with possible modifications, from the networking perspective. The simulator
is written in Python3 for accessibility, but we can imagine rewriting it at one point for
scalability and efficiency.
Currently we simulate the first part of the process which is to get segments of the 2D Reed Solomon
erasure coded block from the block builder to validators. The simulator tracks diffusion in the
network and validation progress. It is highly configurable, and it allows to explore the parameter
space in one run, generating also summary figures.
### Talks
Results from the simulator were featured in the following talks:
* EthereumZuri.ch 2023 - Csaba Kiraly - Data Availability Sampling from the Networking Perspective,
[see on YouTube](https://www.youtube.com/watch?v=M-xkP4FzYMQ)
* EDCON 2023 - Leonardo Bautista-Gomez - Understanding Design Choices in Data Availability Sampling
[see on YouTube](https://www.youtube.com/watch?v=N1e_LDrKxZg)
* EthPrague 2023 - Leonardo Bautista-Gomez - Understanding Design Choices in Data Availability Sampling
[see on YouTube](https://www.youtube.com/watch?v=Al7Jns8bCO4)
* EthCC 2023 - Csaba Kiraly - Understanding Design Choices in Data Availability Sampling
[see on YouTube](https://www.youtube.com/watch?v=pUAVEbzLHLk)
### Versions
For recent improvements, see the [develop branch](https://github.com/codex-storage/das-research/tree/develop)
## Usage
### Prepare the environment
* Clone the DAS repository (if not done yet) and go into the das-research directory
```
git clone https://github.com/status-im/das-research.git
cd das-research
```
* Create a virtual environment and install the requirements
```
python3 -m venv myenv
source myenv/bin/activate
pip3 install -r DAS/requirements.txt
```
### Run the simulator
The simulation requires a configuration written in Python. To run a small example, use the `smallConf.py` configuration file:
```
python3 study.py smallConf.py
```
Results with plots will be saved in the `results` folder.
See the same example `smallConf.py` file for the description of configuration options. To derive your own simulations, copy the file, customize, and run.
## License
Licensed and distributed under either of
* MIT license: [LICENSE-MIT](LICENSE-MIT) or https://opensource.org/licenses/MIT
or
* Apache License, Version 2.0: [LICENSE-APACHEv2](LICENSE-APACHEv2) or https://www.apache.org/licenses/LICENSE-2.0
at your option. Files in this repository may not be copied, modified, or distributed except according to those terms.