Notice: On April 23, 2014, Statalist moved from an email list to a forum, based at statalist.org.
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
st: RE: Re: Snowball sampling
From
"Ray Hawkins" <[email protected]>
To
<[email protected]>
Subject
st: RE: Re: Snowball sampling
Date
Tue, 16 Apr 2013 09:19:08 -0500
Hello,
I posted a similar question a while ago, but have a related question. My
data looks the following (without 'keep'), a network data. To generate
'keep', I ran the following code. However, this code covers the first two
steps (up to giveid 11) of the whole network starting giveid=17 -> 2 -> 11
-> 18 -> 32 -> 40 -> 16. That is, keep=1 only for giveid=17,2,11. I would
like to keep all 7 giveid that are connected. The problem is that I don't
know how many steps I need to go to keep all connected id. Or, even if I
know, the code will be very complicated to go to 50 or 100 steps, for
example. Is there any way I can keep all those connected id starting from a
seed id? If Stata cannot handle this problem, then maybe I need to use a
social network software? Thank you.
Ray Hawkins.
gen byte keep=giveid==17 // seed id
qui levelsof recid if giveid==17, local(keepers)
foreach keeper of local keepers {
replace keep=1 if giveid==`keeper' // keep all recid for seed id
qui levelsof recid if giveid==`keeper', local(keepers1)
foreach keeper of local keepers1 {
replace keep=1 if giveid==`keeper' // keep all recid for those who
received from giveid=17 and gave to others
}
}
keep if keep==1
giveid recid keep
2 11 1
3 15 0
6 10 0
11 18 1
11 190 1
16 187 0
17 1 1
17 2 1
17 5 1
17 23 1
18 32 0
19 782 0
32 17 0
32 21 0
32 23 0
32 37 0
32 40 0
32 68 0
33 111 0
40 16 0
40 20 0
40 70 0
40 92 0
41 15 0
41 22 0
41 23 0
41 27 0
-----Original Message-----
From: [email protected]
[mailto:[email protected]] On Behalf Of Joseph Coveney
Sent: Friday, March 22, 2013 11:06 PM
To: [email protected]
Subject: st: Re: Snowball sampling
Ray Hawkins wrote:
I am working with social network data, but it is too big, so I would like to
do snowball sampling. My data look like the following. Can you help me
figure out how to keep 'giveid' and corresponding 'recid' for a seed id? For
example, giveid=17 is a seed id. So, I would like to keep giveid=17 and all
giveid (=recid for giveid=17) = 6, 2, 5, 23, 1, 11, 4, 16, 33, 27, 16 (if
exist, of course). Then, for another seed id=32, for example, I would like
to repeat the same process to get certain data size. Thank you in advance.
--------------------------------------------------------------------------
------
Not very efficient, but it should work and it has an easy-to-debug
one-to-one correspondence with the specifications:
* "keep giveid=17"
generate byte keep = giveid == 17
* "and all giveid (=recid for giveid=17)"
quietly levelsof recid if giveid == 17, local(keepers) quietly foreach
keeper of local keepers {
replace keep = 1 if giveid == `keeper'
}
* "repeat the same process" "for another seed id=32"
quietly replace keep = 1 if giveid == 32 quietly levelsof recid if giveid ==
32, local(keepers) quietly foreach keeper of local keepers {
replace keep = 1 if giveid == `keeper'
}
quietly keep if keep
Joseph Coveney
*
* For searches and help try:
* http://www.stata.com/help.cgi?search
* http://www.stata.com/support/faqs/resources/statalist-faq/
* http://www.ats.ucla.edu/stat/stata/
*
* For searches and help try:
* http://www.stata.com/help.cgi?search
* http://www.stata.com/support/faqs/resources/statalist-faq/
* http://www.ats.ucla.edu/stat/stata/