Statistiques
| Révision :

root / ase / test / strain.py @ 13

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)