【基于矢量射线的衍射积分 (VRBDI)】基于矢量射线的衍射积分 (VRBDI) 和仿真工具(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

📋📋📋本文目录如下:🎁🎁🎁

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码实现及详细文章讲解


💥1 概述

  • 基于矢量射线的衍射积分(Vector Ray-Based Diffraction Integral,VRBDI)是一种用于模拟光的衍射现象的方法。它基于矢量射线追踪技术,通过对光波的传播路径进行追踪和积分,来计算衍射图样。VRBDI方法可以用于模拟各种衍射现象,包括光栅衍射、衍射光栅、衍射孔径等。

    VRBDI方法的基本思想是将光波看作是由许多矢量射线组成的,每条射线具有位置、方向和振幅等属性。通过追踪这些射线的传播路径,并根据衍射积分的原理进行积分计算,可以得到衍射图样的近似解。VRBDI方法可以考虑光的波动性和干涉效应,适用于模拟复杂的衍射现象。

    在VRBDI方法的实现中,通常需要借助计算机仿真工具来进行数值计算和模拟。一些常用的仿真工具包括:

    1. MATLAB:MATLAB是一种常用的科学计算和仿真工具,它提供了丰富的数值计算和图形绘制函数,可以用于实现VRBDI方法的数值计算和模拟。

    2. Zemax:Zemax是一种专业的光学设计和仿真软件,它提供了强大的光学建模和分析功能,包括衍射现象的模拟和分析。可以使用Zemax来实现VRBDI方法的仿真。

    3. VirtualLab:VirtualLab是一种专业的光学仿真软件,它提供了全面的光学建模和仿真功能,包括衍射、干涉、衍射光栅等现象的模拟和分析。可以使用VirtualLab来实现VRBDI方法的仿真。

    这些仿真工具都具有强大的功能和灵活的使用方式,可以根据具体的需求选择合适的工具进行VRBDI方法的实现和仿真。

  • 详细文章讲解见第4部分。

📚2 运行结果

 

 

本文一共分为五个部分,这里仅展现第一部分结果图。

 部分代码:

%Definitions (all lengths in mm, wavelength in nm)

lambda=532;     %Wavelength
w0=2.3;         %Gaussian waist radius
zw=-10000;      %Distance from waist (negative value => beam convergent)
z0=10;          %Distance from input plane to front lens apex
z1=1;           %Distance from rear lens apex to intermediary plane
n=Sellmeier(lambda,'AIR');  %Refractive index immersion medium

b1=15;          %Edge length of square-shaped input window
b2=15;          %Edge length of square-shaped intermediary window
b3=0.2;         %Edge length of square-shaped output window
Pix1=55;        %Pixels along one dimension of input window
Pix2=99;        %Pixels along one dimension of intermediary and output 
                %window

%Lens parameters THORLABS LBF254-050-A ####################################

RL1=30.06;      %Front curvature radius
RL2=-172;       %Back curvature radius
TL=6.5;         %Center thickness
fB=46.4;        %Back focal distance
ApL=12.7;       %Aperture radius
nL=Sellmeier(lambda,'N-BK7');

%Remaining distance after lens to focal region

z2=fB-z1;

%Definition of lens component and initialization of System ################

SL=AddSurf([0 0 0],RL1,ApL,n,nL,-1,1);      %Initialization surface list SL
SL=AddSurf([0 0 TL],RL2,ApL,nL,n,-1,1,SL);  %Appending surface to SL    
Lens=DefComp([0 0 z0],[0 0 0],SL);          %Definition of Lens
System=AddComp(Lens);                       %Initialization of System with
                                            %Lens

%Definition of detector component and addition to System ################## 

SL=AddDet([0 0 0],1e30,1e30,n,0);           %Detector size should be large
Det=DefComp([0 0 z0+TL+z1],[0 0 0],SL);     %to catch all remaining rays!
System=AddComp(Det,System);                 %Appending Detector to System

%Definition of spatial point grids ########################################

[X1,Y1]=meshgrid(-b1/2:b1/(Pix1-1):b1/2);
[X2,Y2]=meshgrid(-b2/2:b2/(Pix2-1):b2/2);
[X3,Y3]=meshgrid(-b3/2:b3/(Pix2-1):b3/2);

%Reshaping of input and output grids for VDI propagation ##################

P2=[X2(:) Y2(:) 0*X2(:)];
P3=[X3(:) Y3(:) 0*X3(:)+z2];

%Definition of tangent electric field components on input plane ###########

E1x=GaussianField(w0,zw,lambda,n,b1,Pix1);
E1y=zeros(Pix1);

%Get irradiance and other field components on input plane #################

[I1,E1z,H1x,H1y,H1z]=GetIrrad(E1x,E1y,lambda,n,b1,b1);

%Get plane wave spectrum from input field ################################

🎉3 参考文献

部分理论来源于网络,如有侵权请联系删除。

[1] B. Andreas, G. Mana, and C. Palmisano, "Vectorial ray-based diffraction integral," J. Opt. Soc. Am. A 32, 1403-1424 (2015).

[2]陈光炜, 陈光炜. 光学与光谱学实验指导[M]. 科学出版社, 2015.

[3]李大鹏, 李大鹏. 光学实验指导[M]. 高等教育出版社, 2017.

🌈4 Matlab代码实现及详细文章讲解

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/19422.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows系统下的mysql版本升级

Windows系统下的mysql版本升级 1、下载Mysql https://dev.mysql.com/downloads/mysql/ 2、停止mysql 3、解压到对应路径 mysql-8.0.33-winx64 4、备份旧数据库 5、将8.0.32 下的data文件和my.ini文件copy至8.0.33路径下 6、进入到mysql文件夹bin目录下面执行 mysqld --…

Java版本电子招标采购系统源码:营造全面规范安全的电子招投标环境,促进招投标市场健康可持续发展

营造全面规范安全的电子招投标环境,促进招投标市场健康可持续发展 传统采购模式面临的挑战 一、立项管理 1、招标立项申请 功能点:招标类项目立项申请入口,用户可以保存为草稿,提交。 2、非招标立项申请 功能点:非招标…

STM32 Proteus仿真HCSR04超声波测距报警DS18B20温度采集 -0055

STM32 Proteus仿真HCSR04超声波测距报警DS18B20温度采集 -0055 Proteus仿真小实验: STM32 Proteus仿真HCSR04超声波测距报警DS18B20温度采集 -0055 功能: 硬件组成:STM32F103R6单片机 LCD1602显示器HCSR04超声波测距传感器DS18B20温度传感器…

【C#】Kestrel和IIS服务器下的同步与异步配置

最近在回看自己写的代码时,发现服务配置里最开头写了两段代码,第一感觉,这是啥功能,太久有点生疏了,经过一顿搜索和回顾,简单整理如下 目录 1、Kestrel服务器1.1、跨平台1.2、高性能1.3、可扩展性1.4、安全…

备战秋招 | 笔试强训

目录 一、选择题 二、编程题 三、选择题题解 四、编程题题解 一、选择题 1、使用printf函数打印一个double类型的数据,要求:输出为10进制,输出左对齐30个字符,4位精度。以下哪个选项是正确的? A. %-30.4e B. %4.…

什么是OA系统,什么是工单系统,有啥区别?

一、OA系统与工单系统介绍 1、什么是OA系统 OA系统全称为Office Automation,即办公自动化系统。它是一种专门为企业和机构的日常办公工作提供服务的综合性软件平台,具有信息管理、流程管理、知识管理(档案和业务管理)、协同办公…

Appium+Python3环境搭建,其实超简单!

appium可以说是做app最火的一个自动化框架,它的主要优势是支持android和ios,另外脚本语言也是支持java和Python。略懂Python,所以接下来的教程是appiumpython,自己搭建环境的时候,按照某些博客安装遇到各种奇葩问题&am…

将Windows系统上的音频、视频通过iTunes传输到iPhone上

这个地方需要下载安装版的iTunes 下载地址: https://www.apple.com/itunes/download/win64 不要从Windows的APP Store中下载iTunes,不好使。 安装完成后,如果是导入一个文件夹中的资料,则点击 【文件】》【将文件夹添加到资料库】…

netwox伪造ARP响应【网络工程】(保姆级图文)

目录 伪造ARP响应1) 在模拟之前,验证局域网中是否存在主机 192.168.43.97。在主机 B 上使用 arping 命令 ping 该主机。执行命令如下:2) 在主机 A 上伪造 ARP 响应,创建虚拟主机 192.168.43.97,设置其 MAC 地址为 A1:B…

【华为OD机试】完全二叉树非叶子部分后序遍历【2023 B卷|200分】

【华为OD机试】-真题 !!点这里!! 【华为OD机试】真题考点分类 !!点这里 !! 题目描述: 给定一个以顺序储存结构存储整数值的完全二叉树序列(最多1000个整数), 请找出此完全二叉树的所有非叶子节点部分,然后采用后序遍历方式将此部分树(不包含叶子)输出。 1、只有一个…

ASPICE汽车软件能力如何评估

第一节我们介绍了:什么是ASPICE 上一节我们介绍了:什么是aspice认证 这一节我们看一看:ASPICE汽车软件能力是如何评估 为了使汽车电控系统的研发具有统一的流程和规范的标准,并且使整个开发进度具有可控性和可预测阻借用具有国际…

2023(WAIC)智能驾驶科技峰会丨拓数派大模型下的数据计算系统,助力汽车智能化产业数据增值

2023 智能驾驶科技峰会在上海圆满落幕,本次大会由世界人工智能大会(WAIC)组委会办公室指导,浦东新区人民政府支持,浦东新区科技和经济委员会、中国 (上海)自由贸易试验区管理委员会金桥管理局主…