.-
help for ^hplot^
.-

Horizontally labelled plots
---------------------------

    ^hplot^ varlist [^if^ exp] [^in^ range] [ ^,^

    ^a^xtol^(^#^) c^start^(^#^) gapm^ag^(^#^) gap^s^(^string^)^
    ^g^rid ^li^ne ^pts^ize ^r^ange ^so^rt^(^string^)^
    ^s^ymbol^(^string^)^

    ^bo^rder ^f^ormat^(^format^) lap nox^axis ^noy^axis ^tti^ck
    ^xla^bel^(^string^) xli^ne^(^string^) xsc^ale^(^string^)^
    ^xti^ck^(^string^)^

    ^b^lank ^gl^egend^(^string^) gllj glpos(^#^) l^egend^(^legendvar^)^

    ^flipt nit2 t1m(^#^) t1^title^(^string^) t2m(^#^)^
    ^t2^title^(^string^) tim(^#^) ti^tle^(^string^)^

    ^fontr(^#^) fontc(^#^) fontrb(^#^) fontcb(^#^)^
    ^pe^n^(^string^) pent^ext^(^#^) sa^ving^(^graph_filename^)^ ]

Description
-----------

The basic form of ^hplot^ is a graph with one horizontal line for each
observation included. On that line are one or more point symbols
representing the values in varlist according to a common scale.

^hplot^ can produce a variety of horizontally labelled plots for data,
including W.S. Cleveland's dot charts or dot plots; variations on them
with continuous rather than dotted lines; D.R. McNeil's horizontal
parallel line plots; and displays for showing key quantities with or
without confidence intervals.

By default, the data in varlist are represented on horizontal dotted
lines with base at zero that extend to the maximum for each observation.
If negative values are present, dotted lines also extend to the minimum.
Point symbols are used to show actual values.

If the ^grid^ option is used, the data are represented on horizontal
dotted lines that extend over the whole data region of the graph.

If the ^line^ option is used, the data are represented on horizontal
continuous lines with base at the left-hand margin. This can be a lot
faster and may be adequate for exploratory analyses.

If the ^range^ option is used, the data are represented on horizontal
dotted or continuous lines which extend only over the range of values
for each observation, from the smallest value to the largest value.

If the data allow it, a different base may be forced using the ^xscale^
option.

A legend on the left of the data region can be from a specified
variable. If that variable is not specified, the order in the data will
be used; or, if that is not desired, the legend can be blank. The legend
is right-justified. The legend should look readable up to about 30
observations.

For understanding placement of material on the plot, it helps to know
that @gph@ draws in a space defined by 23063 rows and 32000 columns
with origin at top left. See help for @gph@.


Options
--------

Options controlling size, layout and symbol presentation:
---------------------------------------------------------

^axtol(^#^)^ controls the space between the x axis or the position of
    the top border and the nearest data line. Default 600.

^cstart(^#^)^ controls the column (horizontal position) of the start of
    the lines.

^gapmag(^#^)^ controls the magnitude of any gaps relative to the spacing
    between lines. Default 1.

^gaps(^string^)^ places gaps after lines. ^gaps(3,6)^ places gaps after
    the 3rd and 6th lines as they appear on the graph, counting down
    from the top. ^0^ means a gap before the first line.

^grid^ places point symbols on horizontal dotted grid or guide lines
    that extend all the way across the plot. This was originally
    recommended by Cleveland if the base is not 0, and later used by him
    in all examples.

^sort(^string^)^ means that observations are to be plotted in the
    vertical order determined by application of @gsort@. For example,
    ^sort(^sortvar^)^ indicates sort in ascending order of sortvar
    (highest values on bottom) and ^sort(- ^sortvar^)^ indicates
    descending order (highest values on top).

^line^ replaces dotted by continuous horizontal lines from the left-hand
    margin to each data point.

^ptsize(^#^)^ controls point symbol size. Default 275.

^range^ restricts the dotted or continuous lines to extend from the
    minimum to the maximum of those quantities plotted on each
    horizontal line.

^symbol(^#^)^ controls point symbols available. The list is most of the
    standard list for @graph@, with some additions.
    ^.^  dot
    ^o^  small circle
    ^O^  large circle
    ^S^  square
    ^T^  triangle
    ^d^  diamond
    ^p^  plus
    ^i^  invisible
    ^|^  vertical bar
    ^,^  short vertical bar
    ^-^  short horizontal bar
    ^>^  arrow pointing right
    ^<^  arrow pointing left
    ^x^  small cross
    ^X^  large cross
    ^a^  arrow pointing from the value for the previous variable
         to the value of the present variable

    ^symbol^ defaults to ^opSdT^ for up to 5 variables and ^o^ for every
    variable for 6 or more variables. With 2 or more variables and a
    single symbol specified, that symbol is used for every variable.
    That is, ^hplot a b c, sy(|)^ expands to ^hplot a b c, sy(|||)^.

Options controlling axes, lines, labels, ticks, border:
-------------------------------------------------------

^border^ adds a border.

^format(^format^)^ controls the format with which ^xlabel^s are shown.
    Default %1.0f.

^lap^ (^l^abels ^a^ll ^p^ositive) makes the labels as shown all
    positive. ^xla(-40,-20,0,20,40) lap^ will place the labels
    40, 20, 0, 20, 40 at the axis positions for -40, -20, 0, 20, 40.

^noxaxis^ suppresses the x axis.

^noyaxis^ suppresses the y axis.

^ttick^ produces short unlabelled ticks on the border above the x axis
    that echo the labelled and unlabelled ticks on the x axis. Note that
    (unlike the option in @graph@) ^ttick^ with a string is illegal, and
    that ^ttick^ necessarily implies ^border^, but not conversely.

^xlabel(^string^)^ controls the labelled ticks on the x axis. Note that
    (unlike the option in @graph@) ^xlabel^ without a string is illegal.
    numlists may be used, such as ^1/5^ for ^1,2,3,4,5^ and ^0(10)50^
    for ^0,10,20,30,40,50^.

^xline(^string^)^ specifies lines drawn for constant values of x. Note
    that (unlike the option in @graph@) ^xline^ without a string is
    illegal. numlists may be used, such as ^1/5^ for ^1,2,3,4,5^ and
    ^0(10)50^ for ^0,10,20,30,40,50^.

^xscale(^string^)^ controls the scale of the graph, except that (like
    the option in @graph@) it will not cause values to be omitted (for
    which purpose use ^if^).

^xtick(^string^)^ controls the unlabelled ticks on the x axis. Note that
    (unlike the option in @graph@) ^xtick^ without a string is illegal.
    numlists may be used, such as ^1/5^ for ^1,2,3,4,5^ and ^0(10)50^
    for ^0,10,20,30,40,50^.

Options controlling legends to left and between gaps:
-----------------------------------------------------

^blank^ blanks out any legend on the left of the data region.

^glegend(^string^)^ places right-justified legend in the gaps between
    lines. ^gaps(0,4) glegend(Males!Females)^ places ^Males^ in the gap
    before line 1 and ^Females^ in the gap after line 4. Note that ^!^
    must be used to separate legends, which thus enables the use of
    commas within the legend, but has the side-effect of disallowing the
    use of exclamation marks. ^.^ has the special meaning of blank.

^gllj^ makes ^glegend^ left-justified.

^glpos(^#^)^ controls the horizontal position of ^glegend^ and defaults
    to an alignment with the main legend.

^legend(^legendvar^)^ specifies a variable to be used for the legend. If
    legendvar is a numeric variable with labels, the labels will be used
    in the legend.

Options controlling titles (^t1title^, ^t2title^, ^title^):
-----------------------------------------------------

^flipt^ flips titles: ^title^ will be shown at its (default larger) font
    size and left-justified at the top of the graph, and ^t1title^ will
    be shown at default font size and centred below the axis at the
    bottom of the graph (but closer to the axis than the default).

^nit2^: see ^t2title^ below.

^t1title(^string^)^ controls the ^t1title^, shown at default font size
    and left-justified at the top of the graph. But see ^flipt^ above.

^t2m(^#^)^ moves the ^t2title^ bodily # to the right. The default is to
    start hard left to allow plenty of space for several variable labels
    or names in a key, but that default may seem too far left.

^t2title(^string^)^ controls the ^t2title^, shown at default font size
    and left-justified at the top of the graph. This defaults to a key
    of point symbols if the number of variables is more than 2: the key,
    however, is likely to be a mess if the number is more than 5. The
    key uses variable labels, or variable names if either they do not
    exist or the further option ^nit2^ is invoked. As with @graph@,
    ^" "^ blanks out the title.

^tim(^#^)^ moves the ^title^ bodily # to the right. The default is to
    centre at whatever column would bisect the x axis.

^title(^string^)^ controls the ^title^, shown at its (default larger)
    font size and centred below the axis at the bottom of the graph. But
    see ^flipt^ above. As with @graph@, ^" "^ blanks out the title.

Other graph options:
--------------------

^fontr(^#^)^ and ^fontc(^#^)^ control the font used for all but the main
    title and default to 570 and 290 (which is the default of @gph@).
    Font sizes should be changed circumspectly.

^fontrb(^#^)^ and ^fontcb(^#^)^ control the font used for the main
    title and default to 923 and 444.

^pen(^string^)^ controls the pens used for data. ^pen^ defaults to ^2^
    for every variable. With 2 or more variables and a single pen
    specified, that pen is used for every variable. That is,
    ^hplot a b c, pen(3)^ expands to ^hplot a b c, pen(333)^.

^pentext(^#^)^ controls the pen used for text and other non-data
    elements.

^saving(^graph_filename^)^ saves the graph in a .gph file.


Examples
--------

        . ^hplot reserves, l(area) xsc(0,30) xla(0(5)30)^
          ^t1(percent of total) ti(Oil reserves 1994) flipt border^

        . ^hplot area, l(name) xsc(0,6) xla(0/6) t1(million^
          ^square km) ti(Areas of major drainage basins) flipt line^
          ^fontr(491) fontc(250)^

        . ^hplot lcl mean ucl, l(name) xsc(0,6) xla(0/6)^
          ^t1(95% confidence intervals) sy(|O|) border^


Remarks
-------

In addition to the options above, many choices are coded into ^hplot^
as parameter values. Users may want to copy ^hplot^ and then edit
these permanently or temporarily according to taste.

Cleveland's dot plots are not the same as the histogram-like dotplots
implemented in @dotplot@.


References
----------

Cleveland, W.S. 1984. Graphical methods for data presentation: full
scale breaks, dot charts, and multibased logging. American Statistician
38, 270-80.

Cleveland, W.S. 1994. The elements of graphing data. Hobart Press,
Summit, NJ.

McNeil, D.R. 1992. On graphing paired data. American Statistician
46, 307-11.

McNeil, D.R. 1996. Epidemiological research methods. Wiley, Chichester.


Author
------
         Nicholas J. Cox, University of Durham, U.K.
         n.j.cox@@durham.ac.uk


Acknowledgments
---------------

         Mike Bradburn, Arne Kolstad and Fred Wolfe made very helpful
         comments.


Also see
--------

On-line: help for @graph@, @gph@, @format@, @gsort@, @dotplot@,
         @hbar@ (if installed), @cihplot@ (if installed),
         @tabhplot@ (if installed), @numlist@