Skip to content

Commit

Permalink
Merge pull request #22 from zkpstandard/minor-fixes
Browse files Browse the repository at this point in the history
optimizations.md: minor fixes
  • Loading branch information
mmaller authored May 22, 2024
2 parents 18daaf9 + 276b9df commit c56d846
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 6 deletions.
19 changes: 15 additions & 4 deletions src/optimizations.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,16 +14,27 @@ TODO: define variables, and make this consistent with changes to [the relation](

Below we will use the convention that variables marked with a prime ($'$) refer to *concrete* column or row indices.

We say that an advice cell with coordinates $(i, j)$ is "used" if it appears in some nontrivial copy constraint or custom constraint, i.e. $\mathsf{used}(i, j)$ is true iff any of the following hold:
We say that an advice cell with coordinates $(i, j)$ "might be used" if it appears in some nontrivial copy constraint or custom constraint, i.e. $\mathsf{used}(i, j)$ is true iff any of the following hold:
$$
\begin{array}{rcl}
\exists (k, \ell) \neq (i, j) &:& (i, j) \equiv_A (k, \ell) \\
\exists k, \ell &:& (i, j, k, \ell) \in S_I \\
\exists k, \ell &:& (i, j, k, \ell) \in S_F \\
\exists u &:& j \in \mathsf{CUS}_u \text{ and the } w[i, \_] \text{ argument to } p_u \text{ is used nontrivially}.
\exists k &:& ((i, j), k) \in S_I \\
\exists (k, \ell) &:& ((i, j), (k, \ell)) \in S_F \\
\exists u &:& j \in \mathsf{CUS}_u \text{ and } w[i, j] \text{ ``might be used'' in } p_u(\mathsf{ROW}_j),
\end{array}
$$

where
$$p_u(\mathsf{ROW}_j) = \sum_{z=0}^{\nu-1} \left( c_z \cdot \prod_{b=0}^{m_F-1} f[b, j]^{\alpha_{z,b}} \cdot \prod_{b'=0}^{m_A-1} w[b', j]^{\alpha_{z,m_F+b'}} \right).$$

<!---
TODO: Move p_u definition into relation.md if we need it for specifying the encoding (which will need to access c_z etc).
-->

$w[i, j]$ "might be used" in $p_u(\mathsf{ROW}_j)$ iff $\exists z \in [0, \nu)$ s.t. $\alpha_{z,m_F+i} > 0$.

----

$w$ represents $m_A$ _abstract_ columns, that do not directly correspond 1:1 to actual columns in the compiled circuit (but may do so if the backend chooses).

Rotations are represented by hints $\mathbf{h} : [0,m_A) \mapsto [0,m_A') \times [0,n)$ where $m_A'$ is the number of concrete columns. To simplify the programming model, the hints are not supposed to affect the meaning of a circuit (i.e. the set of public inputs for which it is satisfiable, and the knowledge required to find a witness).
Expand Down
4 changes: 2 additions & 2 deletions src/relation.md
Original file line number Diff line number Diff line change
Expand Up @@ -77,8 +77,8 @@ Copy constraints that enforce that advice entries must be equal to other inputs.

| Copy Constraints | Description |
| ----------------- | -------- |
| $((i,j),k) \in S_I \Rightarrow w[i, j] = \phi[k]$ | The $k$th instance entry is equal to the $(i,j)$th advice entry for all $((i,j),k) \in S_I$. |
| $((i,j),(k,\ell)) \in S_F \Rightarrow w[i, j] = f[k, \ell]$ | The $(k, \ell)$th fixed entry is equal to the $(i,j)$th advice entry for all $((i,j),(k,\ell)) \in S_F$. |
| $((i,j),k) \in S_I \Rightarrow w[i, j] = \phi[k]$ | The $k$ th instance entry is equal to the $(i,j)$ th advice entry for all $((i,j),k) \in S_I$. |
| $((i,j),(k,\ell)) \in S_F \Rightarrow w[i, j] = f[k, \ell]$ | The $(k, \ell)$ th fixed entry is equal to the $(i,j)$ th advice entry for all $((i,j),(k,\ell)) \in S_F$. |
| $(i,j) \equiv_A (k,\ell) \Rightarrow w[i, j] = w[k, \ell]$ | $\equiv_A$ is an equivalence relation indicating which advice entries are constrained to be equal. |

#### Custom constraints
Expand Down

0 comments on commit c56d846

Please sign in to comment.