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可能会更直观些。

相关推荐
图码5 天前
矩阵操作优化:从 O(q×n) 到 O(q) 的优雅进阶
数据结构·线性代数·算法·性能优化·矩阵·python3.11
AIBox3658 天前
Claude 中转站怎么接入:2026 年国内调用 Claude API 的方法、能力与示例
服务器·开发语言·人工智能·gpt·php·python3.11
:mnong11 天前
附图报价系统设计分析6
人工智能·opengl·cad·python3.11·opencascade
何中应19 天前
Conda安装&使用
python·conda·python3.11
Trouvaille ~22 天前
零基础入门 LangChain 与 LangGraph(八):真正让 Agent“活起来”——持久化、记忆、人机交互与时间旅行
langchain·人机交互·agent·python3.11·持久化机制·langgraph·ai应用开发
半部论语22 天前
CentOS7 + pyenv 安装 Python 3.11 完整指南)
大数据·elasticsearch·python3.11
诗句藏于尽头1 个月前
CentOS 7 源码编译安装 Python 3.11 完整教程
linux·centos·python3.11
HEADKON1 个月前
武特里西兰Vutrisiran治疗淀粉样变性每三个月打一针剂量固定还是按体重算
python3.11
图码1 个月前
递归入门:从n到1的优雅打印之旅
数据结构·c++·算法·青少年编程·java-ee·逻辑回归·python3.11
Chockmans1 个月前
2026年3月青少年软件编程(Python)等级考试试卷(六级)
开发语言·python·青少年编程·蓝桥杯·pycharm·python3.11·python六级