量子计算笔记|可能会涉及一点点高量的量子力学基础(一)

简介:

因为主题并非量子力学,所以这里只是简要介绍,更详细的内容可以买本书来看。然后还可以参考

@sym cheng

好久以前的Live(这篇文章大约是知乎Live刚出现的时候写的)

量子力学的基本假设

类似于其它的物理理论(比如分析力学的最小作用量原理),量子力学也有一些基本的假设:

原理一:描写微观系统状态的数学量是Hilbert (希尔伯特)空间中的矢量。相差一个复数因子的两个矢量,描述同一状态。我们用归一化的右矢量或左矢量表示系统的状态,这个希尔伯特空间称为态空间

原理二

  1. 描写微观系统的物理量是Hilbert空间中的Hermitian(厄米)算符,也就是说一个Hermitian算符就代表了一个微观系统的物理量
  2. 物理量所能取的值,是相应算符的本征值
  3. 物理量A在状态|\psi\rangle中取各值\alpha_i的概率,与态矢量|\psi\rangle按照A的归一化本征矢量的展开式中的系数(一般我们称为概率幅)的复平方成正比。

原理三

  • 微观系统中每个粒子的广义坐标(不理解换成直角坐标也行)下的位置算符X_i(i=1,2,3),与相应的正则动量算符P_i有下列对易关系:[X_i,X_j]=0,\quad [P_i,P_j]=0,\quad [X_i,P_j]=i\hbar\delta_{ij} 其中\delta_{ij}当且仅当i=j的时候为1,其余时候都是都是0


  • 粒子的自旋角动量算符\mathbf{S}各分量之间的对易关系为:[S_i,S_j] = i\hbar\sum_{k}\epsilon_{ijk} S_k,并且各分量与粒子的位置和动量算符都对易

原理四:微观系统的状态|\psi(t)\rangle随时间变化的规律是薛定谔方程,这里\hbar是一个常数(实数),H称为这个系统的Hamiltonian(哈密顿量)

i\hbar\frac{\partial}{\partial t}|\psi(t)\rangle = H|\psi(t)\rangle

原理五:描写全同粒子系统的态矢量,对于任意一对粒子的对调是对称的(对调前后完全相同)或者反对称的(对调前后差一个负号),前者称为玻色子,后者称为费米子。这里全同粒子系统是指由同一种粒子组成的系统,这些粒子每个都是一样的。

量子计算机的运行就是基于以上五个基本原理。关于基本原理是否正确,以及以上的称述方式是否严格我们不在这里讨论,在具体实现的时候我们更关心这些原理是否能够帮助我们预测微观系统的行为。毕竟对于量子力学的诠释,除了最经典的哥本哈根诠释,还有诸如流体力学诠释,Bohm理论(在非局域的情况下依然能用),随机诠释等等。我们还没有找到在实验中能直接否定它们的方法,所以目前来说信哪个是一种信仰...

从经典的哈密顿量到量子力学的哈密顿量

从经典的哈密顿量到量子力学的哈密顿量是有一些固定的方法的,我们在这里也不关心这背后的原理具体是什么,如果对这里感兴趣,可以参看本章的参考文献。这个具体的方法就是用算符替换经典系统里的动量,角动量等符号,比如在经典力学中的动量将被替换为动量算符p \rightarrow \hat{p} = -i\hbar\nabla\quad x \rightarrow \hat{x} = x

在量子计算中,我们暂时不关心量子力学到底是怎么回事儿(当然有一些人实际上也在利用量子计算机研究量子力学基础,这里就不展开了),我们更加关心的是,一个人造的微观(量子)结构如何按照预想的方式进行演化。除了我们熟悉的(可能现在还不那么熟悉的)解析的数学方法,数值计算往往是一个(相对)简单暴力直接的工具,很多时候很有用。所以首先先介绍一下怎么数值解一个含时的薛定谔方程。下面的代码将用Julia语言编写。

我们要求解的问题是这样的,有这样一个哈密顿量

H = \hbar \cdot ((1-t/T)\frac{1}{2}(1-\sigma_x) + \frac{1}{2}(1+\sigma_z)\cdot t/T) =\hbar (\frac{1}{2}(1-t/T) \begin{pmatrix}1 & -1\\-1 & 1\end{pmatrix}+t/T\cdot \begin{pmatrix}1 & 0\\0 & 0\end{pmatrix})

其中T是总的演化时间,是10^2 s,我们将\sigma_z的本征矢量记为|0\rangle, |1\rangle。这个系统的演化就满足薛定谔方程
i\hbar \frac{\partial}{\partial t}|\psi(t)\rangle = H|\psi(t)\rangle

而由于|0\rangle, |1\rangle是这个Hilbert空间的本征矢量,|\psi(t)\rangle总可以表示为它们的线性组合


注意这个Hamiltonian是不显含时间变量的,那么我们就可以分离变量,使得在很小的\Delta t时间里,下面的式子成立

|\psi(t+\Delta t)\rangle = e^{-iH\Delta t /\hbar}|\psi(t)\rangle

这是因为在很小的\Delta t时间里,我们可以把H(t)随时间的变化忽略(当然这么说是不严格的),把H看做常数就有

i\hbar\frac{\partial}{\partial \Delta t}|\psi(t+\Delta t)\rangle = H|\psi(t+\Delta t)\rangle

可以解得

|\psi(t+\Delta t)\rangle = e^{-iH(t)\Delta t /\hbar}|\psi(t)\rangle

所以对于这样一个问题,我们就可以用很小的\Delta t来进行数值计算。代码如下

mutable struct QuSystem
    H::Function
    current_state::Vector
    current_time::Float64
    dt::Float64

    function QuSystem(
    end
end

function evolute!(sys::QuSystem)
    sys.current_state = expm(
    sys.current_time += sys.dt
end

# 初态
initial_state = [1/sqrt(2), 1/sqrt(2)]
# 总的演化时间
T = 1e2
# 定义哈密顿量
Hamiltonian(t) = 0.5*[1 -1;-1 1]*(1-t/T)+[1 0;0 0]*t/T
# 构造这个量子系统,为了节约时间把dt设成1吧,这个步长没有明显的误差
qs = QuSystem(Hamiltonian, initial_state, dt=1.0)

# 打印一下初态,看看初态是什么
@show qs.current_state

#开始演化
for i = 1:1e2
    evolute!(qs)
end

# 打印演化结束的态
@show qs.current_state


这是用Julia语言写的,因为中文文档比较落后,如果你不想看英文文档可以先看我写的这个比较简单的教程。

实际上,这只是数值求解微分方程的方法中最简单的一种,在JuliaQuantum开源组织的QuDynamics.jl中已经封装好了很多来自于ODE.jl和Expmv.jl的其它数值方法。这里就暂且不详细介绍了,等到后面介绍量子计算的模拟的时候具体说明。


原文发布时间为:2018-03-12
本文作者:罗秀哲
本文来源:创见,如需转载请联系原作者。

目录
相关文章
|
11月前
|
机器学习/深度学习 人工智能 自然语言处理
扩散模型背后数学太难了,啃不动?谷歌用统一视角讲明白了
扩散模型背后数学太难了,啃不动?谷歌用统一视角讲明白了
190 0
|
12月前
|
存储 算法 量子技术
量子计算入门:量子计算机的理解与术语科普(一)
量子计算入门:量子计算机的理解与术语科普
209 0
|
12月前
|
存储 量子技术
量子计算入门:量子计算机的理解与术语科普(二)
量子计算入门:量子计算机的理解与术语科普
191 0
|
SQL 缓存 架构师
谈谈架构师是何种生物
架构师也可以分为初级、中级、高级三档,江湖上真正高水平的软件架构师就更少了。 所以,大部分(超过九成的)码农干上许多年,还是做不了架构师,这是什么原因造成的呢? 什么是架构师? 写代码和做架构是两个不同的事情。什么是架构师,架构师要做什么事情,为什么 Java 的领域里,会更注重架构师? 很早很早之前,我对于架构的概念一点都不理解,依稀记得,架构( architecture)这个词,来自于建筑领域。
147 0
谈谈架构师是何种生物
|
存储 传感器 人工智能
从现实世界的角度去理解计算机领域的知识
​ “ 从现实世界的角度看计算机,可以帮助我们更清晰的学习计算机领域的知识。 本文试图用生活中常见的事物来解释计算机技术领域,让知识更通俗易懂 ”
871 0
 从现实世界的角度去理解计算机领域的知识
|
量子技术
带你读《量子编程基础》之一:量子编程研究简史
本书讨论了如何扩展当前计算机的新程序设计方法和技术,以利用量子计算机的独特能力。相比于现有计算机系统,量子计算机在处理速度上具有显著优势。世界各地的政府和企业都投入了大量资金,希望建造实用的量子计算机。本书结合作者在量子计算领域多年的研究经验,并辅以大量的例子和插图,介绍了量子编程语言及其所需的重要工具和技术,对于学者、研究人员和开发人员来说都是非常宝贵的参考资料。
|
存储 算法 量子技术
|
量子技术 数据安全/隐私保护
《战争论》第二篇《论战争理论》的主要内容
《战争论》第二篇《论战争理论》的主要内容   《论战争理论》是《战争论》的第二篇,主要论述了军事艺术和军事活动特点(如图1所示)。 图1 《论战争理论》的主要原则   一 军事艺术 战争是通过精神力量使用物质力量,使用直线或者包围战术,在各种地理环境中作战。
1830 0