点击 1285回复 0 原帖 2023-03-14 10:44

Ansys Zemax | 如何使用 OpticStudio 非序列优化向导

 本文描述了如何使用 OpticStudio 非序列优化向导创建常见的评价函数类型,以及创建用于匹配导入图像文件的目标能量分布评价函数。(联系我们获取文章附件)

简介

在非序列模式下优化光学系统通常比在序列模式下的优化更复杂、更耗时。下期我们将会为大家介绍非序列模式优化系列文章的第二篇-《如何优化非序列光学系统》,这篇文章描述了非序列优化的基础,其中我们发现所有的非序列评价函数必须在计算性能目标之前清除探测器和光线追迹。这个过程经常是重复且容易出错的,通常通过 OpticStudio 非序列优化向导自动实现。该向导支持创建常见类型的评价函数,并创建用于匹配导入图像文件的能量分布的相关评价函数。本文将详细讨论如何使用这两种功能来辅助优化。

非序列优化向导

许多非序列系统有着共同的性能目标,如光通量均匀性或最大光通量等。非序列优化向导提供了一种快速创建由常用评价目标组成的评价函数的工具。该工具可以在评价函数编辑器中通过 优化 (Optimization) …优化向导 (Optimization Wizards) …优化向导 (Optimization Wizard) 设置。

您还可以通过单击评价函数编辑器中的优化向导和操作数 (Wizards and Operands) 来访问优化向导(注意此工具在混合模式下不可用)。下面的窗口中评价功能组件简洁地被划分为三类。

优化向导总是将一个 NSDD 操作数添加到评价函数的顶部,该函数将在每次运行开始时清除探测器。无论是否勾选“清除数据设置 (Clear Data Settings)”选项,这在添加任何非序列评价函数时都是必要的。除此之外,“清除数据设置”选项允许用户在评价函数的任意点清除单个探测器。通常这种操作是不必要的,除非您确认需要此操作,否则请保持设置的默认值。

光线追迹设置支持常规光线追迹和 LightningTrace™ (LT)。常规光线追迹是系统默认的追迹方式,如果要使用 LT,请选择使用 LightningTrace™。注意,它只支持矩形和颜色探测器的空间数据,并且只支持极坐标探测器的角度数据,除此之外的其他任何探测器都不支持。当该功能被启用时,窗口将自动更新,以显示特定探测器的有效标准。有关  LT  和采样设置的更多信息,请参见 OpticStudio 的帮助文件:优化选项卡(非序列UI模式) (The Analyze Tab (non-sequential ui mode)) … 光线追迹选项组  (Trace Rays Group) … Lightning 追迹 (Lightning Trace)。

所有其他常规的光线追迹设置都与原光线追迹设置的选项相同。

“标准设置 (Criteria Settings)”定义了评价函数的计算目标。下拉对话框中显示的可用标准基于指定的探测器。边界条件可以通过“边界”下拉菜单选择,然后在文本框中可以定义评价目标(不管是阈值还是确切目标)。此外“最小光通量 (Minimum Flux)”也应当设置,这对于避免优化时出现没有光线入射到探测器的方案是十分必要的。如果在探测器上没有光线的情况下仍有机会达到最小光通量目标,那么这个值应该设置为非零值,不然优化向导在生成评价函数时将忽略这个评价标准。

优化向导支持点击应用 (Apply) 按钮创建动态评价函数。按下后,OpticStudio会基于当前定义的设置添加操作数,但对话框仍然保持打开状态,等待添加其他条件。点击应用 (Apply) 后,“清除数据”和“光线追迹”部分默认是停用的。通常,这些设置只在评价函数的开始时定义一次。但是如果有需要,它们也可以被重新激活。此外,“起始行”值将被更新为当前评价函数末尾的行数,这样添加新操作数时将不会覆盖任何当前定义的操作数。如果只需要添加一次操作数,点击确认 (OK) 按钮后系统将在添加完必要的操作数后关闭对话框。

投影仪示例

为了演示该功能的工作方式,请打开以下文件:

“{Zemax}\Samples\Non-sequential\Miscellaneous\Digital_projector_flys_eye_homogenizer.zmx.”。顾名思义,该系统被设计用于数字投影仪,其中透镜阵列通过模拟多个光源而不是一个非均匀光源来均匀化光束。

该模型已经优化完成,但我们可以建立评价函数来研究在这种类型的系统中哪些评价标准更加重要。


对于任何投影系统来说,最重要的两个性能是光通量均匀性和效率。我们可以构建一个以这两种性能为目标的评价函数。打开评价函数编辑器并打开优化向导。如前文所述操作,“清除数据设置”和“清除探测器:”设置应该保持原样。在光线追迹设置下,勾选启用分裂光线 (Split Rays),使用偏振 (Use Polarization),和忽略错误 (Ignore Errors)。我们的目标是最终的像平面,所以从目标设置中选择探测器对象7。我们将“空间均匀度 (Spatial Uniformity)”定义为评价标准,边界条件为“等于”零。注意,这实际上是针对光通量分布的标准差设置,因此零这个值代表完全均匀。保留所有其他设置的默认值并点击应用 (Apply)。创建的对话框和设置的评价函数如下图所示:

必要的操作数已被添加到评价函数中。注意,对话框保持打开状态,“清除数据设置”和“光线追迹设置”现已被禁用。我们目标的任何其他性能都不需要再次定义这些操作数。此外,“起始行”值已被更新当前定义的操作数之后,所以此后添加的任何评价函数都将出现在当前存在的操作数之后。

如果我们想要达到 100% 的效率,我们可以使用最小光通量设置,但我们将设定一个更实际的限制。放映机的合理标准是至少 65% 的效率。并且,这个投影仪的光源是一盏 10,000 流明的灯,因此我们的目标是总流明超过 6500 流明。定义如下所示的设置,并单击确认

OpticStudio 在之前定义的评价函数之后为总光通量添加了额外的操作数。在确定了恰当的变量之后,系统就可以进行优化了。这个添加额外操作数的过程使评价函数的定义过程变得更为快速容易。

非序列 BMP 位图向导

非序列 BMP 位图向导是一个专门用于定位探测器上复杂的光通量和颜色分布的工具。窗口中的大多数设置,如下图所示,与前面讨论的评价功能工具相同,而这里的区别在于“目标设置 (Target Settings)”部分。


探测器对话框中只会显示矩形探测器和颜色探测器,因为它们是该功能支持的仅有探测器类型。输入文件可以是位于 “{Zemax}\IMAFiles”目录中的任何 BMP、JPG 或 PNG 文件。该输入图像定义了光通量和颜色的相对分布,但它没有定义绝对光通量。总光通量设置允许目标缩放以获得一定的总光通量,同时保留在图像中定义的相对分布。如果选择了颜色探测器,颜色目标设置将启用。

预览显示了在探测器上的目标分布中定义的设置具体看起来如何。如果图像分辨率与探测器分辨率不同,图像将被重新采样到探测器的大小。请注意,低分辨率探测器可能会出现混叠,也可能只在对话框中显示图像。在上面的对话框中,一个306 x 306的位图被向下采样到一个50 x 50的探测器。或者您可以选择重新取样探测器。通过激活“重采样探测器 (Resample Detector)”,探测器上的像素数将被改变以匹配位图中的像素数。

预览还显示是否选择了彩色目标,或者目标是否简单地聚焦于每个像素的光通量(灰度)。预览是一种快速而强大的功能,可以根据已定义的设置可视化所需的目标。

该工具还可以在不关闭对话框的情况下添加操作数。请注意,在使用位图向导时,通常会添加大量操作数。对于灰度目标,探测器上的每个像素都需要添加一个操作数。对于一个颜色目标,探测器上的每个像素也都要添加三个操作数。即使是中等大小的图像文件也需要一段时间才能将目标添加到评价函数中。一个306 x 306探测器需要93,636个用于灰度的操作数,280,908个用于颜色的操作数。建议使用可以准确地表示所需的光通量/颜色分布的最低分辨率图像。

当单击确认 (OK)应用 (Apply) 时,OpticStudio 将在窗口顶部给出一个进度指示器。如果进程花费的时间太长,可以按终止 (Terminate) 按钮结束进程。在这种情况下,OpticStudio 将删除进程终止前添加到评价函数的所有操作数。

彩色测试靶示例

为了简单地说明这个工具,让我们看一看如何为一个简单的方格颜色测试靶创建的评价函数。本示例中使用的图像 “ColorTestMeritFunction” 是为了演示该工具的功能而设计的,可在附件部分下载。如下图所示,使用彩色象限组成的图像作为测试靶。


当启用彩色测试靶时,OpticStudio 将为每个像素添加三个目标操作数。这些目标对应每个像素的 X 、 Y 和 Z 三刺激值。此外,添加一个总光通量操作数以确保绝对光通量是测试探测器面的。用这种方式定义目标似乎有些单调乏味,但是这种针对单个像素的方法非常有效。一旦光线被追迹,OpticStudio 可以非常快速地确定任何像素的颜色和强度。最耗时的优化部分是光线追迹,在此之后数据则容易计算。

通过 OpticStudio 优化向导,可以轻松定义复杂的评价函数。非序列优化向导工具允许用动态的方式定义常见的目标。非序列 BMP 位图向导自动建立任何图像文件中可描述的光通量和颜色分布操作数,将这项极其耗时的任务在几秒或几分钟内完成。所有上述功能都与  OpticStudio  中的强大优化工具和算法协同工作。

举报收藏 0打赏 0