qutip+mayavi可视化SO(3)旋转操作

2024-01-07 19:32

本文主要是介绍qutip+mayavi可视化SO(3)旋转操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇文章说到python的qutip包可以实现布洛赫球的可视化,并附上了产生动画的代码。

这一篇文章可以对SO(3)旋转操作进行可视化:(需要用到上一篇的new_bloch3d)

import numpy as np
import qutip# SO(3)旋转矩阵总共包含三个参数theta, phi, deltadef rn(state, theta, phi, delta):rn_mat = qutip.Qobj([[np.cos(delta/2) - (0+1j)*np.cos(theta)*np.sin(delta/2),-(0+1j)*np.exp(-(0+1j)*phi)*np.sin(delta/2)*np.sin(theta)],[-(0+1j)*np.exp((0+1j)*phi)*np.sin(delta/2)*np.sin(theta),np.cos(delta/2) + (0+1j)*np.cos(theta)*np.sin(delta/2)]])r_state = (rn_mat*state)*(rn_mat*state).dag()return(r_state)# 设置两个想要绕这个轴旋转的向量
state1 = qutip.Qobj([[-0.6747969 -0.54760216j],[ 0.35928193-0.34014339j]])
state2 = qutip.Qobj([[0.17668045-0.55481338j], [0.59620446-0.5527263j ]])
print(state1, state2)
# state = qutip.Qobj([])
# 设置旋转轴的其中两个参数
theta0 = 0.9
phi0 = np.pi/2+0.5############################################产生每一帧对应的坐标
sx1 = []
sy1 = []
sz1 = []
for delta in range(100):r_rho = rn(state1, theta0, phi0, (delta/100)*2*np.pi)sx1.append((qutip.sigmax()*r_rho).tr())sy1.append((qutip.sigmay()*r_rho).tr())sz1.append((qutip.sigmaz()*r_rho).tr())sx2 = []
sy2 = []
sz2 = []
for delta in range(100):r_rho = rn(state2, theta0, phi0, (delta/100)*2*np.pi)sx2.append((qutip.sigmax()*r_rho).tr())sy2.append((qutip.sigmay()*r_rho).tr())sz2.append((qutip.sigmaz()*r_rho).tr())#下面是画图的函数   
#################################################################
import mayavi.mlab as mlab
import matplotlib.colors as colors
import moviepy.editor as mpy
from new_bloch3d import new_Bloch3dduration= 4
fps = 25fig_myv = mlab.figure(1, size=[800, 800],bgcolor=colors.colorConverter.to_rgb('white'),fgcolor=colors.colorConverter.to_rgb('black'))b3d = new_Bloch3d(fig=fig_myv)def make_frame(t):mlab.clf() # clear the figure (to reset the colors)b3d.clear()p1_color = (135.0/255, 206.0/255, 235.0/255)s1_color = p1_colorp2_color = (254.0/255, 129.0/255, 125.0/255)s2_color = p2_colorv_color = (255/255, 130.0/255, 71.0/255)index = round(t*fps)# print(index)b3d.add_points([sx1[:index+1], sy1[:index+1], sz1[:index+1]],p1_color)b3d.add_vectors([sx1[index], sy1[index], sz1[index]], s1_color)b3d.add_vectors([np.sin(theta0)*np.cos(phi0), np.sin(theta0)*np.sin(phi0), np.cos(theta0)],v_color)b3d.add_points([sx2[:index+1], sy2[:index+1], sz2[:index+1]],p2_color)b3d.add_vectors([sx2[index], sy2[index], sz2[index]], s2_color)b3d.add_vectors([np.sin(theta0)*np.cos(phi0), np.sin(theta0)*np.sin(phi0), np.cos(theta0)],v_color)b3d.make_sphere()mlab.title('delta='+format((index/100)*360, '.2f')+'°', figure = fig_myv)#清除画纸上的上一帧,然后产生新的一帧f = mlab.gcf()f.scene._lift()return mlab.screenshot() #antialiased=True# 使用MoviePy把这个图片创建为一个动画,并保存
animation = mpy.VideoClip(make_frame, duration=duration)
animation.write_videofile("bloch_rotation_2.mp4", fps=fps)

可视化效果如下: 

一键三连一下呗 



可视化波片对光子偏振态的影响_哔哩哔哩_bilibili

这篇关于qutip+mayavi可视化SO(3)旋转操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/581009

相关文章

poj 2187 凸包or旋转qia壳法

题意: 给n(50000)个点,求这些点与点之间距离最大的距离。 解析: 先求凸包然后暴力。 或者旋转卡壳大法。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <s

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字

Python:豆瓣电影商业数据分析-爬取全数据【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】

**爬取豆瓣电影信息,分析近年电影行业的发展情况** 本文是完整的数据分析展现,代码有完整版,包含豆瓣电影爬取的具体方式【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】   最近MBA在学习《商业数据分析》,大实训作业给了数据要进行数据分析,所以先拿豆瓣电影练练手,网络上爬取豆瓣电影TOP250较多,但对于豆瓣电影全数据的爬取教程很少,所以我自己做一版。 目

MySQL——表操作

目录 一、创建表 二、查看表 2.1 查看表中某成员的数据 2.2 查看整个表中的表成员 2.3 查看创建表时的句柄 三、修改表 alter 3.1 重命名 rename 3.2 新增一列 add 3.3 更改列属性 modify 3.4 更改列名称 change 3.5 删除某列 上一篇博客介绍了库的操作,接下来来看一下表的相关操作。 一、创建表 create

封装MySQL操作时Where条件语句的组织

在对数据库进行封装的过程中,条件语句应该是相对难以处理的,毕竟条件语句太过于多样性。 条件语句大致分为以下几种: 1、单一条件,比如:where id = 1; 2、多个条件,相互间关系统一。比如:where id > 10 and age > 20 and score < 60; 3、多个条件,相互间关系不统一。比如:where (id > 10 OR age > 20) AND sco

PHP7扩展开发之流操作

前言 啥是流操作?简单来讲就是对一些文件,网络的IO操作。PHP已经把这些IO操作,封装成流操作。这节,我们将使用PHP扩展实现一个目录遍历的功能。PHP示例代码如下: <?phpfunction list_dir($dir) {if (is_dir($dir) === false) {return;} $dh = opendir($dir);if ($dh == false) {ret

浙大数据结构:树的定义与操作

四种遍历 #include<iostream>#include<queue>using namespace std;typedef struct treenode *BinTree;typedef BinTree position;typedef int ElementType;struct treenode{ElementType data;BinTree left;BinTre