|
[Date Prev][Date Next][Thread Prev][Thread Next][Date index][Thread index]
Re: st: Map logical operator across varlist?
From
David Kantor <[email protected]>
To
[email protected]
Subject
Re: st: Map logical operator across varlist?
Date
Wed, 17 Jan 2007 15:31:20 -0500
I don't think you can "map" an arbitrary operator.
But there are many ways to program your problem.
If you create a set of indicators as to whether the med variables are
nonmissing (and by the way, a more generally correct test is ~mi() )...
gen byte nonmis_med1 = ~mi(med1)
gen byte nonmis_med2 = ~mi(med2)
etc., (and that can be made into a loop)
then if you have the trinary module, you can do
egen byte med_ok = rtvor(nonmis_*)
this will give you the row-or of the arguments. (The fact that it is
3-valued logic is irrelevant.)
Then you can
list med* if med_ok
To get trinary,
ssc inst trinary
I hope this helps.
--David
At 03:01 PM 1/17/2007, Joel J. Adamson wrote:
Does anyone know how to map a logical operation (e.g., | or &) across
a list so that I can save myself some typing?
Let me give you an example (the one that prompted the search for an
answer):
I want to list a set of variables, only if an observation is not missing
for the variables in question. We usually handle this by constructing
a small logical expression:
l med1 med2 if (med1~=.|med2~=.)
However, if I have six, or a hundred "med" variables (med*), it would
be easier (less error-prone) to type:
l med* if |(med*~=.)
Where the "|" before the "(" maps the operation onto the expanded list
of variables.
I know that Scheme (and hence probably S) have a function called "map"
that maps any operation onto a list, e.g.,
(map or '(1 2 3 ... ))
Does anyone know of a similar construct in Stata? How about an egen
function that would accomplish the same goal?
Thanks,
Joel
--
Joel J. Adamson
Biostatistician
Pediatric Psychopharmacology Research Unit
Massachusetts General Hospital
Boston, MA 02114
(617) 643-1432
(303) 880-3109
[...]
*
* For searches and help try:
* http://www.stata.com/support/faqs/res/findit.html
* http://www.stata.com/support/statalist/faq
* http://www.ats.ucla.edu/stat/stata/
© Copyright 1996–2025 StataCorp LLC | Terms of use | Privacy | Contact us | What's new | Site index |