1. 从零开始理解你的设计任务与Zemax基础设置大家好我是老张一个在光学设计领域摸爬滚打了十多年的工程师。今天我想和大家分享一个非常经典但也最能体现光学设计核心思路的实战案例在Zemax里如何把一个简单的单透镜从“能成像”优化到“成像好”最终通过引入非球面实现性能的“跃迁”。这个过程就像打磨一块璞玉每一步的思考和操作都至关重要。咱们先别被“RMS半径”、“非球面”这些词吓到。简单来说这次的任务就是设计一个“单片眼镜”。给你一堆硬性指标镜头口径50毫米F数是4意味着焦距是200毫米视场角8度只用一种叫BK7的常见玻璃。你的目标就是让这个单片透镜的成像斑点Spot Diagram尽可能小、尽可能集中。听起来是不是有点像用一片老花镜片去给相机拍照没错本质就是挑战单片透镜的成像极限。在Zemax里开工前我心里通常会过一遍“三步走”策略设置、分析、优化。这是所有光学设计的通用心法。第一步“设置”就是搭好舞台。打开Zemax新建一个空白文件我们首先得告诉软件我们的“舞台规格”。在“系统选项”里把孔径类型设为“入瞳直径”数值填上50。单位记得检查咱们用毫米mm。这就好比确定了镜头光圈的大小。接着设置“观众席”的视野也就是视场。题目说全视场8度那半视场就是4度。我习惯设置三个视场点来看整体表现中心0度、0.7视场2.8度和边缘4度。在视场数据编辑器里添加这三个Y方向的角度值。波长更简单就一个588nm黄色光在波长数据里输入0.588。至此光线从哪里来孔径、看多宽的范围视场、是什么颜色波长这三个最基础的设定就完成了。然后开始搭建镜头结构。既然是单透镜结构非常简单物面无限远、光阑面、透镜前表面、透镜后表面、像面一共5个面。在镜头数据编辑器里逐个插入。关键一步来了如何保证F数4我们知道F数 焦距 / 入瞳直径。现在入瞳直径50mmF数要4那么焦距EFFL就必须是200mm。在Zemax里一个非常巧妙的做法是直接对像面前的那个面也就是透镜后表面的曲率半径使用“F数”求解类型并将目标值设为4。软件会自动调整这个曲率使得整个系统在给定孔径下的焦距满足要求。这比在优化函数里硬性约束EFFL操作数更直接、更“物理”。材料选BK7这是最经典的光学玻璃性能稳定价格也相对亲民。接下来给几个距离赋上初始值光阑到透镜的距离我先给个中间值3mm透镜厚度考虑到50mm的口径给个5mm不算厚透镜后表面到像面的距离既然焦距大概是200mm我就先给个200mm。这些初始值不用太精确只要在合理的物理范围内就行它们后续都会变成我们优化的变量。至此一个初始的、粗糙的单透镜系统就搭建好了。别急着优化我们先看看它“裸奔”的时候表现有多差这样才能体会后续优化的价值。2. 第一轮打磨基于RMS半径的球面优化实战系统搭好了现在进入“分析”阶段看看它到底有多糟糕。我一般会同时打开几个核心的分析窗口2D布局图、标准点列图Spot Diagram、光线光扇图Ray Fan和光程差图OPD。把它们平铺在屏幕上一目了然。先看2D图光线穿过透镜后远远没有汇聚到像面上而是发散开的这成像质量可想而知。重点看标准点列图这是我们本次优化的核心评判指标。点列图直观显示了不同视场的光线在像面上的落点分布。优化前三个视场0 0.7 1的光斑都大得吓人。注意看文本数据里的“RMS Radius”均方根半径它定量描述了光斑弥散的程度。0视场中心视场的RMS半径就超过了1100微米1.1毫米而边缘视场4度更是达到了1338微米。作为对比这个系统的艾里斑半径衍射极限大约只有几十微米。这说明当前的像差尤其是球差非常严重。再看光线光扇图它展示了不同孔径的光线在像差上的表现。理想情况下所有曲线都应该紧贴横轴零像差线。但现在你看曲线幅度非常大像差高达几千微米而且不同视场的曲线形状各异说明存在多种像差混合。光程差图也类似曲线远离横轴。这些图都一致地告诉我们这个初始透镜根本没法用。诊断完毕开始“治疗”也就是优化。优化的核心思想是在给定的材料BK7和形状球面约束下通过调整透镜的弯曲程度曲率、厚度和位置找到一组参数使得成像光斑最小。在Zemax中这通过构建“评价函数”来实现而我们的目标就是最小化评价函数的值。首先确定变量。我们把能动的几个参数设为变量按‘CtrlZ’光阑到透镜的距离空气间隔、透镜前表面的曲率半径、透镜的厚度、以及透镜后表面到像面的距离后截距。注意透镜后表面的曲率半径已经被“F数求解”锁定了以保持焦距为200mm所以它不能设为变量。然后打开“评价函数编辑器”点击“优化向导”。这里就是告诉Zemax我们想要什么。既然设计目标是“Spot Diagram的RMS半径最小”那么在“优化函数”里我们自然选择“点列图”下的“RMS”类型参考点选“质心”。光瞳采样选“高斯求积”环数Rings和臂数Arms决定了追迹光线的数量会影响优化精度和速度。对于这个单透镜我通常选3环6臂开始如果优化遇到瓶颈可以增加到4环8臂。接下来是关键一步设置边界条件。题目要求光阑到透镜的距离在2-6mm之间透镜厚度在5-10mm之间。在优化向导的“厚度边界”页面我们需要设置玻璃和空气的最小、最大及边缘厚度。但这里有个新手极易踩坑的细节软件生成的厚度边界操作数如MNCA MXCA MNCG等默认是针对所有面的我们必须手动修改只约束我们关心的那两个间隔。例如将空气厚度约束MNCA MXCA的“面1”和“面2”改为1和2这代表从面1光阑到面2透镜前表面的空气间隔。将玻璃厚度约束MNCG MXCG的“面1”和“面2”改为2和3这代表透镜本身的厚度。其他自动生成的、无关的厚度约束操作数一定要右键删除否则它们会干扰优化导致得不到合理结果。设置完成后评价函数列表里会生成一大堆操作数核心是那个RMS点列图的操作数默认是RMS。点击“优化”-“执行优化”选择“局部优化”勾选“自动更新”这样我们就能实时看到优化过程中透镜形状和成像质量的变化。点击“开始”看着评价函数值从最初的1.3多开始快速下降。优化完成后评价函数值降到了0.04左右这是一个巨大的进步。我们再来对比分析窗口点列图所有视场的光斑都显著收缩。最大视场的RMS半径从1338微米降到了132.5微米缩小了整整10倍虽然离衍射极限还有距离但已经是质的飞跃。光斑变得集中、对称。光线光扇图所有曲线都向横轴收紧幅度减小了一个数量级曲线形态变得更加规整。2D布局图可以清晰地看到所有视场的光线都很好地汇聚到了像面上。检查优化后的镜头数据光阑到透镜的距离变成了6.000mm符合≤6mm的要求透镜厚度变成了9.999mm符合5-10mm的要求透镜前表面曲率半径变为约119.3mm后截距变为约191.5mm。系统有效焦距EFFL稳稳地保持在200mm。这第一轮球面优化我们成功地利用RMS半径作为“指挥棒”在球面这个框架内把单透镜的性能榨取到了当前结构下的极限。3. 性能跃迁引入非球面的降维打击经过球面优化我们的单透镜已经像模像样了。但如果你仔细看优化后的点列图会发现边缘视场的光斑虽然小了很多但依然比中心视场大不少形状也不是完美的圆形这说明还有残余的像差主要是球差和彗差。对于单片球面透镜来说这几乎是它的理论极限了因为球面本身就有固有的球差。这时候就该请出我们的“性能跃迁”法宝——非球面。什么是非球面简单说就是表面形状不再是球面只有一个曲率半径描述而是可以用更复杂的高次方程来描述的面型。它给了光学设计者更多的“自由度”可以针对性地修正特定像差尤其是球差。在Zemax里操作起来非常简单。我们回到镜头数据编辑器找到透镜的某一个面通常是后表面因为加工等因素将其“面型”从“标准面”改为“偶次非球面”。你会发现下面多出来很多行参数二次曲面系数Conic和4阶、6阶、8阶……等高次项系数。这些系数就决定了面型偏离球面的程度。我们不需要一下子把所有高次项都设为变量那样容易导致优化失控陷入不切实际的解。一个稳健的做法是逐步释放变量。我先将“二次曲面系数”Conic和“4阶项”A4设为变量。保持其他优化设置变量、边界条件、评价函数不变再次点击“执行优化”。优化过程可能会比第一次慢一点因为软件在探索更复杂的面型空间。优化完成后你会立刻看到评价函数值进一步下降从0.04左右降到了0.027左右。别小看这零点零几的变化在光学优化里这往往意味着显著的性能提升。我们来看最直观的点列图对比。引入非球面后最大视场的RMS半径从132.5微米进一步降到了76.7微米几乎又缩小了一半光斑变得更加紧凑和对称。光线光扇图的曲线也进一步贴近横轴残余像差更小。光程差图同样显示出波前更接近理想平面。在2D或3D布局图上你可能看不出透镜形状有明显变化因为非球面的偏离量可能非常微小微米级别但正是这微小的、精心设计的形状改变带来了成像质量的巨大提升。这就是非球面的魔力用微小的形状修正抵消掉球面带来的固有像差。这里分享一个我踩过的坑非球面系数优化后一定要检查其数值是否在可加工的合理范围内。比如A4项的值是1e-8量级还是1e-3量级如果数值过大或过小可能导致加工成本急剧上升甚至无法加工。通常对于可见光系统中低阶的非球面Conic A4 A6就足以带来很大改善并且加工性较好。优化时也可以给这些非球面系数加上适当的边界操作数如操作数ASPH限制其变化范围确保设计的可实施性。4. 深度解析关键操作与避坑指南走完了从球面到非球面的完整流程咱们来深入聊聊其中的一些关键操作和容易出问题的地方。这些“Tricks”是我在多年实战中总结出来的能帮你少走很多弯路。首先关于“变量”的选择。不是所有能设变量的参数都要设。像被“F数求解”或“边缘光线高度求解”锁定的面其曲率或厚度已经被一个等式约束如果再设为变量可能会造成冲突导致优化不稳定或无法收敛。我们的原则是释放足够的自由度但避免过度参数化。对于这个单透镜四个变量一个空气间隔、一个透镜曲率、一个透镜厚度、一个后截距已经足够。其次优化函数的构建是门艺术。我们用的是默认的RMS点列图优化它对于减小光斑整体尺寸很有效。但有时候你可能更关心中心视场的质量或者边缘视场的形状。这时你可以手动在评价函数编辑器中添加操作数。例如你可以为0视场、0.7视场、1视场分别添加RSCERMS点列图尺寸以质心为参考操作数并赋予不同的权重。比如给中心视场更高的权重让优化更倾向于保证中心成像锐利。你还可以加入FCGT、FCGS等操作数来控制场曲和畸变。记住评价函数是你设计意图的数学表达你想让镜头侧重什么性能就在这里体现。第三厚度边界约束至关重要但设置要精确。前面提到的厚度边界操作数MNCAMXCAMNCGMXCG一定要精确指定到具体的面。一个更直观的方法是使用TTHI操作数直接控制某个面的厚度并设置其最小值和最大值。例如用TTHI操作数控制面2透镜的厚度最小5最大10。用CTGT或CTLT操作数也可以实现类似功能。清晰、无冲突的边界约束是优化能产出合理、可加工设计的前提。第四优化策略从局部到全局。我们一直用的是“局部优化”它会在当前设计附近寻找一个“局部最优解”。但光学系统的评价函数往往像多山峰的地形图局部优化可能让你停在一个小山坡上而旁边就有更高的山峰更好的设计。当你觉得局部优化无法再提升性能时可以尝试“全局优化”或“锤形优化”。它们会以更大的步长在变量空间里随机搜索有更大几率找到“全局最优解”或更好的“局部最优解”。但代价是计算时间很长。对于这个单透镜局部优化通常就能得到不错的结果。第五分析工具要综合使用。不要只看点列图。RMS vs Field图能一目了然地看到不同视场的RMS半径变化趋势理想情况是一条平缓的曲线。FFT MTF调制传递函数是评价成像系统分辨率的金标准优化后期一定要查看MTF曲线是否接近衍射极限。场曲/畸变图可以确保图像不变形。多维度分析才能全面评价一个镜头的性能。最后关于非球面的使用我想再强调两点一是必要性如果球面已经能满足要求就不要为了用非球面而用它会增加成本二是平衡性非球面的引入可能会改善一种像差而恶化另一种或者对公差变得极其敏感。优化后一定要做公差分析看看在合理的加工和装配误差下性能是否依然稳定。一个对公差敏感的非球面设计在实际生产中可能远不如一个稳健的球面设计。设计永远要在性能、成本和可制造性之间找到最佳平衡点。