Reverse sweep operator.
There are two forms 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/64580/64580a2647c0780f39cfeb56c8ce33c2e27107c1" alt=""
be an application of the symmetric sweep operator. Then,
data:image/s3,"s3://crabby-images/65473/6547350b2c0dc52777ad1a8fb228cc2badf6626e" alt=""
,
data:image/s3,"s3://crabby-images/88dd8/88dd891192a23598772ba63e9ecf281ca4aede0f" alt=""
where
data:image/s3,"s3://crabby-images/194b9/194b9979423e82846e3c472b6b532d552f5e5fa0" alt=""
,
data:image/s3,"s3://crabby-images/45018/450182febc2f2ea189c3c3c3ac71c6cf9f491103" alt=""
where
data:image/s3,"s3://crabby-images/30ba1/30ba1b1b2e03caf19a6b7df78655ce21aea5a0d8" alt=""
, and
where
data:image/s3,"s3://crabby-images/b7b73/b7b7364124c244b57bfc8a76fb6ac0f982bb6356" alt=""
and
data:image/s3,"s3://crabby-images/2f034/2f034df16f937ad936f279cb62a6f55afca8fe8d" alt=""
.
Let
data:image/s3,"s3://crabby-images/54d51/54d51aa2ed4a1b68c35cf81c8b7839206e42a925" alt=""
be an application of the non-symmetric sweep operator. Then,
data:image/s3,"s3://crabby-images/b963a/b963ace60d2745b0aa53ca7b68b329266378599b" alt=""
,
data:image/s3,"s3://crabby-images/cf062/cf06224708efac8f310e05c6e19573a63b1c9f0b" alt=""
where
data:image/s3,"s3://crabby-images/75b42/75b42811fef08a89e91038b6c7f34bd23e91da54" alt=""
,
data:image/s3,"s3://crabby-images/2ab06/2ab06a0275f45bbce6d44270bc796f975c19cba0" alt=""
where
data:image/s3,"s3://crabby-images/0be13/0be13f2c1f14d40f56e6da3272cbdde380dbf4c0" alt=""
, and
where
data:image/s3,"s3://crabby-images/81efb/81efb4fe3e7675969ef00b7f4666b5582c1ec59e" alt=""
and
data:image/s3,"s3://crabby-images/eb1b4/eb1b4aa11cf16058aedda88d3aff1da52a7256fd" 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.