【光学】基于matlab涡旋光束全息与拓扑荷仿真【含Matlab源码 1945期】

举报
海神之光 发表于 2022/07/08 23:27:36 2022/07/08
【摘要】 一、获取代码方式 获取代码方式1: 完整代码已上传我的资源:【光学】基于matlab涡旋光束全息与拓扑荷仿真【含Matlab源码 1945期】 获取代码方式2: 通过订阅紫极神光博客付费专栏,凭支付凭...

一、获取代码方式

获取代码方式1:
完整代码已上传我的资源:【光学】基于matlab涡旋光束全息与拓扑荷仿真【含Matlab源码 1945期】

获取代码方式2:
通过订阅紫极神光博客付费专栏,凭支付凭证,私信博主,可获得此代码。

备注:
订阅紫极神光博客付费专栏,可免费获得1份代码(有效期为订阅日起,三天内有效);

二、部分源代码

clear;
clc;
display('...starting...');

N=512;  % 像素点个数,表示N*N个像素点的图像
node=3; % 拓扑荷数,可修改
pitch=15e-6; % 像素点的宽度,单位为米
lambda=532e-9; % 参数,单位为米
kappa=2*pi/lambda; % 参数k, 单位为米
d=0.30; % 菲涅尔衍射距离,单位为米,可修改
[xn,yn]=meshgrid(-N/2:N/2-1,-N/2:N/2-1); %用于矩阵运算的坐标栅格,
vortex=node*atan2(yn,xn); % 产生漩涡光束的相位全息图
vortex=rem(rem(vortex+2*pi,2*pi)+2*pi,2*pi);% 调整取值范围

% 显示产生漩涡光束的相位全息图
figure;
imagesc(vortex);
title('phase hologram'); %标题
axis square;
colormap hot;


FFT_FLAG=0; %标志位,两种变换,如果选傅立叶变换(FFT)就等于1,菲涅尔变换就等于0,可修改

if(FFT_FLAG)
    display('FFT transform');
    U2=fftshift(ifft2(exp(2i*vortex))); %进行傅立叶变换 U2为计算得到的输出平面的复振幅
else
    display('Fresnel diffraction');
    hpz=exp(2i*2*pi*d*sqrt(1/lambda^2-(xn/(N*pitch)).^2-(yn/(N*pitch)).^2));
    U2=ifft2(fftshift((fftshift(fft2((exp(1i*vortex))))).*hpz)); %进行菲涅尔衍射计算
end

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32

三、运行结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

四、备注

1 matlab版本
2014a

2 参考文献
[1] 门云阁.MATLAB物理计算与可视化[M].清华大学出版社,2013.

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

文章来源: qq912100926.blog.csdn.net,作者:海神之光,版权归原作者所有,如需转载,请联系作者。

原文链接:qq912100926.blog.csdn.net/article/details/125666475

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。