Hi,
I have written a macro to make a pdf with results for analytes tested in crops. There is a one page summary for each analyte with a box and whisker plot, histogram, scatter plot, and summary statistics table.
I have the columns set to 4 inches wide, but I cannot get the graphs to utilize all available width in the columns.
How can I make the plots wider?
Code and example output attached.
Thanks!
ods _all_ close;
%MACRO SGPLOT; %DO i=1 %TO &total;
ODS NORESULTS; ODS PDF STARTPAGE=NOW NOTOC /*STYLE=ceafigstyle*/;
ODS GRAPHICS ON / ANTIALIASMAX=1400;
ODS LISTING /*STYLE=ceafigstyle*/ GPATH =
'<path inserted here>' IMAGE_DPI=600;
OPTIONS topmargin=0.1in bottommargin=0.1in leftmargin=0.1in rightmargin=0.1in NODATE NONUMBER ORIENTATION=Portrait;
ODS PDF FILE="<file inserted here>";
TITLE "&&CROP_TYPE&i& &&TISSUE_TYPE&i &&ANALYTE&i";
ods layout gridded columns = 2 rows = 1 row_heights = (3in)  column_widths = (4.00in 4.00in);
ODS REGION;
PROC SGPLOT DATA=summary_pages_box NOAUTOLEGEND NOCYCLEATTRS;
WHERE CROP_TYPE="&&CROP_TYPE&i" AND TISSUE_TYPE="&&TISSUE_TYPE&i" AND ANALYTE="&&ANALYTE&i";
TITLE "&&CROP_TYPE&i& &&TISSUE_TYPE&i &&ANALYTE&i"; HBOX VALUE; RUN;
ODS REGION;
PROC SGPLOT DATA=summary_pages_all NOAUTOLEGEND NOCYCLEATTRS;
WHERE CROP_TYPE="&&CROP_TYPE&i" AND TISSUE_TYPE="&&TISSUE_TYPE&i" AND
ANALYTE="&&ANALYTE&i";
TITLE "&&CROP_TYPE&i& &&TISSUE_TYPE&i &&ANALYTE&i";
HISTOGRAM VALUE/boundary=lower; DENSITY VALUE; RUN;
ods layout end;
ods layout gridded columns = 1 rows = 2 row_heights = (3in 3in);
ODS REGION;
PROC SGPLOT DATA=summary_scatter NOAUTOLEGEND NOCYCLEATTRS;
WHERE CROP_TYPE="&&CROP_TYPE&i" AND TISSUE_TYPE="&&TISSUE_TYPE&i" AND
ANALYTE="&&ANALYTE&i";
YAXIS label="&&UNIT_OF_MEASURE&i&" min =0 OFFSETMIN = 0.08 OFFSETMAX = 0.08;
XAXIS DISPLAY=(nolabel) OFFSETMIN=0.05 OFFSETMAX=0.05;
X2AXIS display = (nolabel noticks novalues) values=(0 to 100 by 100)
OFFSETMIN=0 OFFSETMAX=0;
TITLE "&&CROP_TYPE&i& &&TISSUE_TYPE&i &&ANALYTE&i";
SCATTER x=Pass_Fail y=VALUE / NOMISSINGGROUP MARKERATTRS=(SIZE=10px); RUN;
ODS REGION;
PROC REPORT NOWINDOWS LIST DATA=summary_stats_tables;
WHERE CROP_TYPE="&&CROP_TYPE&i" AND TISSUE_TYPE="&&TISSUE_TYPE&i" AND
ANALYTE="&&ANALYTE&i";
COLUMNS Statistic Value;
DEFINE Statistic / display format = $20. width=20 center "Statistic";
define Value / display format = best8. width = 8 center "Value"; RUN;
ods layout end;
%END; %MEND SGPLOT; %SGPLOT;
ODS PDF CLOSE;
The size of the graphics are determined by the ODS GRAPHICS ON statement, so use the WIDTH= and HEIGHT= options, like this:
ODS GRAPHICS ON / ANTIALIASMAX=1400 width=400px height=300px;
The size of the graphics are determined by the ODS GRAPHICS ON statement, so use the WIDTH= and HEIGHT= options, like this:
ODS GRAPHICS ON / ANTIALIASMAX=1400 width=400px height=300px;
It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.
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.
Ready to level-up your skills? Choose your own adventure.
