Statalist


[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

st: AW: AW: AW: AW: AW: Error in egen rank(), unique?


From   "Martin Weiss" <[email protected]>
To   <[email protected]>
Subject   st: AW: AW: AW: AW: AW: Error in egen rank(), unique?
Date   Tue, 3 Nov 2009 16:52:03 +0100

<> 

In this example, everything seems fine, but maybe I just do not get in which
respect your dataset is peculiar. Note that the -format- of the variable
should have no bearing whatsoever on the result of the operation. It merely
determines how the thing is -display-ed, not the underlying value - which in
your case is something like "571" (-di monthly("2007m8", "YM")=-)


*************
clear*

inp str10 datestring
"2009m3"
"2007m8" 
".     "
"2008m5" 
".     "
end

compress
list, noo

gen month= /* 
*/ monthly(trim(datestring), "YM")
format month %tm

egen rank=rank(month), unique 
li, noo
*************



HTH
Martin


-----Ursprüngliche Nachricht-----
Von: [email protected]
[mailto:[email protected]] Im Auftrag von Kaulisch, Marc
Gesendet: Dienstag, 3. November 2009 16:40
An: [email protected]
Betreff: st: AW: AW: AW: AW: Error in egen rank(), unique?

I see the problem or a counter-intuitive result as follows:
The egen rank(), unique gives the following ranks:
1 2 3 3
If the sequence is 2007m8 2008m5 . 2009m3

In my opinion it is counter-intuitive because
1) I understand unique as giving not identical ranks - but it does if a
missing is inserted
2) I would think that a rank command sorts the values in the var on its own
and does not need help to perform this

Best regards,


Marc

-----Ursprüngliche Nachricht-----
Von: [email protected]
[mailto:[email protected]] Im Auftrag von Martin Weiss
Gesendet: Dienstag, 3. November 2009 15:47
An: [email protected]
Betreff: st: AW: AW: AW: Error in egen rank(), unique?


<> 

Honestly, I cannot see the point of the problem, but note that your

*************
sort id dbep
by id, sort: egen rank_dbep = rank(dbep), unique
*************

can be telescoped into

-bys id (dbep): egen rank_dbep = rank(dbep), unique-


HTH
Martin


-----Ursprüngliche Nachricht-----
Von: [email protected]
[mailto:[email protected]] Im Auftrag von Kaulisch, Marc
Gesendet: Dienstag, 3. November 2009 15:46
An: [email protected]
Betreff: st: AW: AW: Error in egen rank(), unique?

Dear Martin,

Thanks for your answer. Your example works just fine. As it does with a
different dataset. The deletion of the qualifier [_n] does not change the
behaviour.

I found a work around:
The problem was that the var dbep (being formated as %tm) was not ordered.
Dbep1 dbep2 dbep3 dbep4 dbep5
2007m8 2008m5 . 2009m3 .

This sequence was ranked:
1 2 3 3

After inserting
. sort id dbep
Before the
. by id, sort: egen rank_dbep = rank(dbep), unique It just works fine

Nonetheless I consider this behaviour as not congruent with the description
of the Egen rank(), unique function saying "The unique option calculates the
unique rank of exp: values are ranked 1,...,#, and values and ties are
broken arbitrarily.  Two values that are tied for second are ranked 2 and 3.
"
(. h egen)

Best regards,


Marc

-----Ursprüngliche Nachricht-----
Von: [email protected]
[mailto:[email protected]] Im Auftrag von Martin Weiss
Gesendet: Dienstag, 3. November 2009 13:18
An: [email protected]
Betreff: st: AW: Error in egen rank(), unique?


<> 

No problem occur in this code, so where is the material difference to yours?

*************
clear*
set obs 10

gen id=_n
gen dbep1=5+int(10*runiform())
gen dbep2=5+int(10*runiform())
gen deep1=5+int(10*runiform())
gen deep2=5+int(10*runiform())
gen durep1=rnormal()
gen durep2=rnormal()

reshape long dbep deep durep, i(id) j(episode) by id, sort: egen rank_dbep =
rank(dbep), unique by id, sort: egen rank_deep = rank(deep), unique by id,
sort: replace rank_dbep =_n if rank_dbep[_n] == .
sort id rank_dbep
drop episode
reshape wide dbep deep durep rank_deep, i(id) j(rank_dbep)
*************

You do change the values returned by -egen, rank()- with your -replace-
line, so it is hard to argue that -egen- is at fault. Still, the line
clearly intends to replace the rank by its running number if it is missing.
So insert something like -inspect rank_dbep- before that line to see whether
there are any missings in the first place.

Also note that the -if rank_dbep[_n] == .- qualifier could easily be - if
rank_dbep == .-...


HTH
Martin


-----Ursprüngliche Nachricht-----
Von: [email protected]
[mailto:[email protected]] Im Auftrag von Kaulisch, Marc
Gesendet: Dienstag, 3. November 2009 11:27
An: [email protected]
Betreff: st: Error in egen rank(), unique?

I have a problem with an egen rank(), unique command (Stata version 10.1).
It looks like it does not produce the unique values as I like.
 
This is my start to rank episodes by their beginning (dbep). First I reshape
the dataset into the long-format.
 
. reshape long dbep deep durep, i(id) j(episode)
 
. by id, sort: egen rank_dbep = rank(dbep), unique . by id, sort: egen
rank_deep = rank(deep), unique
 
. by id, sort: replace rank_dbep = _n if rank_dbep[_n] == .
 
. sort id rank_dbep
 
When I do want to transform this dataset back in the wide format:
 
. drop episode
 
. reshape wide dbep deep durep rank_deep , i(id) j(rank_dbep)
 
I receive the following error:
 
rank_dbep not unique within id;
there are multiple observations at the same rank_dbep within id.
Type "reshape error" for a listing of the problem observations.
r(9);
 
reshape error gives out the number of 15 cases in which rank_dbep is not
unique.
 
Strangely enough with a different dataset the same commands work just fine.
 
Any ideas?
 


Marc Kaulisch

 
iFQ
Institut für Forschungsinformation und Qualitätssicherung Godesberger Allee
90
53175 Bonn, Germany
Tel.: *49 - 228 - 9 72 73 - 25
Fax: *49 - 228 - 9 72 73 - 49
E-mail: [email protected]
www.forschungsinfo.de

*
*   For searches and help try:
*   http://www.stata.com/help.cgi?search
*   http://www.stata.com/support/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/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/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/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/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/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