# 使用 ASE 来完成晶胞及原子结构的进一步优化 mol = mol_ini.clone() p1 = spdkit.to_ase_atoms(mol) calc_elastic = ElasticModel(mol, chemenv) p1.set_calculator(calc_elastic) box = Mushybox(p1) # dyn = FIRE(p1, maxstep=0.1) dyn = FIRE(box, maxstep=0.1) dyn.run(fmax=0.001, steps=100)。修改上述代码,输出ASE晶胞优化的结构
时间: 2024-03-07 18:46:41 浏览: 66
可以在上述代码的最后加上以下代码来输出优化后的结构:
```
# 输出优化后的结构
print("优化后的晶格参数:", box.get_cell())
print("优化后的原子坐标:")
for atom in box:
print(atom.symbol, atom.position)
```
其中,`box.get_cell()`可以获取优化后的晶格参数,`for atom in box:`可以遍历优化后的原子坐标并输出。
相关问题
修改代码:要求输出ASE晶胞优化后的结构。mol_ini = Molecule.from_file("Fe32C9/60_1/POSCAR") mol_opt = Molecule.from_file("Fe32C9/60_1/CONTCAR") mol_refined, chemenv = refine(mol_ini, submols) # 使用 ASE 来完成晶胞及原子结构的进一步优化 mol = mol_ini.clone() p1 = spdkit.to_ase_atoms(mol) calc_elastic = ElasticModel(mol, chemenv) p1.set_calculator(calc_elastic) box = Mushybox(p1) # dyn = FIRE(p1, maxstep=0.1) dyn = FIRE(box, maxstep=0.1) dyn.run(fmax=0.001, steps=100)
您需要将代码中的最后一行修改为以下内容:
```
ase.io.write("Fe32C9/60_1/optimized_POSCAR", box.to_atoms())
```
这将输出ASE优化后的结构到名为“optimized_POSCAR”的文件中。如果需要输出其他格式的文件,可以将`optimized_POSCAR`替换为所需格式的文件名,如`optimized.xyz`或`optimized.cif`。
使用 ASE 来完成晶胞及原子结构的进一步优化 mol = mol_ini.clone() p1 = spdkit.to_ase_atoms(mol) calc_elastic = ElasticModel(mol, chemenv) p1.set_calculator(calc_elastic) box = Mushybox(p1) # dyn = FIRE(p1, maxstep=0.1) dyn = FIRE(box, maxstep=0.1) dyn.run(fmax=0.001, steps=100)。修改上述代码,输出ASE晶胞优化的结构为cif
要将优化后的晶体结构输出为cif文件,可以使用ASE中的`write()`函数。具体来说,可以在代码最后添加以下代码:
```
from ase.io import write
# 输出优化后的结构为cif文件
write('optimized_structure.cif', box, format='cif')
```
其中,`write()`函数的第一个参数是要输出的文件名,第二个参数是要输出的结构,第三个参数是输出格式,这里选择了cif格式。这样,优化后的晶体结构就会被保存到名为`optimized_structure.cif`的文件中。
阅读全文