BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
Cuneyt
Obsidian | Level 7

Dear All,

 

I am using PROC SYSLIN with dummy variables generated by PROC GLMMOD. However, I must manually intervene as shown below:

 

proc glmmod data=dataset1 outdesign=dummies noprint;

    class customer supplier;     /* Each customer and supplier has a unique number */

    model y = customer supplier; /* Generate dummy variables for customers and suppliers */

run;

 

data dataset2; /* Add dummy variables columns to the data set */

    set dataset1;

    set dummies;

run;

 

/* See which columns are for customers and which columns are for suppliers */

proc contents data=dataset2;

run;

 

/* MANUALLY add customer and suppliers columns */

proc syslin data=dataset2 3sls;

    endogenous y1 y2;

    instruments w z  Col2-Col100 /* assuming 100 customer and supplier dummies */;

customer: model y1 = w Col3 - Col61   /* customer columns only */;

supplier: model y2 = z Col63 - Col100 /* supplier columns only */;

run;

 

My questions is: How can I get the range of columns corresponding to customer and supplier dummies and pass that info as a macro variable to PROC SYSLIN? I do not want to hardcode the column numbers in PROC SYSLIN. Any help will be greatly appreciated.

 

Sincerely,

Cuneyt

1 ACCEPTED SOLUTION

Accepted Solutions
Rick_SAS
SAS Super FREQ

In addition to the OUTDESIGN= option, which writes the dummy variables to a data set, you will want to use the OUTPARM= option, which outputs a table that connects the levels of the original variable to the names of the dummy variables. For an example, see the call to PROC GLMMOD in the article "Create dummy variables in SAS."  You can use a DATA step or PROC SQL to extract the column numbers for the CUSTOMER and SUPPLIER variables. 

 

For example, the following uses the SEX and BP_STATUS variables in the Sashelp.Heart data.  I am not familiar with PROC SYSLIN, but I use PROC MEANS to count the number of levels in each dummy variable.

 

proc glmmod data=sashelp.heart outdesign=GLMDesign outparm=GLMParm noprint;
   class sex BP_Status;
   model Cholesterol = Sex BP_Status;
run;
 
data _NULL_;
set GLMParm(where=(EFFNAME^="Intercept"));
by notsorted EFFNAME;
if first.EFFNAME then do;
   macroName = catt(EFFNAME, "Min");
   call symputx(macroName, _COLNUM_);
end;
if last.EFFNAME then do;
   macroName = catt(EFFNAME, "Max");
   call symputx(macroName, _COLNUM_);
end;
run;
 
%put &=SexMin;       /* first column for SEX */
%put &=SexMax;       /* last column for SEX */
%put &=BP_StatusMin; /* first column for BP_STATUS */
%put &=BP_StatusMax; /* last column for BP_STATUS */

proc means data=GLMDesign sum;
var COL&SexMin - COL&SexMax
    COL&BP_StatusMin - COL&BP_StatusMax;
run;

/* should give the same counts as PROC FREQ */
/*
proc freq data=Sashelp.Heart(where=(Cholesterol^=.));
tables Sex BP_Status;
run;
*/

View solution in original post

2 REPLIES 2
Rick_SAS
SAS Super FREQ

In addition to the OUTDESIGN= option, which writes the dummy variables to a data set, you will want to use the OUTPARM= option, which outputs a table that connects the levels of the original variable to the names of the dummy variables. For an example, see the call to PROC GLMMOD in the article "Create dummy variables in SAS."  You can use a DATA step or PROC SQL to extract the column numbers for the CUSTOMER and SUPPLIER variables. 

 

For example, the following uses the SEX and BP_STATUS variables in the Sashelp.Heart data.  I am not familiar with PROC SYSLIN, but I use PROC MEANS to count the number of levels in each dummy variable.

 

proc glmmod data=sashelp.heart outdesign=GLMDesign outparm=GLMParm noprint;
   class sex BP_Status;
   model Cholesterol = Sex BP_Status;
run;
 
data _NULL_;
set GLMParm(where=(EFFNAME^="Intercept"));
by notsorted EFFNAME;
if first.EFFNAME then do;
   macroName = catt(EFFNAME, "Min");
   call symputx(macroName, _COLNUM_);
end;
if last.EFFNAME then do;
   macroName = catt(EFFNAME, "Max");
   call symputx(macroName, _COLNUM_);
end;
run;
 
%put &=SexMin;       /* first column for SEX */
%put &=SexMax;       /* last column for SEX */
%put &=BP_StatusMin; /* first column for BP_STATUS */
%put &=BP_StatusMax; /* last column for BP_STATUS */

proc means data=GLMDesign sum;
var COL&SexMin - COL&SexMax
    COL&BP_StatusMin - COL&BP_StatusMax;
run;

/* should give the same counts as PROC FREQ */
/*
proc freq data=Sashelp.Heart(where=(Cholesterol^=.));
tables Sex BP_Status;
run;
*/
Cuneyt
Obsidian | Level 7

Hi Rick,

 

Thank you very much. This solution worked like a charm!

 

Sincerely,

Cuneyt

SAS Innovate 2025: Call for Content

Are you ready for the spotlight? We're accepting content ideas for SAS Innovate 2025 to be held May 6-9 in Orlando, FL. The call is open until September 16. Read more here about why you should contribute and what is in it for you!

Submit your idea!

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.

Click image to register for webinarClick image to register for webinar

Classroom Training Available!

Select SAS Training centers are offering in-person courses. View upcoming courses for:

View all other training opportunities.

Discussion stats
  • 2 replies
  • 1788 views
  • 0 likes
  • 2 in conversation