用于计算短离散对数和分解RS大整数的量子算法

简介:

阅读Martin Eker˚a Johan H˚astad在17年二月份发表的Quantum algorithms for computing short discrete logarithms and factoring RSA integers的文章,本人有所收获,在此写个小文。

文章基于量子计算机上主要描述了计算短离散对数的量子算法和分解RSA大整数量子算法。

首先,我们对比一下传统计算机和量子计算机。量子计算机是指利用量子相干叠加的原理,理论上具有超快的并行计算机。能实现当下的许多优化。相对比传统计算机一位只能表示一种状态0/1,量子计算机的优势是,当它有N个量子比特时,由于状态的相互叠加,它可以最多同时处于2^N个状态。并且,量子计算机是可逆计算机,经典计算机是不可逆的,会有热损耗,理论上量子计算机耗能可以降到极低。这为量子算法的实现提供了基础。

量子算法在算法需要的次数、算法复杂度和量子计算机的需要之间进行权衡取舍。用量子算法进行RSA大整数分解比Shor算法简单,要求也少。例如:分解数n位,Shor算法指数需要2n位,量子算法需(1/2+1/s)n位。量子算法和Shor算法主要的技术都在于计算模幂的叠加运算。模幂的叠加运算也是主要障碍。

下面主要概括文章中的量子计算、计算短离散对数、分解大整数

(一)量子计算

1)首先,先了解量子系统。每个状态位用|j>表示(0 j< 2n),状态的叠加即为量子系统。系统表达式函数如下:


(其中复振幅

aj R是一个非负实波,相位


)故而,系统表达函数亦可表示为:


2)通过建设性干预手段,离散量子傅里叶变换算法(QFT)放大一系列所需要的状态的幅度,所需状态的的折叠概率会增大。如果量子比特形成了最大程度的纠缠,他们的波函数坍缩结果就完全相关。

QFT将每个状态映射到n个量子位寄存器中


所以,QFT映射下的量子系统函数为

系统叠加到k的概率为


在和的运算中术语用向量C表示。如果向量C几乎指向相同一个方向,那么它们的规范总和有很大可能概率。那么我们就说,对于k,建立了建设性干预。

主张一:


(二)计算短离散对数

计算离散对数可用于攻击一些非对称加密算法,例如DH加密,选择和比较非对称密码参数。计算短离散对数的生成算法包括两个阶段:初始化量子阶段和经典后处理阶段。

初始化量子阶段:输入生成元g和x = [d] g得到一对(j,k)。


经典后处理阶段:用一个经典的算法来描述,基于lattice-based技术,经典算法输入一系列s对(j,k),计算输出d。

具体算法如下:

令:

int d(0<d<2^m);

固定int s>=1;

int l close to m/s;

g为阶数r>=2^(l+m)+2^ld的一个有限循环群的生成元;

g叠加到长度为l + m位的指数上的指数运算

input g,x = [d] g;

output (j,k);

when s>=1

calculate (j,k);

return d。

(解决离散对数问题d = log g x)

Tips1

良好对的定义:

当j为整数(0<=j<2^(l+m)),如果


(j决定k,dj mod 2^(l+m),最高阶为l)

至少有2^(l+m-1)个不同的j,才会有一个k,使得(j,k)为良好对。

Tips2

为了降低产生一个良好对的概率,我们首先需要对(a,b)数量的下界产生具体确定的e

定义:Te表示对(a,b)的数量,e=a-bd

(其中,a,b均为整数并且0<=a<2^(l+m),0<=b<2^l)

文章主张二:


文章主张三:


文章主张四:


从算法的单个执行中,获得特别良好对(j,k)的概率至少为2^(-m-l-2)

算法单次运行结果产生一副良好对的概率至少为2^(-3)

Tips3

基于lattice-based技术,经典算法输入一系列s对(j,k),计算输出d

Lattice格子定义:(L由下列行跨度产生的整数)


从对(j,k)中恢复d

具体算法如下:

for all


使得



if最后一个分组u==d,return d;

else fail;

(三)分解大整数

分解RSA大整数作为一个短离散对数问题,因为算法可忽略群组的顺序,所以产生了比Shor算法需求小的因数分解法用于RSA中的大整数分解。

首先,我们通过将分解因式的问题作为解短离散对数问题对待,来获得两个因子。一个方法就是N近似φ(N),这使得我们解决短的离散对数问题时不需要事先知道顺序。其次,我们通过执行量子算法产生一系列的部分结果来获得两个因素。我们可以基于lattice-based技术在经典后期处理中恢复离散对数d。它从产生的一系列部分结果中构造格L和向量v,通过L趋近于V恢复d。

具体算法如下:

任意素数p,q(p>2^(n-1),q<2^n);

N=p*q;

φ(N)=(p-1)(q-1);

t>=gcd(p-1,q-1);

φ(N)/t>(p+q-2)/2;

G的生成元为g(1<g<N-1)

根据g和x计算短离散对数d=(p+q-2)/2;

when(0<d<2^m)

m=n+1;

阶数φ(N)/t>=2^(l+m+1));

if s>=1,l=m/s=(n+1)/s;

t<2^(n-l-4)概率很高;

φ(N)=(p-1)(q-1)>=2^(2(n-1))'

N=(2d-q+2)q (其中2d+2=p+q)

if c=d+1,


return p,q;


总结:

量子算法和Shor算法主要的技术以及主要障碍都在于计算模幂的叠加运算。但是我认为最主要的障碍是量子计算机技术未成熟。量子算法基于量子计算机上,倘若我们拥有实用的量子计算机,在此条件下会有更多优秀的算法。

目前,量子算法正在等待量子计算机的问世,量子计算机现仍然处于研究阶段,基于其中的量子算法也需要等待。就好比阿基米德曾经说过,“给我一个支点,我能撬动整个地球”,理论上是可行的。但是实际上造这样的杆又是困难的。量子算法的实践仍然有很大的探索空间。

值得庆幸的是,造出玻色彩样装置为制造通用的量子计算机扫清了重要的技术障碍。不过,因为量子比特越多,制造难度就越大。现在科学家在超导量子计算中,只能完全操控9个量子比特。在超导量子处理器中,中国科学家做到了让10个量子比特形成最大程度的纠缠态,使得它们的波函数坍缩结果完全相关。虽然离我们日常使用的2048比特相差甚远,但是这一天会到来的。量子计算机让我们看到了超越经典计算机巨大的潜力,它的能力范围到底有多广还在探索中。

量子算法的高效会使得一些加密算法变得不堪一击,但是各类学界都是矛和盾相互推进的,没有绝对安全的密码,也没有对任何密码都绝对高效的破解方法。用量子的方法来对付传统的方法,比较有优势,但是新的攻击总会出现,有量子的攻击,也会有量子的防守。

在未来,要想有实用的量子计算机,用上量子算法,我们还有很多路要走,期待那一天的到来。



原文发布时间为:2018.01.02
本文作者:杨立宇20152100058
本文来源:简书,如需转载请联系原作者。

目录
相关文章
|
3月前
|
存储 分布式计算 算法
大数据-106 Spark Graph X 计算学习 案例:1图的基本计算、2连通图算法、3寻找相同的用户
大数据-106 Spark Graph X 计算学习 案例:1图的基本计算、2连通图算法、3寻找相同的用户
81 0
|
2月前
|
算法 Python
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果
在Python编程中,分治法、贪心算法和动态规划是三种重要的算法。分治法通过将大问题分解为小问题,递归解决后合并结果;贪心算法在每一步选择局部最优解,追求全局最优;动态规划通过保存子问题的解,避免重复计算,确保全局最优。这三种算法各具特色,适用于不同类型的问题,合理选择能显著提升编程效率。
67 2
|
3月前
|
机器学习/深度学习 算法 搜索推荐
django调用矩阵分解推荐算法模型做推荐系统
django调用矩阵分解推荐算法模型做推荐系统
50 4
|
3月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
88 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
3月前
|
算法 Oracle 关系型数据库
本源量子云平台实现Grover算法
本源量子云平台实现Grover算法
47 0
|
4月前
|
算法 数据可视化 数据安全/隐私保护
基于LK光流提取算法的图像序列晃动程度计算matlab仿真
该算法基于Lucas-Kanade光流方法,用于计算图像序列的晃动程度。通过计算相邻帧间的光流场并定义晃动程度指标(如RMS),可量化图像晃动。此版本适用于Matlab 2022a,提供详细中文注释与操作视频。完整代码无水印。
|
4月前
|
算法 C++
如何精确计算出一个算法的CPU运行时间?
如何精确计算出一个算法的CPU运行时间?
|
5月前
|
算法 Go Python
[算法]计算斐波拉契数列
[算法]计算斐波拉契数列
|
6月前
|
并行计算 算法 Python
Dantzig-Wolfe分解算法解释与Python代码示例
Dantzig-Wolfe分解算法解释与Python代码示例
|
5月前
|
算法
计算空间物体包围球的两种算法实现
计算空间物体包围球的两种算法实现
63 0

热门文章

最新文章

下一篇
开通oss服务