packages icon

==============================================================
xbs ball-and-sticks plotting program (M. Methfessel Nov. 1995)
==============================================================


This program uses X-window graphics to produce ball-and-sticks plots.
It reads coordinates and other data from an input file (ie. ch4.bs)
and possibly different "frames" with shifted coordinates from an
auxillary move file (ie. ch4.mv). The default files are in.bs and in.mv.


----- INSTALLATION -----

Compile by command 'cx xbs'. This compiles the C program together 
with the X-Window includes and libraries.
If everything works properly, you can do 'cx -O xbs' in a second
step to optimize.
Possibly the settings inside cx have to be changed for some
operating systems. Presently cx is set up for IBM AIX.
There is a second version called cx.sgi which is set up for 
Silicon Graphics workstations.


----- INPUT -----

In a simple case, a file ch4.bs could look like this:

 atom      C       0.000      0.000      0.000 
 atom      H       1.155      1.155      1.155 
 atom      H      -1.155     -1.155      1.155 
 atom      H       1.155     -1.155     -1.155 
 atom      H      -1.155      1.155     -1.155 

 spec      C      1.000   0.7
 spec      H      0.700   1.00 

 bonds     C     C    0.000    4.000    0.109   1.00 
 bonds     C     H    0.000    3.400    0.109   1.00 
 bonds     H     H    0.000    2.800    0.109   1.00 

This sets the coordinates in the format
  atom  species  x  y  z

and how to draw each atomic species, in the format
  spec name radius color

and how to draw bonds, in the format
  bonds name1 name2 min-length max-length radius color

A move file contains additional frames like this:

  frame This is frame number two
     0.000      0.000      0.000    1.155      1.155      1.155 
    -1.155     -1.155      1.155    1.155     -1.155     -1.155 
    -1.155      1.155     -1.155 

After the keyword 'frame' comes an indentifying string,
then come the coordinates for all the atoms. Line breaks can 
appear anywhere between the coordinates.

Other input lines are also possible, namely the lines which set
parameters (see below). Example:  'inc  5'  sets the increment 
for the rotation to 5 degrees.

In both files, lines starting with * and blank lines are comments.


----- USAGE -----

After starting the program with 'xbs ch4' the plot can be controlled
directly by selected keys. For example, to rotate the molecule 
use the cursor keys and the keys "," and "." The last two were chosen 
because they are below "<" and ">" whch look like arrows.
To step through the frames to show a "movie", use keys '[' and ']'.
A number of other keys are defined to function directly.
More complicated functions are done by pressing 'i' to get an
input line and then typing a command. 
Use 'xbs -hh' to get information on keys and commands.

Sizing: Keys '+' and '-' make the plot bigger or smaller. 

Perspective: Key p switches the perspective. Default is off.
For pseudoperspective, the sphere sizes depend on the distance
to the viewer but the positions on the page are unchanged.
For true perspective, the sizes and the positions both change.
The strength of the perspective effect depends on the distance to 
the viewer, which is shown in the status line. It is changed with 
keys 'd' and 'D' or can be set directly with command 'dist'.
(Note: if you come too close and put the viewpoint inside an atom, 
the program will try to color the whole universe, which takes very long).

Lighting: command 'gramp slope middle' greys out the atoms in the
back by an exponential ramp. Command 'light x y z' shades
the atoms somewhat as if light shines along vector (x,y,z).
These commands only work in black/white mode. To switch back 
to normal coloring, enter 'gramp' or 'light' without arguments.

Positioning: Keypad keys 8,6,4,2 move the plot about by an increment
dpos (which can be set by the command 'dpos'). Keypad key '*' saves
the current position as 'home' (or use command 'pos' to set the
home position directly). Keypad key 7 moves the plot home.
Positions are relative to the center of the window.

Saving: command 'save' writes the data to a file (default Save.bs).
If there are multiple frames, a move file is also written. 
The 'save' command has some options, see below.

Printing: the command 'print' writes output to a postscript file,
by default the file 'Bs.ps'. A print file stays open until it
is explicitly closed. In this way several plots can be superimposed
on the same page, using the keypad cursor keys to shift the subplots
on the page. The 'print' command has some options, see below.


----- GETTING HELP -----

Typing 'xbs -h' and 'xbs -hh' gives short respectively long help.

After starting xbs, key 'h' toggles an overview. This is the same
information as is obtained with 'xbs -hh'.

On the input line, use 'help print' or 'print ?' or even 'print -h'
to get help on a specific command such as (in this case) print. 
This help also shows any possible options for the command.

The space bar toggles extra information about the plot written
into the window.


----- SOME MORE DETAILS AND RECENT CHANGES -----

1. Color:

 - A color is specified either as a number between 0 and 1 (gray value),
   three numbers between 0 and 1 (red, green, blue values or RGB),
   or as a color name from the file /usr/lib/X11/rgb.txt (or similar).

 - In the input file, the color of each species or bond is set 
   in these three ways.

 - The following xbs options are related to color:
      -color   enable colors (default)
      -bw      uses greys only
      -st      uses grays only, stippled from a few values
      -rv      reverse all colors
      -auto    choose own colors.
   You can change these interactively with the update command.
   For consistency, black is now 0 and white is 1. The -rv option
   switches this. The only reason for using -bw or -st is that
   the commands 'light' and 'gramp' do not work with colors.

 - The '-auto' option is used to color the atoms in some standard way.
   These colors are set in routine 'set_auto_colors' in file subs.h.
   Starting from the species label (ie. Pd3 or Mg-a) the leading
   alpha part is extracted and capitalized (ie. PD or MG) and
   this string is used to select a color.
   The idea is to put one's favorite colors into the routine
   and then recompile xbs.
   
 - The command 'color' changes the colors of atoms interactively,
   ie. 'color C* green' changes the color of all matching species.
   To show the color of a species, use the command without
   specifying a color (ie. 'color C1' or 'color C-a').

 - When data is saved with the 'save' command, the current colors
   (as set with 'color') are saved as a string.
   With 'save -rgb' the RGB values are written instead of color names. 
   If the -rv option is used, the reversed colors are saved as RGB values.

2. Some commands have options, eg. print, save, update. 
   For example:
      print -T                   print and add some info as title
      print -t 'text .... '      print and put text as title
      update -rv                 update but switch on reversing
      update +rv                 update but switch off reversing
      update -bw                 update but switch to black/white
      save -rgb                  save with colors as rgb values
      save -step n               save with only every n'th frame
                                 (good to compress a big .mv file).
   Use 'help update' etc on the input line to see the options.
   
3. Pattern matching for atom labels: * matches any string, + any char.
   This can be used in the 'color' command and in the 'bonds' lines
   in the input file (which determine what bonds are drawn).
   For example, 'bonds C* H*  ...' selects all bonds between 
   atoms like C1 and H34 etc. and 'bonds * * ...' selects all pairs.
   
4. Other miscellaneous changes:

 - Key 'a' displays the axis directions.

 - Key 'n' shows atom names or numbers. Key 'c' shows the coordinates.

 - To close a postscript print file, use command 'close'.

 - Command 'dup x y z' duplicates all atoms shifted by (x,y,z).

 - Command 'cut x y z a b' cuts to those atoms between a and b
   along the vector (x,y,z). 

 - The input line has a history list to retrieve old commands.
   Use the up and down arrows when the input line is active.

 - On some systems, the backspace key does not work to edit the
   input line. Therefore the left-arrow key was defined to have
   the backspace function also.