infotek |
2022-12-29 08:47 |
VirtualLab Fusion中运用optiSLang进行光栅优化
f)Xr!7 摘要 :5fAPK2r< j&R+2%
)|bC^{kH!l [KJ
q 现代光学系统的优化一般会涉及到大量的参数,例如:优化光栅时不仅需要考虑光栅的几何参数,还有所需的入射方向。随着参数数量的大量增加,优化越来越具有挑战性。对于这种情况,VirtualLab Fusion提供了与Dynardo的optiSLang软件的接口,可以使用不同的高级优化算法。 GV.A+u w
ej[+y- VirtualLab Fusion和optiSLang的界面 Q{g;J`Z)p MV>$BW VirtualLab Fusion是一种灵活且可定制的建模工具平台,可以仿真复杂的光学装置,例如:将一组平面波耦合入光波导。 Jc6R{C >rsqH+oL
MrRaU x6z ~lAKJs#{ optiSLang是一种包含各种高级工具的软件平台,包括敏感度分析、多元和多学科优化、鲁棒性评估、可靠性分析和鲁棒设计优化。 5ETip'<KT6 两种软件平台的结合使得例如智能光波导耦合等高级光栅结构变为可能。 gJ$K\[+ (la[KqqCO VirtualLab Fusion – 光学装置初始化 tWeFEVg ZraT3 初始装置
*f%>YxF ─ 一般来说,在VirtualLab中定义的光学系统都可以使用optiSLang进行优化。 x#.C4O09 ─ 该例中的光学系统包含了平面波光源和用于周期性介质的波导耦合探测器。 !p/%lU65 X0(tboj#
@%ip7Y]e .
#lsic8] VirtualLab Fusion – 波导耦合探测器 2i{cQ96 SMH<'F7i 波导耦合探测 [BBEEI=|r ─ 波导耦合探测器是一种特殊工具,用以探测某个周期性结构以特定角度范围入射的效率。 ?p<.Fv8. ─ 可以从探测器的编辑对话框中的目录定义或加载周期性结构。 <
0M:"^f I
pzJ#
'B5^P rKH:[lKm VirtualLab Fusion – 波导耦合探测器 XQ%4L-rhN 波导耦合探测 %UUH" ─ 该例中使用了倾斜光栅。 a,
Q#Dk L|-98]8>
94skkEj o2z]dTJ}o VirtualLab Fusion – 波导耦合探测器 G7!W{;@I 波导耦合探测 PO:"B6 ─ 该例中使用了倾斜光栅。 t\P<X^d% 05yZad*
;W>Cqg= [r+ZE7$2b" VirtualLab Fusion – 波导耦合探测器 bV8g|l-4( BrRL7xX 波导耦合探测 'r1LSht' ─ 输入光源的入射角度范围在探测器编辑对话框中指定。 W[EKD 7 ─ 通过最小和最大笛卡尔坐标系角度alpha和beta与它们的采样点数定义。 yz8mP3"c:o eW5SFY.
~/^5) g_ G,Z^g|6 VirtualLab Fusion – 波导耦合 F
H ]4Hj 波导耦合探测 sGh(#A0Pt ─ 可以从探测得到的效率计算平均值和均匀对比度,并在探测器结果标签页中给出。 3rLTF\ ─ 作为结果,探测器可以用于评估在特定角度范围内的周期性结构。 ['8!qr su*Pk|6%
ljl^ GFo z[`@}}Q VirtualLab Fusion – 输出LPD至OPtiSLang pym!U@$t `Al;vVMRO 输出LPD至OPtiSLang AJ#Nenmj ─ File→Export→Export to optiSlang Project g&/T*L
.bBdQpF- V#VN%{ VirtualLab Fusion – 输出LPD至OPtiSLang Xpzfm7CB/ ca+5=+X7 输出LPD至OPtiSLang df7wN#kO+ ─ File→Export→Export to optiSlang Project 9tF9T\jW ─ 输出LPD文件,并产生输入至optiSLang的必要光学装置文件。 ;a:[8 Yi Eke5Nb
Ua!aaq& vpmj||\- VirtualLab Fusion – 输出LPD至OPtiSLang A}eOFu`
95el'K[R 输出LPD至OPtiSLang I? ,>DHUX ─ 在输出对话框窗口。 Lemui) 可定义参数空间,并包含了参数的变化范围。 M4as 可以选择保存到的输出文件夹。 w@,zFV 可以指定模拟引擎,用于分析。 '7O3/GDK lg^Z*&(
!47n[Zs 1GzAG;UUo6 optiSLang – 初始化优化 6}r`/?"A1 *}P~P$q% 设置求解器系统 -'6Dg ─ File→New project… 2}8v(%s p |1j["u1
dAuJXGo j]`PSl+w optiSLang – 初始化优化 l\i)$=d&g 41&\mx
设置求解器系统 EFz&N\2 ─ 继续,拖动求解器(Solver)向导到场景(Scenery)窗口。 B_.%i+ZZ ─ 打开了一个对话框,列出了几种求解器(Solver)范例。 ;+ "+3 ─ 求解器(Solver)范例中必须选择VirtualLab。 yqPdl1{Qr= ]q4rlT.i
Ofs<EQ optiSLang – 初始化优化 wb0L.'jyR) 9H]{g*kL 设置求解器系统 A}l3cP;
`# ─ 然后会弹出文件对话框,必须打开VirtualLab输出的system.lpd文件。 wpN=,&! >7 ="8
4t=G
vam;4vyu optiSLang – 初始化优化 u A<n DMO Mh#[ 参数化的求解器系统 m;,N)<~ ─ 参数化的求解器系统包含相应的VirtualLab文件和两个含有参数和结果的XML文件,用于定义优化函数。 1jcouD5?H ─ 请务必保存计划。 FYpzQ6s~ s%W C/ZK
~A\GT$ 6e|*E`I optiSLang – 初始化优化 {z{bY\ [TmIVQ!B 参数化的求解器系统 p>huRp^w ─ 运行求解器系统以检查是否能正常工作并给出预期的结果。 (JOgy.5C~ iUN Ib
" )1V]}+m K|[*t~59 optiSLang – 初始化优化 {N+$Q' JJN.ugT}1 参数化的求解器系统 p;>ec:z3M ─ 运行求解器系统以检查是否能正常工作并给出预期的结果。 %V7at7>o ─ 通过双击结果(Result)设计标签页中的参数化(Parametric)求解器系统窗口,可以检查参数和结果。 cPlZXf oG_~q
w|h
,
K~}\CR U2W|:~KM optiSLang –设置优化 MDn ua ``hf=`We 参数化的求解器系统 FOE4>zE ─ optiSLang可以进行多目标函数的光学系统优化。 Hquc
o ─ 这可以在参数化(Parametric)求解器系统配置的判据(Criteria)标签页中定义。
"y}-- K &N
e w$B)W k5'Vy8q optiSLang –设置优化 w9EOC$|Y 0Qf,@^zL* 参数化的求解器系统 3[Qxd{8r ─ 可以通过拖动均匀化对比度(Uniformity Contrast)到目标最小化(Objective Minimize)判据中定义第一目标函数。 ?67Y-\} ─ 因此优化算法会尽可能地使均匀度对比最小化。 !$gR{XH$] wfLaRP
#Lh;CSS 9y"@( optiSLang –设置优化 +nFu|qM} _Tm3<o. 参数化的求解器系统 KW pVw! ─ 可以通过拖动平均值(Mean)到目标最小化(Objective Maximize)判据中定义第二目标函数。 I;wp': ─ 因此优化算法会尽可能地使平均效率最大化。 Rl?_^dPx ─ 这步操作被称为多目标优化。 G3Hx!YW ;U+3w~
iP ->S\ .YAT:;L optiSLang –设置优化 *k.G5>@ ;n*.W|Uph 优化向导 EE06h-n s ─ 下一步可以通过拖放来使用优化向导。 #A JDWelD lZ]ZDb?P
(c=6yV@ 6
ob@[ @ optiSLang –设置优化 Z>k#n'm^z UD2C>1j 优化向导 Y!w`YYKP ─ 第一步,提供了各种系统参数,包括其指定的值范围。 Q{>+ft U ─ 此外,optiSLang提供了一个可视化的值范围,其中标出了初始值。 KQ!8ks] ─ 然后点击下一步。 y.mda:$~= [}E='m}u9+
6H.0vN& m$>H u@Va optiSLang –设置优化 P~ >OS5^ 3Ei#q+7 优化向导 7rc0yB
─ 第二步,如果在参数化的求解器系统中没有指定优化条件,则此时可以指定。 q 376m-+ ─ 也可以从其他文档中输入条件。 pP&7rRhw ─ 然后点击下一步。 a/4T>eC /K@XzwM
M2,l7
K7_UP&`=J optiSLang –设置优化 7WLy:E" [Kg+^N%+ 优化向导 NRs13M<ftf ─ 第三步,选择优化方法。 g[' ^L+hd ─ optiSLang提供了类似于红绿灯的建议形式来选择合适的方法: 5}l[>lF 红:不适用 24 ' J 黄:适用 XPXIg 绿:推荐 r=
`Jn6@ ─ 该例中推荐使用进化算法。 U2#"p
─ 然后点击下一步。 i#n0U/ MS~(D.@ZS
RLjc&WhzXu iy.p n optiSLang –设置优化 i+ ?^8# gV's=cQ 优化向导 =7=]{Cx[ ─ 然后,需要指定一些附加选项。 HAdg/3Hw ─ 建议在算法运行期间显示后期处理选项,以便在优化运行期间访问结果数据。 G5BfNU ─ 然后点击结束。 #jvtUS \ yLvDMPj
O m|_{ e'NJnPO optiSLang –进化算法的高级设置 0*3R=7_},o _`j7clEz 高级设置 {UI+$/v# ─ 双击创建优化,可以调整优化算法的详细参数。 *w`sM%]Rq Woym/[i
`r6 ,+& optiSLang –进化算法的高级设置 A:%`wX} Q->sV$^=T 高级设置 -$ls(oot ─ 双击创建优化,可以调整优化算法的详细参数。 y'q$| ─ 在标签页“初始化”、“选择”、“交叉”和“突变”中授予算法中许多参数的权限。 W:2( .? 6@5+m
0`u3
E<Y$>uKA _
]ipajT optiSLang –进化算法的高级设置 .W%)*&WH\ m=:9+z 高级设置 0Th&iA4 ─ 双击创建优化,可以调整优化算法的详细参数。 Se}c[|8 ─ 在标签页“初始化”、“选择”、“交叉”和“突变”中授予算法中许多参数的权限。 VscE ^'+ ─ 在标签页“其他”中,提供了一些预定义的参数,适用于大部分优化。(例如“EA 10000”) CY5Z{qiX =&]g "a'
""G'rN_=Bi U?Zq6_M& optiSLang –进化算法的高级设置 (y~TL*B JX;G<lev 高级设置 oLeq!K}re ─ 此外,作为附加选项,可以调整optiSLang是否自动保存。 B~ GbF*j ─ 默认情况下,在计算每个设计迭代后,项目会自动保存。 .|70; ─ 特别是对于计算时间短的设计,这会产生大量开销并减慢优化速度。 X&`t{Id?6 ─ 因此,建议将自动保存选项设置为每50或100个完成的设计后保存。 r),kDia 4Z&lYLq;
EV%gF \r+
a GB optiSLang –设计计算的并行化 g}cq K ",; H`V 并行化设置 +a+Om73B2 ─ 一些优化算法允许并行计算设计。 dR,fXQm ─ 例如,在进化算法的情况下,一代的所有成员设计的参数是已知的,因此可以同时计算以减少计算时间。 /
zPO ─ 为了允许并行计算,必须启用多个求解器。 <\^8fn ─ 通过双击VirtualLab求解器,可以找到此附加选项。 JPw.8|V)y ─ 建议数量为CPU的一半到全部真实核心之间,具体取决于每个设计的计算并行化。 VU3upy< %P|/A+Mg"
3F2w-+L bWU'cw optiSLang –开始优化 tT_\ i6My BQMpHSJ_ 运行优化 ggR.4&< ─ 单击场景(Scenery)中的进化算法(Evolutionary Algorithm)窗口。 ^u ~Q/4 ─ 点击运行按钮开始优化。 n/:33DAB E ~<JC"]
2E'UZ
m OQJ6e:BGt optiSLang –优化结果 j A%u 5V 2c*GuF9(0 优化结果 H* *Xu;/5@ ─ 优化结束后,可以在新窗口中得到结果。 b8 likP"T 2P0*NQ
eeB{c.# ZUd-<y optiSLang –优化结果 zK@@p+n_#. 3
Za} b| 优化结果 [{,1=AB ─ Pareto2D图以点云的形式同时给出了目标值、均匀度对比和平均效率。 l]8uk^E ─ 用户能够为他的应用选择最合适的设计。 T_4/C2 ─ 在这个例子中,选择了设计no.8842,具有~16%的均匀度对比和~20%的平均效率。 XwaXdvmK 4,DeHJjAlE
&D*b|ilvc ( a#BV}= optiSLang –优化结果 &F~T-i>X $=4QO 优化结果 ^ [@, ─ 每个设计都存储在子文件夹〜Optimization.opdEvolutionary_Algorithm中的optiSLang项目目录中。 cbTm'}R(G ─ 此目录中的每个文件夹(由设计编号命名)包含将设计再次导入VirtualLab所需的所有文件。 a&? :P1$ ZJiG!+-j
eJ-nKkg~a ujpJ@OWj optiSLang –导入优化结果 I; rGD^ = dN@Sa/ 导入优化结果 utV_W& ─ 要导入感兴趣的设计,使用Import optiSLang Results功能,选择相应的设计文件夹。 O:K2Y5R?B ─ 最后,可以在VirtualLab中进一步分析导入的LPD。 0o&5]lEe =rdV ]{Wc
GZIa4A 'm$L Ij?@ 总结 4j^
@wV' 9hyn`u. 作为总结,下表给出了初始和优化后的设计之间的光栅参数和性能标准的比较。 Iu=(qU
|
|