Free Objects for Xtallography

version 1.5CVS

Fox Home Page

News
Introduction
Screenshots
Download
Installation
License

Manual
Reference
Examples
Tutorial PbSO4
Tutorial Cimetidine
F.A.Q.
Hints & tricks

Mailing List
Subscribe
Archive

Development & Helping
Development info
Test versions
Compiling Fox
SF project page
Browse CVS

Using FOX for Ab Initio Structure Determination: PbSO4 tutorial

Prerequisite

  • The refined unit cell parameters, and a possible spacegroup
  • Some information about the unit cell contents (stoechiometry, possible building blocks)
  • one or several diffraction data sets. They are in the Fox/examples/tutorial-pbso4 directory.

    If you have all this, you can launch Fox !

First step: create your Crystal Structure

  • From the top menu 'Objects', create a new Crystal Object.
  • Click on the 'Crystals' tab to see your created crystal.
  • You can already display you crystal structure: in the Crystal, use the 'Display' menu-> 3D Display. You can use the mouse to change the display:
    • drag with the left mouse button down to change the orientation
    • drag with the middle button to change the distance/aspect ratio. You can also use the '+' and '-' keys to change the distance, if you have a two-mouse button.
    • right-button click will display a popup menu to update the Crystal Display when you have changed some parameter (sometimes the program will try to do it by itself).
  • You can name your Crystal ("PbSO4" or "Lead Sulfate",...) in the Field just after 'Crystal' (where it is written 'Change Me!'). This will be useful to choose your Crystal Structures thereafter.
  • You can change the spacegroup by entering either a symbol or the spacegroup number in the SpaceGroup Field (in our case, "Pnma" will do). (for high symmetries it can take a few seconds to find the asymmetric unit). [Note: If (after validation), the symbol reverts to the old entry, it means that it has not been understood. In doubt (when using not standard settings), use the full Hermann-Mauguin Symbol (eg '-I 4bd 2c 3', 'P1121/a',...)]
  • You can change the lattice parameters (8.482 5.398 6.959). Use the right-button menu to update the 3D Display of the structure.
  • To add atoms to your structure, you must first create the atom types, what is called 'ScatteringPower' in the program. Go to the 'Scatterers' menu of the Crystal, and choose 'Add Atomic Scattering Power'. This will add a 'SccatteringPowerAtom' a bit lower. You should change the name (eg 'Lead' or 'Pb'-this is free format, you can call it 'George' if you want) of this atom type, as well as the symbol corresponding to the atom - the symbol must correspond to a "standard" symbol or ion (e.g. "Pb" or "Pb2+"). Do this until you have the scattering powers for Pb, S and O.
  • Then add a Pb Atom to the structure, using the 'Scatterers'->'Add Atom' menu of the Crystal object. You will be prompted to choose one atom type from those you have entered (choose the lead atom type). The atom will be put by default at (0,0,0), which you can see by updating the 3D view (right-click...)
  • Then add a SO4 tetrahedron: to do this use the 'Scatterers'->'Add Tetrahedron' menu of the Crystal Object. You will be prompted for the central atom type (the sulphur), the peripheral one (oxygen), and then the distance (roughly 1.5 Angstroem). a 'ZScatterer' will appear in the list of scatterers of the Crystal Structure. You should then change the name of the tetrahedron to something sensible (SO4), as well as the names of the atoms (this is not mandatory, but nicer). Note that the parameters (bond lengths, bond angles and dihedral angles) are not fixed (the refinement buttons are pushed for all parameters), but set with tight limits which should be fine in this example (they can be changed globally using the ZScatterer 'parameters' menu, or individually by right-clicking on the parameter's name).
  • NOTE: you have nothing to do for special positions, as long as the 'Use Dynamical Occupancy Correction' field is set to 'Yes' (the default).

    You're done with the Crystal structure. You can (should) save using the top Fox menu 'File'->'Save'. This will save everythoing as an xml file, using a specific format to ObjCryst++/Fox.

Second step: create the PowderPattern object (X-Ray)

  • Go to the next tab 'Powder Diffraction', and then use the top 'Object' menu to create a PowderPattern object. You can give this one a name, e.g. "PbSO4 X-ray"
  • You can import the X-Ray data using the PowderPattern object 'Data'->'Import Fullprof Pattern', and select the xray.dat file in the Fox/example/tutorial-pbso4 directory.
  • You can display the powder pattern using the 'Pattern'->'Show Graph' menu. You can click &amp drag with the left button to zoom in (double-click to unzoom). You can right-click on the graph to update the graph if you have changed manually a parameter. The coordinates (2theta, intensity of the mouse pointer is displayed at the bottom).
  • By using the zoom and the displayed, prepare a 2-column (2theta, intensity) text file with the points you want to use to interpolate the background (see the xray-backgd.dat file for example). This is free-format, as long as the two columns are separated by spaces, and using a dot "." as decimal separator (not a comma).
  • Then add the background phase, using the 'Component'->'Add Interpolated Background' menu. In the newly appeared 'PowderPatternBackground' part, use the 'Object'->'Import' menu to import this 2-column file you have just created. If you update the powder pattern (right-click on the graph), you should see the base calculated graph change.
  • Now add the Crystalline phase, using the 'Component'->'Add Crystalline Phase', which will prompt you to choose one crystal structure available (the one you have already defined) from its name. (NOTE: for multi-phased powders, you can add several crystalline phases)
  • Now set the correct wavelength: use the PowderPattern 'Radiation'->'X-Ray Cu Tube Ka12' to select the correct radiation. This will update the entry field, and normally also the graph.
  • NOTA BENE: the scale factor is normally horribly wrong before launching the optimization. You can, however, fit manually the scale factor by using the 'Pattern' menu of the PowderPattern object... the fit will of course remain wrong as long as the atom positions are far from the correct ones.
  • OK, to obtain reasonable fit you need to choose adequate profile parameters. Approximate parameters will be sufficient for our needs, so using a W parameter of .01 with U=V=0, a pseudo-Voigt profile with Eta0=0.5 and Eta1=0 will do. (you can change the values and update the graph to choose the values). Of course, if you did profile fitting, you can use these values.
  • NOTE: generally it is a good idea to run a bit the optimization before choosing the correct profile parameters (this way there are more reflections at the correct scale).
  • You can also see that a 2theta zero (shift) of -0.02 is necessary (again, this is approximate but sufficient)
  • Finally, for a global optimization it is not necessary to use the entire pattern, so put 0.25 in the max sin(theta)/lambda. (this discards a lot of information but as you'll see it was useless information).

    Maybe you should save now ?

Second step (bis): create the PowderPattern object (neutron)

  • Just repeat the same steps (create a second PowderPattern object) (you can display both graphs at the same time), and choose neutron radiation with a wavelength of 1.909. A W parameter of 0.25, and a pseudo-Voigt witha Eta0=0.15 should be fine. Again, put a value of 0.25 in the max sin(theta)/lambda field.

Third step: create the Global Optimization object

  • Go to the last tab of the Fox window 'Global Optimization', and use the main window's 'Objects' to create a new Monte-Carlo Object.
  • Then we need to tell the algorithm what it is going to optimize (which objects), so we need to declare both Powder Patterns and the Crystal Structure. So use the 'Objects & Cost Functions'->'Add object to optimize' menu, and add all three objects (one at a time). (This is where you see it is useful to set meaning ful names for all objects).
  • Then we must tell the algorithm which criterion we want to choose to validate the structure, the 'Cost Functions'. In this case we will use the agreement factors for both powder patterns. To be unsensitive to profile parameters (which are not too important for structure solution), it is VERY recommended to use the integrated Rwp factors. So use the 'Objects & Cost Functions'->'Add cost function' and choose the 'Best Rw, integrated' function for the X-ray pattern. Then do the same for the neutron data. You shoud see two fields appear with the value of these cost functions.
  • OK, you're all set ! Normmaly, you should not change the choice of algorithm (Parallel Tempering is better than Simulated Annealing), nor the temperature or displacement amplitude parameters. They are supposed to work with any structure and combination of data.

    Now would be a good time to save using the top 'File'->'Save' menu.

  • So Launch the optimization, using the 'Run'->'Run Optimization' menu of the Monte-Carlo object. If you have left the 3D Crystal structure window and the powder pattern graphs opened, they should be live-updated. Convergence is quick in this case, normally less than 50 000 trials.
  • Once the algorithm has converged, if you change the max sin(theta)/lambda fields in both powder patterns, and update the graphs (right-click...), you should see that the part of the pattern which was not used as a criterion is relatively well fitting (not great at high angle for the neutron, but that's what Rietveld is for !).

Last step: export the crystal Structure

  • You can export the atomic coordinates by going to the Crystal structure, and use the 'File'->'Save as text' menu. this will save a file with all atom fractionnal coordinates and occupancies. You should see that all atoms have a 'dynamical occupancy' of 0.5, which is due to the fact that they are all (except two oxygens) on a special position. The other two oxygens are in fact equivalent, as the distance table included in the output shows.

Documentation © Vincent Favre-Nicolin , generated on 29 Jan 2003 by doxygen 1.2.18
This project is hosted on SourceForge and mirrored on CCP14 ( UK, Canadian Mirror, US Mirror)