Reverse sweep operator.
There are two syntaxes for @rsweep, one for the symmetric, and the other for then non-symmetric operator.
Syntax: @rsweep(s[, n])
s: sym
k: integer
k2: (optional) integer
Return: matrix
Returns the result of applying the symmetric sweep operator to symmetric matrix S at diagonal element k. If k2 is specified, sweeps on all diagonal elements between k and k2, inclusive.
This is merely an alias for @sweep(s, k[, k2]), since the symmetric sweep operator is its own reverse/inverse.
Syntax: @rsweep(m, r, c)
m: matrix, sym
r: integer
c: integer
Return: matrix
Returns the result of applying the reverse non-symmetric sweep operator to general matrix M at element (r, c).
Let
data:image/s3,"s3://crabby-images/ddd57/ddd574d4496bb8c739e3ad5db7982d0b416112bf" alt=""
be an application of the symmetric sweep operator. Then,
data:image/s3,"s3://crabby-images/a2db0/a2db07a38cc5173d2fd7d844c62d3bbe31e9f677" alt=""
,
data:image/s3,"s3://crabby-images/b8454/b845461449176d881479861c2cc83d2d64b3bb23" alt=""
where
data:image/s3,"s3://crabby-images/5906f/5906f2ef634727b8c5fc9ae4f4d171c24d710f06" alt=""
,
data:image/s3,"s3://crabby-images/da6cd/da6cdbc399d62ba1986785e0b2ee5eb3f0019cff" alt=""
where
data:image/s3,"s3://crabby-images/1f99e/1f99e7208c8a90cea9d4465a9692eb7af8121f70" alt=""
, and
where
data:image/s3,"s3://crabby-images/a9590/a9590d1db7bff955177ee454307cbd056a2c7c0b" alt=""
and
data:image/s3,"s3://crabby-images/6cda5/6cda5eb07feb886ba047bbecf91e732fce5c828b" alt=""
.
Let
data:image/s3,"s3://crabby-images/b9f6c/b9f6c154672e8fc322ea3f9a190b08bfd2ddab18" alt=""
be an application of the non-symmetric sweep operator. Then,
data:image/s3,"s3://crabby-images/34e62/34e622f077de90e7a7b0842441e99fd3cffc1300" alt=""
,
data:image/s3,"s3://crabby-images/c8313/c83134ad80833f5574710b7256848ae29b4f28f8" alt=""
where
data:image/s3,"s3://crabby-images/1c671/1c671568b65bc817077117af7e5ef135697316fb" alt=""
,
data:image/s3,"s3://crabby-images/bf6d9/bf6d92c222a9df24ce2cdfe57c94c478a7eaa283" alt=""
where
data:image/s3,"s3://crabby-images/ed643/ed6439f6e8352990a1591d21cf638073b2f702fb" alt=""
, and
where
data:image/s3,"s3://crabby-images/85282/85282d1e37d801e5c3906c332feceb1d8298ee51" alt=""
and
data:image/s3,"s3://crabby-images/68e4d/68e4dbde350dac33bc4c234b4766d272d8bea1a6" alt=""
.
Examples
Consider a swept matrix replicating the results of an OLS regression (see @sweep function).
group g y x1 x2 x3
sym usscp = @inner(g)
sym s = @sweep(usscp, 2, 4)
Just as each application of the sweep operator effectively switched the role of a variable from dependent to regressor, each application of the reverse sweep operator switches the role of a variable from regressor back to dependent.
For example, we can remove X1 as a regressor for Y by applying @rsweep to the corresponding diagonal element.
s = @rsweep(s, 2, 2)
We can also verify these results against a standard equation object:
vector beta = @subextract(S, 3, 1, 4, 1) ' Regressor coefficients
scalar ssr = s(1,1) ' Sum of squared residuals
sym invXtX = -@subextract(s, 3, 3)
vector se = @sqrt(ssr * @getmaindiagonal(invXtX) / (@obssmpl - 2)) ' Coefficient standard errors
equation eq.ls(noconst) y x2 x3
Cross-references
Goodnight, James H. (1979). “A Tutorial on the SWEEP Operator,” The American Statistician, 33, 149–158.