Statistiques
| Révision :

root / ase / examples / plot-ase-atoms.py

Historique | Voir | Annoter | Télécharger (1,25 ko)

1 1 tkerber
from ase import Atoms, Atom, view
2 1 tkerber
from gpaw import GPAW
3 1 tkerber
4 1 tkerber
logo = """\
5 1 tkerber
 H   HH HHH
6 1 tkerber
H H H   H
7 1 tkerber
HHH  H  HH
8 1 tkerber
H H   H H
9 1 tkerber
H H HH  HHH"""
10 1 tkerber
11 1 tkerber
d = 0.8
12 1 tkerber
atoms = Atoms()
13 1 tkerber
for y, line in enumerate(logo.split('\n')):
14 1 tkerber
    for x, c in enumerate(line):
15 1 tkerber
        if c == 'H':
16 1 tkerber
            atoms.append(Atom('H', [d * x, -d * y, 0]))
17 1 tkerber
atoms.center(vacuum=2.0)
18 1 tkerber
view(atoms)
19 1 tkerber
20 1 tkerber
if 0:
21 1 tkerber
    calc = GPAW(nbands=30)
22 1 tkerber
    atoms.set_calculator(calc)
23 1 tkerber
    atoms.get_potential_energy()
24 1 tkerber
    calc.write('ase-logo.gpw')
25 1 tkerber
else:
26 1 tkerber
    calc = GPAW('ase-logo.gpw', txt=None)
27 1 tkerber
28 1 tkerber
density = calc.get_pseudo_density()
29 1 tkerber
image = density[..., density.shape[2] // 2]
30 1 tkerber
31 1 tkerber
if 1: # scale colors to wiki background / foreground
32 1 tkerber
    import numpy as np
33 1 tkerber
    background = np.array([[[19., 63., 82.]]]).T / 255 # 1c4e63 blueish
34 1 tkerber
    foreground = np.array([[[1., 1., 1.]]]).T  # white
35 1 tkerber
    image = background + image / image.max() * (foreground - background)
36 1 tkerber
    image = image.T
37 1 tkerber
else: # Use a standard color scheme
38 1 tkerber
    image = pl.cm.hot(image.T)
39 1 tkerber
40 1 tkerber
import pylab as pl
41 1 tkerber
x, y, z = atoms.cell.diagonal()
42 1 tkerber
pl.figure(1, figsize=(8, 8 * y / x), dpi=80)
43 1 tkerber
pl.axes([0, 0, 1, 1])
44 1 tkerber
pl.imshow(image,
45 1 tkerber
          origin='lower',
46 1 tkerber
          extent=[0, x, 0, y],
47 1 tkerber
          aspect='equal',
48 1 tkerber
          interpolation='spline16')
49 1 tkerber
pl.axis('off')
50 1 tkerber
pl.savefig('ase-logo.png', dpi=80)
51 1 tkerber
pl.show()