news 2025/12/25 23:04:44

伪代码示意

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
伪代码示意

利用CST对三维超材料的能带计算程序

刚接触超材料能带计算那会儿,被三维结构搞得头皮发麻。传统平面结构的Floquet模式分析套路在立方体、金字塔这些立体结构面前直接失效。摸索了两个月,终于搞定了CST里三维能带计算的完整流程,这里把踩过的坑和关键代码整理成实战指南。

打开CST先别急着建模,先调后台参数。在Global Properties里把Solver选成"Eigenmode",这个模式对周期性结构更友好。三维单元的边界条件最容易翻车,记得在Boundary Conditions里把X/Y/Z方向都设成"Periodic",相位滞后参数直接用变量kx,ky,kz代替具体数值,后面跑参数扫描要用。

建模阶段有个偷懒技巧:用VBA脚本批量生成蜂窝状立体晶格。这段循环代码能自动排列六边形单元:

For i = 0 To 10 For j = 0 To 10 Component.New "UnitCell_" & i & "_" & j ' 生成六边形基体 Block.Create "Polygon", Array(0,0.5,0), Array(1,0,0), Array(0,1,0) ' 生成内部谐振结构 Cylinder.Create "SplitRing", Array(0.3,0.3,0), 0.2, 0.05 Component.Transform "Translate", Array(i*2.5, j*2.2, 0) Next Next

重点在Z轴方向的层叠处理,用Component.Stack命令实现三维堆叠时,相位匹配参数要跟着调整,否则算出的色散曲线会有断点。

能带扫描的核心是参数化k矢量。在Solver Parameters里创建三个参数变量:

StoreParameter("kx", 0) StoreParameter("ky", 0) StoreParameter("kz", 0)

然后写个三重循环遍历布里渊区路径。比如计算Γ-X-M路径时:

for kx in np.linspace(0, π/a, 20): for ky in np.linspace(0, 0, 20): for kz in np.linspace(0, 0, 20): update_parameters(kx, ky, kz) run_solver() extract_eigenfrequencies()

实际在CST里要用VBA实现,注意每次跑完仿真要Reset才能更新k值。建议用Batch Solver模式并行计算,比单线程快5倍以上。

后处理阶段最容易忽略模式追踪。用这个Python脚本匹配不同k点的模式连续性:

def mode_matching(prev_freq, current_freqs): # 寻找最接近的上一个模式频率 indices = np.argsort(np.abs(current_freqs - prev_freq)) return indices[0]

处理完的数据用Mayavi做三维等频面可视化,能清晰看到Dirac锥的位置。遇到带隙闭合的情况,重点检查结构对称性是否被破坏,或者晶格常数设置是否导致模式简并。

最后提醒几个实战经验:1)网格划分用"Hexahedral"类型更稳定 2)设置0.1%的损耗避免奇异解 3)先跑低精度测试找到关键k点区域。曾经有个案例,完整计算需要32小时,用这个技巧优化后8小时就出结果了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/22 22:51:28

玩轮胎仿真不上手?老司机带你飙车。今天咱们用ABAQUS搞点硬核操作,从过盈充气到滚动传涵,手把手教你怎么让虚拟轮胎活起来

ABAQUS 轮胎建模-过盈充气-模态-滚动-频响仿真 abaqus 轮胎仿真包括自由模态仿真,刚度仿真,印痕仿真,接地静止的模态仿真,接地滚动模态仿真,三种状态:自由,接地静止和接地滚动的传涵仿真&#x…

作者头像 李华
网站建设 2025/12/24 23:09:33

当风电遇上“太极推手“:混合储能如何化解功率波动

5MW风电永磁直驱-1200V直流并网仿真,带混合储能系统,其中采用滑动平均滤波算法(可改为自己想用的算法)对波动功率进行分解,然后交由储能系统进行平抑。 台风天的风电场像极了喝醉酒的拳击手——出招毫无章法。我们给这个5MW的永磁直驱风电机…

作者头像 李华
网站建设 2025/12/24 13:40:31

MIPI DSI DPHY FPGA工程源码:Artix7-100t彩条驱动1024*600像...

MIPI DSI DPHY FPGA工程源码 mipi-dsi tx/mipi-dphy协议解析 MIPI DSI协议文档 纯verilog 彩条实现驱动mipi屏幕 1024*600像素。 的是fpga工程,非专业人士勿。 artix7-100t mipi-dsi未使用xilinx mipi的IP。 以及几个项目开发时搜集的MIPI DSI参考源码。最近在折腾…

作者头像 李华
网站建设 2025/12/24 7:42:32

最近在折腾四旋翼导航时踩了不少坑,发现真正让无人机听话飞行的核心都在代码细节里。今天就拿手头正在调试的飞控项目举例,聊聊怎么用代码让四旋翼实现基础导航

四旋翼代码导航先看最关键的姿态控制部分。下面这段C PID控制器代码看着简单,实测参数调不好能让无人机直接表演死亡翻滚: class PID { public:float kp, ki, kd, integral_max;float error_sum 0, last_error 0;float compute(float error, float dt)…

作者头像 李华
网站建设 2025/12/25 22:33:47

永磁同步电机全速域无传感器控制探索

永磁同步电机全速域无传感器控制 全速域 无传感器控制 1. 零低速域,采用高频脉振方波注入法 2. 中高速域采用改进的滑膜观测器,开关函数采用的是连续的sigmoid函数,转子位置提取采用的是pll锁相环 3. 转速切换区域采用的是加权切换法 带有参考…

作者头像 李华
网站建设 2025/12/23 11:05:58

Linly-Talker生成视频的镜头拉近推远动态效果实现

Linly-Talker生成视频的镜头拉近推远动态效果实现 在当前AI内容创作高速发展的背景下,数字人已不再是实验室里的概念演示,而是逐步渗透进教育、电商、金融等实际业务场景中的生产力工具。用户不再满足于“能说会动”的基础表现,而是期待更具影…

作者头像 李华