# memory\_stark

draft

| PADDING | ADDR | CLK | OP | VALUE | DIFF_ADDR | DIFF_ADDR<br>_INV       | DIFF_CLK |
|---------|------|-----|----|-------|-----------|-------------------------|----------|
| 0       | 100  | 0   | SB | 5     | 0         | 0                       | 0        |
| 0       | 100  | 1   | LB | 5     | 0         | 0                       | 1        |
| 0       | 100  | 4   | SB | 10    | 0         | 0                       | 3        |
| 0       | 100  | 5   | LB | 10    | 0         | 0                       | 1        |
| 0       | 200  | 2   | SB | 15    | 100       | 350488137318<br>8771021 | 0        |
| 0       | 200  | 3   | LB | 15    | 0         | 0                       | 1        |
| 1       | 200  | 3   | LB | 15    | 0         | 0                       | 0        |
| 1       | 200  | 3   | LB | 15    | 0         | 0                       | 0        |

## Constraints

#### VM

Sorted by addresses and then the clock

| ADDR | CLK |  |  |
|------|-----|--|--|
| 100  | 0   |  |  |
| 100  | 1   |  |  |
| 100  | 4   |  |  |
| 100  | 5   |  |  |
| 200  | 2   |  |  |
| 200  | 3   |  |  |

#### **STARK**



new\_addr = diff\_addr\*diff\_addr\_inv

- a) if new\_addr: op === sb
- b) if new\_addr == 0: diff\_clk\_next <== clk\_next clk\_cur
- c) if new\_addr == 1: diff\_clk === 0
- d) diff addr next <== addr next addr cur
- e) if op\_next == lb: value\_next === value\_cur
- f) (new\_addr 1)\*diff\_addr===0 (new\_addr - 1)\*diff\_addr\_inv===0 todo) range check: diff\_addr is a u32 diff\_clk < run time?

### Some notes

LB inst:

Addr\_next === addr\_cur

Value\_next === value\_cur

When address changed:

OP must be SB

Calculate diff\_addr

In the previous design, there is no way to make the following constraint:

if New\_addr==1, then Diff\_addr>0

New\_addr Diff\_addr

) (

1 100

We can make the constraints using the current design:

(diff\_addr\*diff\_addr\_inv - 1)\*diff\_addr===0 (diff\_addr\*diff\_addr\_inv - 1)\*diff\_addr\_inv===0