dFzlcKFFD CAtdx!
^k}%k#) =x-@-\m 由于相位和
结构之间的直接关系,
衍射分束镜通常采用一定的傍轴近似来设计,这些算法也提供了这种近似,反之亦然。在非傍轴或甚至高NA分束器的情况下,这些近似将引入一些不准确性,因此,如果不进行额外严格的后
优化,至少建议进行严格的分析。在这个用例中,使用奇数衍射级对典型的二元1:6分束器执行这样严格的评估。为此,对初始
系统的结构进行了
参数化,并通过可编程
光栅分析器定义了一组自定义的评价函数。对于参数优化和后续的公差分析,使用严格的傅里叶模态法 (FMM)。
?X~U[dV? vI0::ah/ 建模任务 n+H);Dg<8
W?2Z31;7
,+o*>fD BiI`oCX 衍射分束面初始设计(*) ,%U'>F?
b$/'dnx
}1?
2 `%Jq^uW 1. 采用VirtualLab Fusion的迭代傅里叶变换算法(IFTA)设计工具计算了分束器的初始相位函数。
#n6<jF1G 2. 对于高度轮廓的转换,采用了基于薄元件近似(TEA)的结构设计。
BjAmM*k Y4,LXuQ (*)不是这个用例的一部分 (**)这些会话编辑器在衍射
光学工具箱银版中可用。
OE[N$,4I* ? yek\X TEA和等距抽样结构的局限性 xAJuIR1Hi
xSL%1>MrN
ctT6va D/TEx2.=J3 TEA非常适合于最小特征尺寸不小于约5倍
波长的情况。如果不是这样,振幅/相位分布与设计高度轮廓相互作用后可能会显示出与期望值的相关偏差。
v|#}LQZ 因此,需要进行严格的评估。
B,avI&7M;S 对于参数优化,需要对结构数据进行不同的定义。
Fpckb18}(O ?n9?`8a# 后优化的数据准备(参数化) | x/Z
qY *WK0dn
P,ud"F=r QTbv3# 衍射分束器表面进一步优化 k/mO(i%qi
} 0x'm
A-5'OI qgk6 \&K[ 哪个衍射级次有哪些评价函数? L>{p>
WbH#@]+DN
=x^b U]W+ers 利用可编程光栅分析器 >Z&Y!w'A|u
J)"g`)\2 +
= 6^phZ( PHv0^l]B 分束器初始设计的严格分析 gbL!8Z1h
j/PNi@
18];fC $9Asr07 设置优化参数 iR6w)
$pGdGV\H
N_eZz#); KL4vr|i, 两个优化过程对比 z[bS
soK` 在这个用例中,我们演示了两种具有不同配置目标和约束的优化:
Jrm 9,7/ 在优化#1中,优先考虑均匀性误差。
^L +@oS 在优化#2中,0级也要最小化。
k CVA~%d7
g}Esj"7 关于评价函数约束,用户可以指定
d/!R;,^ 单独的目标值、范围、下限或上限是什么
ncCgc5uP 以及通过权重,它们的贡献应该是什么。
x9s1AzM{
p`}'-A|@ 在优化过程中,采用了内建的下降单纯形算法
L2
^-t7 76j5 评价函数约束的配置 72;ot`
^oT!%"\
P_8z'pYd> "l.1 UB& 优化#1(优先级=均匀性误差) Mz#<Vm4
@EV*QC2l;Y
dzn[4 ?O.1HEr 优化#2(优先级=均匀性误差&低0级) Re^~8q[
\.,qAc\[
d]<S/D'i l\%LT{$e 严格结果对比(初始—优化#1—优化#2) %?WR9}KU0
?OFl9%\ V
E3==gYCe* j!;y!g 公差仿真结果 /yn%0Wish
ne(zGJd
z-X_O32 1?j['~aE 研究了在±5%范围内生产过程中可能的高度公差时质量函数的表现。
!Ey= 在大部分的公差范围内,蚀刻深度误差约为±1.5%(蓝色&红色区域长度),第二种优化设计的均匀性明显较差。
TEY n^/n~ 乍一看,优化#2的最小均匀性误差(红色曲线@0%)并不居中,这似乎有些奇怪。这是因为优化#2优先考虑了低0级效率,从而牺牲了一些均匀性来实现这一目标。
jt? .g' 因此,对于公差分析的整个预期范围,第2种优化的结构总是有一个明显较低的0阶。
i9Tq h 注意:
r#;GVJR6 公差仿真结果中的参考值1总是指被检测结构的各自单独优化高度(用紫色线表示)。
|A0)-sVZ *sbZ{{]e 公差仿真结论 t/`~(0F
!0k'fYCa
@f z!]/ 公差测试提供了一个更好的信息基础,以决定什么是最适合所需应用的结构。
X:1&Pdi 可以看出,如果使用均匀度误差最低的高度,在相似的±1.3%(黄色区域长度)的公差范围内,第2次优化的结构均匀度误差低于0.5%(绿线)。
%zCV>D 因此,具有 0.9825 (707.7 nm) 额外高度缩放的第二次优化结果可能是一个具有整体性能合适的良好解决方案。在下表的最后一列“优化#2b”中显示了相应的结果。
r(Vz( ~vMdIZ.h