ZKP15.2 Formal Methods in ZK (Part I)

ZKP学习笔记

ZK-Learning MOOC课程笔记

Lecture 15: Secure ZK Circuits via Formal Methods (Guest Lecturer: Yu Feng (UCSB & Veridise))

15.2 Formal Methods in ZK (Part I)

  • Circuits Workflow
    在这里插入图片描述

    • Source Code: Witness Generation and Constraints
    • Witness Generation and Constraints should (generally) be equivalent!
  • What is Equivalence
    在这里插入图片描述

    • Every input-output of P must satisfy C
    • Every (x,y) which satisfies C must be an input-out pair of P
  • Equivalence Violations
    在这里插入图片描述

    • Underconstrained Bugs: Verifier can accept bad inputs/ outputs
  • A Taxonomy of ZK Bugs
    在这里插入图片描述

  • Unconstrained Signals

    • Corresponds to signals whose constraints always evaluate to true, accepting everything

    • Example: Underconstrained Output
      在这里插入图片描述

      • Error: for (var i = 0; i< n, i++)
      • No constrains over the last element of output
      • Attacker can pass in any value for out 2
  • Unsafe Component Usage

    • Sub-circuits often assume constraints are placed on inputs and outputs

    • Corresponds to cases where the use of a sub-circuit does not follow

    • Example: Under-Constrained Sub-Circuit Output
      在这里插入图片描述

      • Missing constraint lt.out === 0
      • Without the missing constraint, attackers can withdraw more funds than they have
  • Constraint/Computation Discrepancy

    • Not all computation can be directly expressed as a constraint

    • Corresponds to constraints that do not capture a computation’s semantics

    • Example: No Zero Inverse
      在这里插入图片描述

      • Accepts arbitrary out when a and b are 0!
  • Circuit Dependence Graphs (CDG)

    • Goal: Identify discrepancies between computation and constraints

    • Data dependence <–

    • Constrain ===
      在这里插入图片描述

    • CDG Example
      在这里插入图片描述

在这里插入图片描述

  • Vanguard Framework
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值