news 2026/7/5 6:44:09

Ansys Zemax|如何自定义优化操作数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Ansys Zemax|如何自定义优化操作数

附件下载

联系工作人员获取附件

概要

虽然Zemax OpticStudio有300多个内建优化操作数,但是还是会有一些特殊情况是这300多个操作数无法涵盖的。这就要求使用者根据要求计算出某些特定的数值,将这些数值返回到某个操作数,再对此操作数进行优化。

Zemax OpticStudio支持用户编程,计算出特定的数据,再通过Merit Function Editor(MFE)中的操作数来定义该数据。这些数据可以是独立于Zemax OpticStudio计算的,也可以是由Zemax OpticStudio计算的但是没有具体的优化操作数表达的。当然,不管是上述哪种情况,使用者都可以用以下两种方法计算此数值:

  • 使用ZPL宏语言

  • 使用外部定义和汇编程序

ZPL宏具有容易编写、执行快速、以及和Zemax OpticStudio集成较好的特点。只要使用者具备一点点的编程经验就可以编程计算。

另外ZPLM优化操作数可以用于从评价函数中调用ZPL宏,这样使用者就可以直接使用宏计算出结果并返回到评价函数编辑器中从而实现优化。

本文我们将介绍如何使用宏计算并通过操作数ZPLM将数值返回给评价函数。

使用操作数ZPLM返回宏计算的数值

如果您不熟悉如何创建、编辑、保存和执行宏,推荐阅读“编程语言 (ZPL) 简介”,然后再继续本练习。

现在,假设我们需要计算并优化Working F/#。当然Zemax OpticStudio中操作数WFNO已经可以解决此问题,本文只是举一个例子。所以我们可以先假设操作数WFNO不存在,我们需要用宏计算该数值并返回到评价函数中进行优化。Working F/#的定义如下:

其中n为像方空间的折射率, θ为实际边缘光线(Real Marginal Ray)在像空间的角度。根据这些定义,我们需要用宏追迹一条实际光线并计算Working F/#:

注意OPTRETURN关键字的使用,此关键字记录了全局阵列位置0处“X”的结果值。我们在MFE的ZPLM操作数“Dat#”列中填入的就是这个全局阵列的位置数。

上图中“Mac#”对应着宏数。

注意每个被ZPLM操作数调用的宏必须命名为:“ZPLxx.ZPL”的格式,宏数可以是0到99的任何数,因此ZPL17.ZPL是一个有效的文件名,可以通过在MFE中的“Mac#”填入17来调用执行。

本例中,命名该宏为ZPL10.ZPL并保存在合适的文件夹中。在MFE中,插入ZPLM操作数,分别在“Mac#”和“Dat#”中填入10和0。

更新该MFE,执行宏并返回计算得到的数值。

计算返回的Working F/#是4.9782。在MFE中插入操作数WFNO验证宏的正确性。由下图可以看出,两者计算得到的数值相同。

这种方法也可以用于单个宏调用并返回多个数值(如果想了解更多,请参考前文所说的使用者手册),这些值可以用于优化或者仅仅提供一个值给MFE做进一步分析。ZPLM可以提供惊人的速度以及弹性,使用者可以用该操作数计算并优化一些特殊数值。

用户自定义操作数是否会使评价函数计算缓慢?

也许您会好奇,在评价函数中使用自定义的操作数时,是否会使得评价函数计算缓慢?其实,这很大程度依赖于您宏计算的复杂程度,一般情况下宏计算是非常快的。

作为演示,我们现在对Cooke Triplet执行两次优化:一次使用ZPLM操作数加上宏,一次使用内建操作数WFNO。

第一种情况,我们将ZPLM的目标值设置为5,权重设置为1。第二种情况,我们将WFNO的目标值设置为5,权重设置为1。按下图设置评价函数:

我们使用DLS优化,可以看到执行的时间大约4.4s:

点击F3撤销优化,将ZPLM操作数权重设置为0,WFNO目标值设置为5,权重设置为1,再次优化。

可以看出两者计算的时间相差并不大。

因此,即使我们使用了自定义的宏,Zemax OpticStudio依旧可以高效的执行计算。

总结

在使用Zemax OpticStudio的过程中,我们有时会遇到内建的优化操作数不能满足我们要计算/返回的数值情况。这时我们需要利用ZPLM和宏结合或使用外部定义和汇编程序对这些数值进行计算和优化。两种方法,ZPLM和宏结合更为简单,与Zemax OpticStudio集成的更好,需要更少的编程技巧。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 7:34:05

LangFlow tcpreplay重放网络流量

LangFlow 与 tcpreplay:低代码 AI 开发与真实流量验证的融合实践 在今天,AI 应用正以前所未有的速度渗透进企业服务、智能客服、自动化流程等关键场景。随着大语言模型(LLM)能力不断增强,开发者面临的挑战已从“能否实…

作者头像 李华
网站建设 2026/7/4 20:11:30

PMBus读取命令流程图解:通俗解释通信步骤

PMBus读取命令实战解析:从波形到代码的完整通信链路拆解 你有没有遇到过这样的场景? 在调试一块数字电源模块时,MCU通过IC总线发起PMBus读取命令,却始终收不到有效数据——要么是NACK超时,要么返回乱码。查遍了地址、…

作者头像 李华
网站建设 2026/6/29 18:00:18

基于门电路的4位全加器设计与共阴极数码管适配

从门电路到数码管:亲手搭建一个会“算数”的数字系统 你有没有想过,计算器是怎么做加法的?在芯片内部,其实是一大堆微小的“开关”在协同工作——这些开关就是逻辑门。今天,我们就从最基础的与门、或门、异或门出发&am…

作者头像 李华
网站建设 2026/7/3 9:41:14

LangFlow AppDynamics业务影响分析

LangFlow 与 AppDynamics:构建可观察的 AI 应用开发运维闭环 在企业加速拥抱大模型的今天,一个现实问题日益凸显:如何让非专业开发者也能快速构建高质量、可维护、可观测的 AI 应用?传统的基于代码的开发方式虽然灵活,…

作者头像 李华
网站建设 2026/7/2 22:38:59

Allegro导出Gerber文件手把手教学(附参数设置)

Allegro导出Gerber文件实战指南:从设置到交付,一次成功的秘诀你有没有遇到过这样的情况?辛辛苦苦画完一块8层板,信号完整性调得明明白白,电源平面铺得整整齐齐,结果发给工厂后收到回复:“顶层缺…

作者头像 李华
网站建设 2026/7/3 8:28:36

Vivado使用从零实现:SPI接口控制器设计全过程

从零构建SPI主控制器:Vivado实战全记录 你有没有遇到过这样的场景?手头有个传感器,文档写得清清楚楚“支持SPI接口”,可你的FPGA板子上偏偏没有现成的IP核可用。这时候,是去翻Xilinx库找现成模块,还是自己动…

作者头像 李华