BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
PamG
Quartz | Level 8
I have two categorical variable of 4 levels each and a continuous variable.  Is there a way to save schoenfeld's residuals for all the variables?  The way I know is to provide the residual variable names in the OUTPUT statement and SAS outputs the residuals in the order of the variables that come in the "Analysis of Maximum Likelihood Estimates' table. for eg. 
 
PROC PHREG;
CLASS race sex;
MODEL time*censor(0)=race sex age;
OUTPUT OUT=outres RESSCHI=reswhite resblack resAsian resfemale resage; **these variables come in this order
in the Analysis of MLE table.
RUN;
I have to run multiple models with different comorbidities and I am wondering if there is a way to request SAS to output the residuals for all the variables in the model without having to write them out in OUTPUT statement..
1 ACCEPTED SOLUTION

Accepted Solutions
FreelanceReinh
Jade | Level 19

Hello @PamG,

 

Have you tried the RESSCH=_ALL_ option of the OUTPUT statement or are you not satisfied with the default variable names RESSCH_... created by this option?

View solution in original post

3 REPLIES 3
ballardw
Super User

I am not sure exactly what your need is.

Are you looking for a way to create matching list of residual variable names? Such as provide the list of variables on the model and create the matching variable names for the output statement?

 

As far as I know Proc Phreg will only use one model statement and output statement per procedure call so I'm not sure where the "all variables" come into the request. The names are actually irrelevant. you can use an output statement like

   output out=work.phregout ressch=v1-v100;

which would name the residual variables v1 through v100 if there are 100 variables in the model. If there are only 5 variables in the model only v1 through v5 are created. But with different variables on the model V1 from one model doesn't represent the residuals of the same variable if the first variable in the model statement differs.

 

This a macro that allows you to place a prefix in front of each of a space delimited words, default is res_ provide a different string as prefix=oth as desired. This will create a matching list simpler.

%macro res(vlist,prefix=res_);
   %let result=;
   %do i=1 %to %sysfunc(countw(&vlist));
      %let word= %scan(&vlist,&i);
      %let result= &result &prefix.&word;
   %end;
   &result. 
%mend;
/* example to show what the result looks like in the log*/
%put %res( one two three);

Use would look like this

model <whatever> = one two three /other options;
output out=outset ressch= %res( one two three) <other options>;

Caveats: If your variable names are long the resulting variable names can get truncated with unexpected results.

If you have name literals "this is a literal"n for names this macro will not work at all.

Please note that the line of the macro before the %mend statement does not have a ; because it would become part of the value returned by the macro ending your output statement early. And likely to cause a number of errors therefrom.

 

 

FreelanceReinh
Jade | Level 19

Hello @PamG,

 

Have you tried the RESSCH=_ALL_ option of the OUTPUT statement or are you not satisfied with the default variable names RESSCH_... created by this option?

PamG
Quartz | Level 8
Thank you @FreelanceReinh. I did not know that was an option. It worked. Thanks!!!

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

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 3 replies
  • 2955 views
  • 0 likes
  • 3 in conversation