今天要给大家介绍的是这本书《Programming Quantum Computers —— Essential Algorithms and Code Samples》,主要讲如何在量子计算机上编程,又示例的代码可以跑 https://oreilly-qc.github.io./ ,这本书的理解方向是纯粹计算机的,连矩阵都很少涉及,一个量子计算机就像是协处理器一样,很像我们现在的GPU。

单量子比特

这本书中对于量子的表达方式如下circle notation:

蓝色圈的面积就是这个量子态测量后是这个状态的概率,中间的蓝色短线代表他们的相位,因为全局相位也观察不出来,所以一般|0〉 |0〉就是朝上的。对于一个量子比特来说,重要的也就这两个,magnitude和relative phase(可能因为重要的是概率大小,所以他其实没有提amplitude其实是一个复数)。

这两个态实际上是等价的。

电路图呢,一般长这样

这个电路图对应的代码如下:(这个例子都可以在上面那个网站上跑起来)

qc.reset(1); // allocate one qubit

qc.write(0); // write the value zero

qc.had(); // place it into superposition of 0 and 1

var result = qc.read(); // read the result as a digital bit

第一步就是申请一个qubit,就像你要给变量分配空间一样。

第二步写0,其实写0很容易,你可以直接测量,要么0,要么1,如果结果是1的话,再做一个not操作就好;当然,你要是嫌麻烦,对于一个qubit,长时间的静置他,他也会变成0,毕竟还是基态比较稳定。

第三步就是进行一个H门的操作

第四步读,其实就是测量了

常见的作用于单量子比特操作的表达方式:

其中值得一提的是PHASE相位操作,phase操作只作用在 |1〉|1〉 上,因为他的效果是改变相对相位,如果大家都改变就没有什么用了。可能有同学听说过绕X轴旋转和绕Y轴旋转,这些都是针对Bloch球的表达方式,与这里的circle notation的方式不要弄混了。

一个操作也可能是其他几个操作的组合,比如:

如果我们可以把not变成H+180°旋转+H,那么我们也可以把中间的180°旋转变成两个90°的旋转,中间再加上两个H,因为HH=IHH=I,他们可以相互抵消,这样我们还可以得到RNOT:

COPY:这是一个需要注意的操作,因为量子程序里没有复制,这也保障了量子传输的信息不会被窃听, 因为你要窃听,你就需要去读,一读就是测量,而量子比特一测量就是坍缩。由于量子不能复制,所以,上述所有操作都是在原有的那个比特上操作的,所以操作就会被发现。

一个简单例子:

对于这里例子来说, A1A1 和 A2A2 是对qubit Hadmard门操作后测量得到的随机值,因为这个是真随机,所以就不会被窃听者提前知道或者预估,那么当我传输这个被我用红色圈出来的比特的时候,spy并不知道这个比特是否执行了H门和not操作,那他就只能猜了,25%的概率,图里面所示就是他猜有执行了,然后他再按照他的猜测如法炮制一个qubit继续传递,当B收了这个bit后,B也随机一个数据B2B2,看是否执行H门,然后测量。这个时候消息也都收到了,测量也都测量好了,那么把 A2A2的信息发过来也和窃听没有关系了,如果 B2B2 A2A2 的结果一样,那么测量结果应该一样,如果不一样,那么一定被窃听了。

这样的成功概率有多少呢? B2B2 A2A2 一样的概率0.5,在这种情况下spy被发现的概率0.25。看起来不是很高,但是如果我们有一百个比特先检测一下这条线路,不被发现的概率将会降到百万分之一。

现在来看一下代码:https://oreilly-qc.github.io/?p=2-4

qc.reset(3);//申请三个qubit

qc.discard();

var a = qint.new(1, 'alice'); //给其中一个变量命名为a,但是画出来的电路图中显示alice

var fiber = qint.new(1, 'fiber');

var b = qint.new(1, 'bob');

function random_bit(q) {//对一个初始化为0的比特,进行H操作,然后测量,测量结果是随机的

q.write(0);

q.had();

return q.read();

}

// Generate two random bits

qc.label('get two random bits');

var send_had = random_bit(a);//得到是否执行H门的随机值

var send_value = random_bit(a);//得到是否not的随机值

qc.label('');

// Prepare Alice's qubit

a.write(0);//a重新赋值为0,所以前面取随机值的操作也可以在a上进行

qc.label('set value');

qc.nop();

if (send_value)

a.not();

qc.nop();

qc.label('');

qc.nop();

qc.label('apply had');

qc.nop();

if (send_had)

a.had();

qc.nop();

qc.label('');

// Send the qubit!

fiber.exchange(a);

// Activate the spy

var spy_is_present = true;

if (spy_is_present)

{

var spy_had = 1;

qc.nop();

qc.label('spy');

if (spy_had)

fiber.had();

stolen_data = fiber.read();

fiber.write(0);

if (stolen_data)

fiber.not();

if (spy_had)

fiber.had();

qc.label('');

qc.nop();

}

// Receive the qubit!

var recv_had = random_bit(b);

fiber.exchange(b);

qc.label('apply had');

qc.nop();

if (recv_had)

b.had();

qc.nop();

qc.label('');

qc.nop();

qc.label('read value');

qc.nop();

recv_val = b.read();

qc.nop();

qc.label('');

qc.nop();

// Now Alice emails Bob to tell

// him her had setting and value.

// If the had setting matches and the

// value does not, there's a spy!

if (send_had == recv_had)

if (send_value != recv_val)

qc.print('Caught a spy!\n');

多量子比特

多量子比特的表示方法和单量子比特没有什么区别,下面的数字就是把他们从01的二进制换算成了我们熟悉的十进制。0x是十六进制的表示方法,最上面的是地位,正好可以not操作表示了出来,0就是000,1就是001,2就是010……以此类推

真要说和单量子比特的区别,那主要是两方面,一个是纠缠;另一个就是受控操作。

纠缠

纠缠好说,两个纠缠的量子比特就是其中一个的测量结果会影响另一个。

具体可以看一下这篇量子纠缠1——量子比特、Bell态、EPR佯谬

受控操作

受控操作就是说有两类比特,一个是用来控制的,另一个是被控制的。

比如大家耳熟能详的CNOT,当控制比特是1的时候,就翻转被控制的比特,如果控制比特是0的时候,那就不做操作。还有CCNOT门,又叫做toffli门,有两个控制比特,只有当他们都为1的时候才翻转。

现在要介绍一个前面没有提过的CPHASE受控相位门,和CNOT相似,同样是当控制比特为1的时候才进行,但是正如前面我们提过,PHASE操作只操作在1上,也就是说,如果这个操作被执行其实只有一种情况,那就是|11〉|11〉 。

在前面我们表示过一个旋转180°的相位操作可以表示成一个 H+NOT+H figure 2-14

那么现在受控相位操作拥有了三种表示方法:

当控制比特为0的时候,CNOT就不会发生,两个H又正好抵消了。

phase kickback

在这之所以说这么多的受控相位操作是因为这里面有个一很有趣的小技巧 QPU Trick: Phase Kickback 来看下面这个电路图

这个电路图很容易理解,一种理解方式就是把register 1当作控制比特,register 2 当作受控比特,两个H门使得register 1变成了等可能的四种情况 12|00〉+12|01〉+12|10〉+12|11〉12|00〉+12|01〉+12|10〉+12|11〉 。

现在来看看结果:

因为register 2并不是叠加态,所以没有相对相位,而绝对相位又测不出来,所以他可以说是没有变的,改变了的,反而是register 1 , |3〉|3〉 转了135°是因为两个都为1,45°和90°都转了。作为一个受控操作,控制比特反而变了,而受控比特没有改变。

swap

受控操作当然也能连在一起,得到一些有用的结果,比如三个CNOT操作,他就可以交换两条线路。

这个的证明是一件很容易的事情,你可以取一个任意态推一边,专门把这个提出来说一遍是因为这个还能做一件有趣的事情,那就是验证两个比特是否相等。我们需要用到的是CSWAP,即当控制比特为1时才交换。

当我们的output比特经过H门后,他就变成了等概率的 |0〉|0〉 和 |1〉|1〉 经过一个CSWAP,为1情况下的input1和input2就会交换,也就是说他们原来x概率的ab就变成了x概率的ba了,这样的问题出在哪?

如果概率还是原来的分布,那么在经过一个H门output等待率的 |0〉|0〉 和 |1〉|1〉 又会化简成 |0〉|0〉 ,各种各样的 |1〉|1〉 的概率会相互抵消掉,那么在经历一个NOT操作就一定会得到1。

那,如果这两个数据不一样,就一定得不到1吗?不一定,只是他有概率不是1,而一旦有概率不是1,那只要多检测几次就一定能检测出来,就像上面那个窃听一样,明明只有四分之一的概率,但仅需要一百次,测不出来的可能性就降到了百万分之一。

当然,代码在这里https://oreilly-qc.github.io/?p=3-4,这也是这本书的特色了。

受控操作当然不止这些,但是很多受控操作都可以分解成CNOT加上一些相位操作,我们可以自己构造自己需要的操作。

远距离操控随机

这里的远距离操控不是指我能扣确定他是什么,如果我能确定,那就不是随机了,而是说,我把两个比特弄成纠缠,当我一个测出来是0的时候,另一个以x%的概率得到0,至于我测出来是不是0看天意,对面测出来是不是0,也看天意,其中唯一能确定的,就只有这个x了。

这个例子是书上例子3-6 https://oreilly-qc.github.io/?p=3-6 方法很简单,就是我H门操作后,我旋转45°的角度,这样再来一个H门,因为相位变了,符号对不上,所以回不去了,就有了关联。

更强大的一点的应用是——量子隐形传态,量子隐形传态 Quantum Teleportation 提过了,就不在累述。

量子计算机怎么编程,如何在量子计算机上编程——QPU编程相关推荐

  1. ipad pro能用python编程吗_iPad Pro 上还能编程?一点都不稀奇

    大背景:若干年后,当人们拿着一台 iPad 编程,作图,建模,打 3A 级游戏,看 4K 影片,或许没人会想到,早在 2018 年夏天,所有这些技术早已初露端倪,各大科技公司之间的技术对决,早已在暗中 ...

  2. 树莓派的linux可以编程吗,解答树莓派上用什么编程

    描述 树莓派,英文为Raspberry Pi,也会被缩写称之为RPi,是一种只有扑克牌大写的为计算机编程教育而设计的微型计算机,其系统基于Linux. 树莓派的创造者想让更多小孩学会编程,去用电脑实现 ...

  3. python解释器在语法上不支持 编程方式-python解释器在语法上不支持什么编程方式_后端开发...

    python程序的两种运行方式是什么_后端开发 python程序的两种运行方式是:1.使用REPL模式运行,REPL模式即读取-计算-打印-循环的模式,借助的工具是IDLE(python集成开发环境) ...

  4. python 材料科学与工程专业_2020年最全的python的就业方向+清华计算机社流出上千集编程资料...

    Python是一门面向对象的编程语言,编译速度超快,从诞生到现在已经25个年头了.其特点在于灵活运用,因为其拥有大量第三方库,所以开发人员不必重复造轮子,就像搭积木一样,只要擅于利用这些库就可以完成绝 ...

  5. 在屏幕上输出你好的python语句是_编程实现:在屏幕上输出中文字符“你好,世界”。(输出结果中不带双引号)_学小易找答案...

    [填空题]借战死者诉说战争灾难的汉乐府诗是( ). [判断题]15 的倍数有 15 . 30 . 45 . ( ) [填空题]表现贫民意欲反抗的汉乐府诗是( ). [判断题]不可以在同一台计算机上安装 ...

  6. 鸿蒙系统是单任务还是多任务,在鸿蒙系统上使用MQTT编程

    我们使用的是paho mqtt软件包,这里介绍一下怎么使用mqtt协议编程.关于鸿蒙系统的mqtt移植好的软件包,相关github链接如下: https://gitee.com/qidiyun/har ...

  7. Java黑皮书课后题第8章:*8.15(几何:在一条直线上吗)编程练习题6.39给出了一个方法,用于测试三个点是否在一条直线上。编写下面的方法,检测points数组中所有的点是否都在同一条直线上

    *8.15(几何:在一条直线上吗)编程练习题6.39给出了一个方法,用于测试三个点是否在一条直线上.编写下面的方法,检测points数组中所有的点是否都在同一条直线上 题目 题目描述与运行示例 破题 ...

  8. 学习ASP.NET Core Razor 编程系列十三——文件上传功能(一)

    原文:学习ASP.NET Core Razor 编程系列十三--文件上传功能(一) 学习ASP.NET Core Razor 编程系列目录 学习ASP.NET Core Razor 编程系列一 学习A ...

  9. 【转】matlab与C/C++混合编程——在Windows/Linux上调用Matlab编译的动态库文件

    转自:matlab与C/C++混合编程--在Windows/Linux上调用Matlab编译的动态库文件_sinat_18131557的博客-CSDN博客 date version comments ...

  10. 输入两个数、用python求他们的和_从键盘上输入俩个实型数,编程求它们的和差积商,要求输出时,保留两位小数C语言编程题:从键盘上输入两个...

    从键盘上输入俩个实型数,编程求它们的和差积商,要求输出时,保留两位小数 C语言编程题:从键盘上输入两个 www.zhiqu.org     时间: 2020-11-23 参考代码: #includev ...

最新文章

  1. tensorflow-gpu
  2. Vue 跳转相同路由携带不同参数,而页面不刷新
  3. Linux环境下实现unsigned char*向string的转换
  4. java generic new_java中generic实例详解
  5. 什么是 DNS 劫持、投毒、解析?看这文就懂了!
  6. 正则表达式学习笔记系列----1
  7. 面向对象组件开发一个弹窗
  8. 四、矩阵特征值与特征向量的计算
  9. Cocos2d-x中点九图(Scale9Sprite)创建图片按钮
  10. paip.java OutOfMemoryError 解决方法o33
  11. 释放数据价值的真正法宝,数据要素市场化开发迫在眉睫
  12. GUI优化工具optimtool
  13. 打造个性QQ,适合网吧做自己安全的QQ
  14. python学习资源整理
  15. python中如何判断一个输入值为整数
  16. content provider nullpoint
  17. 【转载】蠕虫病毒 incaseformat 在国内肆虐,可导致用户数据丢失
  18. sigmoid与softmax的区别与联系
  19. 财路网每日原创推送:那些被滥用的区块链关键词
  20. 扭转战局的棋子 安卓4.4 ART模式实测解析

热门文章

  1. 寒假第二周 总结与反思
  2. VSCode如何更换背景图片
  3. matlab波形转换,matlab波形图怎么转换为矢量图并导出?
  4. PHP公众号商家收银台微信扫码付款支付源码
  5. 多方向如何选择数据分析之营业额不一定可以决定方向
  6. 麦肯锡的13个高效工作法则:重要的事,永远摆在第一位
  7. 物联网嵌入式开发人员面临的5大挑战
  8. 基于JAVA的即时通信软件
  9. WPF 设置本地打印的纸张和方向
  10. 苹果鼠标右键怎么按_IOS13.4更新后的鼠标用途在哪?