How to Build Tabular Dashboards Using Proc Report

Slides:



Advertisements
Similar presentations
Summary Statistics/Simple Graphs in SAS/EXCEL/JMP.
Advertisements

DIVERSE REPORT GENERATION By Chris Speck PAREXEL International Durham, NC.
Statistical Methods Lynne Stokes Department of Statistical Science Lecture 7: Introduction to SAS Programming Language.
Using ODS Regions to Create Custom Reports Kate Morrow, M.S. Statistician Vermont Oxford Network, Burlington, VT.
Examples from SAS Functions by Example Ron Cody
Outline Proc Report Tricks Kelley Weston. Outline Examples 1.Text that spans columnsText that spans columns 2.Patient-level detail in the titlesPatient-level.
SAS coding used in creating a routine report February 23, 2009 February is Heart Month.
MASUG December 5, Agenda Announcements Announcements Tips & Tricks Tips & Tricks Presentation: Presentation: Working Smarter, Not Harder with DDE:
Welcome to CMPE003 Personal Computer Concepts: Hardware and Software Winter 2003 UC Santa Cruz Instructor: Guy Cox.
Get Fancy Department Level Reports Using SAS ExcelXP Tagset 2008 AIR Forum Seattle, Washington Ray Wallace Washington State University.
Introduction to SQL Session 1 Retrieving Data From a Single Table.
Spreadsheets and Business Graphics: Facts and Figures Chapter 13.
Word Processing Chapter 5 Review Slides. All template files have this file extension and are stored in the Templates folder.dotx.
Let SAS Do the Coding for You! Robert Williams Business Info Analyst Sr. WellPoint Inc.
Copyright © 2006, SAS Institute Inc. All rights reserved. Randy Poindexter & Scott Huntley Output Delivery and Reporting An Introduction to ODS.
The New SAS Engine For CRSP   Benefits of using SAS engine for CRSP   Setting up the interface between SAS and CRSP   Examples of use   Performance.
Copyright © 2010, SAS Institute Inc. All rights reserved. Define.xml - Tips and Techniques for Creating CRT - DDS Julie Maddox Mark Lambrecht SAS Institute.
Copyright © 2010, Meta-Xceed, Inc. All rights reserved. BI Flash and all other Meta-Xceed Inc. product or service names are registered trademarks or trademarks.
Introduction to SAS/Graph Don Miller 812 Oswald Tower
Copyright © 2006, SAS Institute Inc. All rights reserved. Enterprise Guide 4.2 : A Primer SHRUG : Spring 2010 Presented by: Josée Ranger-Lacroix SAS Institute.
SAS PROC REPORT PROC TABULATE
Chapter 9 Producing Descriptive Statistics PROC MEANS; Summarize descriptive statistics for continuous numeric variables. PROC FREQ; Summarize frequency.
1 Overview of Databases. 2 Content Databases Example: Access Structure Query language (SQL)
Enhancements in Estimation and Bid Analysis Randy Lawton Info Tech, Inc.
Tips & Tricks MASUG02/18/2005. Multiple Graphs on One Page.
Introduction to SAS. What is SAS? SAS originally stood for “Statistical Analysis System”. SAS is a computer software system that provides all the tools.
Essential ODS PDF Patrick Thornton.
01/20151 EPI 5344: Survival Analysis in Epidemiology SAS code and output February 24, 2015 Dr. N. Birkett, School of Epidemiology, Public Health & Preventive.
Macro Overview Mihaela Simion. Macro Facility Overview Definition : The SAS Macro Facility is a tool within base SAS software that contains the essential.
SAS Software Version 8 The Output Delivery System.
Introduction to SAS/Graph 9.2 Ken Barz Colorado Prevention Center 22Oct2009 Ken Barz Colorado Prevention Center.
Using the new Version 8 Template Procedure for Complete Control of SAS Output Style and Format David Ghan Technical Training Specialist SAS, Canada.
Introduction to Enterprise Guide Jennifer Schmidt Rhonda Ellis Cassandra Hall.
SAS ODS (Output Delivery System) Donald Miller 812 Oswald Tower ;
Copyright © 2014, SAS Institute Inc. All rights reserved. ACCESSIBILITY TIPS AND TRICKS FOR SAS PROGRAMMERS ED SUMMERS SENIOR MANAGER, ACCESSIBILITY.
Priya Ramaswami Janssen R&D US. Advantages of PROC REPORT -Very powerful -Perform lists, subsets, statistics, computations, formatting within one procedure.
Effective SAS greplay’ing and how to avoid stretching By David Mottershead Senior Programmer, Quanticate.
MASUG September 15, Agenda  Guest Introductions  John Boling – SAS inSchool  Tim Garton – Health Forecasts  Announcements  Tips & Tricks 
YET ANOTHER TIPS, TRICKS, TRAPS, TECHNIQUES PRESENTATION: A Random Selection of What I Learned From 15+ Years of SAS Programming John Pirnat Kaiser Permanente.
Chapter 1: Overview of SAS System Basic Concepts of SAS System.
©Dofasco Inc., 2004 All rights reserved 1 Using the Output Delivery System October 22, 2004 Presentation to: The Toronto Area SAS Society.
Chapter 10 Creating a Template for an Online Form Microsoft Word 2013.
Spreadsheets and Business Graphics: Facts and Figures Chapter 13.
1 Chapter 3: Getting Started with Tasks 3.1 Introduction to Task Dialogs 3.2 Creating a Listing Report 3.3 Creating a Frequency Report 3.4 Creating a Two-Way.
Remember…  Please do not…  Change the background.  Change the icons.  Change the font. Use Times New Roman (size 12 font).  Use color. We cannot print.
SAS ® is a very powerful tool when producing Graphics. A single graphical data step can easily create a Kaplan Meier Plot, but there is no single graphical.
BMTRY 789 Lecture 6: Proc Sort, Random Number Generators, and Do Loops Readings – Chapters 5 & 6 Lab Problem - Brain Teaser Homework Due – HW 2 Homework.
SHRUG, F EB 2013: N ETWORKING EXERCISE Many Ways to Solve a SAS Problem.
Patrick Thornton SRI International.  Example of a Multiple Response Item ◦ Variable coding and example data  A Cross Tabulation using Proc REPORT 
ODS TAGSETS - a Powerful Reporting Method Derek. 2 Agenda Understanding the tagset How to use tagsets Conclusion.
Using Dictionary Tables to Profile SAS Datasets By Phillip Julian February 11, 2011.
HRP Copyright © Leland Stanford Junior University. All rights reserved. Warning: This presentation is protected by copyright law and.
Based on Learning SAS by Example: A Programmer’s Guide Chapters 1 & 2
Online Programming| Online Training| Real Time Projects | Certifications |Online Classes| Corporate Training |Jobs| CONTACT US: STANSYS SOFTWARE SOLUTIONS.
1 SAS ® ODS Technology for Today’s Decision Makers Sunil Gupta Quintiles.
SAS ® 101 Based on Learning SAS by Example: A Programmer’s Guide Chapters 14 & 19 By Tasha Chapman, Oregon Health Authority.
Better Metadata Through SAS® II: %SYSFUNC, PROC DATASETS, and Dictionary Tables.
Beautiful PROC CONTENTS Output Using the ODS Excel Destination Suzanne Dorinski SESUG 2015 Disclaimer: Any views expressed are those of the author and.
A MORE COMPLETE ODS REPORT. What we’re going to talk about…  Creating a title page  Creating an introduction page  Creating long-form text descriptions.
Data Visualization with Tableau
Session 1 Retrieving Data From a Single Table
Applied Business Forecasting and Regression Analysis
Jonathan W. Duggins; James Blum NC State University; UNC Wilmington
SAS Data Set Utility with Excel Output
Lab 3 and HRP259 Lab and Combining (with SQL)
Never Cut and Paste Again
Purpose Real life scenario: I have a set of reports to refresh every month but data is only available at any day during Day 3 – 5 at beginning of each.
Tips and Tricks for Using Macros to Automate SAS Reporting.
Presentation transcript:

How to Build Tabular Dashboards Using Proc Report Shana Bereznay ACS Raff Rushton IBM Frank Bereznay Credit Raff for Original Idea Wanted to share what he came up with

Agenda Management Reporting Dashboard Organization How to Build Two Phases Related Reporting How to Automate Email Notification Summary / Questions Just read the agenda OK to ask questions any time, especially SAS questions

Management Reporting A very key point… There is no single right way Beauty is in the eye of the beholder Tabular vs Graphical Representation Read the slide Here is an example

A Tabular View of Some Data A lot of valuable information , but the presentation is visually neutral. Compare this to a graphical display of a subset of the data.

A Graphical View of the Same Data Some key points with graphs like this. We naturally see a time series for the x axis, so we are looking at a time series analysis of some sort. One bar in each graph is for a specific date so we are looking at before and after upgrade analysis Gets the main point across, but lacks the presentation details or density of the tabular presentation Key theme of Tufte’s ‘rules’. Provide the reader of the document as much data as possible and Allow him to derive the infformation content out of the data.

Management Reporting A very key point… There is no single right way Beauty is in the eye of the beholder Tabular vs Graphical Representation Some Common Themes Time Series Data Analysis Drill Down Capability Threshold based Exception Alerting Do Something if you see a ‘problem’ No matter how we present the data we have some common themes in our field. We generally deal with time series data analysis Complex data that needs to be explored Comparing metrics against established or expected thresholds to look for exceptions Do something if you see a problem Over time, we gravitated to the tabular dashboard as a way to satisfy these reporting requirements

Dashboard Organization Review key themes Well suited for time series data, natural left to right progression of data values Linked cells provide a intuitive drill down capability Color coding of cells allow for exceptions to be highlighted. Behind the scenes we can generate email alerts based on any business rule or exception value Best of all, this is very easy to build (a little tedius at times) and requires base SAS

How to Build Phase I Phase II Create Unattributed Dashboard Design Dashboard Code Proc Report Statements Phase II Attribute Cells Add links to related reporting Add format to color cell background More like a set of general guidelines than a specific coding requirement or standard. Describe the two phases Unattributed Dashboard Attribute Cells

Phase I Design Wysiwyg design style Draw the dashboard on paper or in EXCEL The starting point or foundation is the metric(s) you want to report on. Resource in this example The date range is to the right of the resource column along with the derivation of the metric to be displayed Left hand side of resource column is used to group / categorize / summarize Very simple layout, but an important starting point

Example 1 – SAS Code LibName VelSoft "&Path\VelSoft"; ODS Html File="&Path\VelSoft\Example_1.html" Style=Statistical; ODS Listing Close; ODS Html; Proc Report Data=VelSoft.XAMCPUBY NoWindows; Column Serial Startime CPUUtil; Define Serial /'Serial' Group; Define Startime /'Date' Group Format=Datetime7.; Define CPUUtil /'Mean Busy' Analysis Mean Format=4.1; Where DatePart(Startime) Between '01Mar10'd and '05Mar10'd and Serial In ('04E910','05D3A0'); Title1 "Proc Report Example 1 – List of Data with Average Calculated"; Title2 "Reporting on two zVM Instances to Save Space"; Run; ODS Html Close; ODS Listing; First example is to introduce Proc Report Items to note Column statement defines what is displayed and in what order Define statements provide attributes for the variables to be displayed Group is like ID combined with BY on a Proc Print Interaction between Startime (formatted value) and how the mean is calculated. The dataset being processed is 15 minute interval data Lets look at the result Before that brief ODS discussion

Example 1- Output Very simple and straight forward Three variables on the column statement and three columns get printed. Note the single reported value per day based on the format specified for startime. Simple, but not the left to right order we wanted so we will introduce the across variable in the second example

Example 2 – SAS Code LibName VelSoft "&Path\VelSoft"; Data XAMCPUBY; Set VelSoft.XAMCPUBY; LPAR = Serial; Env = Serial; Cat = 'CPU'; ODS Html File="&path\VelSoft\Example_2.html" Style=Statistical; ODS Listing Close; ODS Html; Proc Report Data=XAMCPUBY NoWindows; Column Env LPAR Cat Startime, CPUUtil; Define Env / '' Group Format=$Env.; Define LPAR / '' Group Format=$LPAR.; Define Cat / '' Group Format=$Cat.; Define Startime / '' Across Format=Datetime7.; Define CPUUtil / '' Analysis Format=4.1 Mean Width=7; Where DatePart(Startime) Between '01Mar10'd and '05Mar10'd; Title1 "Proc Report Example 2 - Use of the Across Parameter and Grouping Variables”; Run; ODS HTML Close; ODS Listing; This example fills out the left hand side categorization columns and uses the across variable to get the left to right visual we desire Note data step at top to create some additional categorization variables. Setting up a dashboard that will handle multiple types of resources, reason for the Cat variable (category) Start with column statement again, this time we have five variables and a comma What is the comma for? Nesting Hierarchy Puts metric value beneath the data variable. Notice we have removed the column header titles, the organization of the data is now intuitive Go over the defines Lets see how this looks

Example 2 - Output Success – We now have the left to right orientation of the data we wanted and notice how intuitive the presentation of the data is. No column headings needed now However, we want to show 30 days of data on a single non scrolled web page and this presentation density is not going to accommodate that. Next step is to introduce ODS style statement to increase the presentation density

Example 3 – SAS Code LibName VelSoft "&Path\VelSoft"; Data XAMCPUBY; Set VelSoft.XAMCPUBY; LPAR = Serial; Env = Serial; Cat = 'CPU'; ODS Html File="&path\VelSoft\Example_3.html" Style=Statistical; ODS Listing Close; ODS Html; Proc Report Data=XAMCPUBY headline headskip missing Style(Report)={Background=Black CellSpacing=1MM CellWidth=1MM} Style(Column)={Font_Size=10PT} Style(Header)={Foreground=Black Background=White Font_Size=10PT}; Column Env LPAR Cat Startime, CPUUtil; Define Env / '' Group Format=$Env.; Define LPAR / '' Group Format=$LPAR.; Define Cat / '' Group Format=$Cat.; Define Startime / '' Across Format=DTDate5.; Define CPUUtil / '' Analysis Mean Format=3.; Where DatePart(Startime) Between '01Mar10'd and '12Mar10'd; Title1 "Proc Report Example 3 - ODS Style Elements"; Run; ODS HTML Close; ODS Listing; No change to the Proc Report column or define statements for this example. ODS statements are added to reduce the size of a cell. We have also increased the date range to generate more columns Notice we did not make any coding changes to introduce more columns, that is driven by the values in the data itself.

Example 3 - Output We have finished Phase I. We have a non attributed (no links in the cells) tabular dashboard. For some reporting this may be all that is needed. A logical intuitive presentation of time series data ranging from left to right

Phase I Summary Proc Report Unattributed Dashboard Easy to Use Powerful Integrates with ODS Unattributed Dashboard May be all that is needed Read the slide Onward to Phase II – Lets attribute the cells!

Example 4 – SAS Code LibName VelSoft "&Path\VelSoft"; Data VelSoft.XAMCPUBY; Length URL_Trend $19.; Set VelSoft.XAMCPUBY; LPAR = Put(Serial,$LPAR.); Env = Serial; Cat = 'CPU'; URL_Trend = Cats(Cat,'-',LPAR,'-mth.html'); ODS Html File="&path\VelSoft\Example_4.html" Style=Statistical; ODS Listing Close; ODS Html; Coding got too big to be on one page so it is now split across two slides. We are going to add a link to a related trend report for each zVM LPAR Note the new variable URL_Trend So we have crated a new variable URL_Trend, lets see how we will use it.

Example 4 – SAS Code Proc Report Data=VelSoft.XAMCPUBY headline headskip missing; Style(Report)={Background=Black CellSpacing=1MM CellWidth=1MM} Style(Column)={Font_Size=10PT} Style(Header)={Foreground=Black Background=White Font_Size=10PT}; Column Env URL_Trend LPAR Cat Startime, CPUUtil; Define Env / '' Group Format=$Env.; Define URL_Trend/ '' Group NoPrint; Define LPAR / '' Group; Define Cat / '' Group Format=$Cat.; Define Startime / '' Across Format=DTDate5.; Define CPUUtil / '' Analysis Mean Format=3.; Compute Cat; Call Define('Cat','URLP',URL_Trend); EndComp; Where DatePart(Startime) Between '01Mar10'd and '12Mar10'd; Title1 "Proc Report Example 4 - Assigning a URL"; Run; ODS HTML Close; ODS Listing; Introducing the Compute Block A data step within the Proc Report procedure. Has many purposes, but for our use it will be the place to attribute cells. Also the NoPrint attribute on a define statement. We need a place to hold the URL_Trend value, but we don’t want it to be printed on the report page. Every time the Cat variable gets processed, the compute block is executed. Call define assigns the URL attribute to Cat and the link value specified in URL_Trend. Still very easy. A quirk about Proc Report to note. This procedure execution is literally left to right top to bottom one row at a time. Because of that the URL_Trend variable must be infront of the Cat in the column statement in order for the compute block to know its value when it is processing the Cat variable. Lets see the output

Example 4 - Output Point out the colored underlined link for the % CPU Busy column Nothing connected to that link yet, so don’t try to use it. Now it gets interesting, we want to assign attributed for each of the metric cells 01Mar values through 12Mar Lets see how we do that

Example 5 – SAS Code LibName VelSoft "&Path\VelSoft"; Data XAMCPUBY; Length URL_Trend $19. URL_Day $23.; Set VelSoft.XAMCPUBY; Date = Datepart(StarTime); LPAR = Put(Serial,$LPAR.); Env = Serial; Cat = 'CPU'; URL_Trend = Cats(Cat,'-',LPAR,'-mth.html'); URL_Day = Cats(Cat,'-',LPAR,'-',PUT(DATE,DATE7.),'.html'); Where Date Between '01Mar10'd and '12Mar10'd; Proc Summary Nway Data=XAMCPUBY; ID CAT ENV URL_Day URL_Trend; Class LPAR Date; Var CPUUtil; Output Out=CPU_Rpt(DROP=_TYPE_ _FREQ_) P90(CPUUtil)=Metric; Data CPU_Rpt; Set CPU_Rpt; Bk_Color = Put(Metric,CPUFmt.); ODS Html File="&path\VelSoft\Example_5.html" Style=Statistical; ODS Listing Close; ODS Html; I’ve saved the best for last. Lots of changes in the this example. Now we are creating two URL links, a trend and a daily graph link for the individual daily metric cells. Again, this is being setup as a multiple resource table. This means we need to summarize the data ahead of time so we can determine the proper color to apply to the cell. Note the Proc Summary followed by the data step. Now on to the rest of the code

Example 5 – SAS Code Proc Report Data=CPU_Rpt headline headskip missing Style(Report)={Background=Black CellSpacing=1MM CellWidth=1MM} Style(Column)={Font_Size=10PT} Style(Header)={Foreground=Black Background=White Font_Size=10PT}; Column Env LPAR URL_Trend Cat Date, (URL_Day BK_Color Metric); Define Env / '' Group Format=$Env.; Define LPAR / '' Group Format=$LPAR.; Define URL_Trend/ '' Group NoPrint; Define Cat / '' Group Format=$Cat.; Define Date / '' Across Format=Date5.; Define URL_Day / '' Noprint; Define BK_Color / '' Noprint; Define Metric / '' Analysis Mean Format=3.; Compute Cat; Call Define('Cat','URLP',URL_Trend); EndComp; Compute Metric; Call Define( 7 ,"style",CATS("style={background=",_C6_,"}")); Call Define( 7,'URLP',_C5_); Call Define(10 ,"style",CATS("style={background=",_C9_,"}")); Call Define(10,'URLP',_C8_); Call Define(13 ,"style",CATS("style={background=",_C12_,"}")); Call Define(13,'URLP',_C11_); Repeating code blocks removed to save space Call Define(40 ,"style",CATS("style={background=",_C39_,"}")); Call Define(40,'URLP',_C38_); EndComp; Title1 "Proc Report Example 5 - Attributing Metric Cells"; Run; Quit; ODS HTML Close; ODS Listing; No change to earlier code, however we are not using the 90th percentile and we have left the mean statistic on the define statement. There will only be one observation per startime value so mean is OK Note the way URL_Day and BK_Color are part of the hierarchy (Inside the list of variables to be nested below each date, but only metric will be printed on the report. The other two are attributes with the NoPrint define parameter. Big discussion about referencing columns by number, go to the next page to show the data table

Example 5 - Output We have done it. A fully attributed dashboard Natural left to right organization of the data, color coding of individual cells to highlight exception conditions and links to allow us to go to related reporting (once it has been created) Here is a production version of the dashboard

Production zVM Dashboard 30 days of data for five zVM LPARs and four resources being tracked for each LPAR and it all easily fits on a single browser screen. That’s presentation density!

Related Reporting A Very Powerful Extension to the primary data table. Can be 1 to N layers deep. Only limit is the perseverance of the SAS programmer. Number of Reports Quickly Adds Up 5 vVM Lpars * 4 Resources * 30 Days + 20 Trend Graphs = 620 Reporting Objects Housekeeping can become an issue Read Slide

Related Reporting Use a Single SAS Dataset for all the reporting tasks. Simplifies Link Value tracking Subset data with Where Clause using Link Values Reporting Object Macros are a must Use Proc SQL to create ‘parameterized’ invocation code Programming Suggestions

Macro for Trend Reports %Macro Mth_Trend(URL_Trend=); ODS HTML Body="&URL_Trend" Path="&Path" (URL=None); Symbol1 I=BOXJ10; Axis1 ORDER=(&STRT_DAT TO &STOP_DAT BY DAY); Axis2 Order=(0 to 100 by 10) Label=None; Proc GPLOT Data=CPU; PLOT CPUUTIL*DATE / HAXIS=AXIS1 VAXIS=AXIS2 LEGEND=LEGEND1; LABEL CPUUTIL = "Total CPU Utilization"; Where URL_Trend = "&URL_Trend"; Title1 C=BLACK H=12 "zVM systems"; Title2 H=9 C=BLACK "CPU Percent Busy -- Fifteen Minute Interval Data"; Title3 "Box Range Spans the 25th to 75th Percentile"; Title4 "Wiskers Extend to the 90th Percentile"; Run; %Mend Mth_Trend; Sample Macro – Note the URL_Trend parameter This GPLOT provides the daily drill down Note where URL_Trend is used, names the graph and subsets the input.

Proc SQL to Create ‘Parameterized’ SAS Code %MACRO Gen_Mth_Stmt; Proc SQL NoPrint; Select Distinct URL_Trend Into :Trend1 - :Trend&SYSMAXLONG From XAMCPUBY; Quit; %Do I = 1 %To &SQLOBS; %Mth_Trend(URL_Trend = &&Trend&I.); %End; Run; %MEND Gen_Mth_Stmt; One way to create the customized ‘parameterized’ SAS code. Also write out and read back in.

Sending Email Notices Very Easy to Code in SAS Requires some setup work by SAS support programmer and email support staff. SAS views email as an external file output destination. Two step process Develop list of notices to send Use Data Step or Proc Print to send them.

Collect the Notices Data CPU_Rpt Exceptions; Set CPU_Rpt; If Metric = . Then Metric = 0; Bk_Color = Put(Metric,CPUFmt.); Output CPU_Rpt; Select (Bk_Color); When ('lime’,’blue'); Otherwise Output Exceptions; End; Run;

Send the Emails FileName MyMail EMAIL Subject=("zVM Exceptions") TO=("CapMgmt@Gmail.Com" "zLINUXAdmin@Gmail.Com") TYPE="TEXT/HTML"; ODS CHTML File=MyMail; Proc Print Data=Exceptions N NOOBS; TITLE1 "zVM Exceptions"; Run; ODS CHTML Close;

Summary Powerful framework for reporting if your audience is receptive to tabular data. Accommodates a dense presentation format and discrete data points at the same time. Easy to create with base SAS product. Traffic lighting of data cells highlights exception conditions Drill down capability allows user to investigate.

Questions