Monday, November 23, 2020

Moving PEGA Adaptive Model learning between environments

There might be a use case, we may need to copy/move the ADM learning from PRODUCTION environment to other lower environments to simulate the results OR Reproduce Some scenarios referring to ADM learning from Production environment.

The following steps should be sufficient to import learning to a target system even if that system has previously had ADM models itself. However, they assume that you want to completely replace any ADM data on that target system with data from the source system, not merge the two. It is also assumed that your Cassandra cluster is not set up for Active/Active, across multiple datacenters.

In the source system

1. Export the pyADMFactory dataset from the source System.

In the Target system

1.     Ensure the adaptive rules are present.

2.     Decommission all ADM nodes.

3.     Navigate to the pyADMFactory dataset and run truncate operation.

4.     If the target system has any model reporting data in the following tables, these should also be manually truncated to prevent misleading reports.

a.     pr_data_dm_admmart_mdl_fact

b.    pr_data_dm_admmart_pred_fact

c.     pr_data_dm_admmart_pred (this may not exist depending on the version of Pega)

5.     Connect to Cassandra on one of the DSS nodes

a.     Remove the ADM model’s response lifecycle event data

drop keyspace adm_commit_log.

b.    Remove the rest of the ADM Data

drop keyspace_null_adm and/or drop keyspace adm - which ever present

6.     Navigate to the pyADMFactory data set and run the import data using the data exported from the source system.

7.     Decommission ADM nodes (the first node to start will create scoring models from the imported factory data).w

8.     When the ADM nodes have status NORMAL, check the Adaptive Model Management landing page. Model data should now reflect what was imported

Saturday, October 31, 2020

PEGA Decisioning - Decision Table to be defined on the Strategy Result (SR class) or a Customer class? How to Deciside?

One common design question usually asked by many of our Decisioning Architects is, where should i define my Decision Table? Whether the Decision Table to be defined on the Strategy Result (SR class) or a Customer class? How to choose the Applies to Class while creating my Decision Table in my Decisioning application. 


The Decision Table can be defined on the Strategy Result, SR class, or a Customer class. The choice often depends on where the properties used in the Decision Table are located. Let us discuss the following three design options:


If the Decision table is using the properties from the Customer Class and Decision Table returns result from Decision Table OR result of the Decision Table directly sets the property available in the same customer class, you should create Decision Table in a Customer class. 


If the Decision table is using the properties from the Customer Class, if you want to refer the very few computed properties from SR class, creating Decision Table in Customer Class OR SR class OR both options are valid. The design decision here could be, if you want to set result of the Decision Table to a specific property directly from the Decision Table. If you want to set the result of DecisionTable to a SR class, Create the Decision Table in SR class. If we want to set the result of DecisionTable to a Customer class, Create the Decision Table in Customer class. If the Decision Table returns the result and result of the Decision table referred using pxSegment result property, creating DecisionTable in Customer,SR class both valid. 

 

Let us take an example below. Customer CreditScore is a derived property from SR class. OutstandingLoanAmount is a Customer class property. Based on these two property values, Decision Table returns RiskScore.  


Decision Table to compute the RiskScore

PEGA DecisionTable

Creating the table requires two condition columns. First is the Principal Loan, which is the property in the data model representing the outstanding loan amount. 


The Operator represents the condition applied to the column. In this case, greater than, which allows you to express the Outstanding loan amount condition from the requirement.


The second condition column is the Credit Score property. The Credit Score is a parameter, so you need to use the Param.PropertyName construct.


The Use Range checkbox groups the credit scores together.

Fill in the bank’s requirements and specify a Return value for each row in the table.


Filter credit cards based on the calculated risk segment

Configure two Filter components to ensure that you identify High Risk and Low Risk customers.



Based on the Customers in the risk category, we can compute the customers eligiblity. The pxSegment Strategy property contains the output of the Decision Table.


Still confused with the Desion option to Define the Decision Table in a PEGA Decisioning application? Feel free to reachout to me.


Happy Learning, 

Nanjundan Chinnasamy 


Sunday, October 11, 2020

PEGA Decisioning - Managing the Business Rules(Revision Management) for quick Production deployment

PEGA Decisioning - Managing the Business Rules(Revision Management)

AppOverlay & Decision Manager Portal configuration:

·         Decision Manager portal mainly used for PROD Simulation & PROD. Use an applicationOverlay for development

·         Business sandbox & AppOverlay env & Direct deploy for Decision Data update

·         Need to configure ADM monitoring, IH, VBD

Building An app overlay application:

·         Create New App Overlay wizard and create an app

·         Define the accessgroup & list of available rules to expose to AppOverlay to make the changes. Primarily on Decision data.

·         Default application Overlay will be created after Landing opage. The name of the overlay starts with ‘RTC-‘.

·         Start the Application Overlay wizard via the Decisioning > Infrastructure > Revision Management->Application Overlays landing page.

·         Define the AppOverlay applicaiton, Revision ruleset, accessgroup & the Rules to be included as part of AppOverlay

·         Selet the rules to make available for the revision Management, select the rules and click "Include for Revision Management"

·         Review the AppOverlay and credit the AppOverlay application

·         Setup new accessgroups & their roles and the required operator IDs to use.

Managing the Business Rules(Revision Management):

Has 3 envs in PROD (build-Sandbox, test-sandbox and prod).Revision Management enabled business users to make the change with the limited rules.

Post every release, AppOverlay reset will be done in the dev environment (PROD-AUTH). ie, new version of the app overlay will be created. Post creation, completed package will be deployed in business sandbox (Simulation) followed by PROD like regular BAU release.

·         AppOverlay release & package deployment as part of BAU release has to be explored.

·         The process to create a version & export is based on the dynamic case management process

·         As part of Revision management, CRs will be created by Revision Manager and the change will be implemented by Strategy Designer. Revision manager will approve/Reject the CR

New AppOverlay version will be installed like below:

·         The System Architect can use the revision activation landing page which can be found at Decisioning -> Infrastructure -> Revision Management -> Revisions.

·         These revisions are primarily used to implement the config parameter to alter the decision application behavior

·         To sendback the CR to the RevisionManager, use SendBack CR option incase any additional RuleSet access required.

·         Once you submit the Revision, jar package file will be generated. We need to download them.

·         To implement the changes in pre-prod & Prod environment, Decisioning -> Infrastructure -> Revision Management -> Revisions->Import revision

·         Select the Operator from the available list to test the changes for the selected operators before promoting the change.Decisioning -> Infrastructure -> Revision Management -> Revisions->"Activate" the change. Change will be activated to all the users. We can roll-back if needed

·         After activating the package, we need to logout and login again

Working with the Revision Management is 2 set process. 1. Create Revision. 2. Create CR. We can have more than 1 CR in a given Revision. Once Revision Submitted, Jar will be generated. If the change is not working, we can revert the change by doing "Roll-back", otherwise activate the Revision.

PEGA DSM - App Overlay


More details about app overlay setup is available at https://community.pega.com/knowledgebase/articles/decision-management-overview/applying-changes-business-rules


Happy Learning!


PEGA Decisioning (DSM) - Strategy Design Patterns

Avoid Redundant Product Offers in PEGA Decisioning Strategy

To avoid the same product recommendation which customers own already, from PEGA we need to define the data relationship using DataFlow. For example, to cater to a use case where a customer owns multiple products and details of all products are available in a Product master table. So, there is a one-to-one relationship between the ProductHoldings and Product entities.



Now to implement the business case discussed (Filter the products already owned by the customer), you must filter out the products already owned by the customer. For this, you use a strategy pattern that is composed of three components: Data Import, Data Join and Filter, we can filter out the products which customer is holding already.  DataImport+DataJoin+Filter is the Strategy design pattern used to achieve.

 


Making NBA more relevant using Interaction History - Learn from IH (Interaction History)


Update the Strategy to include a component that retrieves Interaction History data for previous phone offers. We then filter out phone offers for customers that have accepted a phone offer in the past. We can of course make the filtering process much more sophisticated by considering phone upgrades, etc. But for the sake of our demonstration, we will keep the strategy simple; anyone who has been made a phone offer within the last 120 days will not be made another phone offer of any kind. IH+GroupBy+Filter is the Strategy pattern used to prevent Redundant offer recommendation in PEGA Strategy logic.



Interaction History Data model in PEGA7 & Extending the IH Data Model

Interaction History users STAR schema (Inherited from Cordiant framework) uses 1 FACT table and 8 Dimensions table. DIM table always has non-duplicate reference records which can be referred in FACT table using PK-FK relationship. IH table stores all Interactions in IH Tables through pegaDATA schema.

PEGA IH STAR Schema


For more details, refer the PDN article- https://community.pega.com/knowledgebase/articles/decision-management-overview/interaction-history-data-model-pega-72-73

 

We can also extend the PEGA’s IH table. Below PDN reference article has all the needed information - https://community.pega.com/knowledgebase/articles/decision-management-overview/extending-interaction-history

 

The process of extending the Interaction History layer in your application consists of the following steps:

1.        Adding columns in a database table

a.        Write a alter sql statement to alter the IH Table

2.        Adding extensions in application rulesets

a.       Perform the following actions to extend Interaction History with the HandleTime property for the call center application:

                                                               i.      Add a new property HandleTime of type Integer to the Data-Decision-IH-Fact data model in the application ruleset of the call center application.

                                                              ii.      Add the HandleProperty to the SR class of the call center application.

                                                            iii.      Override the pyInteractionHistoryConfiguration data transform in Data-Decision-IH-Configuration for the call center ruleset:

1.        Add a Set action and set Primary.pyFactProperties(<APPEND>) to "HandleTime".

2.        Add a Set action and set Primary.pyMeasurements(<APPEND>) to "HandleTime". This step is necessary so that you can use the property as a KPI.

3.        Enable the Call superclass data transform setting.

 

Happy Learning!

 

Sunday, September 27, 2020

PEGA Decisioning - Predicting Customer Behavior Using Real-time Data

·         Applying adaptive analytics to your strategies will enable them to detect changes in customer behavior as they occur and act on them immediately

·         Adaptive Decision Manager is a closed-loop system that automates the model creation, deployment, and monitoring process. It can manage a large number of models without human intervention.

·         ADM can capture and analyzing response data in real-time. cases where data is available for offline modeling, predictive models can be used as an alternative, or in conjunction.

·         ADM models to be created under Customer class, Decisioining, Adaptive Model

·         Any Single value Property from Customer class can be a predictor. It can be added under Predictors tab. It can be either symbolic/Numeric. PEGA ADM will automatically remove the unused predictors

·         Define Positive & Negative Outcomes under Outcome Tab

·         On the Settings tab of the Adaptive Model rule instance, you can define values that will fine tune the behavior of a model as a whole. For example, the ‘Performance threshold’ value is a limit that indicates that any predictor performing below this threshold will not be used to predict customer behavior.

·         When you configure an adaptive model record no models are created. The models are created on-the-fly, once there is demand for a given model. When it evaluates the Adaptive Model component, it requests the propensity for each single proposition or channel combination that is dictated by the component inputs. If the models do not exist, they are created at this time

·         It is strongly recommended that you set both the channel (.pyChannel) and the direction (.pyDirection) properties in your strategies before you use adaptive models. The channel and direction settings enable you to make decisions based on customer behavior in a specific channel.

·         Adaptive Model Outputs - Propensity, Performance, and Evidence

Propensity – This is the predicted likelihood of positive behavior. Such as, the likelihood of a customer accepting an offer.  The propensity for every proposition starts at 0.5 or 50% (the same as a flip of a coin) because in the beginning the model has no response behavior on which to base its predictions.

Performance: This is how well the model is able to differentiate between positive and negative behavior. Again, the initial value for each model is 0.5, with 1.0 being perfect performance. Therefore, the performance value should be somewhere between 0.5 and 1.0. Performance is generally used to differentiate between two models relating to the same proposition.

Evidence: – The number of responses used in the calculation of the Propensity.

In strategies, model propensity is automatically mapped to the strategy property called .pyPropensity. 

There is no automatic mapping for the Performance or Evidence outputs. But they can be manually mapped to any of the strategy properties under the Output mapping tab (ModelEvidence, ModelPerformance).

Smoothened Propensity: To reduce the ADM Propensity error in early days.

(@divide(.StartingEvidence, (.StartingEvidence + .ModelEvidence+1.0),3) * .StartingPropensity) +

 (@divide(.ModelEvidence, (.StartingEvidence + .ModelEvidence+1.0), 3)*.pyPropensity)

Where: Starting Evidence and Starting Propensity are proposition properties representing the assumed values for evidence and propensity.

Pega Decision Management uses “Coefficient of Concordance” (CoC) to measure the performance of predictors and models.

 

 

 

Trend Deduction:

·         How to measure the performance of the new Proposition using Adaptive, Trend Deduction.

·         Define the required Predictors, Outcome (keydown will prompt IH Data options) and memory settings (Run analysis after 500 records)

How to define More than one ADM for the same propositions?

·         Define the 2 diff ADMS using different Memory settings

·         Add 2 ADMs and add GroupBy Proposition (pxIdentifier) with the highest performance. Now, we should able to select the highest performance Proposition.

 

All ADM models Management options can be found under ADM Management.

o    Clear Model - Clears the model responses

o    Delete Model - Removes the physical model

o    View Model Properties - see the settings of an Individual Model parameters

o    Upload Responses will allow you to import the Historical data. upload the CSV file and map the outcome.

Monitoring the Adaptive Models:

·         DS->Decisioining->Monitoring->Adaptive Models Reporting

·         You can analyze the Behavior report under Reports to analyze the Active/Inactive predictors. Also the Classifier allows you to analyze the propensity.

·         Performance Model allows you to analyze the performance of the ADM

·         The Predictors overview will enable you to analyst the various predictors defined

The implementation of the Next-Best-Action mechanism is a staged process with each stage refining the proposition selection process.

Pega Decisioning Consultant - Mission Test Quiz & Answers

The Pega Certified Decisioning Consultant (PCDC) certification is for professionals participating in the design and development of a Pega ...