Matlab模拟矢量光束之径向偏振光束

Matlab模拟矢量光束之径向偏振光束

打开Matlab准备画个径向偏振光束玩玩。这玩意儿的特点是电场矢量沿半径方向分布,就像无数箭头从圆心向外发射。先别急着敲代码,咱得把极坐标系转成直角坐标------Matlab画图还是直角坐标系顺手。

先整点基础参数:

matlab 复制代码
N = 512;   % 网格尺寸
lambda = 632e-9; % 波长
k = 2*pi/lambda;  % 波数
w0 = 1e-3; % 束腰半径
[x,y] = meshgrid(linspace(-2e-3,2e-3,N)); % 生成2mm见方的网格

这里故意把坐标范围设成±2mm是为了防止边缘截断,后面算相位分布时才不会出幺蛾子。接着把直角坐标转极坐标:

matlab 复制代码
[theta, rho] = cart2pol(x,y); % 关键转换函数

重点来了!径向偏振的横向电场分量得这么算:

matlab 复制代码
Ex = rho.*cos(theta).*exp(-(rho.^2)/(w0^2));
Ey = rho.*sin(theta).*exp(-(rho.^2)/(w0^2));

注意看cos(theta)和sin(theta)这对组合,这就是把径向矢量分解成x、y分量的精髓。exp项是高斯包络,rho乘在前面让中心场强归零------典型的径向偏振特征。

想看效果?用quiver画矢量图:

matlab 复制代码
sample_step = 20; % 抽样步长避免箭头太密
quiver(x(1:sample_step:end,1:sample_step:end),...
       y(1:sample_step:end,1:sample_step:end),...
       Ex(1:sample_step:end,1:sample_step:end),...
       Ey(1:sample_step:end,1:sample_step:end));
axis square; colormap jet;

但这么直接画可能发现箭头大小不一致,得做个归一化处理:

matlab 复制代码
E_norm = sqrt(Ex.^2 + Ey.^2);
Ex_norm = Ex./E_norm;
Ey_norm = Ey./E_norm;

替换掉原来的Ex/Ey再画矢量图,这下箭头长度就统一了,方向分布更清晰。

进阶玩法可以加相位涡旋:

matlab 复制代码
l = 1; % 拓扑荷数
phase = exp(1i*l*theta);
Ex = Ex .* phase;
Ey = Ey .* phase;

这样处理后的光束携带轨道角动量,用imagesc(angle(Ex))能看到漂亮的螺旋相位分布。不过要注意实部虚部得分开处理,做传播仿真时得用复数场。

最后提醒下,内存不够的把N调小点,512*512的矩阵在低配电脑上可能会卡。遇到箭头方向混乱的,检查下theta的计算是否正确------有时候cart2pol返回的角度范围在(-π, π],而用atan2可能会更直观些。

相关推荐
AAA_bo18 小时前
liunx安装canda、python、nodejs、git,随后部署私有网页内容提取工具--JinaReader全攻略
linux·python·ubuntu·typescript·aigc·python3.11·jina
天机️灵韵9 小时前
[特殊字符] Ubuntu上安装Conda的完整指南(2025年最新版)
python3.11
我命由我123451 天前
Python Flask 开发问题:ImportError: cannot import name ‘Markup‘ from ‘flask‘
开发语言·后端·python·学习·flask·学习方法·python3.11
我命由我123451 天前
Python Flask 开发问题:ImportError: cannot import name ‘escape‘ from ‘flask‘
服务器·开发语言·后端·python·flask·学习方法·python3.11
码界奇点2 天前
Python与OpenCV集成海康威视工业相机从基础配置到高级应用的全方位指南
python·数码相机·opencv·相机·python3.11
我命由我123452 天前
Python Flask 开发 - Flask 路径参数类型(string、int、float、path、uuid)
服务器·开发语言·后端·python·flask·学习方法·python3.11
林九生2 天前
【CentOS7】CentOS 7 编译安装 Python 3.11.9
python·centos·python3.11
峰兄1983054 天前
探索新的奇异小波时频分析方法(MATLAB环境)
python3.11
醇氧6 天前
Windows 安装 Python 3.11.9
python3.11