最前沿・量子退火建模方法(2) : Domain wall encoding讲解和python实现

本文介绍了Domainwall编码,一种利用N-1位量子比特表示N位One-hot编码的高效方法。通过直观解释和数学定义,展示了其如何节省量子比特资源,并提供了Python实现示例。
摘要由CSDN通过智能技术生成

前言

上篇讲的subQUBO属于方法论,这次讲个通过编码量子比特的方式,同样的约束条件,不同的编码,所需的量子比特数是不同的。有的编码方式,很节省量子比特。比如,这次要讲的Domain wall encoding。


一、Domain wall encoding是什么?

1.1 直觉上的理解

Domain wall的概念来自于物理学,具体的由来我还没有考古,等我有时间了再补充。

  • 它主要是可以用N-1位量子比特,来代表N位的One-hot编码。
  • 它的概念解释中用的变量是Ising machine的spin变量,也就是变量取值是+1或-1。

下面资料的图主要来自以下文章:

https://qiita.com/sotobenjamin0307/items/2cd329923fb3f0c03692
Domain-Wall / Unary Encoding in QUBO for Permutation Problems
https://ieeexplore.ieee.org/document/9951263

大家对比一下0~4的one-hot编码和Domain wall encoding的区别。

  • one hot编码,有几个数值,就需要几个量子比特。

在这里插入图片描述

  • Domain wall encoding,N个数值的话,就只需要N-1个spin。
    在这里插入图片描述

为什么4个量子比特可以代表5个数值呢?

  • 因为,它隐藏了首尾两个默认值,
  • 所以,就是它本来用了N+2个spin,所有会有N个边,就是下图中的竖线段的位置。
    就想象成,10个电线杆的话,需要8段线。

在这里插入图片描述

1.2 Domain wall encoding的数学定义

  • one hot编码的约束项,等价于下面的Domain wall encoding的约束项。

在这里插入图片描述

  • spin串里,从-1变为+1的位置下标数值i,就是该编码的代表的数值。(*满足该条件的位置仅存在一个)
    在这里插入图片描述
    下面的Domain wall value就是,上面👆约束项的最小值。可以代入验算一下。
    在这里插入图片描述

二、Domain wall encoding的python实现

1. 安装amplify库

pip install -U amplify

2.创建Domain wall约束

from amplify import domain_wall

gen = VariableGenerator()
q = gen.array("Binary", 4)
dw = domain_wall(q)

也可以换成Binary变量,具体约束项参考以下文档。

https://amplify.fixstars.com/en/docs/amplify/v1/constraint.html

在这里插入图片描述


总结

Domain wall encoding的概念并不难理解,但是网上资料太少了,搞懂也花了点时间,不过终于搞懂了,希望能帮到大家。还有更高级的Domain wall encoding在某些问题上可以缩减到正常one hot编码的几十分之一。以后有机会再介绍。

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值