ZEMAX | 如何編寫 ZPL 宏:計算環(huán)帶垂軸色差
本文介紹如何使用 Zemax 編程語言 (ZPL) 創(chuàng)建宏來計算和繪制用戶自定義的性能指標。在本示例中,系統(tǒng)的環(huán)帶垂軸色差 (Zonal Transverse Chromatic Aberration, ZTCA) 將被分析。在解釋了需要使用的基本算法之后,本文將描述如何將宏通用化以允許用戶進行更加靈活的使用,包括用戶輸入和錯誤捕獲。(聯(lián)系我們獲取文章附件)
簡介
假設(shè)我們要計算系統(tǒng)的環(huán)帶垂軸色差 (ZTCA)。ZTCA 作為光瞳區(qū)域的函數(shù),定義為兩個波長在像平面上的光線高度差
ZTCA = YF - YC
基本算法如下:
1、定義步進式光瞳區(qū)域
2、對應(yīng)追跡每個波長的邊緣光線
3、減去 y 坐標
4、輸出結(jié)果
我們建議在編寫 ZPL 宏時將采用以下編程規(guī)范,使宏更易于閱讀:
· 將所有變量寫成小寫形式
· 將所有 ZPL 函數(shù)和關(guān)鍵字寫成大寫形式
· 對IF和FOR循環(huán)采用文本縮進
· 賦予變量有意義的名稱 (例如 ray_angle 而不是 a)
· 使用描述性注釋(例如使用 ! 或 #)
為了使宏更易于閱讀,OpticStudio 具有內(nèi)置的文本編輯器,將語法突出顯示:

初版宏的編寫
對于此示例,我們將使用示例文件

輸入以下代碼,以根據(jù)之前描述的算法流程來計算環(huán)帶垂軸色差 (ZTCA) :

使用功能區(qū)上的第二個按鈕將宏另存至

然后,從“編程 (The Programming tab) ”選項卡中,從“宏列表 (Macro List) ”下拉菜單中選擇已保存的宏,或者從“編輯/運行 (Edit/Run) ”中選擇它,然后單擊“運行 (Run) ”。

運行宏時,將出現(xiàn)一個新的文本窗口,其中包含宏的輸出。在本示例中,輸出結(jié)果為環(huán)帶垂軸色差 ZTCA ,作為光瞳區(qū)域的函數(shù):

請注意,此宏文件需要基于許多假設(shè),確保宏能夠正常運行:
· 邊界波長是 1 和 3
· 步進數(shù)為 10
· 它僅計算軸上視場的環(huán)帶垂軸色差 ZTCA
· 無錯誤檢查功能
如果只有一個波長怎么辦?
讓我們改進宏,使其可以與其他文件一起使用。
通用宏的編寫 用戶自定義的步進數(shù)
我們可以使用 INPUT 關(guān)鍵字提示用戶輸入步進數(shù),而不是使用固定值 10。在宏的開頭,刪除賦值“numsteps = 10”并按如下方式使用 INPUT :

運行宏時,“ ZPL 宏輸入 (ZPL Macro Input) ”窗口將出現(xiàn):

IF 語句通過函數(shù) INTE() 測試 numsteps 是否為正整數(shù),該函數(shù)將會對數(shù)值進行四舍五入。 GOTO 命令 OpticStudio 使用指定的 LABEL 命令將程序跳至某一行(向前或向后)。在這種情況下,我們使其跳到程序的結(jié)尾:

盡管 END 在使用子例程時才被嚴格要求,但是使用它來指示宏的執(zhí)行在何處終止是一個良好的編程習(xí)慣。
適應(yīng)不同的波長
接下來,我們可以要求宏確定臨界波長(最小和最大),并將其用于光線追跡中。如果文件中僅定義了一個波長,我們也可以要求宏返回錯誤消息:

現(xiàn)在,用于光線追跡的波長是 minwav 和 maxwav,因此在 FOR 循環(huán)中,將行:
RAYTRACE 0, 0, 0, py, 1
RAYTRACE 0, 0, 0, py, 3
用以下兩行替換:
RAYTRACE 0, 0, 0, py, minwav
RAYTRACE 0, 0, 0, py, maxwav
錯誤檢查
最后,我們可以使用 RAYE() 檢查光線追跡期間的錯誤。因此,代碼變?yōu)椋?

將宏另存為 ZTCA2.ZPL 并測試代碼正確性,確保您測試了每種錯誤情況:
· 用戶定義的步進 < 1 或非整數(shù)
· 僅1個波長
· 光線錯誤
以下是20個光瞳區(qū)域的宏輸出:

錯誤檢查
除了輸出數(shù)據(jù)外,我們還可以使用 PLOT 或 PLOT2D 關(guān)鍵字來繪制數(shù)據(jù)。 PLOT 支持一個自變量和一個因變量,而 PLOT2D 支持兩個自變量和一個因變量。這兩個關(guān)鍵字都允許用戶充分控制繪圖格式,例如:
· 標題,坐標軸圖例
· X,Y 軸刻度
· 注釋
· 數(shù)據(jù)點和擬合線:顏色、樣式、大小
· 窗口縱橫比
為了能夠繪制數(shù)據(jù),首先需要聲明兩個數(shù)組變量:一個用于光瞳坐標,一個用于環(huán)帶垂軸色差 ZTCA。在用戶輸入和錯誤檢查代碼之后添加數(shù)組聲明:
DECLARE pupil, double, 1, (numsteps + 1)
DECLARE ztca, double, 1, (numsteps + 1)
然后,在主循環(huán)內(nèi),您需要將值存儲在先前聲明的數(shù)組中,而不是將其輸出到屏幕上。 這意味著將此行:
PRINT "Pupil zone = ", py, " ZTCA = ", yf-yc
用下兩行替換:
pupil(i+1) = py
ztca(i+1) = yf-yc
最后,在主循環(huán)之后添加代碼以創(chuàng)建繪圖:
PLOT NEW
PLOT BANNER, "ZTCA vs Py"
PLOT TITLE, "Zonal Transverse Chromatic Aberration"
PLOT TITLEX, "Normalized Pupil Coordinate (Py)"
PLOT TITLEY, "ZTCA (mm)"
PLOT RANGEX, 0, 1
PLOT RANGEY, -0.005, 0.005
PLOT DATA, pupil, ztca, (numsteps + 1), 1, 2, 0
PLOT GO
PLOT DATA 用于定義要繪制的一系列數(shù)據(jù)點。它需要以下參數(shù):
x_array, y_array, #points, color, style, options
在本例程中顏色 1 = 藍色 (Color 1 = blue), 樣式 2 = 虛線 (style 2 = dashed), 可選項 0 = 無數(shù)據(jù)點標記 (option 0 = no data point markers)。
PLOT 語法的完整說明可以在幫助文件部分的編程選項卡 (The Programming Tab) > 關(guān)于 ZPL (About the ZPL) > 關(guān)鍵字(關(guān)于zpl) (KEYWORDS (about the zpl) ) > 繪圖 (PLOT) 中進行了描述。
現(xiàn)在將宏另存為 ZTCA3.zpl 并運行它。該宏將產(chǎn)生以下繪圖:
