【光学】生成螺旋波带片【含Matlab源码 3116期】

在这里插入图片描述

⛄一、获取代码方式

获取代码方式1:
完整代码已上传我的资源:【光学】基于matlab生成螺旋波带片【含Matlab源码 3116期】
点击上面蓝色字体,直接付费下载,即可。

获取代码方式2:
付费专栏Matlab物理应用(初级版)

备注:
点击上面蓝色字体付费专栏Matlab物理应用(初级版),扫描上面二维码,付费29.9元订阅海神之光博客付费专栏Matlab物理应用(初级版),凭支付凭证,私信博主,可免费获得1份本博客上传CSDN资源代码(有效期为订阅日起,三天内有效);
点击CSDN资源下载链接:1份本博客上传CSDN资源代码

⛄二、部分源代码

clear;
lam=532e-6; %设置波长为600nm
R=1; %设置菲涅尔波带片半径为1mm
f=100; %设置焦距100mm
ym=R;
xm=R;
w=401;
y=linspace(-ym,ym,w);
x=linspace(-xm,xm,w); %设置程序中x,y向量,将屏幕分为10011001个点
for m=1:w
for n=1:w %设置二重循环依次求菲涅尔波带片屏幕上各点
p=sqrt(x(m).2+y(n).2); %求各点所在圆半径
fi=atan2(y(n),x(m));
dd=sin(fi-((pi
pp)/(flam)));
if p>R%如果屏幕上点大于波带片半径
I(m,n)=0;% 则用灰色表示背景,不是波带片部分
else
if dd>=0 %判断半波带数透还是不透
I(m,n)=1;
else
I(m,n)=0; %为偶数则不涂黑表示透光
end
end

⛄三、运行结果

在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2014a

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

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

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Matlab领域

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值