ZEMAX进阶:ZPL宏优化与ZPLM操作数详解

本文介绍了如何通过使用 ZPLM 优化操作数在 评价函数编辑器 (Merit Function Editor )中使用 ZPL 宏定义复杂的优化目标。本文介绍了如何使用 ZPLM 约束系统的质心,以确保其能正确地平衡。

简介

OpticStudio 中有将近400个操作数,几乎可以将任何感兴趣的值作为目标,包括SINE,PROD,SQRT 等数学操作数,可以定义详尽的评价函数。有时所需的值需要进行复杂的计算,但是无法在评价函数编辑器中执行。在这种情况下,可以使用优化操作数 ZPLM 执行宏来确定操作数的值。运行宏,并使用 OPTRETURN 关键字将值返回给评价函数。
 

ZPLM 操作数

ZPLM  操作数包含六个参数: Mac#, Data, Hx, Hy, Px, Py

  • Mac# 是 OpticStudio 应该执行的宏的编号。应将与 ZPLM 操作数一起使用的宏另存为 ZPLnn.zpl,其中,00 ≤ nn ≤ 99。
  • 例如,ZPLM 调用宏 ZPL03.zpl 时,Mac# 应该为3。
  • Data 是由宏计算出来的数据值。单个宏中最多可以计算51个数据值 (0 ≤ Data ≤ 50)。为了提高效率,仅当 Data = 0 时才执行宏;否则,将使用来自先前宏调用的数据(即 Data = 0,至少需要调用一次)。
  • Hx, Hy, Px, 和 Py 是可以传递给宏以用于计算的值,它们不一定必须是归一化的视场/光瞳坐标:

ZEMAX | 使用 ZPL 宏进行优化:ZPLM 操作数的图1


下面的示例将说明与 ZPLM 优化操作数一起使用的宏的定义。
 

ZPLM 示例:质心约束


在某些光学系统(瞄准镜,双筒望远镜,安装在三脚架上的照相机等)中,质心是要考虑的重要的机械因素。假设我们正在设计瞄准镜,其中一个约束条件是使系统平衡。这意味着,质心(CM)应该位于前组元件和后组元件之间的中间位置。
 

加载示例文件:<Documents>\Zemax\Samples\Sequential\Afocal\Afocal Riflescope.zmx
 

ZEMAX | 使用 ZPL 宏进行优化:ZPLM 操作数的图2


出于本示例的目的,将做出一些简化示例的假设:

  • 所有透镜均旋转对称
  • 所有材料为均匀介质
  • 每个透镜的质心都位于顶点的中间(严格来说,这仅适用于曲率相等且符号相反的透镜)
  • 表面1是全局坐标参考(GCRS)


要限制质心的位置需要有以下参数:

  • 每个元件的全局位置
  • 每个元件的质量
  • 系统总长(前透镜至后透镜)


因此,将使用以下 ZPL 函数和关键字:

  • GLCZ() 函数返回表面的全局 z 坐标
  • OPEV() 函数使用 TMAS 优化操作数提取元件的质量
  • GETSYSTEMDATA 关键字返回总光路长度(表面1到像面)
  • OPTRETURN 关键字将数据返回到宏

ZPLM 宏代码

文章附件中“质心”宏,如下所示:(联系我们获取文章附件)

ZEMAX | 使用 ZPL 宏进行优化:ZPLM 操作数的图3

将宏另存为:ZPL01.ZPL,以便可以使用 Mac#= 1调用它。

评价函数中的 ZPLM

在评价函数中,添加 Mac#= 1,Data= 0 的 ZPLM 操作数,这将运行宏并返回系统的质心。
 

ZEMAX | 使用 ZPL 宏进行优化:ZPLM 操作数的图4


此处仅返回一个值,要返回其他值,只需在宏中添加额外的  OPTRETURN 行:
 


OPTRETURN data_number, value


在此示例中,不进行优化,但是,操作过程与其他操作数相同(即设置所需的目标值和非零权重)。请注意,宏返回的值的单位可以是任意的,因此需要考虑ZPLM操作数的权重,以准确地表达此目标值相对于评价函数中列出的其他目标值的重要性。特别是,此宏需要非常小的权重才能使ZPLM与其他针对系统性能的操作数保持平衡。
 


如前所述,ZPLM 可以使用最多四个值(Hx,Hy,Px,Py)将数据传递到宏。可以使用  PVHX(), PVHY(), PVPX(), PVPY() 数值函数在宏中访问传递的值。在此示例中,可以将镜筒质心的位置和质量传递给宏,以说明镜筒和透镜组合的质心。
 

  • Hx = 镜筒质心到系统中心的距离
  • Hy = 镜筒质量

按照下图修改宏,并将修改后的宏另存为ZPL02.zpl。

ZEMAX | 使用 ZPL 宏进行优化:ZPLM 操作数的图5


在评价函数中,将 Mac#设置为2,输入镜筒质心位置(Hx)和质量(Hy)的值,并注意报告的数据值的变化:
 

ZEMAX | 使用 ZPL 宏进行优化:ZPLM 操作数的图6


切记:仅当 Data = 0 时才执行宏,以提高评价函数的评估速度。




免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删

QR Code
微信扫一扫,欢迎咨询~

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 155-2731-8020
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

手机不正确

公司不为空