Ansys Zemax | 如何模拟自适应光学系统

news2024/12/27 12:01:27

概述

这篇文章介绍了如何在OpticStudio中使用多重结构创建反射式自适应光学系统。本文详细介绍了:

  • 如何通过缩放光阑镜面的偏心来模拟一组镜面阵列

  • 如何使用公差功能生成随机的波前差来模拟大气不均匀性对成像的影响

  • 如何补偿该影响引入的像差以得到最优的几何和衍射点扩散函数

  • 如何使用求解功能简化系统的设置和调整参数的过程(联系我们获取文章附件)

介绍

在本文介绍的自适应反射光学系统中,反射抛物镜由多个子反射镜组成,其中每个子反射镜可以调整自身的空间位置和旋转方向来一定程度的矫正像差。特别是对于处在大气环境中的望远镜系统来说,自适应系统可以有效的降低大气层不均匀性引入的像差。OpticStudio可以在非序列或混合序列模式下模拟自适应反射光学系统。本文将展示如何在序列模式下使用多重结构对该系统进行建模。下图两幅动画展示了序列模式下自适应光学系统中反射元件的倾斜和偏心:

首先,我们需要在系统输入波前上引入随机的波前差来模拟大气不均匀性对输入光的影响。其次,我们需要调整每个反射元件的z轴位置以及绕元件中点的旋转角度,使像面上的像差最小。在下图给出的2x2报告图 (2x2 Report Graphic) 中,左上图描述了系统在输入波前上引入的随机像差,它是由蒙特卡洛算法自动生成的随机波前差。其中,其它图表动画对比了不同输入波前差的情况下,自适应光学系统矫正像差之前和之后的几何PSF和衍射PSF分析结果。

前提假设和设计目标

对于本文示例系统,我们作如下前提假设:

  • 我们将只模拟望远镜的主镜,即反射抛物面。不考虑望远镜系统中的其他元件,例如次级反射镜等。这主要是为了减少示例的复杂度,但如果需要分析也可以快速添加。

  • 每个子镜面不会产生形变。这同样是为了减少示例的复杂度,如需要也可快速添加。

  • 抛物反射镜面由19个子镜组成,我们将在编辑器中手动输入这些镜面。如果需要模拟数量更加庞大的反射镜组,可以使用ZPL宏来辅助系统建模。

  • 每个子镜面与中心子镜面顶点的径向距离设置为拾取求解,使每个子镜与特定镜面的空间位置相关联。下图动画显示了在编辑器中改变其中一个子镜的位置时,其他子镜位置的整体变化。

  • 系统使用OpticStudio产生的随机像差表示大气不均匀性对输入波前的影响。

以下为系统的部分设计指标:

镜面的矢高形状:抛物面(圆锥系数为-1)

镜面的曲率半径:-4000mm

对应焦距:-2000mm

子镜的形状:六边形

子镜的半径:150mm

在设置这些参数前,您需要充分理解多重结构、光线瞄准和系统孔径的概念。如果您对这些概念不太熟悉,请参考以下文章:

Ansys Zemax | 如何设计单透镜 第一部分:设置
ZEMAX | 如何使用光线瞄准?

系统的初始结构

首先进行如下系统设置:

  • 设置系统单位为mm(系统设置 -> 单位)

  • 设置系统波长为550μm(系统设置 -> 波长)

  • 设置单一轴上视场X = 0, Y = 0(系统设置 -> 视场)

  • 设置系统孔径为光阑尺寸浮动 (Float by Stop Size) (系统设置 -> 孔径)

  • 开启光线瞄准(系统设置 -> 光线瞄准)

我们将使用多重结构功能模拟整个反射镜组,其中每个子镜使用单独一个结构建模。设置每个镜面为光阑面,并且在该表面上设置六边形的自定义孔径 (User Defined Stop Surface, UDA)。每个子光阑的偏心通过拾取求解关联在一起,并且使用光线瞄准功能使输入光线瞄准偏心的子光阑中心。下图动画展示了通过对每个子镜设置不同缩放比例的光缆位置拾取,来实现整个镜面的设置。

            

我们将在反射镜前设置一个玻璃平板,并在平板上使用公差操作数TEZI时使平板产生形变,来实现输入波前引入像差。

系统设置

设置1

下图展示了中心子镜和其中一个偏心子镜(X = 0, Y = +540)的位置关系。需要注意的是,偏心子镜与中心子镜的相对位置关系。另外子镜的旋转中心在本系统中永远位于该表面的中心点。系统中设置有一块虚拟的玻璃平板,其折射率为常数2并且放置在像面之前100mm处。这样输入波前将在发生反射前引入像差。

图片

图片

图片

设置2(透镜数据编辑器)

在将表面输入到编辑器之前,我们需要先创建一个用户自定义的六边形孔径,并将该孔径以 “HEXAGON.UDA” 为名保存在Zemax根目录下Objects文件夹中的Apertures文件夹中。打开任意ASCII码编辑器。使用UDA语句 “POL” 定义六边形,其语法为:POL  X中心  Y中心  半径(中心到顶点)  边数(本例中为6)  绕中心旋角(0°)

               

将该文本文件保存在相应文件夹下。有关UDA语法的更多信息请参考帮助系统“User Defined Apertures and Obscurations”标签。首先,我们需要在透镜数据编辑器里对中心子镜进行建模:

将表面6设为系统的光阑面,并将该表面的表面类型设为不规则面 (Irregular),设置表面半径为150mm。我们使用不规则面代替标准面是因为这样可以直接使用表面的一个参数控制元件的偏心。在定义不规则面时,偏心的单位为透镜单位,倾斜的单位为度,对于中心子镜而言两参数均为零。在不规则面中定义元件倾斜和偏心的原理与使用坐标间断面定义的原理相同,但不规则面的倾斜和偏心在该光线完成该表面的光线追迹后自动复原。此段光线追迹的实际算法如下所示:

  1. 不规则面首先进行偏心,然后沿X轴倾斜再沿Y轴倾斜

  2. 系统在该表面上执行光线追迹

  3. 首先沿Y轴复原倾斜再沿X轴复原倾斜,最后复原偏心

在镜面表面6上定义自定义孔径HEXAGON.UDA:

在表面5的厚度参数上设置位置求解来保证表面3和表面5之间的总距离总是2100mm。这将确保无论设置镜片的偏心量为何值时,系统都会自动计算出正确的局部Z值。设置表面2的玻璃类型设为模型玻璃,并将折射率设为2,阿贝数及相对色散均设为0。这样设置的原因在于该平板只是用来模拟随机的相位分布:

图片

图片

在表面属性中设置表面6镜面的基底厚度为50mm。这只会影响镜面在布局图中的绘制厚度,对其它分析没有任何影响。

图片

设置3(透镜数据编辑器)

本文在多重结构编辑器中使用表面4坐标间断面的X方向和Y方向的偏心参数来移动光阑面位置。其中光阑面的偏心通过表面8坐标间断面的拾取求解复原。表面4坐标间断面沿X轴和Y轴的旋转角同样由表面8的拾取求解复原。需要注意的是,表面4不规则面设置的偏心需要与坐标间断面的偏心量符号相反,这样才能正确表示抛物面的离轴部分。

其中拾取求解的参数均设置为从表面4,缩放因子为-1。下图所示以表面6的参数2为例:

图片

设置4(多重结构编辑器)

设置多重结构编辑器来控制表面4坐标间断面的XY倾斜和偏心(参数4/1到4/4)。同时,插入多重结构操作数THIC来控制表面3的厚度以确保离轴元件正确的Z轴距离。当结构1的所有偏心和倾斜参数设置为0时,该结构表示中心子镜。表面3的厚度设为2100mm,这是因为中心子镜与虚拟玻璃平板的正确距离。添加一个新的结构模拟第一块离轴子镜:

图片

在结构2中模拟位于Y = 270mm,X = 0的离轴子镜。该子镜的中心距离虚拟平板玻璃的厚度可以通过在2100mm的基础上减去基底抛物镜在径向距离为270mm处的矢高得到。本例中不规则面的矢高计算方法与计算标准球面矢高的方法相同,其中不规则面的参数为:圆锥系数为-1,曲率半径为-4000mm以及径向坐标为270mm。可以在优化函数编辑器中使用优化操作数SSAG直接让OpticStudio计算出矢高值。

图片

需要注意的是,此处的计算是针对结构2而言的,因此在计算操作数前需要添加CONF并设置结构为2。由于表面已经进行了偏心,因此优化操作数SSAG的参数X和Y设为0即可。其中,编辑器计算出Z轴距离2100mm - 9.113mm = 2090.887mm作为表面3的厚度需要手动输入到透镜编辑器中。查看当前结构2的参数设置:

图片

虚拟面5与表面4坐标间断面重合。因此子镜(非中心子镜)的顶点与坐标间断面的顶点在Z轴方向上相距9.113mm。也就是说,离轴抛物镜的中点与基底抛物镜的顶点及与之重合的表面4坐标间断面的顶点在Z轴方向上相距9.113mm。由于表面5和表面1为虚拟面,因此为了使布局图正常显示,我们需要在这两个表面的表面属性的绘图选项卡中进行以下设置。

图片

图片

设置5(多重结构编辑器)

添加第三个结构:

图片

图片

从布局图中我们可以看到,第三块子镜中点的Y方向坐标为270mm * sin(30 degree) = 270 * 0.5 mm,X方向坐标为210mm * cos(30 degree) = 270 * 0.866 mm。对于该结构下的参数1到4,我们使用拾取求解并将比例系数输入到求解类型的缩放比例中。

图片

图片

重复这一步骤至结构7:

图片

打开3D布局图,并设置如下参数:

图片

图片

插入结构8,该结构对应的子镜中点位于X = 0, Y = 270mm * 2处。此时表面3的多重结构操作数THIC计算结果为53.55mm。通过优化操作数SSAG计算结构8的矢高。

图片

图片

插入结构9,多重结构操作数THIC的计算结果为62.094mm并且Y轴坐标为270mm * 1.5,X轴坐标为270mm * 0.866。

图片

图片

图片

图片

重复该步骤至结构19:

                       

对于子镜数量更庞大的系统来说,我们可以使用ZPL宏辅助生成所有结构并设置相应的拾取求解。打开3D布局图,我们可以看到如下结构:

图片

图片

设置6(优化函数编辑器)

在设置优化函数之前,首先需要确认多重结构的拾取设置是否正确。打开优化选下卡下的滑块 (Slider) 功能,将结构2的参数1在270mm到350mm范围内进行调整。点击动画 (Animate) 将在布局图中看到如下动画效果:

图片

这说明系统中子镜位置的拾取求解均正确设置。点击停止 (Exit) 推出动画效果。现在需要考虑如何设置评价函数,减小大气散射引入的像差来降低几何和衍射点扩散函数的尺寸。其中一种方法是使所有子镜在像面上光斑的几何质心位置与像面顶点重合。由于几何点扩散函数的质心和衍射点扩散函数的质心相同,因此这个方法最终会得到最小的均方根点扩散函数尺寸。此外为了使优化结果向正确的方向收敛,我们还需要限制每个子镜主光线的光程尽可能一致。打开优化函数编辑器,利用优化函数操作数CENX和CENY(质心位置)设置所有结构在像面上光斑质心的位置为0。使用优化操作数PLEN提取所有结构主光线 (PX=0, PY=0) 的光程,并将它们限制为相同的值。对于子镜数量庞大的系统来说,可以使用ZPL宏快速设置每个结构的优化操作数。

每个结构下定义优化操作数CENX, CENY, PLEN如下所示:

图片

需要注意的是,此时优化操作数PLEN上未设置任何权重。这是因为系统并不需要设置主光线的光程为一个绝对值,而需要设置它们的差值为零。此处可以使用一系列权重为0的优化操作数OPVA提取每个结构的光程值,再使用权重为1的优化操作数EQUA限制一定范围内操作数相同。

图片

图片

设置7(公差数据编辑器

使用OpticStudio中的公差功能对输入波前引入随机的波前差,并通过调整每个子镜的Z轴位置和倾斜来补偿这些像差。在公差函数编辑器中使用公差操作数TEZI在虚拟玻璃平板(表面3)上引入随机的矢高差。同时,设置表面4坐标间断面沿X轴的倾斜和沿Y轴的倾斜以及镜面的位置作为优化的补偿器(变量)。前文中使用了厚度求解来限制子镜的位置。如果想要允许子镜的位置作为优化变量,则必须在多重结构操作数中取消该求解类型并定义子镜的名义位置。在多重结构编辑器中的操作数THIC前插入一个空行,设置多重结构操作数THIC提取表面5的厚度。我们可以查看两个厚度确保玻璃平板与子镜在Z轴方向上的名义距离为2100mm。

图片

打开公差数据编辑器,插入补偿器操作数。为每个结构定义3个公差操作数CMCO分别表示X轴倾斜(多重结构第4行操作数),Y轴倾斜(多重结构第5行操作数)和Z轴位置(多重结构第7行操作数)。在定义补偿器时,必须根据多重结构编辑器中的操作数位置对补偿操作数进行分组(所有多重结构第4行操作数的补偿器为一组,依此类推)。在公差数据编辑器的最后插入公差操作数TEZI来定义引入的波前差。此处使用标准泽尼克多项式的2到9项来定义半径内波前的不规则度。其中均方根误差设置为0.5μm。

图片

图片

运行公差分析,并设置如下参数:

图片

图片

点击确定后系统提示在公差分析前取消求解设置:

图片

在公差分析结束后OpticStudio将打开公差报告文本窗口,并且在当前系统文件目录下保存了5个蒙特卡洛文件。

图片

图片

系统分析

分析1

保存当前镜头文件,并打开任意一个蒙特卡洛文件。注意文件中表面3的表面类型变为了标准泽尼克多项式面,这是由于原镜头文件中的公差操作数TEZI引入的不规则度误差。并且多重结构编辑器中的所有结构的操作数4、操作数5和操作数7被设置为变量,这是因为原镜头文件中我们通过公差操作数CMCO设置这三个参数为补偿器。其中变量均不为0,这是因为在公差分析过程中改变了这些变量以使优化函数最小。

图片

图片

在透镜数据编辑器中,表面3的附加数据中的归一化半径被设为800mm,这与表面3在透镜数据编辑器中的半径值相等。其中第2到9项泽尼克系数则是由公差操作数TEZI随机生成的。

图片

我们可以打开分析工具中的表面矢高图 (Surface Sag),并设置如下参数来查看表面3的形状分布。下图动画显示每个蒙特卡洛文件的矢高分布。由于引入的矢高误差是随机产生的,因此在您的系统中矢高误差分布可能看起来并不相同。

图片

分析2

打开分析工具中的惠更斯PSF (Huygens PSF) 分析图以及标准点列图 (Standard Spot Diagram)。将分析参数设置如下,注意在窗口导航栏中选中所有结构:

图片

图片

我们可以首先查看优化前的几何和衍射点扩散函数。设置多重结构编辑器中所有倾斜参数为零并复原镜面的位置:

图片

更新分析窗口后我们将看到如下结果:

图片

图片

通过比较可以看出对每个子镜的倾斜和Z轴位置的调整极大的减小了像面上的像差。我们可以新建一个2x2报告图在同一窗口中查看所有分析结果。下图展示了5个蒙特卡洛文件在未进行优化时以及优化后的对比分析结果:

小结

这篇文章介绍了在OpticStudio的序列模式下对反射式自适应光学系统进行建模。其中主要包括以下几个要点:

  • 每个子元件都建立在一个单独的结构中

  • 公差功能可以用来产生随机的波前差

  • 可以使用ZPL宏辅助完成元件数量庞大的系统建模

  • 正确使用拾取求解可以减少系统建模的复杂性

本文禁止转载或摘编

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《TCP/IP网络编程》阅读笔记--基于TCP的服务器端/客户端

1--TCP/IP协议栈 TCP/IP协议栈共分 4 层,可以理解为数据收发分成了 4 个层次化过程; 链路层: 链路层是物理链接领域标准化的结果,专门定义LAN、WAN、MAN等网络标准; IP层: IP层用于解决数据传输过程中路径的…

第十八课、Qt 下载、安装与配置

功能描述:介绍了 Qt 的下载、安装和配置的全部过程,并对关键页面选项进行了详细说明 一、Qt 的下载 Qt 官方下载地址:https://www.qt.io/zh-cn/downloadhttps://download.qt.io/https://download.qt.io/https://www.qt.io/zh-cn/download进入…

Unity制作下雨中的地面效果

Unity引擎制作下雨效果 大家好,我是阿赵。   之前介绍了Unity引擎里面通过UV偏移做序列帧动画的做法,这里再介绍一个进阶的用法,模拟地面下雨的雨点效果。 一、原理 最基本的原理,还是基于这个序列帧动画的做法。不过这里做一点…

深度入门 Android 车机核心 CarService 的构成和链路

作者:TechMerger 本文将结合 Android 系统整体,对 CarService 的构成和链路对其做一个全面的分析和理解。 构成 1. CarServiceHelperService 系统服务 SystemServer 中专门为了 Automotive OS 设立的系统服务,用来管理车机的核心服务 CarS…

计算机网络的故事——了解Web及网络基础

了解Web及网络基础 文章目录 了解Web及网络基础一、使用 HTTP 协议访问 Web二、HTTP 的诞生三、网络基础 TCP/IP四、与 HTTP 关系密切的协议 : IP、TCP 和 DNS 一、使用 HTTP 协议访问 Web 根据Web浏览器指定的URL,从对应的服务器中获取文件资源,从而显…

LeetCode(力扣)77. 组合Python

LeetCode77. 组合 题目链接代码 题目链接 https://leetcode.cn/problems/combinations/description/ 代码 class Solution:def combine(self, n: int, k: int) -> List[List[int]]:result []return self.backtracking(n, k, 1, [], result)def backtracking(self, n, k…

神经网络中的一些优化器整理

6 梯度平方的指数移动平均在神经网络优化中具有以下好处: 自适应学习率:梯度平方的指数移动平均允许每个参数的学习率自适应地调整。如果某个参数的梯度平方历史信息较大,那么其指数移动平均值会较大,从而减小学习率,使…

Linux下 /sys/class 一些操作

Linux下&#xff0c;/dev、/sys/class的区别 /dev下面有很多节点&#xff0c;每一个节点代表一个设备&#xff0c;/dev目录下面是按物理器件进行分类&#xff1b;而/sys/class下面的更多是按功能抽象出来的。 参考1 demo 在正点原子的基础上进行演示 #include <linux/ty…

Flink基础实操-计算单词出现次数

&#x1f947;&#x1f947;【大数据学习记录篇】-持续更新中~&#x1f947;&#x1f947; 个人主页&#xff1a;beixi 本文章收录于专栏&#xff08;点击传送&#xff09;&#xff1a;【大数据学习】 &#x1f493;&#x1f493;持续更新中&#xff0c;感谢各位前辈朋友们支持…

【python】读取.dat格式文件

import binascii# 打开二进制文件以只读二进制模式 with open(EXCEL/文件.dat, rb) as file:binary_data file.read()print(binary_data)# 将二进制数据转换为十六进制字符串 hex_data binascii.hexlify(binary_data).decode(utf-8) # binary_data 现在包含了文件的二进制内容…

R语言Meta分析核心技术

Meta分析是针对某一科研问题&#xff0c;根据明确的搜索策略、选择筛选文献标准、采用严格的评价方法&#xff0c;对来源不同的研究成果进行收集、合并及定量统计分析的方法&#xff0c;最早出现于“循证医学”&#xff0c;现已广泛应用于农林生态&#xff0c;资源环境等方面。…

原生代理IP有哪些优势?

在互联网时代&#xff0c;隐私和安全成为人们越来越关注的问题&#xff0c;原生 IP 在网络通信和隐私保护方面拥有独特的优势。原生IP也称为本土IP&#xff0c;相较于其他代理IP质量更高&#xff0c;可以更快速、更稳定地请求目标服务器&#xff0c;同时也更难被目标服务器识别…

MFC中多线程的基础知识——1互斥对象

目录 1 多线程的基本概念1.1 进程一、程序和进程的概念二、进程组成三、进程地址空间 1.2 线程一、线程组成二、线程运行三、线程创建函数 1.3 多进程与多线程并发一、多进程并发二、多线程并发 2 线程同步2.1 一个经典的线程同步问题2.2 利用互斥对象实现线程同步一、创建互斥…

B093-springsecurity整合jwt和RSA

目录 前后端分离后springsecurity核心filter的应用场景介绍JWT令牌的组成部分JWT案例导包TestJwt RSARsaUtilsTestRSA分析图 JWTRSA导包JwtUtilsTestRSAJWT 完善spring-security整合后且不连数据库的代码案例流程分析图 前后端分离后springsecurity核心filter的应用场景介绍 账…

汽车电子系统网络安全解决方案

声明 本文是学习GB-T 38628-2020 信息安全技术 汽车电子系统网络安全指南. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 汽车电子系统网络安全范围 本标准给出了汽车电子系统网络安全活动框架&#xff0c;以及在此框架下的汽车电子系统网络安全活动…

redis 5.0.x 部署

PS&#xff1a;对于使用者来说&#xff0c;Redis5.0和4.0都是一样的&#xff0c;但是redis 4.0的集群部署需要额外安装ruby的东西&#xff0c;5.0中则集成到了redis-cli&#xff0c;部署起来更方便 1.1 安装Redis 本章基于CentOS 7.9.2009编写而成&#xff0c;由于Linux发行版…

Shotcut for Mac:一款强大而易于使用的视频编辑器

随着数码相机的普及&#xff0c;视频编辑已成为我们日常生活的一部分。对于许多专业和非专业用户来说&#xff0c;找到一个易于使用且功能强大的视频编辑器是至关重要的。今天&#xff0c;我们将向您介绍Shotcut——一款专为Mac用户设计的强大视频编辑器。 什么是Shotcut&…

C#-SQLite-使用教程笔记

微软官网资料链接&#xff08;可下载文档&#xff09; 教程参考链接&#xff1a;SQLite 教程 - SQLite中文手册 项目中对应的system.dat文件可以用SQLiteStudio打开查看 参考文档&#xff1a;https://d7ehk.jb51.net/202008/books/SQLite_jb51.rar 总结介绍 1、下载SQLiteS…

【GPT引领前沿】GPT4技术与AI绘图

推荐阅读&#xff1a; 1、遥感云大数据在灾害、水体与湿地领域典型案例实践及GPT模型应用 2、GPT模型支持下的Python-GEE遥感云大数据分析、管理与可视化技术 GPT对于每个科研人员已经成为不可或缺的辅助工具&#xff0c;不同的研究领域和项目具有不同的需求。例如在科研编程…

音视频技术开发周刊 | 309

每周一期&#xff0c;纵览音视频技术领域的干货。 新闻投稿&#xff1a;contributelivevideostack.com。 腾讯云音视频及边缘平台专场邀你一起见证“连接”的力量 9月7日&#xff0c;腾讯全球数字生态大会之腾讯云音视频及边缘平台专场即将开启&#xff01;本次专场将重点分享腾…