BookmarkSubscribeRSS Feed
Barkamih
Pyrite | Level 9

 HI all 

 

I'm trying to build a mixed-effects logistic regression model by using one variable as a random effect

 

I did proc logistic regression but can not take the random effect variable!

 

What do you think the best Prc to use in this situation?

 

These are  the  codes that I tried 

 

the third one takes a random effect variable but I did get any results.

 

So guys any suggestion to solve this issue?

 

best regards 

 

Ibrahim 

 

proc logistic data = have;
class year month;
model mpd = year month;
run; quit;
*//////////////////////;

proc GENMOD data = have;
class year month ;
model mpd = year month;
run; quit;
 */////////////////////;

proc GLIMMIX data = have;
class year month;
model MPD = YEAR month;
RANDOM HERD; 
RUN; QUIT; 


 

16 REPLIES 16
Rick_SAS
SAS Super FREQ

> the third one takes a random effect variable but I did [not] get any results.

1. What happened? Error? The proc never finished?

2. How many distinct levels of the HERD variable do you have?

3. Is the response variable binary? If so, you need to use DIST=BINARY on the MODEL statement for PROC GENMOD and GLIMMIX

 

If the response variable is not binary, you might want to read the 2009 paper "All the Cows in Canada: Massive Mixed Modeling with the HPMIXED Procedure",

which discusses efficiency issues in large linear mixed models.

 

Barkamih
Pyrite | Level 9

 

thanks million for your response 

 

 

1- this is the log message

NOTE: The SAS System stopped processing this step because of errors.
NOTE: PROCEDURE GLIMMIX used (Total process time):
real time 0.63 seconds
cpu time 0.53 seconds

 

2- I have a large number of herds, more than 8000.

 

3= Is the response variable binary? 

yes, which is like 0 or 1. 

 

So, in this case how my code should look like?

 

 

 

best regards 

 

 

 

 

 

Rick_SAS
SAS Super FREQ

The NOTE says there are errors, so please check the log for ERROR and WARNING messages. Please post the complete portion of the code from the last PROC GLIMMIX statement until the end of the log.

Barkamih
Pyrite | Level 9

this is the all message in log

 

156 proc GLIMMIX data = herd;
157 class testyear TIME;
158 model MPD = TESTYEAR TIME;
159 RANDOM HERD;
160 RUN;


160! QUIT;


NOTE: The SAS System stopped processing this step because of errors.
NOTE: PROCEDURE GLIMMIX used (Total process time):
real time 0.64 seconds
cpu time 0.54 seconds

 

 

Rick_SAS
SAS Super FREQ

Without error messages, I cannot determine what might be going wrong.  Can you run the following small example? Do you get results and a clean error-free log?

 

data herd;
call streaminit(1);
do herd = 1 to 10;
   do testyear = 2005, 2015;
      do Time = 1 to 6;
         eta = -1 + 0.1*herd + 0.5*Time - 2*(testyear=2015);
         mu = logistic(eta);
         mpd = rand("Bernoulli", mu);
         output;
      end;
   end;
end;

proc GLIMMIX data = herd;
   class testyear TIME;
   model MPD = TESTYEAR TIME / s dist=binary;
   RANDOM HERD;
RUN;
Barkamih
Pyrite | Level 9

not yet 

 

49 data herd;
50 call streaminit(1);
51 do herd = 1 to 10;
52 do testyear = 2005, 2015;
53 do Time = 1 to 6;
54 eta = -1 + 0.1*herd + 0.5*Time - 2*(testyear=2015);
55 mu = logistic(eta);
56 mpd = rand("Bernoulli", mu);
57 output;
58 end;
59 end;
60 end;
61

NOTE: The data set WORK.HERD has 120 observations and 6 variables.
NOTE: DATA statement used (Total process time):
real time 0.03 seconds
cpu time 0.03 seconds


NOTE: Writing HTML Body file: sashtml.htm
62 proc GLIMMIX data = herd;
63 class testyear TIME;
64 model MPD = TESTYEAR TIME / s dist=binary;
65 RANDOM HERD;
66 RUN;

 

ERROR: Permanent copy of file WORK.UTDATA.UTILITY was deleted.
NOTE: The SAS System stopped processing this step because of errors.
NOTE: PROCEDURE GLIMMIX used (Total process time):
real time 0.79 seconds
cpu time 0.28 seconds

 

Rick_SAS
SAS Super FREQ

There is something wrong with your version of SAS (or GLIMMIX). That program should run correctly in a fraction of a second. 

 

The first thing you should do is exit SAS (and probably reboot, too). Maybe SAS was corrupted by a previous submission, such as your big GLMMIX job.

 

When you log back in and start SAS, run the simple program again. If it still fails, contact SAS technical support and provide them with details about your OS, SAS installation, etc. Also, send them the code you just submitted and the complete SAS log.

StatDave
SAS Super FREQ

Of those three procedures, the only one that can fit a model involving random effects is PROC GLIMMIX. If you are not getting the results you expect, show the results you did get, any messages appearing after GLIMMIX in the SAS Log, and state what specifically you are looking for.

Barkamih
Pyrite | Level 9

Firstly I'm so sorry about the late response, it was late night here. 

 

show the results you did get, 

 

this is What I got.

 

The GLIMMIX Procedure
Model InformationData SetResponse VariableResponse DistributionLink FunctionVariance FunctionVariance MatrixEstimation TechniqueDegrees of Freedom Method
WORK.HERD
mpd
Binary
Logit
Default
Not blocked
Residual PL
Containment

 

Class Level InformationClass Levels ValuesTESTYEARTIME
112004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014
121 2 3 4 5 6 7 8 9 10 11 12

 

this is the log message

558
559 proc GLIMMIX data = herd;
560 class testyear TIME;
561 model MPD = TESTYEAR TIME / s dist=binary;
562 RANDOM HERD;
563 RUN;

 

NOTE: The SAS System stopped processing this step because of errors.
NOTE: PROCEDURE GLIMMIX used (Total process time):
real time 1.00 seconds
cpu time 0.82 seconds

 

 

I'm looking to have a multivariable logistic regression estimation of odd ratios of different months that having mpd including herd as a random effect. 

 

I got my results when I used Logistic Proc, but the problem is I can't include Herd as a RANDOM EFFECT.

 

I hope this information will help to figure this out 

 

best regards to all 

 

Ibrahim 

 

Rick_SAS
SAS Super FREQ
I assume you quit SAS and rebooted, as I suggested?

My first suggestion is to make sure the program can run on smaller data. Use a WHERE clause to restrict the number of herds to 10 and rerun the program to make sure it runs correctly.

IF the program runs correctly on smaller data, then my guess is that this problem has too many levels of the HERD variable and might be running out of memory. I suggest you read the paper by Kiernan, Tao, and Gibbs (2012)
http://support.sas.com/resources/papers/proceedings12/332-2012.pdf
and experiment to see if any of their suggestions make a difference in solving your problem.
Barkamih
Pyrite | Level 9

633
634 proc GLIMMIX data = few;
635 class testyear TIME;
636 model MPD = TESTYEAR TIME / s dist=binary;
637 RANDOM HERD;
638 RUN;

 

ERROR: Permanent copy of file WORK.UTDATA.UTILITY was deleted.
NOTE: The SAS System stopped processing this step because of errors.
NOTE: PROCEDURE GLIMMIX used (Total process time):
real time 0.36 seconds
cpu time 0.06 seconds

 

this error from small data that has 3 herds with 100 90 Obs.

anyway, thanks millions for every single letter you had written to this conversation. 

 

I'll try to work and read more to find out more about this issue.

 

best wishes to all 

Rick_SAS
SAS Super FREQ

You quit SAS and rebooted, as I suggested?

Barkamih
Pyrite | Level 9

Yes 

Rick_SAS
SAS Super FREQ

I don't think there is anything else we can do on this forum. If you cannot run GLIMMIX on the simulated 'herd' data set that I wrote, then there is something wrong with your SAS installation.

 

Please contact SAS Technical Support and provide them information about your operating system, version of SAS/STAT, and how you are submitting the program (SAS Studio, Enterprise Guide, SAS UE, etc). Send them the following code and the complete SAS log that results when you run it

 

data herd;
call streaminit(1);
do herd = 1 to 10;
   do testyear = 2005, 2015;
      do Time = 1 to 6;
         eta = -1 + 0.1*herd + 0.5*Time - 2*(testyear=2015);
         mu = logistic(eta);
         mpd = rand("Bernoulli", mu);
         output;
      end;
   end;
end;

proc GLIMMIX data = herd;
   class testyear TIME;
   model MPD = TESTYEAR TIME / s dist=binary;
   RANDOM HERD;
RUN;

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

What is ANOVA?

ANOVA, or Analysis Of Variance, is used to compare the averages or means of two or more populations to better understand how they differ. Watch this tutorial for more.

Find more tutorials on the SAS Users YouTube channel.

Discussion stats
  • 16 replies
  • 7694 views
  • 6 likes
  • 3 in conversation