SET
statements:
set z1 = (x1 - mean(x1))/stddev(x1) set z2 = (x2 - mean(x2))/stddev(x2)
but this requires a lot of unnecessary typing. Instead, you could
DEFINE a function stand to perform this operation:
define stand(x) = (x - mean(x))/stddev(x)
The argument x to stand is a parameter that could be replaced
with any variable name. The SET statements above can now be
simplified to:
set z1 = stand(x1) set z2 = stand(x2)
SST functions can have many arguments. Each argument to a function should be separated by a comma. For example:
define f(x,y,z) = (x - y)/z
To use the above function in a SET statement, you might try:
set delprice = f(price2,price1,0.5)
The above example shows that constants (like 0.5) can be used as arguments to functions.
SST allows you to nest functions. That is, a function can be inserted in place of an argument to another function. For example:
define yhat(b1,b2,b3) = x1*b1 + x2*b2 + x3*b3 define error(y1,y2) = y1-y2 set e = error(depvar,yhat(1.0,0.0,-1.0))
Thus, it is possible to build up rather complicated expressions. Any SST
predefined function (e.g., cumnorm or mean) can also be used
as an argument in a user-defined function.
To obtain a listing of functions defined in an SST sesssion, use the
LIST command:
list func
and SST will display the names and definitions of all functions that
have been defined during the session. To inspect the definition of
a one or more functions, add these as arguments to the FUNC
subop:
list func[stand]
and SST reproduces the definition for stand.
pop15,
pop75, and dpi repeatedly in some subops. Define a variable
list vlist using the MACRO command:
macro vlist { pop15 pop75 dpi 2
Whenever you want to use this list of variables in a command, you just ask SST to expand the macro. For example:
reg dep[sr] ind[one @vlist]
is equivalent to:
reg dep[sr] ind[one pop15 pop75 dpi]
The @ symbol tells SST to expand the macro, i.e. to substitute the text of the macro in the command. Whenever you ask SST to expand a macro in a command, SST will display the expanded version of the command on the screen to remind you what the macro does.
More complicated macros may involve parameter lists and multiple
commands. For example, it is possible to define a macro to perform
two stage least squares. Suppose, for example, that we are interested
in estimating an equations with one endogenous and two exogenous
variables among the independent variables and that we have two
additional exogenous variables to be used as instruments. In the
first stage of two stage least squares, we regress the included
endogenous variable on all the exogenous variables and save the
predicted values. In the second stage we regress the dependent variable
on the predicted values from the first stage regression and the
included exogenous variables. To define a macro 2sls which
performs this operation in one shot, type:
macro 2sls(y1,y2,x1,x2,z1,z2) {
reg dep[y2] ind[x1 x2 z1 z2] pred[y2hat]
reg dep[y1] ind[y2hat x1 x2] coef[b2sls]
set e2sls = y1 - b2sls(1)*y2 - b2sls(2)*x1 - b2sls(3)*x2
calc stdev(e2sls)
}
The last two commands are necessary to calculate the standard error of the
regression for two stage least squares (the estimated standard errors from
the second stage regression need to be multiplied by the ratio of the last
value calculated and the reported standard error of the regression from the
second stage printout). To use the 2sls macro when price and
quantity are the endogenous variables, one and weather
are the included exogenous variables, and populat and dpi are
the excluded exogenous variables:
@2sls(quantity,price,one,weather,populat,dpi)
and the entire sequence of commands will be executed.
IF and WHILE commands that allow you
to write simple programs within SST.
The IF command is straightforward. You type `if' followed by a
logical expression (enclosed in parentheses) followed by a set of SST
commands enclosed in braces. For example, you might want to rerun a
regression with a variable deleted if its coefficient in the initial
regression was less than some predetermined value:
reg dep[y] ind[x1 x2 x3] coef[b1]
if(abs(b1(3) < 1.0) { reg dep[y] ind[x1 x2] 2
The second REG command (with x1 and x2 as independent
variables) will only be executed if the coefficient of x3 in the
first regression (b1[3]) is less than one in absolute value.
The use of WHILE loops is slightly more complicated. You type
`while' followed by a logical expression (again, enclosed in
parentheses) followed by a set of SST commands enclosed in braces. SST
evaluates the logical expression: if it is true, it performs specified set
of commands; otherwise it proceeds to subsequent commands. After the first
pass through the set of commands, it reevaluates the logical expression.
Again, if it is true it performs the commands. If the expression is now
false, it breaks. The major pitfall to avoid is creating an endless loop
that SST performs until you shut your computer off. The natural way to
control the loop is by resetting a variable that appears in the logical
condition within the WHILE loop.
An example may clarify the use of the WHILE loop. Suppose
you would like to estimate a regression ten times, each time adding
an additional observation to the sample used to compute the regression.
This can be done with a WHILE loop:
set counter=1; obs[1]
while(counter(1) <= 10) {
reg dep[y] ind[x1 x2] if[obsno < 20+counter(1)]
set counter=counter+1
}
The observation range for the regression is determined by the IF
subop. Initially, observations whose obsno index is less than 21 will
be used. Then the variable counter is incremented to two. The next
regression will use observations for which obsno is less than 22, and
so on. Eventually, the variable counter will exceed ten, and SST
will break out of the WHILE loop.
SCAT.
Currently, the supported procedure consists of timeplots, two-way
scatter, and matrix scatterplots (for three variables).
If you give the command:
scat var[y]
SST will plot the variable y (on the vertical axis) with its
observation number on the horizontal axis.
To obtain a scatterplot of a variable y against another variable
x, type:
scat var[y x]
The variable x will appear on the horizontal axis and the
variable y on the vertical axis.
To analyze interactions between three variables, use the SCAT
command to produce a matrix of two-way scatterplots:
scat var[x y z]
This will produce three scatterplots: y against x, z
against x, and y against z. To fit three scatterplots
onto the screen, it is necessary to reduce the size of each scatterplot,
but the simultaneous examination of the scatterplots may aid in the
detection of interesting interactions.
SST uses the variable names to label the axes and automatically
scales the axes to enhance readability. If you would like to add
a title to your scatterplot, use the LAB subop. For example:
scat var[gnp year] lab[U.S. Gross National Product, 1961-1984] \\ if[year >= 1960]
As usual, the IF and OBS subops may be used to restrict
the data range use for the SCAT command, as illustrated above.
We do not provide any special software for the printing of scatterplots. If you have the IBM monochrome card, depressing <Shift> and <PtrSc> simultaneously will dump the contents of the screen to your printer. Most graphics cards, such as the IBM Color Graphics Adapter or the Hercules Graphics Adapter, are equipped with screen dump programs. Consult the documentation for your graphics adapter to determine how to obtain hard copy of your graphics output.