今天搞了个好玩的——用COMSOL复现光子晶体扭转结构的能带和透射谱。这玩意儿和魔角石墨烯有点像,两个光子晶体叠一起转个角度,能带结构就开始整活了

comsol光学仿真文献复现 计算Moire晶格,扭转光子晶体结构能带,透射谱

先说说怎么建模。Moire晶格的关键是两个周期结构叠罗汉,这里用三角形空气孔光子晶体举例。COMSOL里手动画六边形晶格太麻烦,直接上脚本生成坐标:

matlab 复制代码
theta = 7.5; % 扭转角度
a = 500e-9;  % 原胞尺寸
r = 0.3*a;   % 空气孔半径

% 生成初始晶格坐标
[x_base, y_base] = meshgrid(-3*a:a:3*a, -3*a*sqrt(3)/2:a*sqrt(3)/2:3*a*sqrt(3)/2);
x_offset = x_base + a/2*mod(y_base/(a*sqrt(3)/2),2);
coords = [x_offset(:), y_base(:)];

% 应用旋转
R = [cosd(theta) -sind(theta); sind(theta) cosd(theta)];
rot_coords = (R * coords')'; 

这段代码生成两组旋转后的坐标点,导入COMSOL几何界面直接创建圆柱体空气孔就行。注意要控制原胞数量,3×3重复单元足够捕捉Moire特征,再大计算量爆炸。

能带计算的重点是边界条件设置。在"研究"里选频域,波矢k沿着不可约布里渊区边界扫描。这里有个坑------扭转结构原胞变大,得手动修改周期性条件:

java 复制代码
// COMSOL Java API片段
model.physics("pw").prop("Periodic").set("kappax", "k0x");
model.physics("pw").prop("Periodic").set("kappay", "k0y");
model.study("std1").feature("param").set("pname", new String[]{"k0x", "k0y"});

参数扫描时k0x和k0y要走六边形路径。建议用参数化扫描代替传统能带计算,否则遇到简并点容易漏模式。

comsol光学仿真文献复现 计算Moire晶格,扭转光子晶体结构能带,透射谱

透射谱部分更刺激。需要在上下表面加端口,注意高阶衍射的处理。这里用自定义散射边界条件防止反射:

cpp 复制代码
// 自定义材料表达式
double k0 = 2*M_PI*freq/3e8;
ex = ex - 1j*(k0*(x^2+y^2)^0.5)*scattering_field;

实测发现当扭转角接近7度时,透射谱在1550nm附近会出现双共振峰,和文献里的魔角现象吻合。不过计算时网格得加密到λ/10以下,否则共振峰位置漂移严重。

最后说个实用技巧:用LiveLink for MATLAB联动做后处理。COMSOL自带的绘图工具处理能带比较笨,用MATLAB抓取数据后上色处理更灵活:

matlab 复制代码
data = mphgetquad(model, 'e1', 'solution', 'sol1');
band_gap = (data.E > 0.8e15) & (data.E < 1.2e15); 
contourf(data.kx, data.ky, band_gap, 'EdgeColor','none');

这么搞出来的能带图可以直接标出带隙区域,比默认图表直观多了。算完记得喝杯咖啡------这破仿真没六个小时跑不完,趁这个时间正好补个觉。

相关推荐
sun_tao12 小时前
RAG 系统 Embedding 选型要点
人工智能·llm·embedding·rag
Anastasiozzzz2 天前
深入理解RAG:文本分片(Chunking)
embedding
人工智能小豪2 天前
LLM的具身鸿沟有解了!微调让大模型真正学会人类的感官与动作感知
人工智能·ai·llm·prompt·embedding·agent·rag
mo_alo3 天前
Everything Claude Code 完全指南:给 Claude Code 装上涡轮增压【安装和使用超详细教程!!!】
笔记·embedding·ai编程·claude·ecc
大傻^12 天前
LangChain4j RAG 核心:Document、Embedding 与向量存储抽象
开发语言·人工智能·python·embedding·langchain4j
青火coding12 天前
Embedding是什么?从文本转向量
java·机器学习·ai·embedding
L-影13 天前
下篇:从静态到动态,Embedding的进化之路
人工智能·ai·embedding
ん贤15 天前
一文读懂 Go-Eino 的 Embedding
开发语言·golang·embedding
智慧地球(AI·Earth)15 天前
谷歌发布 Gemini Embedding 2:首个原生全模态向量模型,打通音视频与图文!
音视频·语音识别·embedding
小蜗牛~向前冲17 天前
大模型学习系列-Embedding与向量数据库
人工智能·python·神经网络·学习·机器学习·embedding