今天搞了个好玩的——用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');

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

相关推荐
致Great10 小时前
零索引、零 embedding、纯 grep:DCI直接在原始语料上做 deep research
embedding
打小就很皮...1 天前
基于 Python + LangChain + RAG 的知识检索系统实战
前端·langchain·embedding·rag
NCU_wander4 天前
graphrag bm25 和 embedding混合使用
embedding
庞轩px6 天前
Embedding与向量语义——大模型是怎样“理解”文字的?
人工智能·自然语言处理·embedding·向量检索·余弦相似度·rag·高维向量空间
Aision_6 天前
LangGraph 中 State、Node、Edge 是怎么协作的?
langchain·prompt·aigc·embedding·ai编程·ai写作·agi
Arhero6 天前
Semantic Chunk 为什么需要 Embedding API
动态规划·embedding·rag·文本切分·语义分块
鹏子训10 天前
AI记忆新思路:用SQLite替代向量数据库,去EMBEDDINGS化,谷歌开源Google Always On Memory Agent
数据库·人工智能·sqlite·embedding
马优晨12 天前
大语言模型(LLM)、Embedding 模型、reranker重排序模型 有什么关系
人工智能·语言模型·embedding·embedding 模型·大语言模型(llm)