/PCOMPUTE&postcompute=EXPR(expression)
The PCOMPUTE subcommand, which must precede the first
TABLE command, defines computed categories.  It is optional and
may be used any number of times to define multiple postcomputes.
Each PCOMPUTE defines one postcompute.  Its syntax consists of
a name to identify the postcompute as a PSPP identifier prefixed by
‘&’, followed by ‘=’ and a postcompute expression enclosed
in EXPR(…).  A postcompute expression consists of:
[category]This form evaluates to the summary statistic for category, e.g.
[1] evaluates to the value of the summary statistic associated
with category 1.  The category may be a number, a quoted string,
or a quoted time or date value.  All of the categories for a given
postcompute must have the same form.  The category must appear in all
the CATEGORIES list in which the postcompute is used.
[min THRU max][LO THRU max][min THRU HI]MISSINGOTHERNMThese forms evaluate to the summary statistics for a category
specified with the same syntax, as described in previous section
(see CTABLES Explicit Category List).  The category must appear in
all the CATEGORIES list in which the postcompute is used.
SUBTOTALThe summary statistic for the subtotal category.  This form is allowed
only if the CATEGORIES lists that include this postcompute have
exactly one subtotal.
SUBTOTAL[index]The summary statistic for subtotal category index, where 1 is the
first subtotal, 2 is the second, and so on.  This form may be used for
CATEGORIES lists with any number of subtotals.
TOTALThe summary statistic for the total.  The CATEGORIES lsits that
include this postcompute must have a total enabled.
a + ba - ba * ba / ba ** bThese forms perform arithmetic on the values of postcompute expressions a and b. The usual operator precedence rules apply.
numberNumeric constants may be used in postcompute expressions.
(a)Parentheses override operator precedence.
A postcompute is not associated with any particular variable.
Instead, it may be referenced within CATEGORIES for any
suitable variable (e.g. only a string variable is suitable for a
postcompute expression that refers to a string category, only a
variable with subtotals for an expression that refers to subtotals,
…).
Normally a named postcompute is defined only once, but if a later
PCOMPUTE redefines a postcompute with the same name as an
earlier one, the later one take precedence.
The following syntax and output shows how PCOMPUTE can compute
a total over subtotals, summing the “Frequent Drivers” and
“Infrequent Drivers” subtotals to form an “All Drivers”
postcompute.  It also shows how to calculate and display a percentage,
in this case the percentage of valid responses that report never
driving.  It uses PPROPERTIES (see PPROPERTIES) to
display the latter in PCT format.
CTABLES
    /PCOMPUTE &all_drivers=EXPR([1 THRU 2] + [3 THRU 4])
    /PPROPERTIES &all_drivers LABEL='All Drivers'
    /PCOMPUTE &pct_never=EXPR([5] / ([1 THRU 2] + [3 THRU 4] + [5]) * 100)
    /PPROPERTIES &pct_never LABEL='% Not Drivers' FORMAT=COUNT PCT40.1
    /TABLE=freqOfDriving BY gender
    /CATEGORIES VARIABLES=freqOfDriving
                             [1 THRU 2, SUBTOTAL='Frequent Drivers',
                              3 THRU 4, SUBTOTAL='Infrequent Drivers',
                              &all_drivers, 5, &pct_never,
                              MISSING, SUBTOTAL='Not Drivers or Missing'].
| 
 | |||||||||||||||||||||||||||||||||||||||||||||||||