Key Performance Indicators (KPIs) are quantifiable measurements that reflect the critical success factors of an organization ranging from income that comes from return customers to percentage of customer calls answered in the first minute. Key Performance Indicators may also be used to measure performance in other types of organizations such as schools, social service organizations, and the like. Measures employed as KPI within an organization may include a variety of types such as revenue in currency, growth or decrease of a measure in percentage, actual values of a measurable quantity, and the like.
The core to scorecarding is the calculation of a score that represents performance across KPIs, their actual data, their target settings, their thresholds and other constraints. All metrics are, however, not equal. In most practical scenarios, different KPIs reporting to higher level ones have different severity levels. Ultimately most performance analysis comes down to a quantitative decision about resource allocation based on metrics such as budget, compensation, time, future investment, and the like. Since each of the metrics feeding into the decision process may have a different severity level, a confidently and accurately made decision requires assessment of metrics considering their severity levels among other aspects.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended as an aid in determining the scope of the claimed subject matter.
Embodiments are directed to computing scores of performance metrics by determining status bands based on boundary definitions and a relative position of an input value within the status bands. The scores may then be aggregated to obtain scores for higher level metrics utilizing predetermined aggregation rules.
These and other features and advantages will be apparent from a reading of the following detailed description and a review of the associated drawings. It is to be understood that both the foregoing general description and the following detailed description are explanatory only and are not restrictive of aspects as claimed.
As briefly described above, performance metric scores may be computed based on comparison of actuals and targets of performance metrics by determining status bands from boundary definitions and determining a relative position of an input value within the status band. In the following detailed description, references are made to the accompanying drawings that form a part hereof, and in which are shown by way of illustrations specific embodiments or examples. These aspects may be combined, other aspects may be utilized, and structural changes may be made without departing from the spirit or scope of the present disclosure. The following detailed description is therefore not to be taken in a limiting sense, and the scope of the present invention is defined by the appended claims and their equivalents.
While the embodiments will be described in the general context of program modules that execute in conjunction with an application program that runs on an operating system on a personal computer, those skilled in the art will recognize that aspects may also be implemented in combination with other program modules.
Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that embodiments may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like. Embodiments may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
Embodiments may be implemented as a computer process (method), a computing system, or as an article of manufacture, such as a computer program product or computer readable media. The computer program product may be a computer storage media readable by a computer system and encoding a computer program of instructions for executing a computer process. The computer program product may also be a propagated signal on a carrier readable by a computing system and encoding a computer program of instructions for executing a computer process.
Referring to
Scorecards are an easy method of evaluating organizational performance. The performance measures may vary from financial data such as sales growth to service information such as customer complaints. In a non-business environment, student performances and teacher assessments may be another example of performance measures that can employ scorecards for evaluating organizational performance. In the exemplary scorecard architecture, a core of the system is scorecard engine 108. Scorecard engine 108 may be an application software that is arranged to evaluate performance metrics. Scorecard engine 108 may be loaded into a server, executed over a distributed network, executed in a client device, and the like.
Data for evaluating various measures may be provided by a data source. The data source may include source systems 112, which provide data to a scorecard cube 114. Source systems 112 may include multi-dimensional databases such OLAP, other databases, individual files, and the like, that provide raw data for generation of scorecards. Scorecard cube 114 is a multi-dimensional database for storing data to be used in determining Key Performance Indicators (KPIs) as well as generated scorecards themselves. As discussed above, the multi-dimensional nature of scorecard cube 114 enables storage, use, and presentation of data over multiple dimensions such as compound performance indicators for different geographic areas, organizational groups, or even for different time intervals. Scorecard cube 114 has a bi-directional interaction with scorecard engine 108 providing and receiving raw data as well as generated scorecards.
Scorecard database 116 is arranged to operate in a similar manner to scorecard cube 114. In one embodiment, scorecard database 116 may be an external database providing redundant back-up database service.
Scorecard builder 102 may be a separate application or a part of a business logic application such as the performance evaluation application, and the like. Scorecard builder 102 is employed to configure various parameters of scorecard engine 108 such as scorecard elements, default values for actuals, targets, and the like. Scorecard builder 102 may include a user interface such as a web service, a GUI, and the like.
Strategy map builder 104 is employed for a later stage in scorecard generation process. As explained below, scores for KPIs and other metrics may be presented to a user in form of a strategy map. Strategy map builder 104 may include a user interface for selecting graphical formats, indicator elements, and other graphical parameters of the presentation.
Data Sources 106 may be another source for providing raw data to scorecard engine 108. Data sources 106 may also define KPI mappings and other associated data.
Additionally, the scorecard architecture may include scorecard presentation 110. This may be an application to deploy scorecards, customize views, coordinate distribution of scorecard data, and process web-specific applications associated with the performance evaluation process. For example, scorecard presentation 110 may include a web-based printing system, an email distribution system, and the like. In some embodiments, scorecard presentation 110 may be an interface that is used as part of the scorecard engine to export data for generating presentations or other forms of scorecard-related documents in an external application. For example, metrics, reports, and other elements (e.g. commentary) may be provided with metadata to a presentation application (e.g. PowerPoint® of MICROSOFT CORPORATION of Redmond, Wash.), a word processing application, or a graphics application to generate slides, documents, images, and the like, based on the selected scorecard data.
When creating a KPI, the KPI definition may be used across several scorecards. This is useful when different scorecard managers might have a shared KPI in common. This may ensure a standard definition is used for that KPI. Despite the shared definition, each individual scorecard may utilize a different data source and data mappings for the actual KPI.
Each KPI may include a number of attributes. Some of these attributes include frequency of data, unit of measure, trend type, weight, and other attributes.
The frequency of data identifies how often the data is updated in the source database (cube). The frequency of data may include: Daily, Weekly, Monthly, Quarterly, and Annually.
The unit of measure provides an interpretation for the KPI. Some of the units of measure are: Integer, Decimal, Percent, Days, and Currency. These examples are not exhaustive, and other elements may be added without departing from the scope of the invention.
A trend type may be set according to whether an increasing trend is desirable or not. For example, increasing profit is a desirable trend, while increasing defect rates is not. The trend type may be used in determining the KPI status to display and in setting and interpreting the KPI banding boundary values. The arrows displayed in the scorecard of
Weight is a positive integer used to qualify the relative value of a KPI in relation to other KPIs. It is used to calculate the aggregated scorecard value. For example, if an Objective in a scorecard has two KPIs, the first KPI has a weight of 1, and the second has a weight of 3 the second KPI is essentially three times more important than the first, and this weighted relationship is part of the calculation when the KPIs' values are rolled up to derive the values of their parent metric.
Other attributes may contain pointers to custom attributes that may be created for documentation purposes or used for various other aspects of the scorecard system such as creating different views in different graphical representations of the finished scorecard. Custom attributes may be created for any scorecard element and may be extended or customized by application developers or users for use in their own applications. They may be any of a number of types including text, numbers, percentages, dates, and hyperlinks.
One of the benefits of defining a scorecard is the ability to easily quantify and visualize performance in meeting organizational strategy. By providing a status at an overall scorecard level, and for each perspective, each objective or each KPI rollup, one may quickly identify where one might be off target. By utilizing the hierarchical scorecard definition along with KPI weightings, a status value is calculated at each level of the scorecard.
First column of the scorecard shows example top level metric 236 “Manufacturing” with its reporting KPIs 238 and 242 “Inventory” and “Assembly”. Second column 222 in the scorecard shows results for each measure from a previous measurement period. Third column 224 shows results for the same measures for the current measurement period. In one embodiment, the measurement period may include a month, a quarter, a tax year, a calendar year, and the like.
Fourth column 226 includes target values for specified KPIs on the scorecard. Target values may be retrieved from a database, entered by a user, and the like. Column 228 of the scorecard shows status indicators 230.
Status indicators 230 convey the state of the KPI. An indicator may have a predetermined number of levels. A traffic light is one of the most commonly used indicators. It represents a KPI with three-levels of results—Good, Neutral, and Bad. Traffic light indicators may be colored red, yellow, or green. In addition, each colored indicator may have its own unique shape. A KPI may have one stoplight indicator visible at any given time. Other types of indicators may also be employed to provide status feedback. For example, indicators with more than three levels may appear as a bar divided into sections, or bands. Column 232 includes trend type arrows as explained above under KPI attributes. Column 234 shows another KPI attribute, frequency.
A similar process is applied to a second metric KPI B (354), where the initial score is in the red band region on status band 370 as a result of applying the “Increasing is better” (362), “Decreasing is better” (364), or “On target is better” (366) criteria.
Then, the initial scores for both metrics are carried over to a normalized status band 372, where the boundaries and regions are normalized according to their relative position within the status band. The scores can only be compared and aggregated after normalization because their original status bands are not compatible (e.g. different boundaries, band region lengths, etc.). The normalization not only adds another layer of computations, but is also in some cases difficult to comprehend for users.
Once the normalized scores are determined, they can be aggregated on the normalized status band providing the aggregated score for the top level metric or the scorecard. The performance metrics computations in a typical scorecard system may include relatively diverse and complex rules such as:
The ability to express these complex rules may become more convoluted in a system using normalized status bands. At least, it is harder to visually perceive the flow of computations.
As shown in chart 410, input ranges may be defined along an input axis 412. The regions defined by the input ranges do not have to normalized or equal. Next, the score ranges are defined along the score axis. Each score range corresponds to an input range. From the correspondence of the input and score ranges, boundary values may be set on the chart forming the performance contour 416. The performance contour shows the relationship between input values across the input axis and scores across the score axis. In a user interface presentation, the performance contour may be color coded based on the background color of each band within a given input range. In the example chart 410, the performance contour 416 reflects an increasing is better type trend. By using the performance contour, however, an analysis of applicable trend is no longer needed. Based on the definition of input and score thresholds, the trend type is automatically provided.
Example chart 420 includes input ranges along input axis 422 and score ranges along score axis 424. The performance contour 426 for this example matches a decreasing is better type trend. Example chart 430 includes input ranges along input axis 432 and score ranges along score axis 434. The performance contour 436 for this example matches an on target is better type trend.
Example chart 440 illustrates the ability to use discontinuous ranges according to embodiments. Input ranges are shown along input axis 422 and score ranges along score axis 424 again. The boundary values in this example are provided in a discontinuous manner. For example, there are two score boundary values corresponding to the input boundary value “20” and similarly two score boundary values corresponding to input boundary value “50”. Thus, a saw tooth style performance contour 446 is obtained.
As will be discussed later, a graphics based status band determination according to embodiments enables a subscriber to modify the bands and the performance contour easily and intuitively. In an authoring user interface, the subscriber can simply move the boundary values around on the chart modifying the performance contour, and thereby, a relationship between the input values and the scores.
The example scorecard in
Once the scores for lower level metrics are computed, the scores for higher level metrics or for the whole scorecard may be computed by aggregation or by comparison. For example, a relatively simple comparison method of determining the score for top level KPI 1 may include comparing the aggregated actual and target values of KPI 1.
Another method may involve aggregating the scores of KPI 1's descendants or children (depending on the hierarchical structure) by applying a subscriber defined or default rule. The rules may include, but are not limited to, sum of child scores, mean average of child scores, maximum of child scores, minimum of child scores, sum of descendant scores, mean average of descendant scores, maximum of descendant scores, minimum of descendant scores, and the like.
Yet another method may include comparison of child or descendant actual and target values applying rules such as: a variance between an aggregated actual and an aggregated target, and a standard deviation between an aggregated actual and an aggregated target, and the like. According to further methods, a comparison to an external value may also be performed.
The core to scorecarding is the calculation of a score that represents performance across KPIs, their actual data, their target settings, their thresholds and other constraints. According to some embodiments, the scoring process may be executed as follows:
1) Input value for a KPI target is determined
2) Status band is determined
3) Relative position of input value within status band is determined
4) A score is computed
5) The score can then be used to determine performance downstream
Once the aggregation and interpretation is accomplished per the above process, the service can provide a variety of presentations based on the results. In some cases, the raw data itself may also be presented along with the analysis results. Presentations may be configured and rendered employing a native application user interface or an embeddable user interface that can be launched from any presentation application such as a graphics application, a word processing application, a spreadsheet application, and the like. Rendered presentations may be delivered to subscribers (e.g. by email, web publishing, file sharing, etc.), stored in various file formats, exported, and the like.
Returning to
The main panel 620 includes a number of detailed aspects of performance metric computation associated with “headcount”. For example display formats, associated thresholds, and data mapping types for actuals and targets of “headcount” are displayed at the top. The indicator set (624) is described and a link provided for changing to another indicator set (in the example Smiley style indicators are used). A preview of the performance contour reflecting scores vs. input values (622) is provided as well. The bands as defined by the boundaries (e.g. 628) are color coded to show the visualization scheme for status. A test input value is displayed on the performance contour linked to the status preview (626), which illustrates the status, indicator, score and distances to the boundaries for the test input value.
Under the preview displays, an authoring user interface 629 is provided for displaying, defining, and modifying input value, input threshold, and score threshold parameters. These are explained in more detail below in conjunction with
The example user interface of
According to some embodiment, the previews (722 and 726) may be updated automatically in response to subscriber selection of the aggregation rule giving the subscriber an opportunity to go back and modify the boundary values or status indicators.
In other embodiments, the definition user interface may be configured to provide the option of selecting the input value based on an external value providing the subscriber options for defining the source for the external value.
The previews of the performance contour (922) and status (926) for a test input value are the same as in previous figures. In the definition user interface 930, input threshold parameters are displayed and options for setting or modifying them are provided. The parameters include input threshold values 946 for highest and lowest boundaries with other boundaries in between those two. The number of boundaries is based on the selected indicator set and associated number of statuses (944) displayed next to the list of boundary values. The names of the boundaries (942) are also listed on the left of the boundary value list.
The previews of the performance contour (1022) and status (1026) for a test input value are functionally similar to those in previous figures. Differently in
The definition user interface includes a listing of thresholds 1054 (e.g. over budget, under budget, etc.), lower (1056) and upper (1058) boundary values, and the effect of what happens when the input increases within each threshold (1052). For example, as the input increases within the “over budget” threshold, the score decreases. On the other hand, in the “within budget” threshold the score may increase as the input increases. Thus, a behavior of the score within each threshold based on a behavior of the input value may be defined or modified at this stage and the performance contour adjusted accordingly.
According to some embodiments, a multiplicative weighting factor may be applied to the score output when the scores are aggregated. The weighting factor may be a default value or defined by the subscriber using definition user interface 1030 or another one.
As illustrated under the “Sensitivity” tab of the example definition user interface, the subscriber may be provided with feedback by previewing how a KPI performance can change when the test input value is changed. A preview chart 1170 with the performance contour 1176 and the test input value may be displayed. When the subscriber selects another point on the performance contour, a distance of the new selection to the test input value and the new score may be provided instantaneously enabling the subscriber to determine effects of changes without having to redo the whole computation. A score change versus input value change chart 1178 may also be provided for visualization of the effects.
According to some embodiments, statistical analysis for past performance and/or future forecast may also be carried out based on subscriber definition (selection) of the computation parameters. A next step in the scorecard process is generation of presentations based on the performance metric data and the analysis results. Reports comprising charts, grid presentations, graphs, three dimensional visualizations, and the like may be generated based on selected portions of available data.
The example user interfaces and computation parameters shown in the figures above are for illustration purposes only and do not constitute a limitation on embodiments. Other embodiments using different user interfaces, graphical elements and charts, status indication schemes, user interaction schemes, and so on, may be implemented without departing from a scope and spirit of the disclosure.
Referring now to the following figures, aspects and exemplary operating environments will be described.
In a typical operation according to embodiments, business logic service may be provided centrally from server 1212 or in a distributed manner over several servers (e.g. servers 1212 and 1214) and/or client devices. Server 1212 may include implementation of a number of information systems such as performance measures, business scorecards, and exception reporting. A number of organization-specific applications including, but not limited to, financial reporting/analysis, booking, marketing analysis, customer service, and manufacturing planning applications may also be configured, deployed, and shared in the networked system.
Data sources 1201-1203 are examples of a number of data sources that may provide input to server 1212. Additional data sources may include SQL servers, databases, non multi-dimensional data sources such as text files or EXCEL® sheets, multi-dimensional data source such as data cubes, and the like.
Users may interact with server running the business logic service from client devices 1205-1207 over network 1210. In another embodiment, users may directly access the data from server 1212 and perform analysis on their own machines.
Client devices 1205-1207 or servers 1212 and 1214 may be in communications with additional client devices or additional servers over network 1210. Network 1210 may include a secure network such as an enterprise network, an unsecure network such as a wireless open network, or the Internet. Network 1210 provides communication between the nodes described herein. By way of example, and not limitation, network 1210 may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media.
Many other configurations of computing devices, applications, data sources, data distribution and analysis systems may be employed to implement rendering of performance metric based presentations using geometric objects. Furthermore, the networked environments discussed in
With reference to
Business logic application 1322 may be any application that processes and generates scorecards and associated data. Scorecard engine 1324 may be a module within business logic application 1322 that manages definition of scorecard metrics and computation parameters, as well as computation of scores and aggregations. Presentation application 1326 or business logic application 1322 itself may render the presentation(s) using the results of computations by scorecard engine 1324. Presentation application 1326 or business logic application 1322 may be executed in an operating system other than operating system 1305. This basic configuration is illustrated in
The computing device 1300 may have additional features or functionality. For example, the computing device 1300 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape. Such additional storage is illustrated in
The computing device 1300 may also contain communication connections 1316 that allow the device to communicate with other computing devices 1318, such as over a network in a distributed computing environment, for example, an intranet or the Internet. Communication connection 1316 is one example of communication media. Communication media may typically be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. The term computer readable media as used herein includes both storage media and communication media.
The claimed subject matter also includes methods. These methods can be implemented in any number of ways, including the structures described in this document. One such way is by machine operations, of devices of the type described in this document.
Another optional way is for one or more of the individual operations of the methods to be performed in conjunction with one or more human operators performing some. These human operators need not be collocated with each other, but each can be only with a machine that performs a portion of the program.
Process 1400 begins with operation 1402, where an input value for a target of a performance metric is determined. The input may be provide by a subscriber or obtained from a variety of source such as other applications, scorecard data store, and the like. Processing advances from operation 1402 to operation 1404.
At operation 1404, a status band is determined. Each performance metric target has associated status bands defined by boundaries. The status band may be selected based on the boundaries and the input value. Determination of the status band also determines the status icon, text, or other properties to be used in presenting a visualization of the metric. Processing proceeds from operation 1404 to operation 1406.
At operation 1406, a relative position of the input value within the status band is determined. The relative position of the input value is determined by determining the relative distance between boundary values within the status band. Processing moves from operation 1406 to operation 1408.
At operation 1408, the score for the performance metric is computed. The score is computed based on the relative position of the input value within the status band and a range of scores available within the status band. Processing advances to optional operation 1410 from operation 1408.
At optional operation 1410, the score is used to perform aggregation calculations using other scores from other performance metrics. As described previously, scores may be aggregated according to a default or user defined rule and the hierarchical structure of performance metrics reporting to a higher metric. The aggregation result(s) may then be used with the scores of the performance metrics to render presentations based on user selection of a presentation type (e.g. trend charts, forecasts, and the like). After optional operation 1410, processing moves to a calling process for further actions.
The operations included in process 1400 are for illustration purposes. Assessing severity of performance metrics using a quantitative model may be implemented by similar processes with fewer or additional steps, as well as in different order of operations using the principles described herein.
The above specification, examples and data provide a complete description of the manufacture and use of the composition of the embodiments. Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims and embodiments.