Skip to content

Commit

Permalink
VM optimizations (#674)
Browse files Browse the repository at this point in the history
Added 3 optimizations
  • Loading branch information
Sh0g0-1758 authored Oct 22, 2024
1 parent 76b422d commit 167dadd
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 12 deletions.
4 changes: 3 additions & 1 deletion pkg/runner/air_input.go
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
package runner

import (
"github.com/NethermindEth/cairo-vm-go/pkg/vm"
"github.com/NethermindEth/cairo-vm-go/pkg/vm/builtins"
)

func (runner *ZeroRunner) GetAirPublicInput() (AirPublicInput, error) {
rcMin, rcMax := runner.getPermRangeCheckLimits()

// TODO: refactor to reuse earlier computed relocated trace
relocatedTrace := runner.vm.RelocateTrace()
relocatedTrace := make([]vm.Trace, len(runner.vm.Trace))
runner.vm.RelocateTrace(&relocatedTrace)
firstTrace := relocatedTrace[0]
lastTrace := relocatedTrace[len(relocatedTrace)-1]
memorySegments := make(map[string]AirMemorySegmentEntry)
Expand Down
3 changes: 2 additions & 1 deletion pkg/runner/runner.go
Original file line number Diff line number Diff line change
Expand Up @@ -384,7 +384,8 @@ func (runner *ZeroRunner) BuildMemory() ([]byte, error) {

// BuildTrace relocates the trace and returns it
func (runner *ZeroRunner) BuildTrace() ([]byte, error) {
relocatedTrace := runner.vm.RelocateTrace()
relocatedTrace := make([]vm.Trace, len(runner.vm.Trace))
runner.vm.RelocateTrace(&relocatedTrace)
return vm.EncodeTrace(relocatedTrace), nil
}

Expand Down
20 changes: 10 additions & 10 deletions pkg/vm/vm.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,9 @@ func NewVirtualMachine(
// Initialize the trace if necesary
var trace []Context
if config.ProofMode || config.CollectTrace {
trace = []Context{}
// starknet defines a limit on the maximum number of computational steps that a transaction can contain when processed on the Starknet network.
// https://docs.starknet.io/tools/limits-and-triggers/
trace = make([]Context, 0, 10000000)
}

return &VirtualMachine{
Expand Down Expand Up @@ -156,6 +158,7 @@ func (vm *VirtualMachine) RunStep(hintRunner HintRunner) error {

const RC_OFFSET_BITS = 16

//go:nosplit
func (vm *VirtualMachine) RunInstruction(instruction *asmb.Instruction) error {

var off0 int = int(instruction.OffDest) + (1 << (RC_OFFSET_BITS - 1))
Expand Down Expand Up @@ -533,15 +536,13 @@ func (vm *VirtualMachine) updateFp(instruction *asmb.Instruction, dstAddr *mem.M

// It returns the trace after relocation, i.e, relocates pc, ap and fp for each step
// to be their real address value
func (vm *VirtualMachine) RelocateTrace() []Trace {
func (vm *VirtualMachine) RelocateTrace(relocatedTrace *[]Trace) {
// one is added, because prover expect that the first element to be
// indexed on 1 instead of 0
relocatedTrace := make([]Trace, len(vm.Trace))
totalBytecode := vm.Memory.Segments[ProgramSegment].Len() + 1
for i := range vm.Trace {
relocatedTrace[i] = vm.Trace[i].Relocate(totalBytecode)
(*relocatedTrace)[i] = vm.Trace[i].Relocate(totalBytecode)
}
return relocatedTrace
}

// It returns all segments in memory but relocated as a single segment
Expand All @@ -555,17 +556,16 @@ func (vm *VirtualMachine) RelocateMemory() []*f.Element {
relocatedMemory := make([]*f.Element, maxMemoryUsed)
for i, segment := range vm.Memory.Segments {
for j := uint64(0); j < segment.RealLen(); j++ {
cell := segment.Data[j]
if !cell.Known() {
if !segment.Data[j].Known() {
continue
}

var felt *f.Element
if cell.IsAddress() {
addr, _ := cell.MemoryAddress()
if segment.Data[j].IsAddress() {
addr, _ := segment.Data[j].MemoryAddress()
felt = addr.Relocate(segmentsOffsets)
} else {
felt, _ = cell.FieldElement()
felt, _ = segment.Data[j].FieldElement()
}
relocatedMemory[segmentsOffsets[i]+j] = felt
}
Expand Down

0 comments on commit 167dadd

Please sign in to comment.