Ansys Zemax | 如何将光栅数据从Lumerical导入至OpticStudio(下)

2024-04-10 20:12

本文主要是介绍Ansys Zemax | 如何将光栅数据从Lumerical导入至OpticStudio(下),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片

附件下载

联系工作人员获取附件

本文介绍了一种使用Ansys Zemax OpticStudio和Lumerical RCWA在整个光学系统中精确仿真1D/2D光栅的静态工作流程。将首先简要介绍方法。然后解释有关如何建立系统的详细信息。

本篇内容将分为上下两部分,上部将首先简要介绍方法工作流,下部将详细阐述示例部分。

介绍

在此工作流程中,设计人员首先在Lumerical FDTD或RCWA中模拟光栅,然后将数据导出到扩展名为json的文件。在OpticStudio中,用户可以导入这些数据,以精确模拟在整个宏观系统中的光栅特性。

示例

本文提供了8个示例供用户参考。第一个示例是用于演示如何建立光栅的简单光栅。接下来的3个示例(2-4)演示了文章Speos Lumerical Sub-wavelength Model中提供的同样的json示例。最后4个示例(5-8)模拟了CMOS背向衍射效应。该系统包含一个手机镜头模型和一个衍射表面,该表面读取一个json文件,用于模拟CMOS传感器上的背向衍射效应。

1. Simple_period_4um-2023R1.zar

在此示例中,请特别检查我们对光源使用的波长是否与.json文件中定义的波长相同。此外,衍射面两侧的折射率也应与.json文件中定义的相同。

图片

2. triangular_lattice_reflector.zar

在此示例中,json文件加载到了物体2衍射光栅的表面1上。

图片

由于我们将光源设置为宽带波长,因此可以看到衍射光栅引起的“彩虹”。

图片

图片

3. grating1D_x.zar

此示例与上一个示例类似。唯一的区别是我们将json文件替换为一维光栅示例。

图片

4. FDTD_1D_diffraction_grating_export.zar

在此示例中,我们在玻璃平板上放置了一个圆形光栅。准直光束入射到该光栅上,光栅将光线衍射到一个满足全反射条件的大角度,然后衍射光线在玻璃平板内传播。这展现了关于AR光波导如何工作的非常基本的概念。

图片

值得一提的是此示例的设置。如下所示,物体2和3重叠。根据嵌套规则,重叠部分的表面属性将由编辑器中物体编号较大的物体决定。在此示例中,此重叠部分的表面属性将由物体3的表面1决定,提供衍射功能。

图片

另外值得一提的是,我们之所以这样建立系统,是因为坐标系统。首先,我们可以通过从物体属性中选中“绘制局部坐标轴”选项来查看物体3的局部坐标,如下所示。可以看到,物体3的z轴指向内侧。

图片

另一方面,如果我们查看json文件,可以看到它假设-z侧(n_lower)的折射率为1.565,+z侧(n_upper)的折射率为 1.0。这就是为什么我们需要将物体3放置在玻璃平板之外,但将其与玻璃平板(物体2)重叠。另请注意,这也是为什么物体3的材料是空白的,意味着折射率为1.0,这确保了+z侧的折射率为1.0。同样地,物体3的-z侧折射率为1.565,来自物体2(玻璃平板)的材料属性。

通过这样做,我们可以确保 .json文件中的折射率条件与OpticStudio中的设置相匹配。请注意,json文件中的数据进一步来自Lumerical中的设置。从根本而言,在将json文件分配到物体时,我们是将Lumerical和OpticStudio中物体之间的坐标系相匹配。

图片

5. Plan_B_period_1um-2023R1.zar

6. Plan_B_period_1um_use_real_IR_coating-2023R1.zar

下图展示了Plan_B_period_1um_use_real_IR_coating-2023R1.zar中的数据。

图片

7. Plan_B_period_4um-2023R1.zar

8. Plan_B_period_4um_use_real_IR_coating-2023R1.zar

下图展示了Plan_B_period_4um_use_real_IR_coating-2023R1.zar中的数据。

图片

这篇关于Ansys Zemax | 如何将光栅数据从Lumerical导入至OpticStudio(下)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/892029

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指