BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
Tmreal
Calcite | Level 5

I'm performing analysis with proc Mixed or glm and want to add a flag for p-values:

*** <= 0.001

** <= 0.01

* <=0.05

 

I used to do this all the time but after moving to new companies I do not remember my code.

 

Also should I use the '<=' or just '<' ? Is there a symbol code for the '<=' if I need that and what is it?

 

I found the symbol code for degree in temperature.

 

Thank you.

 

Theresa

1 ACCEPTED SOLUTION

Accepted Solutions
PaigeMiller
Diamond | Level 26

In PROC REPORT, you can assign a format in the DEFINE statement.

--
Paige Miller

View solution in original post

8 REPLIES 8
PaigeMiller
Diamond | Level 26

Which parts of the MIXED or GLM output would you like to see this?

 

I think your choices on this are to output the MIXED/GLM output to a SAS data set, and then create a custom format to add the stars. Perhaps you could also use PROC TEMPLATE to modify the appearance of the output via changing the format there, but that's beyond my pay grade.

--
Paige Miller
ballardw
Super User

The numbers displayed ALWAYS relate to a format. So you capture the number value of the P-value in the and assign a custom format.

 

Proc format;
value asterisk
0 - 0.001 = '***'
0.001 <- 0.01 = '**'
0.01 <- 0.05 = '*'
other = [5.3]
;
run;

Assign the asterisk format in the Proc report code to the variable.

 

I though this "more significant" multiple asterisk nonsense had gone away.

Tmreal
Calcite | Level 5

How do I apply this to the p-values prior to putting them within the report?

Of course the p-values are pvalue8.4 format, but do I use the above format instead with them?

 

Thank you.

PaigeMiller
Diamond | Level 26

In PROC REPORT, you can assign a format in the DEFINE statement.

--
Paige Miller
Tmreal
Calcite | Level 5

In other words, use the format suggested above in Proc Report?

 

Thank you. 

Tmreal
Calcite | Level 5

I was given a picture code which looks like what I used to use.

 

It is:

 Proc format;

     picture pvalue3F (round)
    0.999 <- HIGH = '>0.9999' (NOEDIT)
    0.100 <- 0.999 = '9.9999'
    0.050 <- 0.100 = '9.9999'
    0.010 <- 0.050 = '9.9999 (*)'
    0.001 <- 0.010 = '9.9999 (**)'
    0.0001 <- 0.001 = '9.9999 (***)'
    0.0001 = '9.9999 (***)'
    LOW -< 0.0001 = '<0.0001 (****)' (NOEDIT)
        . - .z = ' ' (NOEDIT)
       other = ' ' (NOEDIT)
;

run;

 

within the dataset I use:

pvalue3Fmt = put(pvalue, pvalue3F.);

 

Works Great!!!!

Tmreal
Calcite | Level 5

This didn't work.

 

I have the format set as I showed above and in Proc Report I have:

 

Proc format;
value asterisk
0 - 0.001 = '***'
0.001 <- 0.01 = '**'
0.01 <- 0.05 = '*'
other = [5.3]
;
run;
proc report data=SASDB.ruggedness_temp_lot
nowd headline split='*' spacing=4 missing spanrows
style(report)={just=center outputwidth=10 in}
style(lines)=header{background=white asis=on font_size=10pt font_face="TimesRoman" just=left font_weight=bold}
style(header)=header{background=white font_size=10pt font_face="TimesRoman" frame=box
font_weight=bold}
style(column)=header{background=white font_size=10pt font_weight=medium}
;
columns Name Effect Lot Temp _lot _temp estimate probt ;

define Name / 'Model' order=internal;
define Effect / 'Effect' order ;
define probt / 'P-value^{super 1}' format=$asterick. center style(column)=[cellwidth=.5in];
define LOT / group 'LOT' center style(column)=[cellwidth=.5in];
define Temp / 'Temperature C^{unicode 0B0}' order center style(column)=[cellwidth=.5in];
define _lot / order=data 'vs Lot' center style(column)=[cellwidth=.5in];
define _temp / order=data 'vs Temperature C^{unicode 0B0}' format=F8.4 center style(column)=[cellwidth=.5in];
define estimate / order=data 'Estimate' format=F8.4 center style(column)=[cellwidth=.5in] ;
define LSMean / order=data 'LSMean Esdtimate' format=F8.4 center style(column)=[cellwidth=.5in] ;
define probt / 'P-value^{super 2}' format=$asterick. center style(column)=[cellwidth=.5in];

compute before _page_/ ;
line ' ';
line "Mean RNA Concentration Adjusted on Dilution (µg/mL) by Lot using Ruggedness by Temperature C^{unicode 0B0}";
line ' ';
line '1 * <= 0.05, ** <= 0.01, *** <=0.001, **** <= 0.0001';
line ' ';

endcomp;

run;

 

What is wrong???

 

Thank you for your assistance.

 

Tmreal
Calcite | Level 5

I could not get your suggestion to work and the other suggested to me didn't work within Proc Report. It didn't like the picture format.

 

HELP!!!

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

Creating Custom Steps in SAS Studio

Check out this tutorial series to learn how to build your own steps in SAS Studio.

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
  • 8 replies
  • 2335 views
  • 1 like
  • 3 in conversation