Nom : fichier de positions atomiques XYZ
Extension : xyz
Spécification: informelle
Programmes de visualisation : Aten, AViz, gdis, Jmol, OVITO, VESTA, VMD, XMol
Le format XYZ, bien que largement utilisé par de nombreux programmes, n'a jamais été formellement décrit ni publié. Il s'agit d'un fichier texte contenant le nombre d'atomes, une ligne de commentaire, suivi des positions des atomes au format 'espèce x y z
' :
<NP>
commentaire
<atom1> <x1> <y1> <z1>
<atom2> <x2> <y2> <z2>
... ... ...
<atomN> <xN> <yN> <zN>
Puisqu'aucune spécification standard n'existe, certains programmes utilisent le numéro atomique dans la première colonne, tandis que d'autres utilisent le symbole ; et les positions x, y, z sont parfois écrites dans une base cartésiennes, et parfois en coordonnées réduites, selon la périodicité du système (les coordonnées cartésiennes sont souvent utilisées pour des molécules isolées, tandis que les coordonnées réduites sont souvent plus pratiques pour les structures périodiques). De plus, les vecteurs de boîte ne sont pas définis dans le format XYZ par défaut.
Lorsqu'il lit un fichier XYZ, Atomsk détecte automatiquement si c'est le symbole chimique ou le numéro atomique qui apparaît dans la première colonne, et il détecte aussi si les coordonnées sont cartésiennes ou réduites. Puisqu'aucun vecteur de boîte n'est défini dans le format XYZ par défaut, Atomsk en crée automatiquement (ceci est équivalent à l'option -rebox
) pour assurer la compatibilité avec les formats de fichiers qui requièrent une boîte. Il est également possiblle de définir les vecteurs de boîte manuellement grâce à l'option -properties
.
Lorsqu'il écrit un fichier au format XYZ par défaut, Atomsk utilise les spécifications publiées dans le Wiki d'OpenBabel, c'est-à-dire que la première colonne contient le symbole atomique et les positions sont en coordonnées cartésiennes.
Atomsk peut aussi lire et écrire le format XYZ étendu, décrit par exemple ici ou ici. Ce format étendu est pleinement compatible avec le format XYZ par défaut, la principale différence étant que la seconde ligne, au lieu de contenir un commentaire, est utilisée pour enregistrer les vecteurs de boîte et des jeux de mots-clés et valeurs, par exemple :
<NP>
Lattice="H11 H21 H31 H12 H22 H32 H13 H23 H33" Properties=species:S:1:pos:R:3:aux1:R:1:aux2:R:2...auxM:R:2 Time=0.0
<atom1> <x1> <y1> <z1> <aux11> <aux12> ... <aux1M>
<atom2> <x2> <y2> <z2> <aux21> <aux22> ... <aux2M>
... ... ...
<atomN> <xN> <yN> <zN> <auxN1> <auxN2> ... <auxNM>
Le mot-clé "Properties
" définit le format de chaque ligne par un jeu de trois valeurs : le nom de la propriété, son format (S=chaîne dde caractères, I=entier, R=réel), et le nombre de colonnes utilisées par cette propriété. Par exemple "species:S:1:pos:R:3
" signifie que l'espèce atomique est décrite par une chaîne de caractères utilisant une colonne, et les positions atomiques par des nombres réels répartis dans trois colonnes.
Lorsqu'il lit un fichier XYZ étendu, Atomsk lit les vecteurs de boîte suivant le mot-clé Lattice
, et les propriétés auxiliaires (suivant le mot-clé Properties
). Tout autre mot-clé (comme le mot "Time
" dans l'exemple ci-dessus) est ignoré.
Lorsqu'il écrit un fichier au format XYZ étendu, Atomsk écrit toujours les vecteurs de boîte (après le mot-clé "Lattice
") et les propriétés auxiliaires (après le mot-clé "Properties
"). Chaque propriété auxiliaire a des valeurs réelles contenues dans une seule colonne, de sorte que le format ressemble à : "Properties=species:S:1:pos:R:3:aux1:R:1:aux2:R:1...
". Pour écrire un fichier au format XYZ étendu il faut utiliser exyz
comme option en ligne de commande, par exemple :
atomsk initial.cfg final.xyz exyz
Enfin, Atomsk peut traiter une autre variante appelée ici le format XZ spécial. Ce format supporte les propriétés auxiliaires, mais réserve la seconde ligne pour un commentaire. Les propriétés additionnelles se trouvent en fin de fichier : un facteur d'échelle (après le mot-clé "alat"), les vecteurs de boîte (après "supercell" ou "conventional"), les masses des atomes (une ligne par type d'atome), un mot-clé spécifiant si les positions sont en coordonnées cartésiennes ou réduites, et le nom de chaque propriété auxiliaire (s'il y en a) :
<NP>
commentaire
<atom1> <x1> <y1> <z1> <aux11> <aux12> ... <aux1M>
<atom2> <x2> <y2> <z2> <aux21> <aux22> ... <aux2M>
... ... ...
<atomN> <xN> <yN> <zN> <auxN1> <auxN2> ... <auxNM>
alat
<a0>
supercell
<H(1,1)> <H(1,2)> <H(1,3)>
<H(2,1)> <H(2,2)> <H(2,3)>
<H(3,1)> <H(3,2)> <H(3,3)>
mass <species1> <mass1>
mass <species2> <mass2>
...
mass <speciesN> <massN>
property 1 <name1>
property 2 <name2>
...
property M <nameM>
<cartesian/reduced> coordinates
Les vecteurs de boîte peuvent être spécifiés comme vecteurs après le mot-clé "supercell" (comme dans l'exemmple ci-dessus), ou bien en notation conventionnelle après le mot-clé "conventional" (une ligne pour les paramètres "a b c
", et une seconde ligne pour les angles "α β γ
"). Si des propriétés auxiliaires sont présentes, elles doivent apparaître sur chaque ligne après les positions atomiques (les propriétés auxiliaires peuvent seulement être des nombres entiers ou réels), et chacune doit avoir son nom défini par une ligne "property <i> <nom>
" en fin d fichier, <i> étant le numéro de la propriété auxiliaire et <nom> son nom. La ligne "cartesian coordinates
" (ou "reduced coordinates
") signifie que les positions sont en coordonnées cartésiennes (respectivement, en coordonnées réduites).
Pour écrire un fichier au format XYZ spécial, il faut utilser sxyz
comme option dans la ligne de commande, par ex.:
atomsk initial.cfg final.xyz sxyz
Par défaut Atomsk écrit toujours les positions en coordonnées cartésiennes dans tous les formats XYZ décrits ci-dessus. Il est possible d'écrire des coordonnées réduites en utilisant l'option -fractional
.
Les fichiers au format XYZ par défaut (ou XYZ étendu) qui contiennent plusieurs configurations peuvent être lus grâce au mode one-in-all, ou être générés grâce au mode all-in-one. De tels fichiers peuvent aussi être lus et animés par certains programmes de visualisation comme gdis.
atomsk systeme.xsf xyz
Ceci va lire le fichier systeme.xsf
, et le convertira en systeme.xyz
au format XYZ normal.
atomsk systeme.xsf exyz
Ceci va lire le fichier systeme.xsf
, et le convertira en systeme.xyz
au format XYZ étendu.
atomsk systeme.xsf sxyz
Ceci va lire le fichier systeme.xsf
, et le convertira en systeme.xyz
au format XYZ spécial.
atomsk initial.xsf -frac final.xyz exyz
Ceci va lire le fichier initial.xsf
, convertira les positions des atomes en coordonnées réduites, et écrira le résultat final dans final.xyz
au format XYZ étendu.
atomsk --all-in-one mesfichiers.lst animation.xyz
Ceci va lire les fichiers apparaissant dans la liste mesfichiers.lst
, et écrira toutes les configurations dans le fichier animation.xyz
.
atomsk --one-in-all animation.xyz cfg
Ceci va lire le fichier animation.xyz
, et écrira chaque configuration dans un fichier séparé au format CFG : animation_1.cfg
, animation_2.cfg
, etc.