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

简介:

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

好久以前的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
本文作者:罗秀哲
本文来源:创见,如需转载请联系原作者。

目录
相关文章
|
6月前
|
算法 量子技术 C#
量子编程入门:从基础到实践
【5月更文挑战第26天】本文引导读者入门量子编程,从量子比特、量子门和量子算法的基础概念,到量子编程语言和量子模拟器的工具介绍,再到编写、运行和调试量子程序的实践步骤。通过学习和实践,开发者可以逐渐掌握量子编程,为未来的量子计算应用打下基础。随着量子计算技术的发展,量子编程将在更多领域展现其潜力。
|
6月前
|
Python
探索电学的奥秘:从基础到应用
探索电学的奥秘:从基础到应用
59 1
|
6月前
|
机器学习/深度学习 算法 搜索推荐
【高效率学习】探索最适合你的学习之路:从心理学、动机到教育学的深度解析
【高效率学习】探索最适合你的学习之路:从心理学、动机到教育学的深度解析
152 0
【高效率学习】探索最适合你的学习之路:从心理学、动机到教育学的深度解析
|
6月前
|
边缘计算 人工智能 算法
探索程序设计的奥秘:从理论到实践的飞跃
探索程序设计的奥秘:从理论到实践的飞跃
|
存储 量子技术
量子计算入门:量子计算机的理解与术语科普(二)
量子计算入门:量子计算机的理解与术语科普
290 0
|
存储 算法 量子技术
量子计算入门:量子计算机的理解与术语科普(一)
量子计算入门:量子计算机的理解与术语科普
371 0
|
量子技术
带你读《量子编程基础》之一:量子编程研究简史
本书讨论了如何扩展当前计算机的新程序设计方法和技术,以利用量子计算机的独特能力。相比于现有计算机系统,量子计算机在处理速度上具有显著优势。世界各地的政府和企业都投入了大量资金,希望建造实用的量子计算机。本书结合作者在量子计算领域多年的研究经验,并辅以大量的例子和插图,介绍了量子编程语言及其所需的重要工具和技术,对于学者、研究人员和开发人员来说都是非常宝贵的参考资料。
|
存储 算法 量子技术
下一篇
无影云桌面