Bookmark and Share

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]

Re: st: Looping and saving regression outputs


From   Sebastian Galarza <[email protected]>
To   [email protected]
Subject   Re: st: Looping and saving regression outputs
Date   Thu, 17 May 2012 11:38:43 -0700

Thanks (Nick, Fernando and Ada Ma) this looks like its working. By the way, sizef is size of field (working on oil data). 



On May 17, 2012, at 11:34 AM, Fernando Rios Avila wrote:

> oops
> You are totally right. The code should be like this:
>> foreach i in 1 2 3 4 5 6 7 8 9 10 {
>> reg y x if sizef==`i'
>> matrix betas=nullmat(beta) \ e(b)
>> matrix r2=nullmat(r2), e(r2)
>> matrix s2=nullmat(s2), e(V)
>> }
> 
> And the Size of firm...I guess too much work on my own data.
> Fernando
> On Thu, May 17, 2012 at 2:27 PM, Nick Cox <[email protected]> wrote:
>> This sounds more likely to be what Sebastian wants, but note that this loop repeats exactly the same code each time round the loop. Something like an -if- condition is presumably needed inside.
>> 
>> (How you do know that -sizef- is "size of firm"? Immaterial, but it's nowhere stated.)
>> 
>> Nick
>> [email protected]
>> 
>> 
>> -----Original Message-----
>> From: [email protected] [mailto:[email protected]] On Behalf Of Fernando Rios Avila
>> Sent: 17 May 2012 19:20
>> To: [email protected]
>> Subject: Re: st: Looping and saving regression outputs
>> 
>> Ok Sebastian,
>> So i believe what you want do is use different samples identified by
>> the size of the firm which is given in the variable sizef.
>> My answer, then, is more "manual". The first thing you need to have is
>> a list of all the possible groups you can obtain by sizef. A simple -
>> tab sizef -, or a recode of sizef should work here.
>> Lets say now that you have 10 groups. Your loop then should look something like:
>> 
>> foreach i in 1 2 3 4 5 6 7 8 9 10 {
>> reg y x
>> matrix betas=nullmat(beta) \ e(b)
>> matrix r2=nullmat(r2), e(r2)
>> matrix s2=nullmat(s2), e(V)
>> }
>> 
>> that should save your betas, the R2 and the variance-covariance
>> matrix. You might need to modify it specifically for your purposes in
>> the case of the var_covar matrix, since you only want the standard
>> errors.
>> 
>> Hope this helps
>> F
>>> Sent: 17 May 2012 19:01
>>> To: [email protected]
>>> Subject: Re: st: Looping and saving regression outputs
>>> 
>>> Nick et al,
>>> 
>>> Sorry for the lack of clarity. I will try to be more clear now and in future posts.
>>> 
>>> Here goes:
>>> 
>>> I have a panel dataset with several variables, including (sizef) with around 50,000 observations.
>>> The code that I am running does not contain the cycling/loop because I am unsure how to write it.
>>> 
>>> So the first question/problem is that:
>>> I would like to cycle through each observation of sizef and run each of three regressions.
>>> 
>>> The second question/problem regards:
>>> Recovering the coefficient vector, r2 and standard errors in a matrix.
>>> 
>>> After recovering these values for each observation, I want to create a histogram by regression for each of these values (coefficients, r2 and standard errors) to get a visual representation of how they are distributed.
>>> 
>>> I hope this helps clarify my issue.
>>> 
>>> On May 17, 2012, at 10:37 AM, Nick Cox wrote:
>>> 
>>>> I think it's the other way round. What you are doing precisely is unclear and more detailed advice is difficult for that reason.
>>>> 
>>>> For example:
>>>> 
>>>> You refer to cycling over variables -sizef- but it is not clear where -sizef- appears in your code.
>>>> 
>>>> You say you have 51,000 variables, but no Stata allows more than 32,767 variables. Do you mean observations?
>>>> 
>>>> Ada's very helpful reply is about as detailed as you can expect until you clarify such details.
>>>> 
>>>> For "STATA" read "Stata".
>>>> 
>>>> Nick
>>>> [email protected]
>>>> 
>>>> Sebastian Galarza
>>>> 
>>>> Ada Ma et al,
>>>> 
>>>> Thank you for your response. Can you be a little bit more explicit in the coding of this? I am still far from being a STATA power user and some examples might be helpful. Im looking into the svmat command and its a good starting point. Thanks for your input,
>>>> 
>>>> On May 17, 2012, at 8:15 AM, Ada Ma wrote:
>>>> 
>>>>> First you can create one matrix for each regression by stacking the r2
>>>>> on to the coefficients.  So say you have Q explanatory variable your
>>>>> row matrix would be 1 x (Q+1+1) (one for the constant one for the r2).
>>>>> You might also consider adding the SEs to your matrix too.  You might
>>>>> want to add an extra item at the top end of your matrix to label your
>>>>> regressions too to save your effort.
>>>>> 
>>>>> Then you can stack all the regression results into one big matrix.
>>>>> 
>>>>> Then after you have done all the loopings use -svmat- to turn your big
>>>>> matrix into variables.
>>>>> 
>>>>> Then finally you -outsheet- those variables into a CSV or save the new
>>>>> variables as a separate Stata dataset.
>>>> 
>>>> 
>>>> On Wed, May 16, 2012 at 6:22 PM, Sebastian Galarza
>>>> 
>>>>>> I want to run the following code and save the beta values and r2 for three different regressions in a matrix such as this:
>>>>>> 
>>>>>> Variable B0a B1a B2a R2a B1b B2b B3b R2b B1c B2c B3c R2c
>>>>>> 1
>>>>>> 2
>>>>>> 3
>>>>>> 
>>>>>> I have a total of 51000 variables (sizef) so that the code I would like to run is:
>>>>>> 
>>>>>> 
>>>>>> *for each variable sizef
>>>>>> 
>>>>>> nl (P_WOR = {b0=0.1}*(1 * exp({b1=0.05}* (ageyear))))
>>>>>> predict a
>>>>>> matrix list e(b)
>>>>>> display e(r2)
>>>>>> 
>>>>>> * save beta values and r2
>>>>>> 
>>>>>> nl log3: P_WOR ageyear
>>>>>> predict b
>>>>>> matrix list e(b)
>>>>>> display e(r2)
>>>>>> 
>>>>>> * save beta values and r2
>>>>>> 
>>>>>> nl gom3: P_WOR ageyear
>>>>>> predict c
>>>>>> matrix list e(b)
>>>>>> display e(r2)
>>>>>> 
>>>>>> * save beta values and r2
>>>>>> 
>>>>>> Any help would be greatly appreciated.
>> 
>> *
>> *   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–2018 StataCorp LLC   |   Terms of use   |   Privacy   |   Contact us   |   Site index