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

附件下载

联系工作人员获取附件

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

简介

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

语法提示

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

1 1

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

1

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

1

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

1

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

1 1

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

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

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

1

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

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

1

当在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可以用来查看类方法名称。例如,代码可以写为:

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

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

运行得到的结果为:

·

在MATLAB中读取枚举

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

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

1

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

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

·

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

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

MATLAB中的时间性能函数

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

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

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

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

如下代码摘录自示例代码:”{Zemax}\ZOS-API SampleCode\MATLAB\MATLABStandalone_15_Seq_Optimization.m”。

    tic
    TheMFE = TheSystem.MFE;
    OptWizard = TheMFE.SEQOptimizationWizard;
    %Optimize for smallest RMS Spot, which is "Data" = 1
    OptWizard.Data = 1;
    OptWizard.OverallWeight = 1;
    %Gaussian Quadrature with 3 rings (refers to index number = 2)
    OptWizard.Ring = 2;
    %Set air & glass boundaries
    OptWizard.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();
    toc
    tic;
        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实时编辑器的更多信息可以联系我们工作人员获取。

=

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

-

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

-

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

 -

相关软件
Logo
ZEMAX光学设计软件
ZEMAX是一套综合性的光学设计软件。它提供先进的、且符合工业标准的分析、优化、公差分析功能,能够快速准确的完成光学成像及照明设计。zemax被广泛应用于光学系统的设计和优化,强大功能使得工程师们能够更加准确和高效地设计光学系统,从而在产品研发和创新方面取得突破性进展。...
4,386浏览  |  厂商已入驻提供最新报价
Logo
Zemax OpticsBuilder
OpticsBuilder简化光学设计的封装流程,帮助光学工程师与CAD工程师高效协作,并能直观地展示光机零件的光学性能。OpticsBuilder™ 是一款帮助OpticStudio® 用户改善光机零件封装流程的软件。将光学设计转化为可生产产品意味着一个工程师团队需要围绕一个共同目标来协作并施展他...
443浏览  |  厂商已入驻提供最新报价
Logo
Zemax OpticsViewer
Zemax OpticsViewer 让设计与生产无缝衔接。Zemax 致力于帮助客户设计出先进的光学产品,并将其更快地推向市场。Zemax OpticStudio 擅长进行光学设计,而 Zemax 公司最新推出的 OpticsViewer 则用于优化光学设计与生产制造之间的流程。从功能的角度, O...
137浏览  |  厂商已入驻提供最新报价
Logo
Zemax OpticStudio
Zemax OpticStudio是一套综合性的光学设计软件。它提供先进的、且符合工业标准的光学设计、分析、优化以及公差分析功能,能够快速准确的完成光学成像及照明系统的设计。Zemax OpticStudio 是光学设计行业内领先的设计软件,其结合了各种复杂的物理以及视觉的互动,使您能够分析、模拟并...
624浏览  |  厂商已入驻提供最新报价
Logo
ZEMAX®光栅插件模块
ZEMAX里边所有的光栅模型均为理想的光栅模型,不考虑光栅的衍射效率随光波长、入射角、衍射级次的变化,所有波长、入射角、衍射级次都假定衍射效率100%,严重不符合物理实际,也无法进行公差分析。...
182浏览  |  厂商已入驻提供最新报价
Logo
Ansys Zemax OpticStudio
Ansys Zemax OpticStudio是一套综合性的光学设计软件,它提供先进的、且符合工业标准的分析、优化、公差分析功能,能够快速准确的完成光学成像及照明设计。Ansys Zemax OpticStudio适合光学工程、室内光源设计等场合,具有功能强大、灵活、快速、容易使用等优点,用户通过使...
1,389浏览  |  厂商已入驻提供最新报价
相关阅读