知行编程网知行编程网  2022-06-24 15:00 知行编程网 隐藏边栏 |   抢沙发  47 
文章评分 0 次,平均分 0.0

教你在经典计算机上搭建一个量子神经网络,已开源

作者 | Sashwat Anagolum

来自 | AI科技评论   编译 | 张大倩、陈彩娴

教你在经典计算机上搭建一个量子神经网络,已开源

本文将教你搭建简单的二分类量子神经网络,并在经典计算机上运行,该项目已经开源。构建量子神经网络与传统的方式并不完全相同——它没有使用带权重和偏置的神经元,而是将输入数据编码为一系列量子比特,应用一系列量子门,并改变门的参数,使损失函数最小化。
项目地址:https://github.com/SashwatAnagolum/DoNew/tree/master/QNN
教你在经典计算机上搭建一个量子神经网络,已开源
虽然这听起来很新鲜,但其根本思想和传统还是一样的——改变参数集,使网络预测和输入标签之间的差异最小化,并且同样基于反向传播算法。
接下来,我们首先会介绍传统神经网络的工作原理,如果你对此已经很熟悉,可以直接跳到第3节阅读如何搭建量子神经网络。


1

权重、偏差和构建模块

几乎人人都知道神经网络。如今,许多酷炫的技术都使用了神经网络,包括自动驾驶汽车、语音助手和恶搞名人照片的软件等。

神经网络与其他算法的不同之处在于:我们不用写下一长串的规则,只需要向神经网络提供数据即可。

我们可以从IRIS数据集中提取一些数据注入神经网络,这些数据包括三种花的信息,然后网络会预测是哪种花。

教你在经典计算机上搭建一个量子神经网络,已开源

神经网络由大量的神经元组成,如下所示:

教你在经典计算机上搭建一个量子神经网络,已开源

大多神经元会含有多个数字输入(上图的蓝色圆圈),然后将每个输入与表示输入重要性的权重(w_i)相乘。权重越大,相关输入就越重要。

偏差被视为另一种权重,只是它所与之相乘的输入值始终为1。将所有加权输入进行相加后,得到输出值。

       教你在经典计算机上搭建一个量子神经网络,已开源       

然后应用激活函数,我们将得到神经元的激活值,如上图中的紫色圆圈所表示。激活值通过一个函数(上图中的蓝色长方形)传递,输出神经元:

       教你在经典计算机上搭建一个量子神经网络,已开源       

我们可以通过更改激活函数来改变神经元的行为。比方说,我们可以进行一个非常简单的转换,例如:

       教你在经典计算机上搭建一个量子神经网络,已开源       

但实际上,我们应用的是更复杂的函数,例如Sigmoid函数:

       教你在经典计算机上搭建一个量子神经网络,已开源       

神经元怎样才能发挥作用呢?

神经元可以根据所接收到的输入来做决策。比方说,我们可以向神经元注入以下三个问题的答案,然后让神经元来猜测我们下次去意大利用餐时是想吃披萨还是想吃意大利面:

  • 问题1:我喜欢这家餐厅的意大利面吗?

  • 问题2:这家餐厅有意大利青酱吗?

  • 问题3:这家餐厅有三层奶酪披萨吗?

抛开可能存在的饮食健康问题不说,我们来看一下神经元会有什么表现:

在对输入进行编码时,我们用0代表“否”,1代表“是”。同样地,对输出进行编码时,我们可以分别用0指代意大利面、用1来指代披萨:

教你在经典计算机上搭建一个量子神经网络,已开源

接着,我们用阶跃函数(step function)来转换神经元的激活值:

       教你在经典计算机上搭建一个量子神经网络,已开源       

只需要一个神经元,我们就可以捕捉多种不同的决策行为:

  • 决策1:如果我们喜欢这家餐厅的意大利面,我们就会点意大利面,除非青酱卖完,或者这家餐厅提供三层奶酪比萨。

  • 决策2:如果我们不喜欢这家餐厅的意大利面,我们就会点披萨,除非还有青酱,或者没有三层奶酪披萨。

或者换个方式:我们可以对神经元进行编程,让这个神经元与一组特定的偏好对应。

如果我们只是想要预测下次出门吃什么,我们很容易就能找出神经元的一组权重和偏差。但如果我们要在一个规模齐全的网络上进行同样的预测,那该怎么办?

预测过程可能要耗很长一段时间。

幸运的是,我们不用猜测所需的权重值,只需创建可以改变神经网络参数(比如权重、偏差甚至结构)的算法,以便网络可以学习如何解决问题。


2

“以退为进”

在理想情况下,神经网络的预测应该与输入关联的标记相同。因此,预测与实际输出的差异越小,神经网络所学到的权重就越优秀。

我们用一个损失函数来量化这种差异。损失函数可以采用任何形式,例如二次损失函数(quadratic loss function):

       教你在经典计算机上搭建一个量子神经网络,已开源       

y(x)是理想输出。当馈送带有参数θ的数据x时,教你在经典计算机上搭建一个量子神经网络,已开源是神经网络的输出。由于损失始终为非负值,一旦取值接近于0,我们就知道网络已经学会了一个好的参数组。当然,这个过程中可能还会出现其他问题,例如过拟合,但这些可以暂时忽略。

应用损失函数,我们可以找到网络设置的最佳参数是:

       教你在经典计算机上搭建一个量子神经网络,已开源       

因此,我们要做的不是猜测权重,而是在使用参数θ时,应用梯度下降技术将C最小化:

       教你在经典计算机上搭建一个量子神经网络,已开源       

这时,我们需要留意,增加θ_i的值后,损失会如何变化,然后更新θ_i,以使损失稍微降低。η是一个很小的数字,它的变化取决于我们更新θ_i时所做的改变。

为什么η是一个小的数字呢?因为我们可以对它进行调整,以保证在每次更新后,数据x的损失会接近0。在多数情况下,这并不是一个好的解决方法,因为这虽然可以减少当下x的损失,但其他馈送到网络的数据样本很可能会因此而表现较差。

想必现在大家都已掌握了基本的原理,接下来我们来看看要如何构建一个量子神经网络(quantum neural network)。


3

量子神经网络工作原理

首先,我们向网络提供一些数据x,这些数据x通过特征图传递——通过特征图,我们可以将输入的数据转换成某种形式,从而构建输入量子态:

       教你在经典计算机上搭建一个量子神经网络,已开源       

我们使用的特征图可能是任何形式,比如将一个二维向量x变换成一个角。

       教你在经典计算机上搭建一个量子神经网络,已开源       

一旦x被编码为量子态,我们应用一系列量子门:

       教你在经典计算机上搭建一个量子神经网络,已开源       

网络的输出,我们称之为π(x,0),是最后一个量子比特被测量为 |1〉状态的概率(Z_n-1代表将Z门应用到最后的量子比特),加上一个经典的偏置项。

       教你在经典计算机上搭建一个量子神经网络,已开源  

最后,我们在输出的数据中取出和 x 有关联的标签,用来计算样本上的损失——我们将使用二次损失,如下:

       教你在经典计算机上搭建一个量子神经网络,已开源       

从输出的数据中可以得到网络 p 的预测:

       教你在经典计算机上搭建一个量子神经网络,已开源       

接下来要计算损失函数教你在经典计算机上搭建一个量子神经网络,已开源的梯度,当然完全可以使用传统的方法,但我们需要的是一种在量子计算机上计算的方法。


4

全新的计算梯度的方法

我们先求损失函数对θ_i的微分:

       教你在经典计算机上搭建一个量子神经网络,已开源       

展开最后一项:

教你在经典计算机上搭建一个量子神经网络,已开源

通过求导,我们可以去掉常数项。

       教你在经典计算机上搭建一个量子神经网络,已开源       

现在,使用乘积法则,我们可以进一步展开:

教你在经典计算机上搭建一个量子神经网络,已开源

上面这个公式读起来有一点痛苦,但是通过 Hermitian 共轭,可以转化为下面这个简单的公式:

       教你在经典计算机上搭建一个量子神经网络,已开源       

U(θ) 由多个门组成,每一个门又由不同的参数控制,求U的偏导数只需要求门U_i(θ_i)对θ_i的偏导数:

教你在经典计算机上搭建一个量子神经网络,已开源

我们把U_i定义为相同的形式,称为G门,当然形式不是唯一的。

       教你在经典计算机上搭建一个量子神经网络,已开源       

定义了U_i的形式后,就能找到它的导数:

       教你在经典计算机上搭建一个量子神经网络,已开源       

幸运的是,我们可以用G门来表示导数:

       教你在经典计算机上搭建一个量子神经网络,已开源       

所以剩下的就是想办法构造出一个电路来得到所需的内积形式:

       教你在经典计算机上搭建一个量子神经网络,已开源       

Hadamard测试是最简单的方法——首先,我们准备好输入的量子态,并将辅助态制备为叠加态:

       教你在经典计算机上搭建一个量子神经网络,已开源       

现在对|ψ>应用Z_n-1B,约束辅助态是|1>:

       教你在经典计算机上搭建一个量子神经网络,已开源       

然后翻转辅助态,用A做同样的操作:

       教你在经典计算机上搭建一个量子神经网络,已开源       

最后,对辅助态使用另一个Hadamard门:

       教你在经典计算机上搭建一个量子神经网络,已开源       

现在辅助态等于0的概率是:

       教你在经典计算机上搭建一个量子神经网络,已开源       

因此如果我们用U(θ)代替B,用U(θ)的共轭对θ_i的导数来代替A,然后辅助量子比特为0的概率将会给我们π(x,θ)对θ_i的梯度。

很好!我们找到了一种在量子计算机上解析计算梯度的方法——现在剩下的就是建立我们的量子神经网络了。


5

建立量子神经网络

我们导入所有模块:

教你在经典计算机上搭建一个量子神经网络,已开源

看看我们的数据,这是一版删除了一个类的IRIS数据集:

教你在经典计算机上搭建一个量子神经网络,已开源

我们需要从标签中分离特征(前四列):

教你在经典计算机上搭建一个量子神经网络,已开源

构建一个函数来做特性映射。

由于输入向量是归一化的,并且是四维的,对于映射有一个超级简单的选择——使用2个量子比特来保存编码的数据,并使用一个映射将输入向量重新创建为量子态。

为此,我们需要两个函数。一个函数从向量中提取角度。

教你在经典计算机上搭建一个量子神经网络,已开源

另一个函数将角度转换成量子态。

教你在经典计算机上搭建一个量子神经网络,已开源

这样讲解可能有点令人困惑,但是你并不一定要理解QNN是如何构建的。如果你想了解构建原理可以阅读这些代码。

代码地址:https://github.com/SashwatAnagolum/launchpad/blob/master/tutorials/load_probability_distributions.ipynb

现在可以编写实现U(θ)所需的函数了,我们将采取RY门和CX门交替层的形式来实现函数。

为什么需要CX层?如果不把它们包括进来,就没办法执行纠缠操作,这将限制网络能够涉及的希尔伯特空间的范。使用CX门,网络可以捕捉量子比特之间的交互。

我们从G 门开始:

教你在经典计算机上搭建一个量子神经网络,已开源

接下来,操作CX门:

教你在经典计算机上搭建一个量子神经网络,已开源

现在把这些结合在一起得到U(θ):

教你在经典计算机上搭建一个量子神经网络,已开源

接下来,我们创建一个函数来获取网络的输出,另一个函数将这些输出转换为类别预测:     

教你在经典计算机上搭建一个量子神经网络,已开源

现在我们可以构建一个函数,在网络执行上前向传递。

教你在经典计算机上搭建一个量子神经网络,已开源

紧接着,需要写出所有关于测量梯度的函数。首先,我们必须能够应用控制版本的U(θ):

教你在经典计算机上搭建一个量子神经网络,已开源

使用这个,我们可以创建一个函数并得出期望值:

教你在经典计算机上搭建一个量子神经网络,已开源

现在我们可以算出损失函数的梯度,最后做的乘法是为了得到π(x, θ) - y(x) 梯度项:

教你在经典计算机上搭建一个量子神经网络,已开源

一旦我们有了梯度,就可以使用梯度下降来更新网络参数,“动量”技巧可以帮助加快训练时间:

教你在经典计算机上搭建一个量子神经网络,已开源

现在我们可以建立自己的损失函数和准确率函数,然后就可以观察网络训练的情况:

教你在经典计算机上搭建一个量子神经网络,已开源

最后,我们创建训练网络的函数,并调用它:

教你在经典计算机上搭建一个量子神经网络,已开源      教你在经典计算机上搭建一个量子神经网络,已开源              教你在经典计算机上搭建一个量子神经网络,已开源

我们传递给np.random.sample()方法的数字决定了参数集的大小——第一个数字(5)是G层的数量。

这是我在测试5层网络、15次迭代后得到的数据输出:

教你在经典计算机上搭建一个量子神经网络,已开源

这些数据看起来是相当不错——我们在验证集上达到了100%的准确率,这意味着网络成功地覆盖了边缘测试示例!


6

结语

我们成功建立了量子神经网络,太棒了!可以使用几种方法来进一步降低损失,例如训练网络进行更多的迭代,或者调整超参数:如批量大小和学习率。另一个很酷的方法是为U(θ)尝试选择不同的门。

原文链接:https://towardsdatascience.com/quantum-machine-learning-learning-on-neural-networks-fdc03681aed3
<section style="white-space: normal;line-height: 1.75em;text-align: center;"><strong style="color: rgb(0, 0, 0);font-family: -apple-system-font, system-ui, "Helvetica Neue", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei UI", "Microsoft YaHei", Arial, sans-serif;letter-spacing: 0.544px;widows: 1;background-color: rgb(255, 255, 255);max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="max-width: 100%;letter-spacing: 0.5px;font-size: 14px;box-sizing: border-box !important;overflow-wrap: break-word !important;"><strong style="max-width: 100%;font-size: 16px;letter-spacing: 0.544px;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="max-width: 100%;letter-spacing: 0.5px;box-sizing: border-box !important;overflow-wrap: break-word !important;">—</span></strong>完<strong style="max-width: 100%;font-size: 16px;letter-spacing: 0.544px;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="max-width: 100%;letter-spacing: 0.5px;font-size: 14px;box-sizing: border-box !important;overflow-wrap: break-word !important;"><strong style="max-width: 100%;font-size: 16px;letter-spacing: 0.544px;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="max-width: 100%;letter-spacing: 0.5px;box-sizing: border-box !important;overflow-wrap: break-word !important;">—</span></strong></span></strong></span></strong></section><pre><pre style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section style="max-width: 100%;letter-spacing: 0.544px;white-space: normal;font-family: -apple-system-font, system-ui, "Helvetica Neue", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei UI", "Microsoft YaHei", Arial, sans-serif;widows: 1;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section powered-by="xiumi.us" style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section style="margin-top: 15px;margin-bottom: 25px;max-width: 100%;opacity: 0.8;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section style="max-width: 100%;letter-spacing: 0.544px;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section powered-by="xiumi.us" style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section style="margin-top: 15px;margin-bottom: 25px;max-width: 100%;opacity: 0.8;box-sizing: border-box !important;overflow-wrap: break-word !important;"><section><section style="margin-bottom: 15px;padding-right: 0em;padding-left: 0em;max-width: 100%;color: rgb(127, 127, 127);font-size: 12px;font-family: sans-serif;line-height: 25.5938px;letter-spacing: 3px;text-align: center;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="max-width: 100%;color: rgb(0, 0, 0);box-sizing: border-box !important;overflow-wrap: break-word !important;"><strong style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="max-width: 100%;font-size: 16px;font-family: 微软雅黑;caret-color: red;box-sizing: border-box !important;overflow-wrap: break-word !important;">为您推荐</span></strong></span></section><section style="margin-top: 5px;margin-bottom: 5px;padding-right: 0em;padding-left: 0em;max-width: 100%;min-height: 1em;font-family: sans-serif;letter-spacing: 0px;opacity: 0.8;line-height: normal;text-align: center;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="font-size: 14px;">吴恩达推荐笔记:22 张图总结深度学习全部知识</span></section><section style="margin-top: 5px;margin-bottom: 5px;padding-right: 0em;padding-left: 0em;max-width: 100%;min-height: 1em;font-family: sans-serif;letter-spacing: 0px;opacity: 0.8;line-height: normal;text-align: center;color: rgb(0, 0, 0);box-sizing: border-box !important;overflow-wrap: break-word !important;">图灵奖得主Yann LeCun《深度学习》春季课程</section><section style="margin-top: 5px;margin-bottom: 5px;padding-right: 0em;padding-left: 0em;max-width: 100%;min-height: 1em;font-family: sans-serif;letter-spacing: 0px;opacity: 0.8;line-height: normal;text-align: center;color: rgb(0, 0, 0);box-sizing: border-box !important;overflow-wrap: break-word !important;">你一定从未看过如此通俗易懂的YOLO系列解读 (下)</section><section style="margin-top: 5px;margin-bottom: 5px;padding-right: 0em;padding-left: 0em;max-width: 100%;min-height: 1em;font-family: sans-serif;letter-spacing: 0px;opacity: 0.8;line-height: normal;text-align: center;color: rgb(0, 0, 0);box-sizing: border-box !important;overflow-wrap: break-word !important;">22课时、19大主题,CS 231n进阶版课程视频上线</section><section style="margin-top: 5px;margin-bottom: 5px;padding-right: 0em;padding-left: 0em;max-width: 100%;min-height: 1em;font-family: sans-serif;letter-spacing: 0px;opacity: 0.8;line-height: normal;text-align: center;box-sizing: border-box !important;overflow-wrap: break-word !important;"><span style="color: rgb(87, 107, 149);font-size: 14px;">震惊!这个街道办招8人,全是清华北大博士硕士!</span><br  /></section></section></section></section></section></section></section></section></section>
教你在经典计算机上搭建一个量子神经网络,已开源

本篇文章来源于: 深度学习这件小事

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写

发表评论

表情 格式 链接 私密 签到
扫一扫二维码分享