root / ase / test / strain.py @ 4
Historique | Voir | Annoter | Télécharger (818 octet)
| 1 | 1 | tkerber | from math import sqrt |
|---|---|---|---|
| 2 | 1 | tkerber | from ase import Atoms |
| 3 | 1 | tkerber | from ase.constraints import StrainFilter |
| 4 | 1 | tkerber | from ase.optimize.mdmin import MDMin |
| 5 | 1 | tkerber | from ase.io import PickleTrajectory |
| 6 | 1 | tkerber | try:
|
| 7 | 1 | tkerber | from asap3 import EMT |
| 8 | 1 | tkerber | except ImportError: |
| 9 | 1 | tkerber | pass
|
| 10 | 1 | tkerber | else:
|
| 11 | 1 | tkerber | a = 3.6
|
| 12 | 1 | tkerber | b = a / 2
|
| 13 | 1 | tkerber | cu = Atoms('Cu', cell=[(0,b,b),(b,0,b),(b,b,0)], pbc=1) * (6, 6, 6) |
| 14 | 1 | tkerber | |
| 15 | 1 | tkerber | cu.set_calculator(EMT()) |
| 16 | 1 | tkerber | f = StrainFilter(cu, [1, 1, 1, 0, 0, 0]) |
| 17 | 1 | tkerber | opt = MDMin(f, dt=0.01)
|
| 18 | 1 | tkerber | t = PickleTrajectory('Cu.traj', 'w', cu) |
| 19 | 1 | tkerber | opt.attach(t) |
| 20 | 1 | tkerber | opt.run(0.001)
|
| 21 | 1 | tkerber | |
| 22 | 1 | tkerber | # HCP:
|
| 23 | 1 | tkerber | from ase.lattice.surface import hcp0001 |
| 24 | 1 | tkerber | cu = hcp0001('Cu', (1, 1, 2), a=a / sqrt(2)) |
| 25 | 1 | tkerber | cu.cell[1,0] += 0.05 |
| 26 | 1 | tkerber | cu *= (6, 6, 3) |
| 27 | 1 | tkerber | |
| 28 | 1 | tkerber | cu.set_calculator(EMT()) |
| 29 | 1 | tkerber | f = StrainFilter(cu) |
| 30 | 1 | tkerber | opt = MDMin(f, dt=0.01)
|
| 31 | 1 | tkerber | t = PickleTrajectory('Cu.traj', 'w', cu) |
| 32 | 1 | tkerber | opt.attach(t) |
| 33 | 1 | tkerber | opt.run(0.01)
|