量子算法入门—4.量子比特与量子门(1)

1.量子比特

  1. 经典比特和量子比特
  • 经典比特只有0、1两种取值,非黑即白,有n位即 2 n 2^n 2n种可能
  • 量子比特使用0、1的量子态描述量子比特的状态,可以通过线性组合形成新的量子态,就像光谱可以调节成分
  1. 引入线代记法,0、1是z轴上的自旋劈裂

  2. 制备叠加态

  3. x、y轴方向基底

    上图代码第6行注解:python中,使用j 代替数学中的虚数i,单独的j不能参与运算,必须前面跟一个数字才能被识别成复数

  4. 经典信息与量子信息

    上图使用α减去β即为z轴上的坐标,其他轴上的坐标同理。

  5. 计算坐标的py代码

python 复制代码
def get_bloch_coordinates(qubit):
	def get_x_bloch(qubit):
		qubit_x_basis = 1./np.sqrt(2) * np.matrix('1 1;1 -1')* qubit
		prob_zero_qubit = (qubit_x_basis.item(θ) * qubit_x_basis.item(θ).conjugate()).real 
		prob_one_qubit = (qubit_x_basis.item(1) * qubit_x_basis.item(1).conjugate()).real 
		return prob_zero_qubit - prob_one_qubit
	def get_y_bloch(qubit):
		qubit_y_basis = 1./np.sqrt(2) * np.matrix('1 1;1 -1')*np.matrix([[1,0],[θ, 1j]]) * qubit 	
		prob_zero_qubit = (qubit_y_basis.item(θ)* qubit_y_basis.item(θ).conjugate()).real
		prob_one_qubit = (qubit_y_basis.item(1) * qubit_y_basis.item(1).conjugate()).real 
		return prob_zero_qubit - prob_one_qubit
	def get_z_bloch(qubit): qubit_z_basis = qubit
		prob_zero_qubit = (qubit_z_basis.item(θ) * qubit_z_basis.item(θ).conjugate()).real 	
		prob_one_qubit = (qubit_z_basis.item(1) * qubit_z_basis.item(1).conjugate()).real 
		return prob_zero_qubit - prob_one_qubit
	return (get_x_bloch(qubit), get_y_bloch(qubit), get_z_bloch(qubit)) //返回布洛赫球面的坐标
  1. 已知线性代数表示的量子态,将其画到布洛赫球上
python 复制代码
def plot_bloch(qubit):
	import matplotlib.pyplot as plt 
	fig = plt.figure()
	ax = fig.add_subplot(111, projection='3d') 
	# 绘制球体
	u,v= np.mgrid[θ:2*np.pi:20j,θ:np.pi:10j] 
	x = np.cos(u)*np.sin(v)
	y = np.sin(u)*np.sin(v) 
	z = np.cos(v)
	ax.plot_wireframe(x, y, z, color="k", alpha=.1) 
	ax.grid(θ)
	
	(x,y,z) = get_bloch_coordinates(qubit)
	ax.quiver([θ],[θ],[θ],[x],[y],[z], length=1, arrow_length_ratio=0.3) 
	
	ax.set_xlim([-1, 1])
	ax.set_ylim([-1, 1]) 
	ax.set_zlim([-1, 1]) 
	ax.view_init(azim = 20) 
	
	return ax
相关推荐
搞笑症患者4 分钟前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER8 分钟前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
快手技术26 分钟前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱27 分钟前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
做科研的周师兄29 分钟前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
X在敲AI代码30 分钟前
leetcodeD3
数据结构·算法
码农小韩37 分钟前
基于Linux的C++学习——循环
linux·c语言·开发语言·c++·算法
CoderCodingNo1 小时前
【GESP】C++五级/四级练习(双指针/数学) luogu-P1147 连续自然数和
开发语言·c++·算法
颜酱1 小时前
前端算法必备:双指针从入门到很熟练(快慢指针+相向指针+滑动窗口)
前端·后端·算法
Wect1 小时前
LeetCode 274. H 指数:两种高效解法全解析
算法·typescript