第八个知识点:交互式的定义如何帮助计算和IP类问题是什么
第八个知识点:交互式的定义如何帮助计算和IP类问题是什么
这是系列中的第8篇,我们主要讨论计算中交互作用的用处和IP类问题是什么.
为了回答这些问题,我们首先给交互式证明系统一个简洁的介绍.众所周知,零知识证明在密码协议中十分重要.零知识的概念在这篇介绍中有 [1].这种证明的迷人之处就在于断言的可验证性被证明了.为了解释这个东西,Goldwasser, Micali和Rackoff在经典证明系统上增加两种结构变成了交互式证明系统.第一个结构是随机化(randomisation),也就是说证明的结果可能是错的,但是这种错误只能以很小的概率出现.第二个结构就是像它名字那样,就是交互性(interaction),静态证明系统被动态的证明代替,动态证明将于验证程序交互并给出断言是否为真.结合这两种结构的经典证明系统就是一个巨大的复杂类问题---IP.
什么是证明
不严谨的说,一个证明就是一个人能让另一个人相信的方法.这两个人在证明系统中叫prover和verifier.
经典的证明
一个经典的数学证明系统就是固定的一些陈述语句的排列.这些排列被prover写下来,然后verifier一步一步的判断这些陈述语句的正确性.这个过程是没有交互的.
任何证明系统应该有下面的属性:
- 有效性 证明应该是有效率的.
- 稳定性 对于错误的命题,很难有不合法的证明
- 完整性 对任何正确的命题都应该有一个证明
回顾NP复杂类问题被看作是一类语言.它的成员都具有可以轻松检查的证书(注:这里建议读读NP的另一种定义,清晰的解释了这个证书是啥.).因此NP恰好就是一类经典证明的语言.
交互式证明系统
在一个交互式证明系统里,prover和verifier被允许交互式的交换信息.在引入交互证明的概念之前,我们来给出一个例子来解释交互式证明系统是怎么工作的.
例子:图的同构和图的非同构
两个图G和H被叫做同构的,如果G的节点可以重新排列使得它可以和H节点相同.我们定义下面这类语言:
\(ISO = \{ <G,H>| G\space and\space H\space are \space isomorphic\space graphs \}\)
ISO是NP类的语言.尽管节点的数量可能非常大,但是我们能非常容易的验证这个问题.
然后我们考虑ISO问题的补,即Non-isomorphism问题,就是定义语言:
\(NOISO = \{ <G,H>| G\space and\space H\space are\space not \space isomorphic\space graphs \}\)
问题是,使用经典的证明我们如何给verifier证明G和H不是同构的.我们不知道如何提供一个短的证明,多项式时间无法对每个情况进行检查.因为我们不知道如何证明NOISO在NP中.然而在考虑到交互式证明,prover可以说服verifier,这两个图是不同构的(多项式时间内).
prover和verifier都有一对图\((G_1,G_2)\)作为初始输入.verifier随机的选择一个随机比特(bit)\(b \in \{ 0,1\}\)和一个排列\(\pi\).然后将\(\pi\)应用到\(G_b\)得到一个图\(H\).(这里意思就是说\(H\)和\(G_b\)同构)verifier发送\(H\)给prover.然后prover在收到\(H\)之后,prover发送一比特\(b^{'} \in \{0,1\}\)给verifier.最后verifier接受当且仅当\(b^{'}=b\).
在协议背后的观点就是,如果被给的\((G_1,G_2)\)不是同构的,那么prover应该能够确定\(H\)是来自于\(G_1\)或者\(G_2\)的.然而,如果输入的两个图是同构的,那么尽管有着无限的计算能力,prover最好的选择就是随机的猜\(b^{'}\).这种情况下,prover至少1/2的接受.
从上面的例子中,我们总结NOISO不能被verifier用一个古典的证明系统证明.但是它可以被一个交互的证明系统证明.我们能看到交互的力量.
现在我们给出交互式证明系统的定义和IP复杂类的定义.
交互式证明系统:一对交互机\((P,V)\)被叫做\(L\)语言的交互式证明系统,如果V是多项式时间的,(P的计算能力是无限的),和现在的条件满足:
- 完整性:对所有的\(x \in L\),\(Pr[<P,V> (x)=1] \ge 2/3\)
- 稳定性:对所有的\(x \in L\),\(Pr[<P,V>(x)=1] \le 1/3\)
IP类复杂问题:IP类问题包含所有交互式证明系统能证明的语言.
通过定义,在BPP语言中的所有语言都在IP中.如果我们限制交换的信息的数量为1,那么这就是IP中的NP类问题.实际上,IP是一个很大的类.在1992年,Shamir证明了\(PSPACE = IP\)[3].
额外的,注意到协议prover应该抛出私有的硬币,如果prover被允许访问verifier的随机字符串,就会导致使用共有硬币的交互式证明,这种模型和AM复杂类[4]很像.
[1] http://dl.acm.org/citation.cfm?id=63434
[2] http://www.amazon.co.uk/Introduction-Theory-Computation-Michael-Sipser/dp/0619217642
[3] http://dl.acm.org/citation.cfm?doid=146585.146609
[4] http://en.wikipedia.org/wiki/Arthur–Merlin_protocol
第八个知识点:交互式的定义如何帮助计算和IP类问题是什么的更多相关文章
- 第二十八个知识点:什么是公钥密码学的IND-CCA安全定义?
第二十八个知识点:什么是公钥密码学的IND-CCA安全定义? 我们将在这篇博客中讨论公钥加密的IND-CCA安全. IND-CCA安全代表选择明文的不可伪造性.这样的安全方案的思想就是给定一个密文,攻 ...
- 第四十八个知识点:TPM的目的和使用方法
第四十八个知识点:TPM的目的和使用方法 在检查TPM目的之前,值得去尝试理解TPM设计出来的目的是为了克服什么样的问题.真正的问题是信任.信任什么?首先内存和软件运行在电脑上.这些东西能直接的通过操 ...
- 第十八个知识点:画一个描述ECB,CBC,CTR模式的操作
第十八个知识点:画一个描述ECB,CBC,CTR模式的操作 第8周是画三个图的任务,但是维基百科上已经有人画的很好了 https://en.wikipedia.org/wiki/File:ECB_en ...
- 重学 Java 设计模式:实战代理模式「模拟mybatis-spring中定义DAO接口,使用代理类方式操作数据库原理实现场景」
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 难以跨越的瓶颈期,把你拿捏滴死死的! 编程开发学习过程中遇到的瓶颈期,往往是由于看不 ...
- 基类中定义的虚函数在派生类中重新定义时,其函数原型,包括返回类型、函数名、参数个数、参数类型及参数的先后顺序,都必须与基类中的原型完全相同 but------> 可以返回派生类对象的引用或指针
您查询的关键词是:c++primer习题15.25 以下是该网页在北京时间 2016年07月15日 02:57:08 的快照: 如果打开速度慢,可以尝试快速版:如果想更新或删除快照,可以投诉快照. ...
- day319 1、正则表达式的定义及使用 2、Date类的用法 3、Calendar类的用法
1.正则表达式的定义及使用2.Date类的用法3.Calendar类的用法 一.正则表达式 ###01正则表达式的概念和作用* A: 正则表达式的概念和作用* a: 正则表达式的概述* 正则表达式也是 ...
- 【Java】定义魔法数字,以及枚举类的构造方法的使用
JavaWeb项目中需要定义各种常量时,常用方法有: 写到Property配置文件中,用静态代码块优先加载配置文件.参考http://www.cnblogs.com/guxin/p/java-prop ...
- 定义一个复数(z=x+iy)类Complex,包含: 两个属性:实部x和虚部y 默认构造函数 Complex(),设置x=0,y=0 构造函数:Complex(int i,int j) 显示复数的方法:showComp()将其显示为如: 5+8i或5-8i 的形式。 求两个复数的和的方法:(参数是两个复数类对象,返回值是复数类对象)public Complex addComp(Compl
因标题框有限,题目未显示完整,以下再放一份: 定义一个复数(z=x+iy)类Complex,包含: 两个属性:实部x和虚部y 默认构造函数 Complex(),设置x=0,y=0 构造函数:Compl ...
- Python全栈day24(面向对象编程作业作业_定义学校老师课程班级学生类)
面向对象作业 作业_定义学校老师课程班级学生类.py #面向对象编程作业,定义学校老师课程班级学生类 #定义几个类,尽可能定义多的数据属性及函数属性 class School: def __init_ ...
随机推荐
- C语言之内核中的struct list_head 结构体
以下地址文章解释很好 http://blog.chinaunix.net/uid-27122224-id-3277511.html 对下面的结构体分析 1 struct person 2 { 3 in ...
- 巩固javaweb的第二十七天
巩固内容 正则表达式: 5. 指定字符串的开始和结尾 正则表达式中字符串的开始和结束符如表 2.6 所示. 表 2.6 开 始 和 结 尾 字符 作 用 ^ 指定以某个字符串开始 $ 指定以某个字符串 ...
- volatile原理和应用场景
volatile是java语言中的一个关键字,常用于并发编程,有两个重要的特点:具有可见性,java虚拟机实现会为其满足Happens before原则;不具备原子性.用法是修饰变量,如:volati ...
- 位运算符在JS中的妙用
正文 位运算 JavaScript 中最臭名昭著的 Bug 就是 0.1 + 0.2 !== 0.3,因为精度的问题,导致所有的浮点运算都是不安全的,具体原因可详见<0.1 + 0.2不等于0. ...
- 【排序算法】——冒泡排序、选择排序、插入排序、Shell排序等排序原理及Java实现
排序 1.定义: 所谓排序,即是整理文件中的内容,使其按照关键字递增或递减的顺序进行排列. 输入:n个记录,n1,n2--,其对应1的关键字为k1,k2-- 输出:n(i1),n(i2)--,使得k( ...
- 超过三张表禁止join
一. 问题提出 <阿里巴巴JAVA开发手册>里面写超过三张表禁止join,这是为什么? 二.问题分析 对这个结论,你是否有怀疑呢?也不知道是哪位先哲说的不要人云亦云,今天我设计sql,来验 ...
- Oracle 表结构管理
表其实是数据的'容器'.oracle有几种类型的表: 普通表(ordinary table)又叫堆组织表. 聚簇表(clustered table) 分区表(partition table) 外部表( ...
- 【Linux】【Services】【DNS】使用Bind搭建DNS服务
1. 简介 1.1. 实现的功能:DNS解析以及智能转发 1.2. 官方文档: 1.3. 基础概念:http://www.cnblogs.com/demonzk/p/6494968.html 2. 环 ...
- c3p0的使用步骤
//1.导入c3p0的连个包,和mysql的驱动包//2.配置c3p0.xml的配置文件 <c3p0-config> <!-- 使用默认的配置读取连接池对象 --> <d ...
- 35、搜索插入位置 | 算法(leetode,附思维导图 + 全部解法)300题
零 标题:算法(leetode,附思维导图 + 全部解法)300题之(35)搜索插入位置 一 题目描述 二 解法总览(思维导图) 三 全部解法 1 方案1 1)代码: // 方案1 "无视要 ...