ZEMAX | 在MATLAB中使用ZOS-API的技巧

本文将介绍一些在MATLAB中使用 ZOS-API 的技巧,以提高您的工作效率并充分利用 ZOS-API 的功能。

简介

OpticStudio开发了应用程序接口 (API) ,用户可以使用API与不同的脚本环境进行连接和交互。使用API,用户可以与已打开的OpticStudio例程进行通信(交互扩展 ( Interactive Extension ) )或在后台运行OpticStudio(独立应用程序 ( Standalone Application ) )。这对于进行重复计算或用户处理OpticStudio生成的数据非常实用。本文只讨论ZOS-API与MATLAB相连接,并重点介绍一些技巧。(联系我们获取文章附件)

语法提示

在MATLAB中,可以使用语法提示完成代码或列出成员(如图所示):

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图1ZEMAX | 在MATLAB中使用ZOS-API的技巧的图2


这对于通过减少拼写错误和其他常见错误来提高编码的速度特别实用。但是,当MATLAB脚本完成时,不能访问变量内部的内容。可以运行示例文件的一部分——示例01:创建新文件并使用快速聚焦 ( New File and QuickFocus ) ,以及安装OpticStudio并进行检查。如果想要在MATLAB脚本已经终止时访问TheLDE,就会得到一条消息——“没有找到已完成文件”。

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图3


为了避免这个问题,必须运行MATLAB脚本并插入断点来阻止脚本运行结束。这适用于独立应用程序或将代码放在用于交互扩展的MATLABZOSConnection脚本中。通过在MATLAB中点击:编辑器 ( Editor ) > 断点 ( Breakpoints ) > 设置/清除 ( Set/Clear ) 插入断点:

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图4


MATLAB中,断点由行号旁边的红色圆圈表示。本例中,在第44行输入断点:

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图5

现在可以通过在MATLAB的 (.) 语句后按TAB键,并在脚本编辑器 ( Script Editor ) 命令窗口 ( Command Window ) 使用语法提示

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图6

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图7


另外,将代码放在单独的脚本中进行交互扩展,将路径添加到MATLABZOSConnection脚本中,并将TheApplication定义为相同的MATLABZOSConnection,而不是将代码放在OpticStudio中生成的交互扩展的MATLABZOSConnection脚本中。本例中,连接号是21。如下为可以使用的代码示例:

addpath('\\zmefs01\redirectedfolders\alastair.humphrey\Documents\Zemax\ZOS-API Projects\MATLABZOSConnection21\')TheApplication = MATLABZOSConnection21;

使用上述的任何一种方法。可以通过OpticStudio进行API命令测试,实时观察命令的运行结果。另外,命令窗口可用作实用的调试工具。因为这两种情况下主函数并没有运行结束,仍然可以通过点击工作空间中的任何对象来研究已声明的对象:

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图8

使用带有'out'参数的 .NET方法

以下是使用带有 ' out ' 参数和GetIndex的 .NET方法的示例:

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图9

当在MATLAB中使用带有 ' out '  参数的 .NET 方法时,必须确保将方法提供给的对象是正确的类型。在这种情况下,需要长度等于波长数量的双数组。下面的代码是返回表面 2在三个波长下的折射率的示例:

surf_num = 2;num_waves = 3; % probably shouldn't hard code thisindex = NET.createArray('System.Double', 3);TheApplication.PrimarySystem.LDE.GetIndex(surf_num, num_waves, index);index_data = index.double;

MATLAB 函数 methods和 methodsview

MATLAB函数methods和methodsview可以用来查看类方法名称。例如,代码可以写为:

MySag=TheApplication.PrimarySystem.Analyses.New_Analysis(ZOSAPI.Analysis.AnalysisIDM.SurfaceSag);methods(MySag)

运行得到的结果为:

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图10

在MATLAB中读取枚举

有时在OpticStudio中,可能需要在MATLAB中循环枚举来读取数据。例如,要将偶次非球面(Even Asphere)的系数读入MATLAB。

偶数非球面的表面矢高为:

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图11

可以使用偶次非球面示例文件 

"{Zemax}\Samples\Sequential\Objectives\Even Asphere.zmx" 读取系数:

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图12

可以使用eval函数并循环枚举将数据读入MATLAB:

TheSystem = TheApplication.PrimarySystem;TheLDE = TheSystem.LDE;for no_coeff=1:8EA_coeff(no_coeff) = eval(['TheLDE.GetSurfaceAt(2).GetSurfaceCell(ZOSAPI.Editors.LDE.SurfaceColumn.Par' num2str(no_coeff) ').DoubleValue']);end


ZEMAX | 在MATLAB中使用ZOS-API的技巧的图13


MATLAB中的时间性能函数

MATLAB中有一些实用的有关时间的函数,能够估计代码或部分代码运行所需的时间。在使用ZOS-API时,这些函数有助于检查优化或公差分析所需的时间。

  • 方法一 :使用 timeit 函数,它将多次运行同一个函数并返回执行代码所需时间的中位数。

  • 方法二:使用 profile 函数,它将返回特定函数执行时间的统计信息。

  • 方法三:使用秒表计时器功能。以下将讨论秒表计时器功能,使用 tic 函数启动秒表, toc 停止秒表:

如下代码摘录自示例代码:

"{Zemax}\ZOS-API SampleCode\MATLAB\MATLABStandalone_15_Seq_Optimization.m"。

ticTheMFE = TheSystem.MFE;OptWizard = TheMFE.SEQOptimizationWizard;%Optimize for smallest RMS Spot, which is "Data" = 1OptWizard.Data = 1;OptWizard.OverallWeight = 1;%Gaussian Quadrature with 3 rings (refers to index number = 2)OptWizard.Ring = 2;%Set air & glass boundariesOptWizard.IsGlassUsed = true;OptWizard.GlassMin = 3.0;OptWizard.GlassMax = 15.0;OptWizard.GlassEdge = 3.0;OptWizard.IsAirUsed = true;OptWizard.AirMin = 0.5;OptWizard.AirMax = 1000.0;OptWizard.AirEdge = 0.5;%And click OK!OptWizard.Apply();toctic;    LocalOpt = TheSystem.Tools.OpenLocalOptimization();    if ~isempty(LocalOpt)        LocalOpt.Algorithm = ZOSAPI.Tools.Optimization.OptimizationAlgorithm.DampedLeastSquares;        LocalOpt.Cycles = ZOSAPI.Tools.Optimization.OptimizationCycles.Automatic;        LocalOpt.NumberOfCores = 8;        fprintf('Local Optimization...\n');        fprintf('Initial Merit Function %6.3f\n', LocalOpt.InitialMeritFunction);        LocalOpt.RunAndWaitForCompletion();        fprintf('Final Merit Function %6.3f\n', LocalOpt.CurrentMeritFunction);        LocalOpt.Close();    end      % Get the elapsed time as a TimeSpan value.    toc;

进行局部优化 ( Local Optimization )……

初始评价函数值为:0.363

最终评价函数值为:0.170

运行时间为:1.765178秒。

MATLAB 实时编辑器 ( Live Editor )

MATLAB实时编辑器是很实用的工具,可以在其中创建实时脚本,该脚本可以与代码并行显示输出。此外,还可以添加文本、方程、图像和超链接。关于MATLAB实时编辑器的更多信息可以联系我们获取

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图14

已经从OpticStudio中检索出如下示例中的库克三片式镜头的波前图(Wavefront Map)和FFTMTF,并绘制成MATLAB图形。本例中使用的MLX文件(MATLAB实时脚本文件格式)在本文的附件中。

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图15


MATLAB 实时编辑器的实用功能是分节符,可以将代码分节并独立运行。

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图16

例如,使用库克三片式镜头,可以选中计算每个表面主光线的AOI 的代码部分,然后单击“ 分节符 ”图标。如果点击“查看每个表面上主光线的AOI”部分(此部分周围会出现蓝色的方框),然后点击“运行小节 ( Run Section) ”图标,可以分别计算该节的代码。

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图17



Zemax 全新 22.1 版本产品现已发布!

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图18

点击图片查看课程详情

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图19

点击图片查看培训详情

相关阅读 - 编程

在 MATLAB 或 Python 中使用 ZOS-API 进行光线追迹的批次处理

ZEMAX  | 了解 ZOS-API 的主要接口——MATLAB

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

ZEMAX | 如何编写 ZPL 宏:计算环带垂轴色差

ZEMAX | ZOS-API、ZPL 和 DLL 之间的区别

ZEMAX  | 如何使用 ZOS-API 创建飞行时间自定义分析

ZEMAX | 如何使用 ZPL 创建用户自定义求解



欢迎扫码添加宇熠工作人员微信,

进入 zemax 微信交流群。

一起来学习光学设计吧!

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图20

扫码邀您入群


如果您对产品感兴趣,或需要技术支持,欢迎致电垂询!

电话:027-87878386

邮箱:market@ueotek.com

关注武汉宇熠视频号 查看更多精彩视频 


ZEMAX | 在MATLAB中使用ZOS-API的技巧的图21
ZEMAX | 在MATLAB中使用ZOS-API的技巧的图22

武汉宇熠科技是 ZEMAX 中国区官方指定代理商,提供 ZEMAX 光学设计软件的培训、销售、技术支持、二次开发、解决方案及 ZEMAX 软件相关全方位定制服务。有关 ZEMAX ,您可以点击文末“阅读原文”了解更多信息,或致电垂询武汉宇熠工作人员:

销售热线:027-87878386

咨询邮箱:sales@ueotek.com

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图23
ZEMAX | 在MATLAB中使用ZOS-API的技巧的图24


ZEMAX | 在MATLAB中使用ZOS-API的技巧的图25

ZEMAX | 在MATLAB中使用ZOS-API的技巧的图26


👇点击阅读原文咨询产品或技术支持。

默认 最新
当前暂无评论,小编等你评论哦!
点赞 评论 收藏
关注