Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/NethermindEth/cairo-vm-go
A virtual machine for Cairo written in Go
https://github.com/NethermindEth/cairo-vm-go
Last synced: 3 months ago
JSON representation
A virtual machine for Cairo written in Go
- Host: GitHub
- URL: https://github.com/NethermindEth/cairo-vm-go
- Owner: NethermindEth
- Created: 2023-07-25T16:10:08.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-12T16:37:03.000Z (9 months ago)
- Last Synced: 2024-04-13T21:52:14.921Z (9 months ago)
- Language: Go
- Homepage:
- Size: 4.16 MB
- Stars: 59
- Watchers: 2
- Forks: 17
- Open Issues: 73
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-cairo - `cairo-vm-go` - A virtual machine for Cairo written in Go. (Cairo VM)
- awesome-starknet - cairo-vm-go - Golang implementation of the Cairo VM. (Additional developer resources)
README
# Cairo VM in Go
> ⚠️ This project is undergoing heavy development and is still on its early stages. There will be constant breaking changes.
This project aims to implement a Cairo Virtual Machine using Go. This is one of [many other](#related-projects) implementations that are being developed and its main goals are:
* making the Starknet ecosystem secure by reducing the risk of a single critical vulnerability,
* decentralizing development and maintenance of the different VMs,
* cross-checking and validation with other implementations and
* to foster innovation through competition.## Intro
The Cairo Virtual Machine is a crucial component of the Starknet ecosystem. It serves as the runtime environment for all smart contracts on the platform.
When users write contracts in high-level Cairo, it gets compiled to Sierra, and then to CASM bytecode. The VM receives this bytecode, executes it and generates a proof of execution. This proof is then sent from a sequencer to the verifier to include the transaction in a new block.## Install
This Virtual Machine is still in development and there is no public release available yet.
Currently, it is only possible to use it by building it from source by following these instructions:1. Clone the repo to your machine: `git clone https://github.com/NethermindEth/cairo-vm-go`.
2. Install `Go` on your PC, instructions [here](https://go.dev/dl/).
3. Execute on the root folder of the repo: `make build`.
4. Make sure everything is running smoothly by executing: `make unit`.After completing these steps, you can find the compiled VM in `bin/cairo-vm`.
### Run The VM
To run the VM you need to have a compiled Cairo file using the Cairo Zero compiler at [cairo-lang](https://github.com/starkware-libs/cairo-lang).
First, make sure you have [Python 3.9.11](https://www.python.org/downloads/release/python-3911/) installed in your machine. Since this version is quite old and can cause problem with your system's Python we suggest the use of [pyenv](https://github.com/pyenv/pyenv) to manage different Python versions.
Then, install the latest version of the cairo-lang package with the following command:
```bash
pip install cairo-lang==0.13.1
```When the installation is completed, you can run the `cairo-compile` command:
```bash
cairo-compile ./integration_tests/cairo_zero_file_tests/factorial.cairo --proof_mode --output ./factorial_compiled.json
```This will compile `factorial.cairo` and store the compilation result in `factorial_compiled.json`. The `--proof_mode` flag makes the compilation output contain special identifiers that allow the generation of a proof of execution from the VM later on.
Finally, let's use our VM to execute `factorial_compiled.json` with the next command:
```bash
./bin/cairo-vm run --proofmode --tracefile factorial_trace --memoryfile factorial_memory factorial_compiled.json
```When this command finishes, `factorial.cairo` has run correctly starting from the `main` function. The `--proofmode` flag indicates that a proof of execution should be generated. The location where this proof is stored is determined by both `--tracefile` and `--memoryfile` flags accordingly.
#### Other VM Options
To learn about all the possible options the VM can be run with, execute the `run` command with the `--help` flag:
```bash
./bin/cairo-vm run --help
```### Testing
We currently have defined three sets of tests:
* unit tests where we check the correct work of each component individually.
* integration tests where we compare that the proof of execution of our VM is the same as the proof of execution of the Python VM.
* benchmark tests to have a baseline performance indicator.Unit tests can be automatically run with:
```bash
make unit
```Integration tests are run with:
```bash
make integration
```Integration tests are run with filters in the following two methods, with the first method having higher priority.
```bash
#1) set global environment variable `INTEGRATION_TESTS_FILTERS`
export INTEGRATION_TESTS_FILTERS=fib,alloc
make integration#2) set by editing `INTEGRATION_TESTS_FILTERS=` in the `./integration_tests/.env` file
make integration
```If you want to execute all tests of the project:
```bash
make testall
```To benchmark the project run:
```bash
make bench
```This will run benchmarks for most of the project packages. It will create a _benchmark_ folder and a subfolder named after the current branch git information. Inside this subfolder, each package that was benchmarked will have a _cpu.out_, _mem.out_ and _stdout.text_. The first two files will hold profiling data regarding CPU and memory usage respectively, the last one will hold allocations/operations per second per benchmark test.
To view profiling information with a web UI, run:
```bash
go tool pprof -http=:8080 benchmarks///cpu.out
```You may also be interested in benchmarking a specific package or a specific function, you can use the `PKG_NAME` and `TEST` flags for this.
```bash
make bench PKG_NAME="hintrunner" TEST="AllocSegment"
```### Useful Commands
For convenience, we have created a `makefile` that includes the most used commands such as `make build`. To see all of them please run:
```bash
make help
```## Documentation
We are planning on writing our documentation soon detailing how we adapt the theory of a non-deterministic machine to a deterministic one. Meanwhile, the next is a list of resources we are currently using to develop the VM.
### Cairo
* Cairo Zero Docs: [How Cairo Works](https://docs.cairo-lang.org/0.12.0/how_cairo_works/index.html)
* Whitepaper: [Cairo a Turing-complete STARK-friendly CPU architecture](https://eprint.iacr.org/2021/1063.pdf)
* A formalization of the whitepaper: [A Verified Algebraic Representation of Cairo Program Execution](https://arxiv.org/pdf/2109.14534.pdf)### Other
The previous list includes the most helpful documentation for the current state of the project but it does not represent all that is available. If you are interested in going beyond, there is this [list](https://github.com/lambdaclass/cairo-vm#-documentation) made by [LambdaClass](https://github.com/lambdaclass) which has a much broader scope.
## Related Projects
* [Cairo VM in Python](https://github.com/starkware-libs/cairo-lang) by [Starkware](https://github.com/starkware-libs).
* [VM in Rust](https://github.com/lambdaclass/cairo-vm), [Go](https://github.com/lambdaclass/cairo-vm.go) and [C](https://github.com/lambdaclass/cairo-vm.c) by [LambdaClass](https://github.com/lambdaclass).
* [oriac](https://github.com/xJonathanLEI/oriac/) a toy VM by [xJonathanLEI](https://github.com/xJonathanLEI)## Contributing
If you wish to contribute please visit our [CONTRIBUTING.md](./CONTRIBUTING.md) for general guidelines.