root / ase / examples / plot-ase-atoms.py @ 1
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() |