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