This specification generally relates to artificial intelligence type computers digital data processing systems and corresponding data processing methods and products for emulation of intelligence, including adaptive systems that continually adjust rules and machine learning systems that automatically add to current integrated collections of facts and relationships, in order to measure, calibrate, or test the effectiveness of a monitoring system. More particularly, this specification generally relates to an adversarial reinforcement learning agent to measure, calibrate, and test the effectiveness of transaction monitoring systems.
Financial institutions such as banks are subject to anti-money-laundering (AML) regulations that require them to identify and report suspicious activity. Financial institutions implement transaction monitoring systems to evaluate transactions with deterministic rules or models called scenarios that detect known forms of suspicious activity. Financial institutions evaluate and improve these rule-based models through simple below-the-line testing. An overall transaction monitoring system can include multiple scenarios.
Financial institutions currently evaluate the quality of a scenario entirely based on whether the alerts created by a scenario lead to effective cases and suspicious activity reports (SARs) downstream. This approach does not accurately measure the value of a scenario or rule in identifying suspicious activity. Often, a SAR is filed for a reason unrelated to an alert triggered in a scenario or rule. At other times, multiple alerts lead to a single case of suspicious activity and it is unclear which alert or scenario should be credited for the effective case.
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate various systems, methods, and other embodiments of the disclosure. It will be appreciated that the illustrated element boundaries (e.g., boxes, groups of boxes, or other shapes) in the figures represent one embodiment of the boundaries. In some embodiments one element may be implemented as multiple elements or that multiple elements may be implemented as one element. In some embodiments, an element shown as an internal component of another element may be implemented as an external component and vice versa. Furthermore, elements may not be drawn to scale.
Systems, methods, and other embodiments are described herein that provide for decommissioning scenarios that are redundant. In one embodiment, a redundant scenario decommissioning system identifies a redundant scenario in a monitoring system and decommissions the redundant scenario. A scenario used for identifying suspicious activity in a monitored system may be redundant where the scenario generally alerts for activity that also causes another scenario to alert, and therefore adds little to no detection power. In one embodiment, redundant scenarios are detected based on statistics of scenario alerts triggered during reinforcement learning (RL) agent attempts to evade the scenarios.
In one embodiment, alerts from various scenarios triggered by actions of the RL agent are tracked and recorded by a redundant scenario decommissioning system. Where discrete scenarios are triggered to alert by the same RL agent action, one of the overlapping scenarios may be considered to be redundant. Redundant scenarios waste compute resources for little or no gain in detection power. A redundant scenario may be removed, deactivated, or otherwise decommissioned so that it is not active in surveilling the monitored system. A redundant scenario may be omitted or removed from a monitoring system with little or no loss in monitoring performance. Decommissioning a scenario from a monitoring system reduces compute overhead for monitoring, and reduces the number of alerts for processing by the monitoring system.
The redundant scenario decommissioning system and its components are one example implementation of a reinforcement learning agent for evaluation of monitoring systems, as shown and described herein in further detail. In one embodiment, the components of redundant scenario decommissioning system are those of system 200 (as shown and described with reference to
No action or function described or claimed herein is performed by the human mind. An interpretation that any action or function can be performed in the human mind is inconsistent with and contrary to this disclosure.
In one embodiment, this redundant scenario decommissioning method 100 is implemented and performed by monitoring system 205 of
At process block 110, the processor records alerts triggered for a plurality of scenarios of a monitoring system by a reinforcement learning agent attempting to evade the scenarios. In one embodiment, the processor executes a reinforcement learning agent to attempt to evade a plurality of scenarios of a monitoring system. In one embodiment, the reinforcement learning agent is configured to attempt to evade scenarios by performing alternative actions in response to discovering actions that trigger a scenario alert. In one embodiment, the reinforcement learning agent is configured to evaluate transaction monitoring systems by performing a series of steps or actions that attempt to move funds without triggering scenarios, as shown and described in further detail below. In one embodiment, the series of steps is the series of steps that make up a training run of one or more training episodes for the RL agent. In one embodiment, the steps are time-steps, where the RL agent may make one action or step per increment of time.
In one embodiment, the processor records alerts triggered by the reinforcement learning agent attempting to evade the plurality of scenarios. In one embodiment, the system records or stores the alerts for each scenario that are triggered by an action or step that fails to evade the scenarios. In one embodiment, these alerts are recorded or stored in a record of steps data structure (for example in database 315). For example, a row may be placed in a table or other data structure for each step performed by the RL agent. In one embodiment, the row may include an alert status that indicates whether or not a scenario is triggered at the step. In one embodiment, the row may include alert statuses for each scenario of the monitoring system. In one embodiment, the alert statuses for each scenario applied by the monitoring system are stored in the record of alerts for each step taken by the RL agent.
In one embodiment, the alerts may be triggered due to one step or action taken by the RL agent. In one embodiment, the alerts do not need to be triggered due to one step or action taken by the RL agent to be considered redundant. Instead, alerts may be considered overlapping or redundant where more than one scenario triggers alerts in the lookback over preceding steps of the episode. For example, a first scenario may trigger an alert due to activity from time steps 1-8, while a second scenario may trigger an alert due to activity from time steps 1-10. For example, the time steps may be days, minutes, or other time periods. Where multiple scenarios consistently occur over the a similar period of lookback, it can be considered a case of redundancy. In one embodiment, a lookback and individual time step may be referred to as a time range. Thus, in one embodiment, to determine the extent of overlap, the system counts a number of times that one of the alerts for the first scenario occurs in a time range in which one of the alerts for the second scenario occurs.
Thus, the record of alerts shows where scenario alerts overlap by occurring concurrently in a time step. For example, in a step where an RL agent attempts to withdraw a large amount of cash through an ATM, alerts may be triggered for both an ATM anomaly scenario and a significant cash scenario. The alert statuses of both triggered scenarios are stored for one step in the record of steps, indicating overlapping occurrence of the alerts.
Processing at process block 110 then completes, and processing continues at process block 115. In one embodiment, the alert statuses for the scenarios are recorded by step taken. Thus, there is a record of where overlapping alerts occur during RL agent activity attempting to evade the scenarios.
At process block 115, the processor determines an extent of overlap between first alerts of a first scenario of the monitoring system and second alerts of a second scenario of the monitoring system. In one embodiment, the processor retrieves the record of steps.
In one embodiment, the processor parses the record of steps to identify steps where there is an alert triggered for both the first scenario and the second scenario. In one embodiment, the processor counts a number of steps where there is an alert triggered for both the first scenario and the second scenario, and stores this count of overlapping alerts. In one embodiment, this count of overlapping alerts indicates an extent of overlap between the first alerts of a first scenario of the monitoring system and the second alerts of the second scenario.
In one embodiment, the processor parses the record of steps to identify steps where there is an alert triggered for the first scenario. In one embodiment, the processor counts a number of steps where there is an alert triggered for the first scenario, and stores this count of the first alerts. In one embodiment, a relationship (such as a ratio, as discussed in further detail below) between the count of overlapping alerts and the count of first alerts indicates an extent of overlap between the first alerts of a first scenario of the monitoring system and the second alerts of the second scenario. In one embodiment, other values may indicate extent of overlap, for example, ratio of overlapping alerts in the first alerts to non-overlapping alerts in the first alerts.
Processing at process block 115 then completes, and processing continues at process block 120. The processor has thus found an indication of how much overlap in alerting there is between the first and second scenarios. This measure of the extent of overlap between alerts of the first and second scenarios can be used to determine whether the scenarios are redundant. Thus, in one embodiment, the RL agent can reveal overlap between scenario coverage.
At process block 120, the processor identifies the first scenario to be redundant based on the extent of overlap. A scenario that rarely alerts in isolation, and instead often with another scenario has scenario overlap. High scenario overlap can indicate redundancy of one of the overlapping scenarios. In one embodiment, a threshold may be set to a level that indicates excessive overlap or redundancy between scenarios. The threshold may be set or adjusted by a user or administrator of a monitoring system (such as monitoring system 205) to be more or less restrictive in identifying redundant scenarios.
In one embodiment, where the extent of overlap is expressed as the ratio of the count of overlapping alerts in the first alerts to the overall count of alerts in the first alerts, the threshold may be set as a percentage value of alerts that are overlapping alerts. The ratio of the count of overlapping alerts in the first alerts to the overall count of alerts in the first alerts is compared to the threshold. Where the threshold is satisfied, the first scenario is identified to be redundant.
Processing at process block 120 then completes, and processing continues at process block 125. At the conclusion of process block 120, the first scenario is identified as being redundant due to the extent of the overlap in alerts between the first and second scenarios. The redundant first scenario thus adds little or no ability to distinguish suspicious activity (also referred to herein as detection power) beyond that provided by the second scenario. Thus, the redundant first scenario may be decommissioned from the monitoring system with little or no effect on the detection power of the monitoring system.
At process block 125, the processor decommissions the first scenario in the monitoring system in response to the first scenario being identified as redundant. In one embodiment, identification of the first scenario as redundant initiates a process to decommission the first scenario. In one embodiment, the decommissioning of the first scenario is completed automatically in response to the identification of the first scenario to be a redundant scenario. In one embodiment, the decommissioning of the first scenario includes presenting in a GUI a recommendation to decommission the first scenario. In one embodiment, the decommissioning includes providing in the GUI a user-selectable option to decommission or not, and proceeding based on the selected response.
In one embodiment, the process identifies the first scenario to the monitoring system, and instructs the monitoring system to cease applying the first scenario to the monitored system in order to decommission the first scenario. In one embodiment, the first scenario is decommissioned by being disabled or toggled off, and retained by the monitoring system for subsequent reactivation or recommissioning by a user. In one embodiment, the first scenario is decommissioned by being removed or deleted from the monitoring system. In one embodiment, the decommissioning causes the first scenario to be removed from deployed scenarios 282. In one embodiment, decommissioning includes storing first scenario, including configuration information describing the first scenario in a data structure for subsequent retrieval and use.
In one embodiment, the process to decommission the identified redundant scenario is automated, and completed without user interruption or action. In one embodiment, the process to decommission the identified redundant scenario is subject to user review. For example, the system generates a recommendation to decommission the identified redundant scenario and presents it to the user in a GUI. The GUI includes a selectable option as to whether or not to proceed to decommission the identified redundant scenario. As discussed below, an analysis of the effect of decommissioning the identified redundant scenario may be presented to the user to inform the user's decision as to whether or not to proceed.
Processing at process block 125 then completes, and processing continues to END block 130, where method 100 completes. In one embodiment, at the conclusion of method 100, a scenario is identified as redundant based on overlapping alerts triggered by RL agent activity, and decommissioned due to the redundancy. In one embodiment, identifying and decommissioning a redundant scenario (for example as performed in method 100) improves a monitoring system. For example, the monitoring system may be made more efficient by reducing compute overhead (at least in processor cycles and memory utilization) wasted on evaluating activity in a monitored system (such as transactions) against the redundant scenario. In another example, alerts generated by the redundant scenario may be eliminated, causing a decrease in the number of cumulative alerts handled by the monitoring system. Downstream computer operations for storing, retrieving, manipulating, and evaluating the alerts generated by the redundant scenario similarly may be eliminated. This may provide a significant reduction in demand on compute resources, enabling the monitoring system to surveil the same amount of activity (with similar detection power to identify suspicious activity) while using fewer compute resources.
In one embodiment, the step of determining the extent of overlap (shown and described with respect to process block 115 above) includes counting a number of times that one of the first alerts occurs at step (or lookback) in which one of the second alerts occurs to find the count of overlapping alerts. This number may, in one embodiment, be further divided by an overall number of the first alerts to determine a ratio of overlapping alerts to overall alerts for the first alerts. In one embodiment, the ratio of overlapping alerts for the first alerts is compared to a threshold indicating an undesirably high rate of overlapping alerts, for example, in the range of 80% or greater overlap.
In one embodiment, the weaker of the first and second scenarios is selected for decommissioning. In one embodiment, to determine which of the first scenario and the second scenario should be decommissioned, the weaker of the two scenarios is identified by comparison of a ratio of overlapping alerts to overall alerts for each scenario. The two ratios are determined. In one embodiment, the overlapping alerts of a scenario are those alerts that are triggered in two (or more) scenarios based on the same activity (action in a one step or over a similar lookback). In one embodiment, a ratio of overlapping alerts to overall alerts is generated for the first scenario and for the second scenario. In one embodiment, where the ratio of overlapping alerts to overall alerts for the first scenario is greater than the ratio of overlapping alerts to overall alerts for the second scenario, the first scenario is the better candidate for decommissioning.
Thus, in one embodiment, the first scenario is determined to be weaker than the second scenario based on a comparison of the ratios of overlapping alerts to overall alerts for first and second scenarios. In one embodiment, the first scenario is determined to be weaker than the second scenario because the ratio for the first scenario compares unfavorably to (for example, by being greater than) the ratio for the second scenario. Thus, the alerts for the first scenario overlap with the alerts for the second scenario more often than the alerts for the second scenario overlap with the alerts of the first scenario. The greater alert overlap for the first scenario indicates that the first scenario is weaker in detection power than the second scenario. The first scenario is therefore selected for decommissioning based on the determination that the first scenario is weaker than the second scenario.
In one embodiment, what-if analyses are run to determine the effects of decommissioning the first scenario while retaining the second scenario, and the effects of decommissioning the second scenario while retaining the first scenario. The results can be compared to see which decommissioning affects the monitoring system least. For example, one or more metrics that quantify overall monitoring strength (generated, for example, as discussed in further detail herein) of the monitoring system with one or the other scenario decommissioned may be compared. In one embodiment, the scenario whose decommissioning leaves the monitoring system strongest, based on comparison of these metrics, is selected for decommissioning.
In one embodiment, the first scenario is determined to be weaker than the second scenario because there are fewer alerts under the first scenario than there are alerts under the second scenario. The alerts under the first scenario are thus independent of the alerts under the second scenario less often than the alerts under the second scenario are independent of the alerts under the first scenario. This indicates that the first scenario is weaker in detection power than the second scenario. The first scenario is therefore selected for decommissioning based on the determination that the first scenario is weaker than the second scenario.
As discussed in further detail herein, in one embodiment, the reinforcement learning agent is operated in a simulation of a monitored system that is monitored by the monitoring system. In one embodiment, in this simulation, the reinforcement learning agent attempts to evade the scenarios in the simulation. In one embodiment, the attempts to evade the scenarios in the simulation are part of a training process of the reinforcement learning agent. In one embodiment, the attempts to evade the scenarios in the simulation are actions that an RL agent that is fully trained would have attempted at a training turn at which the action is performed. These actions may be sampled from the trained RL agent. In one embodiment, the simulated monitored system enables the RL agent to generate the record of alerts far more rapidly than in a live environment.
In one embodiment, the processor will display information about an effect of decommissioning the first scenario in a user interface, for example information informing the user about performance or operation of the monitoring system following decommissioning. In one example, this is a graphical user interface, such as a decommissioning analysis GUI described below. In one example, the information about the effect is gathered by having the RL agent attempt to evade other scenarios of the monitoring system without the first scenario in place. In one embodiment, the information may include a recommendation as to whether or not to decommission the first scenario. Thus, in one embodiment, the system may display a recommendation to decommission the first scenario in the user interface. In one embodiment, the user interface then presents a user-selectable option to accept or reject the decommissioning of the first scenario. For example, this may take the form of selectable buttons for the accept and reject decommissioning options. A user selection to accept the decommissioning of the first scenario is then accepted through the user interface. The decommissioning the first scenario in the monitoring system is performed in response to the user selection.
In one embodiment, the decommissioning of the first scenario in the monitoring system includes, in response to identifying the first scenario to be redundant, automatically instructing the monitoring system to stop, cease, or discontinue analyzing actions in a monitored system to determine whether the actions trigger the first scenario. In one embodiment, the decommissioning of the first scenario is carried out automatically by the system in response to the identification of the scenario as redundant, and without further user intervention.
In one embodiment, the monitoring system produces no further alerts under the first scenario following execution of the instruction to stop, cease, or discontinue analyzing actions with the first scenario. The decommissioning of the first scenario thus causes the monitoring system to stop applying the first scenario in a monitored system. In one embodiment, the redundant scenario decommissioning system composes and sends an electronic message or signal to the monitoring system that causes the monitoring system to disable, shut off, remove, or otherwise decommission the first scenario with regard to the monitored system. In response to the electronic message, the monitoring system will stop or discontinue evaluating actions occurring in the monitored system to determine whether or not the action satisfies the conditions of the first scenario that trigger an alert. Actions performed in the monitored system following the decommissioning will not be evaluated by the first scenario. In one embodiment, the first scenario is decommissioned and not applied in the monitored system, while other scenarios remain in commission and applied in the monitored system.
In one embodiment, evading the scenarios includes the RL agent performing an action without triggering an alert under a scenario. In one embodiment, attempting to evade the scenarios includes taking an action that is not known by the RL agent as to whether the action triggers an alert in a scenario. In one embodiment, the attempt to evade the plurality of scenarios of the monitoring system includes changing a first action that triggers an alert to a second action in a policy that maps states to actions for the reinforcement learning agent; and then performing the second action (which may or may not trigger an alert). In one embodiment, the processor may adjust the policy to indicate that the first action is less desirable than the second action, for example by adjusting an expected reward value of the first action. In this way, the reinforcement learning agent attempts to evade the scenarios by choosing to perform an action which may or may not trigger an alert rather than performing an action known to trigger an alert. In one embodiment, the changing of the first action to the second action (for example by adjustment of reward value) is performed as part of training the reinforcement learning agent. For example, the training of the RL agent may be in an exploration of an environment where the scenarios are active and alerts for the plurality of scenarios may be triggered in response to RL agent actions. Environment exploration and RL agent training are discussed in further detail below.
In one embodiment, the monitoring system monitors a transaction system. In one embodiment, a transaction system divides computing tasks into individual, discrete operations sometimes referred to as transactions, actions, or steps. In one embodiment, a transaction refers to transfer of data from one location to another. In one embodiment, the operations of a transaction system may be monitored for non-permitted, forbidden, or disallowed uses by a monitoring system. The monitoring system may apply various scenarios to detect the non-permitted uses. In one embodiment, the transaction system monitored by the monitoring system is a data access system for controlling shared access to data files or databases. In one embodiment, the transaction system monitored by the monitoring system may be a compute resource allocation system for controlling access to shared computing resources, such as memory, processing cycles, or storage. In one embodiment, the transaction system monitored by the monitoring system is a data transfers system for controlling distribution of data. In one embodiment, the transaction system monitored by the monitoring system is a financial transaction system. In one embodiment, where the transaction system is a financial transaction system, and the first scenario is selected from rapid movement of funds, high-risk geography, significant cash, or ATM anomaly scenarios. These example scenarios are described in further detail below.
In one embodiment, multiple scenarios are analyzed for potential decommissioning as redundant. In one embodiment, the system determines an extent of overlap between alerts of multiple scenarios of the monitoring system and other alerts of an other scenario of the monitoring system. The processor then identifies one or more of these multiple scenarios to be redundant based on the extent of the overlap, for example as described above with reference to the overlap between first and second scenario alerts. (For convenience, the one or more of the multiple scenarios identified to be redundant may be referred to herein as “the identified scenarios”). In one embodiment, the processor then decommissions the identified scenarios in the monitoring system. In one embodiment, the identified scenarios are decommissioned because they are weaker than the other scenario. In one embodiment, the other scenario serves as a reference or basis of comparison against which the multiple scenarios are evaluated for redundancy with the other scenario.
In one embodiment, the determining the extent of overlap causes the system to count a number of times that the alerts of the multiple scenarios occur in a time range in which one of the alerts of the other scenario occurs. In one embodiment, the system further determines that the identified scenarios are weaker than the other scenario based on a comparison of a ratio of overlapping alerts to overall alerts for each of the identified scenarios to a ratio of overlapping alerts to overall alerts of the other scenario. The system then selects the identified scenarios for decommissioning based on the determination that the identified scenarios are weaker than the other scenario.
In one embodiment, the system decommissions the identified scenarios by generating and displaying a recommendation to decommission the identified scenarios in a user interface (such as a GUI). In one embodiment, the system also presents a user-selectable element to accept the decommissioning of the identified scenarios in the user interface. In one embodiment, the system accepts a user selection of the element to accept the decommissioning of at least one of the identified scenarios through the user interface. The decommissioning of the at least one scenario in the monitoring system is performed in response to the user selection.
In one embodiment the system decommissions the identified scenarios by, in response to the identifying the one or more of the multiple scenarios to be redundant, automatically instructing the monitoring system to discontinue analyzing actions in a monitored system to determine whether the actions trigger the identified scenarios. In one embodiment, following receipt and execution of the instruction to discontinue analyzing actions, the monitoring system produces no further alerts under the identified scenarios. In one embodiment, following receipt of and execution of the instruction to discontinue analyzing actions, the monitoring system may continue to produce further alerts under the other scenario.
Additional detail on redundant scenario decommissioning is provided herein under the heading “Scenario Redundancy and Decommissioning.”
Systems, methods, and other embodiments are described herein that provide a reinforcement learning (RL) agent to evaluate monitoring system strength, for example in transaction monitoring systems. In one embodiment, a user is able to fully specify features of an environment to be monitored, including node (account or product) types, types of links (transaction or channel types) between nodes, and rules governing (or monitoring) movement across the links between nodes. An adversarial RL agent is trained in this environment to learn a most effective way to evade the rules. In one embodiment, the training is iterative exploration of the environment by the RL agent in an attempt to maximize a reward function that continues until the RL agent consistently behaves in a way that maximizes the reward function. The activity of the RL agent during training as well as the behavior of the trained agent is recorded, and used to automatically provide objective assessment of the effectiveness of the transaction monitoring system. The policy to evade the rules learned by the agent may then be used to automatically develop new governing or monitoring rule to prevent this discovered evasive movement.
For example, a user is able to fully specify the banking ecosystem of a financial institution, including account types, product types, transaction channels, and transaction monitoring rules. An RL agent acting as an artificial money launderer learns the most intelligent way or policy to move a specified amount of money from one or more source accounts within or outside a financial institution to one or more destination accounts inside or outside the financial institution. Important insights and statistics relevant to the institution may then be presented to the user. The policy to move the specified amount of money while avoiding the transaction monitoring rules may then be used to develop a rule that stymies the said policy, which can then be deployed to the banking ecosystem as a new transaction monitoring rule.
Use of the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein provides for a more comprehensive testing system that automatically reveals loopholes in the overall monitoring system that sophisticated actors could exploit. Identifying such loopholes will allow institutions to assess the seriousness of these gaps and proactively address them, for example by automatically deploying a rule or policy developed by the reinforcement learning agent as a new transaction monitoring rule. Additionally, the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein can be used to quantify the quality of a rule (whether previously implemented or newly developed) in terms of the role it plays in thwarting an adversarial agent. This can allow banks to understand the real value of a rule and make decisions around how to prioritize rules for tuning.
In one embodiment, the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein can be used in at least the following ways:
In one embodiment, the systems, methods, and other embodiments described herein create an adversarial agent to evade the transaction monitoring scenarios or rules in an environment. In one embodiment, reinforcement learning is used to create the adversarial agent. In one embodiment, strength of the overall monitoring system may be quantified in terms of the performance of this adversarial agent. In one embodiment, the value of each scenario or rule in terms may be quantified in terms of the performance of this agent. The complexity of the pattern or policy to evade the rules that is identified by the agent is a proxy for the strength of the transaction monitoring system. Metrics quantifying the pattern complexity may therefore be used to quantify the overall strength of the monitoring system, for example as shown and described herein. Further, the contribution of each individual rule to the strength of the monitoring may be measured by its effectiveness in thwarting the RL agent. Metrics quantifying the extent to which each rule thwarts the RL agent may therefore be used to quantify the relative contribution of each rule to overall system strength, for example as shown and described herein.
At a high level, in one embodiment, the reinforcement learning agent systems, methods, and other embodiments to evaluate transaction monitoring systems as shown and described herein include multiple parts. In one embodiment, the systems, methods, and other embodiments include creation of a flexible environment that can accommodate an arbitrary number of rules. This environment acts as a simulator of a monitored system (such as a transaction system) that the reinforcement learning agent can interact with and get meaningful responses and/or rewards for its actions. In one embodiment, the systems, methods, and other embodiments include a reinforcement learning agent that tries and learns to evade multiple realistic rules. For example, a RL library like Ray RLLib to is used to experiment with various algorithms or patterns in environments of progressively increasing complexity. In one embodiment, the systems, methods, and other embodiments use design metrics that measure the complexity of the algorithm or pattern identified by the agent to be a proxy for the strength of the system simulated by the environment. The value of each rule in the environment is quantifiable depending on its effectiveness in thwarting the agent. Thus, measurements of the RL agent training process in the simulated system and the performance of the trained agent is used to objectively measure the strength of live system. In one embodiment, the systems, methods, and other embodiments include data visualizations, dashboards, and other tools created for business users to view results in a graphical user interface (GUI).
In one embodiment, system 200 includes a monitoring system 205 connected by the Internet 210 (or another suitable communications network or combination of networks) to an enterprise network 215. In one embodiment, monitoring system 205 includes various systems and components which include reinforcement learning system components 220, monitored system components 225, other system components 227, data store(s) 230, and web interface server 235.
Each of the components of monitoring system 205 is configured by logic to execute the functions that the component is described as performing. In one embodiment, the components of monitoring system may be implemented as sets of one or more software modules executed by one or more computing devices specially configured for such execution. In one embodiment, the components of monitoring system 205 are implemented on one or more hardware computing devices or hosts interconnected by a data network. For example, the components of monitoring system 205 may be executed by network-connected computing devices of one or more compute hardware shapes, such as central processing unit (CPU) or general purpose shapes, dense input/output (I/O) shapes, graphics processing unit (GPU) shapes, and high-performance computing (HPC) shapes. In one embodiment, the components of monitoring system 205 are implemented by dedicated computing devices. In one embodiment, the components of monitoring system 205 are implemented by a common (or shared) computing device, even though represented as discrete units in
In one embodiment, remote computing systems (such as those of enterprise network 215) may access information or applications provided by monitoring system 205 through web interface server 235. In one embodiment, the remote computing system may send requests to and receive responses from web interface server 235. In one example, access to the information or applications may be effected through use of a web browser on a personal computer 245, remote user computers 255 or mobile device 260. For example, these computing devices 245, 255, 260 of the enterprise network 215 may request display of monitoring strength analysis GUIs, threshold tuning GUIs or other user interfaces, as shown and described herein. In one example, communications may be exchanged between web interface server 235 and personal computer 245, server 250, remote user computers 255 or mobile device 260, and may take the form of remote representational state transfer (REST) requests using JavaScript object notation (JSON) as the data interchange format for example, or simple object access protocol (SOAP) requests to and from XML servers. The REST or SOAP requests may include API calls to components of monitoring system 205.
Enterprise network 215 may be associated with a business. For simplicity and clarity of explanation, enterprise network 215 is represented by an on-site local area network 240 to which one or more personal computers 245, or servers 250 are operably connected, along with one or more remote user computers 255 or mobile devices 260 that are connected to enterprise network 215 through network(s) 210. Each personal computer 245, remote user computer 255, or mobile device 260 is generally dedicated to a particular end user, such as an employee or contractor associated with the business, although such dedication is not required. The personal computers 245 and remote user computers 255 can be, for example, a desktop computer, laptop computer, tablet computer, or other device having the ability to connect to local area network 240 or Internet 210. Mobile device 260 can be, for example, a smartphone, tablet computer, mobile phone, or other device having the ability to connect to local area network 240 or network(s) 210 through wireless networks, such as cellular telephone networks or Wi-Fi. Users of the enterprise network 215 interface with monitoring system 205 across network(s) 210.
In one embodiment, data store 230 is a computing stack for the structured storage and retrieval of one or more collections of information or data in non-transitory computer-readable media, for example as one or more data structures. In one embodiment, data store 230 includes one or more databases configured to store and serve information used by monitoring system 205. In one embodiment, data store 260 includes one or more account databases configured to store and serve customer accounts and transactions. In one embodiment, data store 230 includes one or more RL agent training record databases configured to store and serve records of RL agent actions. In one embodiment, these databases are MySQL databases or other relational databases configured to store and serve records of RL agent actions, or NOSQL databases or other graph databases configured to store and serve graph data records of RL agent actions. In one embodiment, these databases are Oracle® databases or Oracle Autonomous Databases. In some example configurations, data store(s) 230 may be implemented using one or more computing devices such as Oracle® Exadata compute shapes, network-attached storage (NAS) devices and/or other dedicated server device.
In one embodiment, reinforcement learning system components 220 include one or more components configured for implementing methods, functions, and features described herein associated with a reinforcement learning agent for evaluation of transaction monitoring systems. In one embodiment, reinforcement learning system components 220 include an adversarial RL agent 265. RL agent 265 is controlled (at least in part) by and updates a learned policy 267 over a course of training. During training, reinforcement learning system components 220 generate and store training records (or simulated episodes generated using a learned policy, as described above) 269 describing the performance of RL agent 265. In one embodiment, training records 269 may be one or more databases stored in data store 230. In one embodiment, reinforcement learning system components 220 include a training environment 270 which includes scenarios 272, an action space 273, and a state space 274. Training environment 270 is configured to simulate monitored data system 225. In one embodiment, a user may access a GUI 276 configured to accept inputs from and present outputs to users of reinforcement learning system components 220.
In one embodiment, monitored system components 225 may include data collection components for gathering, accepting, or otherwise detecting actions (such as transactions between accounts) in live data for monitoring by system 205. In one embodiment, monitored system 225 is a live data transaction system that is monitored by deployed scenarios 282. In one embodiment, monitored system 225 may include live, existing, or currently deployed scenarios 282, live accounts 284, and live transactions 286 occurring into, out of, or between live accounts 284. Deployed scenarios 282 include monitoring models or scenarios for evaluation of actions to detect known forms of forbidden or suspicious activity. (Monitoring models or scenarios may also be referred to herein as “alerting rules”). In one embodiment, monitored system components 225 may include suspicious activity reporting components for generation and transmission of SARs in response to detection of suspicious activity in a transaction or other action.
In one embodiment, other system components 227 may further include user administration modules for governing the access of users to monitoring system 205.
In one embodiment, user interface (UI) 310 is a graphical user interface to reinforcement learning system components 220 of monitoring system 205, such as GUI 276. User interface 310 enables a user of monitoring system 305 to provide inputs to adjust settings of the reinforcement learning system components 220 used to test or evaluate a monitoring system. In one embodiment, UI 310 generates and presents visualizations and dashboards that display metrics describing the results of testing or evaluating a monitoring system with an RL agent.
Expected users of the system fall generally into two types: (1) compliance officers 320 (or other business analysts)—users tasked with reviewing information produced by evaluating the monitored system with a RL agent (as shown and described herein) for making decisions regarding rule modification, addition, and removal in the monitored system; and (2) data scientists—users tasked with testing, tuning, and deploying RL algorithms, and customizing an environment (for example, environment 330 or training environment 270) to simulate the monitored system (including specifying granularity of transaction amounts, length of time steps, or modifying the environment to add new account or transaction types).
There is a subset of user inputs available in user interface 310 that a compliance officer user 320 is unlikely to modify because a compliance officer user lacks technical knowledge, while a data scientist user 325 has the technical knowledge to competently use these inputs and may therefore access them. Accordingly, user interface 310 may have two types of views for interaction with the reinforcement learning system components: a simplified view associated with use by compliance officer users 320, and a full-featured view associated with data scientist users 325. The determination to present the simplified or full-featured view to a user is based on whether a stored account profile of the user indicates that the user is a compliance officer or a data scientist. In one embodiment, the selected view may be changed by the user, for example by modifying account settings. In one embodiment, the full-featured view may be inaccessible to compliance officer users 320, and only accessible to data scientist users 325.
In the simplified view, the data-scientist-only features are de-emphasized (that is, not readily accessible, for example by removing or hiding the menus for these inputs) and may be disabled so that modification of the data-scientist-only inputs is not possible from the simplified view. In the full-featured view, all features and inputs are accessible. In one embodiment, the simplified view includes and emphasizes for an option to change default values inputs that can be used to set up scenarios (alerting rules), adjust a lookback period, adjust a rule run frequency, edit account IDs, and edit account details, add new products, controls for these products, add a new customer segment or instantiate a new agent belonging to this segment as shown at reference 326 and discussed further herein.
The functions available in the simplified view allows the RL agent for evaluation of monitoring systems to be operated as a validation tool for observing and recording the performance of an existing monitoring system, for example to observe the performance of existing monitoring, or observe the performance of monitoring using modified thresholds in scenarios. In one embodiment, the full featured view includes and emphasizes the inputs included in the simplified view as well as including and emphasizing inputs that can be used to modify transaction constraints, adjust action multiple and power, adjust time step, edit a cap on the number of steps, and edit learning algorithm choice, as shown at reference 327 and discussed further herein. The additional functions available in the full-featured view allows the RL agent for evaluation of monitoring systems to be operated as an experimentation tool for revising the monitoring system, for example to generate recommended thresholds for scenarios of the monitoring systems.
In one embodiment, UI 310 enables data scientist users 325 to add new rules to the environment in a straightforward and simple manner so that the environment 170, 330 may be made as realistic for the RL agent as possible. In one embodiment, the UI allows rules to be input, for example as editable formulae or as logical predicates, variables, and quantifiers selectable from dropdown menus. In one embodiment, a data scientist user 325 is able to enter an input that specifies a lookback period for a rule. In one embodiment, a data scientist user 325 is able to enter an input that specifies a frequency for applying a rule.
In one embodiment, data scientist users 325 may use UI 310 to use and evaluate various reward mechanisms in the environment in order to identify a reward mechanism that works well for a chosen RL learning algorithm for the RL agent. In one embodiment, the reward mechanism supports an action or step penalty that reduces total reward in response to actions taken. In one embodiment, the reward mechanism supports a goal reward for reaching a specified goal state. In one embodiment, the reward mechanism supports a configurable discount factor (a discount parameter is a user-adjustable hyperparameter representing the amount future events lose value or are discounted for an RL agent as a function of time).
In one embodiment, data scientist users may use UI 310 to specify or edit various actions available in the environment and add new actions to the environment in order to scale the environment up or down. In one embodiment, the data scientist user may use the UI 310 to specify a granularity at which amounts of money are to be discretized. For example, the data scientist user may specify that the RL agent may move money in $1000 increments. Other larger or smaller increments may also be selected, depending on how finely the user wants the RL agent to evaluate transfer thresholds.
In one embodiment, data scientist users may use UI 310 to specify a unit of time that each time step in the environment corresponds to. For example, a time step may be indicated to correspond to a day, a half-day, an hour, or other unit of time. This enables adjustment to policies of the RL agent and experimentation with scenarios of various lookbacks. In one embodiment, the data scientist user may specify the number of time steps per day. For example, if the number of time steps is set to 1, at most one transaction per account may be made in a day by the RL agent. Or, for example, where the number of time steps is set to 24, the RL agent may make at most one transaction per account in each hour of the day.
Based on the configurability of the environment, the RL agent performs in realistic settings such that the evaluation results generated by the RL agent are informative. The environment is therefore configured to include support for multiple scenarios, including support both for rules with focus on accounts and rules with focus on customers, and including support for rules with varying lookbacks and frequencies. In one embodiment, users (both compliance officer and data scientist users) may use UI 310 to add scenarios to and remove scenarios from the environment in order to either replicate a transaction monitoring system already in place, or perform what-if analyses for proposed changes to the transaction monitoring system. Accordingly, in one embodiment scenarios (such as Mantas rules) are available from a library of scenarios. Users may use UI 310 to access the library to select rules from the library, and use UI 310 to adjust or specify thresholds of the selected rules. In one embodiment, UI 310 includes a rule creation module. The rule creation module enables users to compose their own custom scenarios. Users may then deploy configured scenarios from the library or custom scenarios to the environment using UI 310.
The environment is further configured to support multiple account types, products, and transaction channels. In one embodiment, users (both compliance officer and data scientist users) may use UI 310 to expand the environment to include account type, product, and transaction channel offerings by the institution so that the environment closely mirrors the monitoring requirements of the institution. Therefore, in one embodiment, the UI 310 is configured to allow the user to add new account types, and specify constraints associated with the new account types. In one embodiment, the UI 310 is configured to allow the user to add new products and transaction types or channels that may need additional or separate monitoring.
UI 310 is also configured to present reports, metrics, and visualizations that show strengths and weaknesses of the monitoring system. In one embodiment, UI 310 is configured to present metrics that quantify overall strength of the system. In one embodiment, UI 310 is configured to present metrics that quantify the contributions of individual scenarios to the overall strength of the system. In one embodiment, UI 310 is configured to show visual explanations of the paths used by the RL agent to move money to the destination. UI 310 may also be configured to present metrics that describe the vulnerability of products and channels to the RL agent.
In one embodiment, inputs through UI 310 configure various components of RL application stack 305. In one embodiment, RL application stack includes a container 335, such as a Docker container or CoreOS rkt container, deployed in a cloud computing environment configured with a compatible container engine to execute the containers. Container 335 packages application code for implementing the RL agent and its environment with dependency libraries and binaries relied on by the application code. Alternatively, the application code for implementing the RL agent and its environment may be deployed to a virtual machine that provides the libraries and binaries depended on by the application code.
In one embodiment, container 335 includes an application 340. In one embodiment, application 340 is a web application hosted in a cloud environment. In one embodiment, application 340 may be constructed with Python using the Flask web framework. Alternatively, application 340 may constructed using a low-code development web framework such as Oracle Application Express (APEX). Implementation of the RL agent and its environment as an application 340 in in a web framework enables the whole RL agent and environment to be configured as a web application that can be readily hosted on the Internet, or in the cloud, and be accessible through REST requests. Application 340 unites the functions of the environment for the RL agent, the tuning, training, and execution of the RL agent with functions that use the RL agent execution to analyze or evaluate the performance of a transaction monitoring system.
In one embodiment, each of the data discussed above as editable using the UI 310 may be entered as user inputs in editable fields of a form, such as a web form. In one embodiment, user inputs accepted by UI 310 are parsed by UI 310 and automatically converted to electronic messages such as REST requests. The electronic messages carrying the user inputs are transmitted using REST service 345 to the application 340 in order to put into effect the modifications indicated by the user inputs. A first set of user inputs 346 are provided to environment 330 and are used to configure or set up environment 330, action space, or state space. For example, the simulated accounts of environment 330 may be configured by specifying account jurisdiction, indicating whether the account is in a high-risk geography or a low risk geography, and other account features. This first set of user inputs may include the problem or task to be attempted by the RL agent, such as transferring a particular quantity of money from a source account to a destination account. A second set of user inputs 347 are provided to tuning component 350 and training algorithm 355 of the RL agent, and are used to initiate the training exploration by the RL agent.
The training exploration (or simulated episodes generated using the learned policy) by the RL agent provides data for the analysis of the monitoring system. In one embodiment, monitoring system evaluator 360 executes a learned policy of the RL agent through one or more training iterations, visualizes and stores the transactions (that is, the actions performed by the RL agent), and queries storage through database handling rest service 365 to evaluate the performance of the scenarios. The visualized transactions and alert performance 370 are returned for display in UI 310 though rest service 345.
Environment 330 provides a model or simulation of external surroundings and conditions with which an RL agent may interact or operate, and which may simulate or otherwise represent some other system. In one embodiment, environment is an OpenAI Gym environment. In one embodiment, environment 330 is a simulation of a monitored system, including accounts, transaction channels, and scenarios consistent with those applicable to the monitored system. Thus, the environment 330 may simulate a monitored system as currently configured and deployed, or simulate a proposed, but not yet deployed monitored system (for example, a monitored system in which account types or transaction channels beyond those already in place have been added, or a monitored system in which scenarios have been added, removed, or modified).
In one embodiment, the environment 330 is used to replicate a monitored transaction system (such as monitored system 225) that an entity (such as a financial institution or bank) has in place. Environment 330 may therefore be configured to include one or more accounts that can engage in transactions. Accounts in environment 330 can be one of multiple account types, such as savings, checking, trust, brokerage, or other types of accounts that are available in the transaction system being simulated. Each of these types of accounts may have different restrictions, such as withdrawal limits, deposit limits, and access permissions to transaction channels.
To further replicate or simulate the monitored transaction system, environment 330 may also be configured to include the scenarios that are deployed by the entity to monitor transactions between the accounts, as well as monitor transactions exiting or exiting the transaction system to external transaction systems maintained by other entities. The entity implements or deploys scenarios (such as deployed scenarios 282) in the monitored transaction system. The entity may tune one or more thresholds of the rules to adjust the conditions under which alerts are triggered. The deployed and tuned scenarios may be copied from the transaction system into environment 330 to provide a scenario configuration consistent with or the same as that deployed in the monitored transaction system. Scenarios may also be retrieved from a library of scenarios and placed into environment 330 to allow experimentation with rules not currently used in the live transaction system, or to introduce the rules with default threshold settings.
In one embodiment, environment 330 is configured to accept an operation or action by the RL agent, such as a transaction. For example, environment 330 is configured so as to enable the RL agent to specify source account, target or destination account, transaction amount, and channel for a transaction as an action in the environment. In one embodiment, environment 330 is also configured so as to enable the RL agent to open an account of a selected type.
In response to an action taken by the RL agent, environment 330 is configured to update the state of the environment and apply the scenarios to the resulting state. In response to an operation performed by the RL agent, the environment is configured to return an observation that describes the current state of environment 330. In one embodiment, the RL agent may perform one operation or action per time step, and return one observation of the state of the environment at the completion of the step. In one embodiment, an observation may include an amount of money in each account and the aggregated information (like total credit amount, total debit amount, and other information for each account) at each step, and an alert status (alert triggered or not triggered) for each scenario.
In one embodiment, environment 330 includes an action space module. The action space is configured to define possible actions which may be taken by the agent. In one embodiment, the action space is a discrete action space containing a finite set of values with nothing between them (rather than a continuous action space containing all values over a specified interval) in dimensions of the space. The action space includes a dimension for each aspect of a transaction, including, for example a four-dimensional action space including a dimension for source account, a dimension for destination account, a dimension for transaction amount, and a dimension for transaction channel.
The dimension of source accounts includes a listing of all accounts in the environment. Similarly, the dimension of destination accounts includes a listing of all accounts in the environment. The number of accounts may be entered by a user (such as compliance officer user 320 or data scientist user 325) through user interface 310, for example when configuring account IDs. So, for example, where there are five accounts in the environment, the destination account and source account dimensions will each have five entries corresponding to the five accounts in the environment.
The dimension of transaction amount includes an entry for every amount between zero and user-specified amount (the total amount to be moved by the RL agent) at a user-selected increment. In one embodiment, the user specified amount and user selected increment may be entered by the user (such as a data scientist user 325) as transaction constraints through user interface 310. In one embodiment, the increment of the transaction amount is $1000, and so in this case RL agent actions will transfer amounts that are multiples of $1000. Larger or smaller increments may be chosen by the user, or specified by default, for example, steps of $500, $2500, or $5000. The user-specified amount may be, for example, $50,000, $75,000, or $100,000.
The dimension of transaction channel may include cash, wire, monetary instrument (“MI” such as a check), and back office (such as transfers between general ledger accounts that are in the financial institution) transaction channels. The dimension of transaction channel may also include other transaction channels such as peer-to-peer channels like Zelle, Paypal, and Venmo. The number and types of channels available in the environment may be specified by the user (such as compliance officer user 320 or data scientist user 325) through user interface 310.
Thus, the action space encompasses all possible combinations of source, destination, transferred amount, and transaction channel available to the RL agent. Each action by an RL agent may be expressed as a tuple with a value selected from each dimension, for example where the action space has the four dimensions above, an action may be expressed as [Source_Account, Destination_Account, Amount, Channel].
In this way, a processor executing a method associated with RL-agent-based evaluation of transaction monitoring systems may configure an environment to simulate a monitored system for the RL agent, and in particular, configure the environment to define the action space for the environment.
In one embodiment, environment 330 includes a state space module. The state space is configured to describe, for the environment, all possible configurations of the monitored system for the variables that are relevant to triggering a scenario. Thus, the state space that is used may change based on the scenarios deployed in the environment. If a user adds a new rule that evaluates a variable not captured by the other rules, the state space should be expanded accordingly. In the context of transaction monitoring, the state space is finite or discrete due to the states being given for a quantity of individual accounts.
In one embodiment, the system parses all scenarios that are deployed to environment 330 to identify the set of variables that are evaluated by the rules when determining whether or not an alert is triggered. The system then automatically configures the state space to include those variables. For example, the system adds or enables a data structure in the state space that accommodates each variable. Similarly, should a new rule that uses an additional variable be added to environment 330, the system will parse the rule to identify the additional variable, and automatically configure the state space to include the additional variable. Or, should a rule be removed from environment 330 that eliminates the use of a variable, the system may automatically reduce the state space to remove the unused variable. In this way, the state space automatically is automatically configured to test any rules that are deployed into environment 330, expanding or contracting to include those variables used to determine whether a scenario is triggered.
One example state space includes current balance for each account, aggregate debit for each account, and aggregate credit amount for each account. If a rule is added to the environment that evaluates a ratio of credit to debit, the system parses the new rule, identifies that the credit to debit ratio is used by the rule, and automatically configures the state space to include the credit to debit ratio.
In this way, a processor executing a method associated with RL-agent-based evaluation of transaction monitoring systems may configure an environment to simulate a monitored system for the RL agent, and in particular, configure the environment to define the state space for the environment.
In one embodiment, environment 330 includes a step function or module. The step function accepts as input an action from the RL agent. In one embodiment, the step function returns three items: an observation of a next state of environment 330 resulting from the action, a reward earned by the action, and an indication of whether the next state is a terminal (or end or done) state or not. The step function may also return diagnostic information that may be helpful in debugging.
In one embodiment, the observation is returned as a data structure such as an object containing values for all variables of the state space. For example, the observation object may include current balances for each account.
In one embodiment, the step function is configured to determine (i) the next state based on the input action; (ii) whether any scenarios deployed in the environment 330 are triggered by the next state; and (iii) whether a goal state is achieved. As used herein, the RL agent's behavior is not probabilistic—the RL agent is not permitted to act unpredictably—and so the transition probability (for successful transition to the determined next state) for each step is 100%.
During execution of the step function, a reward for the action taken is applied. For example, an interpreter may query the environment to retrieve the state and determine what reward should be applied to the total reward for the individual step. In one embodiment, the reward earned by taking the action is returned as a floating point data value such as a float or double data type. In one embodiment, the value is calculated by a reward module, and includes applying a small penalty (or negative reward) for taking the step, a large penalty where an scenario is triggered, and a reward (that is, a positive reward) where a goal state is accomplished. The RL agent is configured to track the cumulative reward for each step over the course of a training iteration. For example, the sum of the rewards for each step of a training iteration is the cumulative reward for that training iteration.
In one embodiment, a training episode or iteration refers to an exploration of an environment by the RL agent from an initial state (following a setup/reset) to a terminal (or end or done) state indicating that the RL agent should reset the environment. Accordingly, the terminal state status is returned as a Boolean value or flag. This terminal state status indicates whether or not the state is a terminal state of the environment. Where the terminal state status is True, it indicates that the training episode is completed, and that the environment should be reset to the initial state if further training is to occur. Where the terminal state status is False, training may continue without resetting the environment to the initial state. Terminal states include accomplishing the goal. (i.e. when the entire amount is transferred to the target account or length of episode has reached the prescribed limit). Reaching a terminal state indicates an end of one training iteration. In response to receiving an indication of a terminal state, the RL agent is configured to adjust its policy to integrate information learned in the training iteration into its policy, and to reset the environment.
In this way, a processor executing a method associated with RL-agent-based evaluation of transaction monitoring systems may configure an environment to simulate a monitored system for the RL agent, and in particular, configure the environment to define the step function for the environment.
In one embodiment, environment 330 includes a reset function or module. In one embodiment, the reset function accepts an initial state as an input, and places environment 330 into the input initial state. In one embodiment, the reset function does not accept an input, and instead retrieves the configuration of the initial state from a location in memory or storage. In one embodiment, the reset function returns an initial observation of a first or initial state of environment 330. The reset function thus serves as both an environment setup function for an initial training episode, as well as a reset function to return the environment to its initial state for additional training episodes. In one embodiment, the reset function is called at the beginning of a first training episode, and then called in response to the terminal status state being true while convergence criteria (as discussed herein) remain unsatisfied.
In one embodiment, the RL agent is constructed using components from a reinforcement learning library, such as the open-source Ray distributed execution framework for reinforcement learning applications. In one embodiment, the RL agent includes a tuning module 350. In one embodiment, tuning module 350 is implemented using Ray. The RL agent has one or more hyperparameters—parameters that are set independently of the RL agent's learning process and used to configure the RL agent's training activity—such as learning rate or method of learning. Tuning module 350 operates to tune hyperparameters of the RL agent by using differential training. Hyperparameters that affect the performance of learning for the RL agent are identified. Then, those parameters that have been identified as affecting performance of the RL agent are tuned to identify hyperparameter values that optimize performance of the RL agent. The identified best hyperparameters are selected to configure the RL agent for training. The tuned values for the hyperparameters are input to and received by the system, and stored as configuration information for the RL agent. In one embodiment, selected hyperparameters include those that control an amount by which a transition value (an indication of expected cumulative benefit of taking a particular action from a state at a particular time step, as discussed below) is changed. The hyperparameters may thus adjust both the rapidity with which a policy can be made to converge and the accuracy of performance of trained RL model.
In this way, the processor is configured to initiate training of the RL agent to learn a policy that evades scenarios of the simulated monitored system while completing a task, and in particular, to receive and store one or more hyperparameter values that control an amount or increment by which a transition value is changed.
In one embodiment, the RL agent includes a training module 355. After the learning hyperparameters are chosen, the RL agent can begin training. Training module 355 includes a training algorithm configured to cause the RL agent to learn a policy for evading scenarios operating within the environment 330.
In one embodiment, the sequence of actions taken by the RL agent is a Markov decision process. A Markov decision process includes a loop in which an agent performs an action on an environment in a current state, and in response receives a new state of the environment (that is, an updated state or subsequent state of the environment resulting from the action on the environment in the current state) and a reward for the action. In one embodiment, the states of the Markov decision process used for training are the states of the state space discussed above. In one embodiment, the actions performable by the RL agent in the Markov decision process used for training are the actions belonging to the action space discussed above. Each action (belonging to the action space) performed by the RL agent in the environment (in any state belonging to the state space) will result in a state belonging to the state space.
In response to the action taken by the RL agent, the environment will be placed into a new state. Note that transition probability—that is, a probability that a transition to a subsequent state occurs in response to an action—is 100% in the Markov decision process used for training the RL agent. Actions taken by the RL agent are always put into effect in the environment. Transition probability in the training process is therefore not discussed. Note also that the action space may include “wait” actions or steps that result in maintaining a state, delaying any substantive action. Wait actions may be performed either expressly as an action of doing nothing, or for example by making a transfer of $0 to an account, or making a transfer of an amount from an account back into the account (such that the transfer is made out of and into one account without passing through another account).
In response to the environment entering the new state, a reward value for the new state is calculated. The reward value for entering the new state expresses a value (from the RL agent's perspective) of how beneficial, useful, or “good” it is to be in the new state in view of a goal of the RL agent. Accordingly, in one embodiment, states in which a goal (such as moving a specified amount of money into a specific account) is accomplished result in a positive reward; states that do not accomplish the goal, and do not prevent accomplishment of the goal receive a small negative reward or penalty, indicating a loss in value of the goal over time (accomplishing the goal more quickly is “better” than accomplishing it more slowly); and states which trigger an alert and therefore defeat accomplishment of the goal receive a large negative reward or penalty, indicating the very low value to the RL agent of failing to accomplish the goal. Additionally, a further, moderate penalty, may be applied to transferring amounts out of the destination account because such transfers work against achieving the goal.
The RL agent includes a policy—a mapping from states to actions—that indicates a transition value for the actions in the action space at a given time step. The mapped actions for a state may be restricted to those that are valid in a particular state. Validity may be based on what it is appropriate to accomplish within the system simulated by the environment. For example, in an environment simulating a transaction system, in a state in which account A has a balance of $1,000, transferring $10,000 from account A to another account may not be valid. In one embodiment, a default, untrained, or naïve policy is initially provided for adjustment by the RL agent.
The mapping may include a transition value that indicates an expected future benefit of taking an action from a state at a particular time step. This transition value is distinct from the immediate reward for taking an action. The transition value for a particular action may be derived from or based on cumulative rewards for sequences of subsequent states and actions that are possible in the environment following the particular action, referred to herein as “downstream transitions”. The mapping may be stored as a data structure that include data values for transition values for each state and valid action pairing at each time step or may be represented as the weights of a neural network that are continually updated during training.
In one embodiment, monitoring system evaluator 360 is configured to cause the RL agent to execute its current learned policy in one or more training episodes in order to train the RL agent. At the beginning of RL agent training, the policy includes default values for the transition values. RL agent adjusts the policy by replacing the transition values for an action from a state at a point in time with transition values adjusted based on observed cumulative rewards from downstream transitions. The transition values are adjusted based on application of one or more hyperparameters, for example, a hyperparameter may scale a raw transition value derived from downstream transitions. The adjusted transition values for the policy are revised or updated over multiple episodes of training in order to arrive at a policy that causes the behavior of the RL agent to converge on a maximum cumulative reward per episode.
The immediate reward and policy (the set of transition values) are learned information that the RL agent learns in response to exploring—taking actions in accordance with its policy—within the environment. To train the RL agent, the training algorithm can query the environment to retrieve current state, time step, and available actions, and can update the learned information (including the policy) after taking an action. In one embodiment, the RL agent performs actions in the environment in accordance with its policy for one training episode, records the rewards for those actions, and adjusts (or updates or replaces) transition values in the policy based on those recorded awards, and then repeats the process with the adjusted policy until RL agent performance converges on a maximum.
In this way, the reinforcement learning agent is trained over one or more training episodes to learn a policy that evades scenarios of the simulated monitored system while completing a task such as moving an amount from a source account to a destination account in the fastest possible time frame and without triggering any alerts.
In one embodiment, monitoring system evaluator 360 is configured to store the steps taken by the RL agent over the course of training as a record of steps. During the training, action, result state, alert status for one or more scenarios operating in the environment, and goal achieved status are recorded for each time step of each training episode by monitoring system evaluator 360. Training is timed from initiation of the training process until convergence, and the training time is recorded. The recorded items are stored for example in database 315 using REST requests through database handling REST service 365. In one embodiment, database 315 is a MySQL database or other relational database, a NOSQL graph database or other database configured to store and serve graph data, or other database. In one embodiment, database 315 is included in training records 269. The recorded items form a basis for evaluating the performance of the individual scenarios and combined strength of the alerting system for the monitored system. For example, counts of triggered alerts over a training run or count of alerts triggered when episodes are sampled from the agent's learned policy are a proxy for strength of the rule in thwarting prohibited activity, while overall time to train the RL agent, and number of steps in an optimal training episode serve as proxies for the overall strength of the alerting system.
These actions, states, alert statuses, goal achieved statuses, and proxy metrics for rule and overall monitoring performance may be retrieved from database 315 by REST service 365 by monitoring system evaluator 360. Monitoring system evaluator 360 is configured to store transactions (in one embodiment, action and resulting state as well as alert status(es) and goal achieved status) performed. Accordingly, the transactions (and metrics derived from them) may be stored in database 315 so that they can be queried and used in subsequent processes.
In this way, the steps taken by the reinforcement learning agent, the result states, and the triggered alerts for the training episodes are recorded by the processor.
One example training run of an RL agent for evaluation of monitoring systems. The RL agent is trained to identify a policy that evades scenarios of a monitoring system. The environment for the RL agent is small, having five accounts, three scenarios (RMF, HRG, and Sig_Cash), and three transaction channels. In one embodiment, the RL agent is a proximal policy optimization (PPO) agent. An example optimal training episode satisfying the convergence criteria is performed, causing the training iterations to cease. In one embodiment, the convergence criteria include satisfying one or more of the following criteria: (i) standard deviation of Episode Reward mean is less than a first pre-defined value for a minimum standard deviation of mean reward per episode set by a user; (ii) number of training iterations are less than a second pre-defined value for the setting set by the user for a minimum number of training iterations (to guard against chance success by the agent and to ensure sufficient data points to act as a metric of system strength); or (iii) training time—time taken for training the RL agent—is less than a third pre-defined value for a minimum amount of training time. These pre-defined values may be provided by the user through UI 310. Over the course of the training run (from initiation through training episodes until convergence):
In one embodiment, the steps of a training episode are recorded in a format that describes the action taken by the RL agent and the result state following that action, for example in the following format: [‘sourceAccount’, ‘destinationAccount’, transferAmount, ‘transaction Channel’] [account_1_balance. account_2_balance . . . account_N_balance.] where there are N accounts in the environment. The action is described between the first set of brackets, and the resulting state of the environment following the action is described between the second set of brackets. For example, Table 1 below shows the optimal episode arrived at by the RL agent in the example training run:
These steps of an episode may be stored for example in training records database 269 as rows in a table, or as a text file, or as one or more other data structures.
In one embodiment, monitoring system evaluator 360 is configured to query storage to evaluate performance of the scenarios and monitoring system, and to generate visualizations of the transactions and of the alert performance describing the performance of scenarios and monitoring system. These visualized transactions and alert performance 370 are transferred by rest service 345 to UI 310 for presentation to users. In one embodiment, monitoring system evaluator is configured to retrieve action, result state, alert status for rules operating in the environment, and goal achieved status from database 315, and present configure the information as needed to render graphs, charts, and other data presentation outputs useful in real-time, what-if analysis of monitoring system strength.
In one embodiment, outputs presented in GUI 500 include visualization(s) of an optimal transaction sequence 505 performed by a trained agent to achieve the goal of transferring an amount of money into a destination account. In one embodiment, monitoring system evaluator selects a transaction sequence from those stored in database 315 to be an optimal sequence based on a predetermined criteria. In one embodiment, where the criteria is maximized reward over a training episode, the optimal transaction sequence may be the transactions of a training episode in which an RL agent achieved a maximum reward among the training episodes of a training run. In another example, where the criteria is achieving convergence in a training episode, the optimal transaction sequence may be the transactions of a final episode of a training run in which the RL agent's performance converged on a maximum score.
In one embodiment, the steps of the selected optimum training episode are retrieved from database 315 by monitoring system evaluator 360, parsed to identify the accounts that are used in the episode, the transactions that occurred during the episode, and the alerts triggered during the episode (if any). Monitoring system evaluator 360 then generates a network or graph of the behavior by the trained agent, such as example trained agent graph 510. The graph may include vertices or nodes that indicate accounts, alerts triggered (if any), and the end of the episode. For example, graph 510 includes account vertexes ACCT_1, ACCT_2, ACCT_3, ACCT_4, and ACCT_5, and episode end vertex Epi_End. The graph may include edges or links that indicate actions such as transactions or triggering of alerts. The graph may be configured to show edges representing different types of transaction channels using different line styles (such as dot/dash patterns) or colors. For example, graph 510 includes edges that represent wire transactions, monetary instrument (MI) transactions, and cash transactions, and edges that represent alert generation for an end of episode alert. The edges may be labeled with the transaction amount.
In one embodiment, outputs presented in GUI 500 include visualization(s) of a naive transaction sequence 515 performed by an untrained RL agent for contrast with, and to draw out insights by comparison to, the behavior of a trained RL agent. The naive transaction sequence may be the transactions of a first or initial training episode for the RL agent. As discussed above, monitoring system evaluator 360 retrieves the steps of the selected naive training episode are from database 315, parses the steps to identify the accounts that are used in the episode, the transactions that occurred during the episode, and the alerts triggered during the episode (if any), and generates a graph of the behavior of untrained agent, such as example untrained agent graph 520. The actions of the untrained agent result in multiple alert generations, including sig cash alerts, HRG alerts, and RMF alerts, as can be seen in graph 520.
In one embodiment, visualizations 505, 515 include a time progress bar 525 that includes time increments (such as dates) for the period during which the RL agent was active for the training episode shown. Time progress bar 525 may also include visual indicators such as bar graph bars above the dates that show dates on which the RL agent made transactions between accounts. In one embodiment, the height of the bar graph bar is a tally or total of transactions between accounts and triggered alerts for a single time increment (which, for example, may correspond to a single day).
In one embodiment, the outputs presented in GUI 500 include visualization(s) of overall monitoring strength 530 of the monitoring system expressed in terms of number of intermediate accounts required to achieve the goal and number of time steps taken to achieve the goal. In one embodiment, monitoring system evaluator 360 parses the steps of the optimal training episode retrieved from database 315 to identify accounts (other than the initial account and goal account) into which money is transferred and counts the number of those accounts to determine the number of intermediate accounts. In one embodiment, monitoring system evaluator 360 counts the steps of the optimal training episode retrieved from database 315 to determine the number of time steps taken to achieve the goal. The overall monitoring strength is plotted as a point (for example, point 540) with coordinates of the number of time steps and the number of intermediate accounts against a time taken to transfer money axis 545 and a number of intermediate accounts axis 550. Points closer to the origin (0,0) indicate weaker overall monitoring strength. Points farther from the origin indicate stronger overall monitoring strength. Example point 540 has coordinates of 24 days to move all the money and use of three intermediate accounts.
Use of data from RL agent training to generate the overall monitoring strength metric (number of intermediate accounts used and time taken to transfer) provides a consistent, objective metric describing overall strength of a monitoring system. Consistent, objective metrics for overall monitoring strength were not possible for computers before the systems, methods, and other embodiments described herein due at least to the size of the state and action spaces. Thus, in this way, for example, strength of monitoring of the simulated monitored system is determined based on the recorded training episodes.
In one embodiment, the outputs presented in GUI 500 include visualization(s) of the relative strength of scenario between the scenarios operating in the environment, such as example relative strength of scenario plot 555. In one embodiment, monitoring system evaluator 360 parses training episodes of a training run to identify the triggered alerts, by scenario. Monitoring system evaluator 360 tallies or counts the total number of alerts during the training run for each scenario, and the total number of alerts of all types. Monitoring system evaluator 360 then determines for each type of scenario, a ratio of alerts for the type of scenario to the overall count of alerts for all types of scenarios. Monitoring system evaluator 360 then generates a graph or chart, such as a bar graph or pie chart, showing the relative percentages of alerts for the various types of scenarios. As shown in example relative strength of scenario plot 555, 55% of alerts 565 over the course of a training run were from a rapid movement of funds (RMF) scenario, 25% of alerts 570 over the course of the training run were from a high-risk geography (HRG) scenario, 10% of the alerts 575 over the course of the training run were from a significant cash scenario, and 10% of the alerts 580 over the course of the training run were from an ATM anomaly scenario. Relative strength of a scenario may also be determined by looking at the difference in proportion of alerts generated by each scenario for a trained agent and an untrained agent. If the proportion of alerts triggered by a scenario for a trained agent is lower than that of an untrained agent, it means that the agent has learned to evade the scenario meaning that scenario has a lower relative strength.
Use of data from RL agent training to generate these relative strength of scenario metrics provides a consistent, objective metrics describing the individual contributions of scenarios in a monitoring system. This provides the user with the incremental value of each rule in the system, and reveals gaps in scenario coverage. Consistent, objective metrics for individual contributions of scenarios were not possible for computers before the systems, methods, and other embodiments described herein.
In one embodiment, the outputs presented in GUI 500 include visualization(s) of cumulative alerts per week, such as example cumulative alerts per week plot 585. In one embodiment, monitoring system evaluator 360 calculates an average number of alerts per training episode for each scenario type over the course of a training run, and stores it in database 315. Monitoring system evaluator 360 retrieves the average numbers of alerts for each scenario for the training run, and totals them to find an average number of alerts per training episode for the training run. Monitoring system evaluator 360 retrieves an average length of training episode over the training run and converts the retrieved episode length to weeks. Monitoring system evaluator 360 then divides the average number of alerts per training episode by the average number of weeks per training episode, yielding a number of alerts accumulated per week. Monitoring system evaluator 360 then generates a bar graph or bar chart showing this cumulative number of alerts per week, for example as shown in example cumulative alerts per week plot 585. The bar 590 presented in example cumulative alerts per week plot 585 is the cumulative alerts per week generated under a current configuration or setup of scenarios in the environment. In other GUIs, cumulative alerts per week for current and/or other configurations may be presented in the bar graph alongside each other for comparison.
Use of data from RL agent training to generate the cumulative alerts per week or the percentage increase in cumulative alerts per week provides a consistent, objective count of the alerting burden caused by any given configuration of scenarios in a monitoring system. This allows a user to assess the administrative impact that a particular scenario configuration or setup may have. Consistent, objective metrics for predicting the alerting burden of a particular scenario configuration were not possible for computers before the systems, methods, and other embodiments described herein.
In one embodiment, outputs presented in GUI 600 include visualizations of an optimal transaction sequence for transferring a relatively smaller amount (such as 75000) 605 identified in the course of an RL agent training run. Monitoring system 360 generates a graph, such as example graph 610, to display the actions for an optimal transaction sequence for moving the smaller amount. Visualization 605 includes a time progress bar 615 indicating when the transactions shown in graph 610 took place.
In one embodiment, outputs presented in GUI 600 include visualizations of a portion of an optimal transaction sequence for transferring a relatively larger amount (such as 100000) 620 identified in the course of an RL agent training run. Monitoring system 360 generates a graph, such as example graph 625, to display the actions for an optimal transaction sequence for moving the larger amount that are additional to (or different from) the optimal transaction sequence for moving the smaller amount. Visualization 620 also includes a time progress bar 630 indicating when the transactions shown in graph 610 took place. Thus, visualization 620 shows the further steps taken by the RL agent to move the larger amount beyond the steps taken to move the smaller amount.
Alternatively, visualization 620 may simply show an optimal transaction sequence for transferring the relatively larger amount, and the days on which the transaction steps were taken. This alternative visualization may be presented rather than showing differences between the transactions to move the smaller amount and the transactions to move the larger amount.
In one embodiment, the outputs presented in GUI 600 include visualization(s) of overall monitoring strength 635 of the monitoring system showing the overall monitoring strength for both the smaller and larger amounts. In this example, the overall monitoring strength against a goal of moving the smaller amount and against a goal of moving the larger amount are both expressed in terms of number of intermediate accounts required to achieve the goal and number of time steps taken to achieve the goal on a plot, such as shown in visualization 530 discussed above. The overall monitoring strength against transferring 75000 is shown at reference 640, and the overall monitoring strength against transferring 100000 is shown at reference 645. In this example the user can tell at a glance that the number of intermediate accounts used does not change between the smaller and larger amounts, but shows that the larger amount takes longer to move. This confirms the intuition that moving larger amounts of money ought to take longer, and further gives an objective measurement of how much longer it does take to move the larger amount. This objective measurement was not possible for a computing device prior to the introduction of the systems, methods, and other embodiments herein.
In one embodiment, the outputs presented in GUI 600 include visualization(s) of the relative strength of scenario for both the transfer of the smaller amount and the transfer of the larger amount, such as example relative strength of scenario plot 650. The relative strengths of scenario for the smaller amount and larger amount are generated in a manner similar to that described above for example relative strength of scenario plot 555. In one embodiment, a set of relative strengths of scenarios for the smaller amount 655 are shown adjacent to a set of relative strengths of scenarios for the larger amount 660 in a bar chart, thereby facilitating comparison. This assists user understanding of the effects on individual scenarios of changing from a smaller amount to a larger amount to transfer. Both sets of relative strengths of scenarios are generated by a consistent process, the RL agent training, resulting in a consistent and objective analysis of relative strength of scenario regardless of transfer amount, an advantage not available without the systems, methods, and other embodiments herein.
In one embodiment, the outputs presented in GUI 600 include visualization(s) of the cumulative alerts per week for both the transfer of the smaller amount and the transfer of the larger amount, such as shown in example cumulative alerts per week plot 665. The cumulative alerts per week for both the smaller amount and larger amount are generated in a manner similar to that described above for example cumulative alerts per week plot 585. In one embodiment, cumulative alerts per week for the smaller amount 670 are shown adjacent to cumulative alerts per week for the larger amount 675 in a bar chart, thereby facilitating comparison. This assists user understanding of the change in alert burden caused by a change in amount to transfer. The RL agent training-based process for generating these cumulative alerts per week metrics results in in a consistent and objective estimates of cumulative alerts per week regardless of transfer amount, an advantage not available without the systems, methods, and other embodiments herein.
Other GUIs similar to GUIs 500 and 600 may be used to present other comparisons. Generally, a visualization of a first graph showing a first set of RL agent operations under a first condition may be shown adjacent to a visualization of a second graph showing a second set of RL agent operations under a second set of conditions, along with a plot of the overall monitoring strength, a chart of the relative strength of scenario, and cumulative alerts per week under both the first and second conditions serves to inform the user of the effect of the change between the first and second condition. These GUIs may be pages of UI 310, and include visualizations generated by monitoring system evaluator 360. For example, GUI 500 shows the effect of the change in conditions from having an untrained RL agent to having a trained RL agent perform the transfers. In another example, GUI 600 shows the effect of the change in conditions from a having a goal of transferring a relatively smaller amount (such as 75000) into a goal account to having a goal of transferring a relatively larger amount (such as 100000) into a goal account.
Scenario thresholds may be poorly tuned. The systems methods, and other embodiments described herein for using an RL agent for evaluation of monitoring systems enable automated identification and recommendation of tuning threshold values for scenarios. The data generated during the training run includes a set of transactions used by the RL agent to evade a current configuration of thresholds for the scenarios. Multiple alternative thresholds may then be tested on those base transactions to identify thresholds that are most effective against the RL-agent-generated set of transactions. The thresholds may then be presented as recommendations for user review and selection, and may be automatically implemented and deployed to the monitoring system.
In one embodiment, a current threshold value set representing threshold values for scenarios as currently deployed in the monitoring system is shown by a current set indicator 740. In the example shown, current set indicator 740 indicates threshold value set 4. In one embodiment, a recommended threshold value set representing threshold values for scenarios as recommended for adjustment of scenario strength is shown by a recommended set indicator 745. In the example shown, recommended set indicator 745 indicates threshold value set 7.
In one embodiment, a “safe zone”—a range in which a scenario alerts with an acceptable level of sensitivity (for example, a range generally accepted by the applicable sector and/or compliant with applicable regulations)—is demarcated as a box 755 on the plot. Safe zone box 755 encloses threshold value sets that have an acceptable level of sensitivity, and excludes threshold value sets that do not conform to the acceptable level of sensitivity. In one embodiment, safe zone box 755 is dynamically generated to extend between pre-configured lower and upper bounds of the range, and exclude threshold value sets that have sensitivity that wholly or partially extends beyond the range.
In one embodiment, GUI 700 is configured to show individual values for the thresholds in a threshold value set, for example in response to user selection of (such as by mouse click on) any threshold value set 725, scenario strength 715, cumulative alert per week 720, current set indicator 740, or recommended set indicator 745. In one example, selection of recommended set indicator 745 would cause GUI 700 display of a table of threshold values for threshold value set 7 750, for example as shown in Table 3:
In one embodiment, the GUI 700 includes threshold names, modifiable values for the thresholds, checkboxes or radio buttons to indicate that the threshold values is to be tightened, loosened, or automatically tightened or loosened, for example arranged in a table format. In one embodiment, GUI 700 includes a user-selectable option to choose a scenario to modify. In one embodiment, GUI 700 includes a user-selectable option to finalize changes made.
In one embodiment, the threshold value sets are determined automatically. For each scenario, the system generates an N-dimensional matrix or grid of possible threshold value sets, where N is the number of tunable parameters in the scenario. The system populates the matrix with values for each dimension, where the values are incremented along each dimension. The system retrieves the optimal sequence of actions learned by the RL agent to evade the scenarios. The system replaces the threshold values of a scenario applied to the RL agent's actions with a combination of the values in the matrix for the scenario. In one embodiment, the system replaces the threshold values with each unique combination in the matrix in turn. The system then applies the scenario as modified with the replaced thresholds to evaluate the optimal sequence of actions. The system records the number of alerts triggered by the optimal sequence for the modified scenario. In one embodiment, the system repeats application of the scenario as modified for each unique combination of threshold values to the optimal sequence of actions, and records the number of alerts generated. Combinations of threshold values that result in different numbers of alerts are identified. The combination that generates the most alerts is the most robust threshold for the scenario. The combination that generates the fewest alerts is the weakest threshold for the scenario. In one embodiment, the ranges of threshold values between the weakest and most robust thresholds is divided, partitioned, or binned into a number of evenly-spaced (equal) intervals, such as 10 intervals. The threshold values at the transition of each of these combinations form the threshold value sets for the scenario. In one embodiment, this process may be repeated for each scenario in order to generate threshold value sets for the overall set of scenarios.
In one embodiment, a recommended threshold value set is automatically determined based on a pre-determined range of strength for a scenario and a pre-determined range of cumulative alerts per week. In one embodiment, the system automatically selects the threshold value set with the highest strength of scenario that falls within the range of cumulative alerts per week. The recommended threshold may then be selected for further analysis as to its effectiveness, as discussed below.
Where a threshold value set stronger than the current threshold value set results in a number of cumulative alerts within the range of cumulative alerts, the system will automatically recommend strengthening the scenario, for example up to the strongest threshold value set that does not result in a number of cumulative alerts per week greater than the top of the range of cumulative alerts per week. In the example shown in GUI 700, a user may specify a strength range for a scenario between 15% and 40% (consistent with a safe zone 755 as discussed above), and a cumulative alerts per week range between 0 and 700. The system will therefore recommend increasing strength by replacing the threshold values with threshold value set 7 750, as shown by recommendation indicator 745. Threshold value set 7 750 is the strongest threshold value set—35% of transactions performed to evade current scenario configurations result in alerts—that does not cause more than 700 cumulative alerts per week. A scenario that does not produce a large number of alerts may thereby be automatically strengthened.
Where the threshold value set causes a number of cumulative alerts per week that is greater than the pre-determined range, the system will automatically recommend weakening the scenario, for example down to the strongest threshold value set that does not result in a number of cumulative alerts per week greater than the top of the range of cumulative alerts per week. For example, if the current threshold value set is threshold value set 7 750, and the maximum range of cumulative alerts per week is 550, the system will therefore recommend reducing scenario strength to threshold value set 4 760. In this way, a scenario with high relative importance that produces an excessive number of unproductive alerts may have its strength automatically reduced.
In one embodiment, a GUI displaying an impact of tuning threshold values of one or more scenarios may be presented. This can assist in determining appropriate tuning for threshold values. For example, a visualization showing a first graph of a first optimum transaction sequence performed by an RL agent to avoid scenarios configured with a first set of thresholds may be presented alongside a visualization showing a second graph of a second optimum transaction sequence performed by an RL agent to avoid the scenarios re-configured to use a second set of thresholds. In one embodiment, the second set of thresholds is automatically selected to be the recommended threshold value set as determined above. The difference between the first and second sets of thresholds may be a change in any one or more of the threshold values. Thus, a GUI may be configured to show the effect of the change in conditions from having the scenario thresholds configured with a first set of values to having the scenario thresholds configured with a second set of values.
For example, a comparison of relative scenario strengths for two threshold sets TS1 and TS2 may show that TS1 has a relatively low compliance strength (that is, a low overall monitoring strength). RMF is a relatively more complex scenario as compared to HRG and SigCash. A low relative strength of the RMF scenario may indicate that RMF contributes little to overall system effectiveness when configured with TS1. This suggests that the RMF scenario is not suitably tuned for the entity type being monitored. The same point—lack of tuning—may be suggested by a low transfer time and lower number of intermediate accounts used for TS1 as shown in a plot of overall monitoring strength. TS2 represents a tuning of the RMF thresholds. With TS2, the tuned the RMF results in an increase in overall system monitoring strength, as will be shown on a plot of overall monitoring strength, and the relative contribution of the RMF scenario will be much higher, consistent with expectations. Additional alerts will be generated following the tuning, as will be visible in a cumulative alerts per week (or other unit of time) chart.
In one embodiment, threshold tuning in response to increase in overall system strength may be automated. In one embodiment, scenarios in the monitoring system may be automatically reviewed for adjustment of tuning threshold values periodically (for example monthly) or in response to user initiation of a review. In one example, application 340 may analyze a monitoring system (using a training run for an RL agent to produce metrics, as discussed herein) with (i) a first configuration of threshold values for one or more scenarios that is consistent with a configuration of thresholds currently deployed to the monitoring system, for example in deployed scenarios 282; and (ii) a second configuration of threshold values for the one or more scenarios in which one or more threshold value is adjusted by a pre-determined increment. The performance of the monitoring system in both configurations is compared for overall monitoring strength, relative strengths of the scenarios, and cumulative alerts. In one embodiment, individual thresholds are adjusted one at a time, and performance evaluated individually following an adjustment. Where the performance metrics indicate that overall system strength improves while the number of alerts remains constant or decreases after an adjustment to a scenario, the adjustment is indicated to be deployed to the monitoring system.
In one embodiment, before proceeding to adjust a threshold of a scenario, application 340 is configured to present an option to automatically adjust the threshold for review and acceptance by the user. The option may take the form of a GUI for displaying an impact of tuning threshold values, as described above, and include a message recommending the threshold adjustment and a user selectable option (such as a mouse-selectable button) to accept or reject the proposed threshold adjustment. Where the automatic threshold adjustment is subject to user review, the adjustment will not proceed until accepted by the user (for example by selecting the accept option), and will be canceled or otherwise not performed if the user rejects the adjustment (for example by selecting the reject option. In this way, the scenarios in the monitored system are automatically modified in response to the determined strength.
Scenarios may be redundant. The systems methods, and other embodiments described herein for using an RL agent for evaluation of monitoring systems enable detection and measurement of correlation between scenarios. Where a scenario rarely alerts in isolation and alerts mostly along with another scenario, it indicates that there is significant overlap in coverage (redundancy) between the two scenarios, suggesting one of the scenarios can be decommissioned. The extent of correlation between alerts of a first scenario and a second scenario may be derived from the record of a training run retrieved from database 315. In one embodiment, application 340 counts number of times during the training run that an alert for a first scenario occurs at the same time step as an alert for a second scenario, and divides that count by the total number of alerts for the first scenario over the course of the training run.
In one embodiment, a scenario overlap GUI displaying scenario correlation includes a table indicating an extent to which alerts of different types correlate to each other. Table 3 below indicates one example of correlation of alerts for an example training run of the RL agent in an environment with the following four scenarios: RMF, Significant Cash, HRG, and Anomaly in ATM.
In this example, ATM anomaly alerts occur at the same time as Sig. Cash alerts 90% of the time. This may exceed a pre-set correlation threshold (such as 85%) indicating redundancy between the scenarios. Where the correlation threshold is exceeded by a pair of scenarios, one of the redundant scenarios may therefore be indicated for decommissioning. In one embodiment, the weaker of the scenarios (as indicated by relative strength) will be evaluated for decommissioning. Accordingly, a relative strength of scenario chart may be included in the GUI.
In one embodiment, identification and selection of redundant scenarios to study for decommissioning is performed automatically. In one example, the identification and selection are performed in response to performance of an RL agent analysis of a monitored system. Application 340 determines extent of alert correlation between pairs of scenarios in the environment, determines whether the extent of alert correlation between any pair of scenarios exceeds a correlation threshold. Where a pair of scenarios is thus found to be excessively correlated, application 340 selects the scenario in the excessively correlated pair that is relatively weaker (or where the pair are of equal relative strength, selects either one of the scenarios in the pair) to be evaluated for decommissioning.
In one embodiment, before proceeding to evaluate the selected redundant scenario for decommissioning, application 340 is configured to present an option to proceed or not with the evaluation. The option may be included in the GUI displaying scenario correlation as a user-selectable option to proceed or not with the evaluation. Where the automatic evaluation is subject to user review, the evaluation will not proceed until accepted by the user, and will be canceled or otherwise not performed if the user indicates that the evaluation should not proceed.
In one embodiment, a decommissioning analysis GUI displaying an analysis of effect of decommissioning one or more scenarios, such as a redundant scenario, may be presented. This can assist in determining whether a scenario should be decommissioned and removed from the monitoring system. For example, a visualization showing a first graph of a first optimum transaction sequence performed by an RL agent to avoid a set of scenarios may be presented alongside a visualization showing a second graph of a second optimum transaction sequence performed by an RL agent to avoid the set of scenarios with a scenario removed or decommissioned. Thus, a GUI may be configured to show the effect of the change in conditions from having a scenario removed from the set of scenarios.
For example, a plot of overall monitoring strength is configured to show monitoring strength points before decommissioning a scenario and after decommissioning the scenario. A relative strength of scenario chart shows the relative strength of scenarios of the set of scenarios both before and after decommissioning and removal of one of the scenarios. A cumulative alerts per week chart shows the expected number of alerts generated both before and after decommissioning and removal of one of the scenarios. Where these metrics indicate that overall system strength improves or the number of alerts decrease after decommissioning of a scenario, the scenario is redundant, and decommissioning of the scenario is indicated.
In one embodiment, decommissioning the scenario in response to improved strength and/or reduction in the number of alerts may be automated. In one embodiment, scenarios in the monitoring system may be automatically reviewed for decommissioning periodically (for example monthly) or in response to user initiation of a review. For example, application 340 may analyze a monitoring system (using a training run for an RL agent to produce metrics, as discussed herein) both with and without a scenario that is under consideration for decommissioning or removal. In one embodiment, in response to a comparison indicating that (i) the overall strength improves beyond a pre-established threshold amount without the scenario, and (ii) the number of cumulative alerts decrease beyond a pre-established threshold amount, application 340 is configured to automatically decommission the scenario from the monitoring system, for example by removing it from deployed scenarios 282.
In one embodiment, before proceeding to decommission the scenario, application 340 is configured to present an option to automatically decommission the scenario from the monitored system for review and acceptance by the user. The option may take the form of a GUI displaying an analysis of effect of decommissioning the scenario, as described above, and further include a message recommending decommissioning the scenario, with a user-selectable option to accept or reject the decommissioning of the scenario. Where the automatic decommissioning is subject to user review, the decommissioning will not proceed until accepted by the user, and will be canceled if the user rejects it.
New transaction channels or account types (products) may be added to a monitored system. The systems methods, and other embodiments described herein for using an RL agent for evaluation of monitoring systems enable assessment of the impact of adding a new transaction channel or product to the monitored system. The action space and/or action space is updated to accommodate the new components.
In one embodiment, an example new component analysis GUI displaying an analysis of impact of adding a new channel to the monitored system may be presented. This can assist in showing whether scenarios need to be added or reconfigured to address the new channel. For example, a visualization showing a first graph of a first optimum transaction sequence performed by an RL agent to avoid a set of scenarios in an environment without the new transaction channel available may be presented alongside a visualization showing a second graph of a second optimum transaction sequence performed by an RL agent to avoid the set of scenarios with the new transaction channel available. Thus, a GUI may be configured to show the effect of the change in conditions from adding a new transaction channel to a monitored system.
In one example, an option to transfer through a new transaction channel, such as a peer-to-peer transaction channel like Zelle. This new channel is not monitored by scenarios, unlike the WIRE, MI, and CASH channels. Analyzing a monitored system that includes this unmonitored channel with the simulated money launderer (the RL agent) reveals that most transfers will be directed through the unmonitored new channel. The first graph shows actions of the RL agent in an environment that does not have the peer-to-peer transaction channel available. The first graph indicates that the RL agent performs all transfers using the monitored channels WIRE, MI, and CASH, in small amounts per transaction. The second graph shows actions of the RL agent in an environment that introduces an unmonitored peer-to-peer channel. The second graph illustrates a shift in focus by the RL agent to move most transactions through the unmonitored peer-to-peer channel directly from the initial account to the goal account, at a minimum of delay.
A plot of overall monitoring strength is configured to show monitoring strength points before and after introduction of the new, unmonitored channel. The plot will show the clear drop in intermediate accounts used and time taken to transfer money, a clear reduction in overall system strength. A relative strength of scenario chart shows the relative strength of scenarios of the set of scenarios both before and after introduction of the new, unmonitored channel. The relative strength of the scenarios becomes equal, as essentially no transactions are passed through them by the RL agent.
In this way, configuration of the environment also includes introducing one of (i) a new account type and (ii) a new transaction channel to the monitored system in the environment.
Scenarios may be added to a monitored system to monitor new or existing channels. The systems methods, and other embodiments described herein for using an RL agent for evaluation of monitoring systems enable assessment of the impact of adding a scenario to a new transaction channel in the monitored system. In one embodiment, the added scenario may be retrieved from a library of scenarios.
In one embodiment, a new channel GUI displaying an analysis of impact of adding a new channel to the monitored system may be presented. This can assist in showing whether a scenario added to the new channel corrects or resolves weak (or non-existent) monitoring of the new channel. For example, a visualization showing a first graph of a first optimum transaction sequence performed by an RL agent to avoid a set of scenarios in an environment that includes a new transaction channel that is unmonitored by a scenario may be presented alongside a visualization showing a second graph of a second optimum transaction sequence performed by an RL agent to avoid the set of scenarios with the new transaction channel both available and monitored by a scenario. Thus, a GUI may be configured to show the effect of the change in conditions from adding a scenario to monitor a new transaction channel in the monitored system.
In one example, an RMF scenario is added to the new peer-to-peer channel. The second graph will show the RL agent to make an initial transfer of the entire amount through the peer-to-peer channel to an internal intermediate account, and then from the intermediate account to transfer the entire amount in several smaller parts using the WIRE channel. This shows the RL agent's learned policy to evade the RMF monitoring of the peer-to-peer channel.
The metrics from the RL agent training are shown in a plot of overall monitoring strength, a relative strength of scenario chart, and a cumulative alerts per week chart. The plot of overall monitoring strength is configured to show monitoring strength points before and after introduction of the RMF scenario on the new peer-to-peer channel, and may also show a monitoring strength point for before the introduction of the new channel. In this example, the plot indicates increased overall monitoring strength over the unmonitored new channel, but decreased overall monitoring strength when compared with the system where the new channel is not included. A relative strength of scenario chart shows the relative strength of scenarios of the set of scenarios both before and after introduction of the RMF scenario to the new channel, and may further show relative strength of the scenarios before addition of the new channel. In this example, the relative strength without the new channel and with the new channel are as discussed above regarding addition of the new channel, and the relative strength of RMF increases over that of RMF without the addition of the new channel following addition of the RMF scenario to the new channel. A cumulative alerts per week chart shows a slight increase in cumulative alerts per week with the addition of RMF to the new channel.
In one embodiment, the new scenario, as configured with respect to threshold variables, is stored (and added to the step function) for subsequent application by the step function. In this way, configuration of environment 270, 330 also includes introducing an additional scenario to the monitored system in the environment.
In one embodiment, the alerting information gathered over the course of a training run for the RL agent or alerts generated by sampling the policy learned by the trained agent enables explanatory breakdowns of scenario coverage by product type and by transaction channel type. In one embodiment, a scenario coverage GUI describing scenario coverage is presented through UI 310. Monitoring system evaluator 360 retrieves alerts triggered over the course of the training run, along with scenario type for the alerts and channel type for the transactions that triggered the alerts from database 315, and presents this information, for example as shown in Table 4:
Values given in Table 4 are illustrative examples. For each product type/channel, the GUI indicates the scenarios responsible for providing most coverage. For new product types, the GUI indicates the level of coverage provided by existing or new scenarios. Where coverage provided by a scenario over a channel or product is less than what is expected, it suggests thresholds need to be tuned.
Overall system strength may be reduced due to addition of a new channel or product. The systems methods, and other embodiments described herein for using an RL agent for evaluation of monitoring systems enable creation of new scenarios responsive to addition of a new channel or product to the monitored system.
In one embodiment, a scenario creation GUI displaying a collection of predicates used in other scenarios may be presented. The predicates are user selectable for inclusion in a new scenario, for example by selecting a check box or other yes/no option adjacent to the predicate. In one embodiment, the predicates presented include those listed in Table 5:
In one embodiment, a subset of the available predicates may be predictively highlighted as a recommended shortlist for inclusion in the new scenario. The selection of the subset is performed by machine learning trained on existing scenarios in a library of scenarios and application of the library scenarios to similar channels or products.
In one embodiment, the system presents recommended scenarios assembled from the recommended shortlist of predicates such as example recommended scenario “(Predicate1 AND Predicate2) OR Predicate3 OR Predicate 4)” and example recommended scenario “(Predicate1 OR Predicate2) AND Predicate 4)”. The generation of the recommended scenarios is performed by machine learning trained on existing scenarios in a library of scenarios and application of the library scenarios to similar channels or products. In one embodiment, the user may custom-write a rule without using the list of available predicates.
In one embodiment, the system performs the analysis of overall monitoring strength for the current setup or configuration of scenarios, for each of the recommended scenarios, and for each custom-written scenario assembled by the user from predicates, enabling visual comparison (in a visualization of a plot of these data points) of overall monitoring strength by scenario configuration. Similarly, the cumulative alerts per week for each of the scenario configurations may also be presented in visualizations of bar charts comparing the various scenario configurations.
In one embodiment, the scenario creation GUI also accepts inputs to select one or more focuses of the new scenario, for example by selecting a check box or other yes/no option adjacent to the listed focus. In one embodiment, the listed focuses include customer, account, external entity, and correspondent bank.
In one embodiment, the user is presented with options to access the features described herein through UI 310.
Where the user has indicated evaluation of a current transaction monitoring system, the processor retrieves and presents an evaluation user interface page at process block 810. In one embodiment, evaluation user interface page is similar to the visual analysis GUI 500 shown and described with respect to
Where system strength is not as expected, the user may select an option to access a scenario tuning page at process block 820. In one embodiment, the scenario tuning page is similar to the tuning GUI 700 shown and described with respect to
Where the user determines at process block 815 that system strength is as expected, the user may select an option to access a scalability analysis page at process block 825. In one embodiment, the scenario scalability page is similar to the scenario scalability analysis GUI 600 shown and described with reference to
Where the system strength is found to be not higher with the larger amount, at process block 835, the processor automatically identifies the scenario for which relative strength declined or reduced where the transferred amount is larger, for example by comparison of the relative scenario strengths generated at process block 810 and the relative scenario strengths generated at process block 825 to identify a scenario with reduced relative strength. In one embodiment, the identified scenario is presented to the user on the scenario scalability page. The processor then continues to process block 820, where the underperforming scenario is automatically strengthened.
Where the system strength is found at decision block 830 to be higher with the larger amount, at process block 840, the processor automatically proceeds to evaluate product coverage, channel coverage, and scenario overlap. The processor presents these metrics for review, for example in a scenario coverage GUI and a scenario overlap GUI as shown and described herein. From this information, at decision block 845, the user determines whether or not the product coverage and channel coverage by the scenarios are consistent with expectations. Where product coverage or channel coverage are not as expected, the user may select an option to access scenario tuning page at process block 820 to adjust scenario thresholds.
Where product coverage and channel coverage are consistent with expectations, the processor proceeds to automatically determine the extent to which scenarios show significant overlap in coverage. The processor may present this information for review in the scenario overlap GUI. From this information, at decision block 850, the processor automatically determines which, if any scenarios show significant overlap in coverage. If so, at process block 855, the processor automatically identifies the scenario with significant overlap in coverage to be redundant, presents information about the proposed decommissioning to the user on a decommissioning analysis GUI, and automatically decommissions the redundant scenario. The processor then continues to process block 820 to adjust any under or overperforming scenarios following the decommissioning.
Where the user has indicated evaluation of a new channel or product at decision block 805, the processor accepts user input specifying the new channel or product to be added, adds the new channel or product to the environment, and at process block 860, evaluates the overall system strength after adding the new channel or product. The processor retrieves and presents this information on a new component analysis page or GUI similar to GUIs 500 and 600.
At decision block 865, the processor automatically determines whether or not overall system strength has remained stable or increased following addition of the new channel or product, for example by comparing overall system strength values generated without and with the new channel/product. Where overall system strength has remained stable or increased, the processor proceeds to decision block 815 to allow the user to determine whether system strength is as expected. Where overall system strength has decreased following addition of the new channel or product, the processor proceeds to process block 870, where the processor solicits user inputs through a scenario creation GUI to add a new scenario or rule with minimal thresholds, and then automatically assesses the effect on the system.
The processor proceeds to process block 875, where the user is presented with a scenario tuning page. The processor accepts user inputs to select the new scenario and set the objective of the tuning to be strengthening the new scenario, automatically generates recommended thresholds, and accepts user inputs to accept the recommended thresholds. The processor then proceeds to process block 810 to re-evaluate the overall system strength and relative scenario strength with the new, tuned scenario in place.
In one embodiment, each step of computer-implemented methods described herein may be performed by a processor (such as processor 1010 as shown and described with reference to
In one embodiment, each subsequent step of a method commences automatically in response to parsing a signal received or stored data retrieved indicating that the previous step has been performed at least to the extent necessary for the subsequent step to commence. Generally, the signal received or the stored data retrieved indicates completion of the previous step.
The method 900 may be initiated automatically based on various triggers, such as in response to receiving a signal over a network or parsing stored data indicating that (i) a user (or administrator) of monitoring system 205 has initiated method 900, (ii) that method 900 is scheduled to be initiated at defined times or time intervals, (iii) that an analysis of the performance of monitoring system scenario performance is requested, or (iv) an other trigger for beginning method 900 has occurred. The method 900 initiates at START block 905 in response to parsing a signal received or stored data retrieved and determining that the signal or stored data indicates that the method 900 should begin. Processing continues to process block 910.
At process block 910, the processor configures an environment to simulate a monitored system for a reinforcement learning agent, for example as shown and described herein.
In one embodiment the processor accepts inputs that define an action space— a set of all possible actions the RL agent can take—in the environment. In one embodiment, the inputs define a set of accounts in the environment, types of the accounts, an increment of available transaction sizes, a set of transaction channels available in the environment. In one embodiment, the processor parses configuration information of monitored system 225 to extract account types and transaction channel types in use in the monitored system. The processor then stores the definition of the action space for further use by the RL agent.
In one embodiment, the processor accepts inputs that define a state space-a set of all possible configurations—of the environment. In one embodiment, the processor parses scenarios deployed in the environment to determine the set of variables evaluated by the scenarios. The processor then generates the state space to include possible values for the variables, for example including in the state space all values (at a pre-set increment) for each variable within a pre-set range for the variable. The processor then stores the generated state space for further use by the RL agent.
In one embodiment, the processor accepts inputs that define a step function or process for transitioning from a time step to a subsequent time step. In one embodiment, the processor parses deployed scenarios 282 in monitored system 225 to identify and extract scenarios with threshold values configured as deployed in monitored system 225, and includes the extracted scenarios for evaluation during execution of the step function. In one embodiment, the processor receives and stores inputs that define a reward function to be applied during execution of the step function. The processor then stores the configured step function for later execution following actions by the RL agent.
In one embodiment, the processor accepts inputs that define a goal or task for execution by the RL agent. For example, the processor may receive and store inputs that indicate an amount for transfer, an initial or source account from which to move the amount, and a destination or goal account to which the amount is to be moved.
In one embodiment, a user may wish to evaluate the effect of adding a new product (such as a new account type or a new transaction channel) to the monitored system. Accordingly, this new product may also be included in the simulated monitored system of the environment by adding the account types or transaction channels to the state space of the environment. The modifications to the state space consistent with the new product may be specified by user inputs and effected in the environment during the configuration. Thus, in one embodiment, the configuration of the environment also includes introducing one of (i) a new account type and (ii) a new transaction channel to the monitored system in the environment, for example as shown and described herein.
In one embodiment, a user may wish to evaluate the effect of adding a new scenario to the monitored system. Accordingly, this new scenario may also be included in the simulated monitored system of the environment by adding the new scenario to the existing scenarios of the environment. The new scenario may be configured by user inputs and then applied during evaluation of steps taken by the RL agent. Thus, in one embodiment, the configuration of the environment also includes introducing an additional scenario to the monitored system in the environment, for example as shown and described herein.
Once the processor has thus completed configuring an environment to simulate a monitored system for a reinforcement learning agent, processing at process block 910 completes, and processing continues to process block 915.
At process block 915, the processor trains the reinforcement learning agent over one or more training episodes to learn a policy that evades scenarios of the simulated monitored system while completing a task, for example as shown and described herein.
In one embodiment, the processor provides a default, untrained, or naïve policy for the RL agent, for example retrieving the policy from storage and storing it as the initial learned policy 267 of adversarial RL agent 265. The policy maps a specific state to a specific action for the RL agent to take. The RL agent interacts with or explores the environment to determine the individual reward that it receives for taking a specific action from a specific state, and revises the policy episodically—for example, following each training episode—to optimize the total reward. The policy is revised towards optimal, for example by using reinforcement learning algorithms such as proximal policy optimization (PPO), to calculate values of state-action pairs for the state space and action space, and improving the policy by selecting the action with the maximum value given the current state.
In one embodiment, a training episode (or training iteration) ends when either (i) the task (such as transferring the designated funds into the designated account) is successfully completed, or (ii) length of the episode reaches a prescribed limit. In one embodiment, training of the reinforcement learning agent continues until a cutoff threshold or convergence criteria is satisfied that indicates that the reinforcement learning agent is successfully trained. For example, the reinforcement learning agent is trained through successive training iterations (each iteration comprising multiple episodes) until average reward in an iteration is consistently near or at a maximum possible reward value. Thus, in one embodiment, the processor trains the reinforcement learning agent through additional training episode(s) until the average reward converges on a maximum.
In one embodiment, to ensure that a training run completes within a reasonable time, a cap is placed on the number of training episodes or length of each episode. This causes the training run to complete in a pre-set maximum number of episodes, in the event that the reward function fails to converge before the cap on episodes is reached. The cap is a hyperparameter that may be set to a value higher than the expected number of episodes needed for convergence.
Convergence on the maximum reward may be determined by one or more successive training episodes with reward totals within a predetermined amount of the maximum possible reward value. For example, where the maximum possible score is 1, the processor may find the reinforcement learning agent to be successfully trained where the cumulative mean of the reward over the training episodes is greater than −1, with a standard deviation of less than 1. These convergence criteria indicates that the RL agent consistently avoids triggering alerts, and completes the assigned task with few steps. In one embodiment, the convergence criteria may be defined by the user, for example by providing them though user interface 310. Upon convergence (that is, once the convergence criteria are satisfied), the RL agent has explored sufficient sequences of decisions within the environment to know what sequence of decisions will produce an optimal reward and avoid triggering any scenarios.
In one embodiment, the processor calculates the reward for each episode, stores a record of the reward for each episode, calculates the cumulative mean of the rewards over the cumulative set of episodes, calculates the standard deviation of the rewards over the cumulative set of episodes, compares the cumulative mean to a cumulative mean threshold (such as a threshold of −1), compares the standard deviation to a standard deviation threshold (such as a threshold of 1), and determines whether the RL agent is successfully trained based on the two comparisons. In particular, where the cumulative mean exceeds the cumulative mean threshold and the standard deviation is less than the standard deviation threshold, the RL agent is determined to be successfully trained, and the training should cease iterating. Otherwise—where the cumulative mean is equal to or is less than the cumulative mean threshold or the standard deviation is equal to or greater than the standard deviation threshold—the RL agent is not determined to be successfully trained, and the training should continue through another iteration/episode.
In one embodiment, the reward function is based on (i) rewards for completing a task, (ii) penalties for steps taken to complete the task, and (iii) penalties for triggering alerts. In one embodiment, the reward function provides a reward, such as a reward of 1, for completing the task. In one embodiment, the reward function provides a small penalty (smaller than the reward, such as between 0.001 and 0.01) for each step taken towards completing the task. In one embodiment, the reward function provides a significant penalty (significantly larger than the reward, such as a penalty of 50 or 100) for each scenario triggered by an action. In one embodiment, the penalties further include a moderate penalty (for example, a penalty of 0.05) for any step taken that transfers an amount out of the goal or destination account, as such actions defeat the purpose of the RL agent.
Thus, in one embodiment, an episode of training of the reinforcement learning agent also includes, for a set of steps by the reinforcement learning agent: (i) rewarding the reinforcement learning agent with a reward where a step taken causes a result state in which the task is complete, (ii) penalizing the reinforcement learning agent with a small penalty less than the size of the reward where the step taken causes a result state in which the task is not complete and which does not trigger one of the scenarios, and (iii) penalizing the reinforcement learning agent with a large penalty larger than the reward.
In one embodiment, a cap is placed on training iterations, in order to prevent an endless (or excessively long) training period where the RL agent does not promptly converge on an optimal solution. The cap may be expressed in time or in iterations. The size of the cap is dependent on the size of the action space and state space in the environment. In a relatively simple example with 3 rules, 5 accounts, and 3 transaction channels, the RL agent converges on a cumulative mean reward of −0.96 within 50 iterations, and accordingly, a cap between 50 and 100 would be appropriate. The value of the cap, as well as other values such as the reward, the small step penalty, and the large alert penalty may be entered as user input before or during configuration.
In one embodiment, the processor determines whether the result state following an action by the RL agent triggers a scenario. In one embodiment, the processor parses the action of the step and result state of the step, and applies the scenario to the action and result state to determine whether or not the rule is triggered. Where a rule is triggered, the alert penalty is applied in the reward function. Multiple alerts may be triggered by an action and result state, and where multiple alerts are triggered, multiple alert penalties may be applied in the reward function.
In one embodiment, the monitored system is a financial transaction system and the task is transferring funds into a particular account. Accordingly, the scenarios are anti-money laundering (AML) rules. In one embodiment, following each action or step taken by the RL agent, the processor evaluates whether the result state triggers one or more AML rules. In one embodiment, the AML rules applied to the RL agent's actions are one or more of the following scenarios:
Once the processor has thus completed training the reinforcement learning agent over one or more training episodes to learn a policy that evades scenarios of the simulated monitored system while completing a task, processing at process block 915 completes, and processing continues to process block 920.
At process block 920, the processor records steps taken by the reinforcement learning agent, result states, and triggered alerts for the training episodes, for example as shown and described herein.
In the process of exploration of steps within the environment to find a sequence of steps that produces an optimal reward and avoids triggering scenarios (for example as discussed in process block 915 above), the RL agent acts as a tool to measure how difficult it is to evade specific scenarios in the monitoring system. Accordingly, the steps of the RL agent's training episodes over a training run are recorded. In one embodiment, the recorded episodes of steps taken, result states, and triggered alerts is either (i) one of the training episodes, as stated above, or (ii) a simulated episode sampled from a policy learned by the trained reinforcement learning agent.
In one embodiment, recording of a step is performed contemporaneously with or immediately subsequent to the performance of the step, for example being provided by the processor in an ongoing data stream. In one embodiment, the steps are provided as a REST stream of objects (or a JSON stream of objects), where the objects describe the steps taken, the result states returned by the step function, and any alerts triggered. The processor parses the stream to identify the objects, and append them to database 315. Each step taken by the RL agent over the course of the training run is thus included in database 315.
Once the processor has thus completed recording the steps taken by the reinforcement learning agent, the result states, and the triggered alerts for the training (or simulated) episodes, processing at process block 920 completes, and processing continues to process block 925.
Additionally, the sequence of transactions or steps can be sampled randomly from the policy of the trained agent. This can be used in lieu of the sequences recorded during training of the agent. In one embodiment, recording of a step is performed in response to simulation of a step. In one embodiment, an episode (of one or more steps) is sampled from a policy learned by the RL agent over the course of training. The policy learned by the RL agent includes a probability distribution over a set of actions per state. An episode is a sequence of states and actions taken by the RL agent to achieve its goal (such as transferring funds between accounts without triggering an alert in a scenario). Once a policy for accomplishing its goal has been learned by the RL agent (that is, once the RL agent has been successfully trained), multiple simulated or generated episodes may be sampled from the policy without repeating the training process, for example as follows.
In one example, a first state (S0) is a state wherein an entire target amount to be transferred to a destination account is in an originating or initial account. This state (S0) is a beginning or initial state of a current episode. The processor samples an action from the probability distribution for the available actions for the current state. The processor then executes the sampled action and moves the agent to a new state. The processor appends the combination of sampled action and new state to the current episode. If, in the new state, the processor determines that (a) the entire target amount has been transferred to the destination account without triggering any scenario alerts, or (b) length of the episode (measured in time or number of steps elapsed) has exceeded a pre-specified threshold, the processor marks the current episode complete and stops the sampling process. If neither of these base conditions (a) or (b) have occurred, the processor repeats the process from the sampling step above until one of the base conditions occurs. In this way, the processor generates a simulated episode consistent with the learned policy.
At process block 925, the processor determines strength of monitoring of the simulated monitored system based on the recorded training episodes, for example as shown and described herein.
In one embodiment the processor parses through the record in database 315 of the training run to count a total number of times specific scenarios were alerted during the training run. Rule strength may be defined by the difficulty with which the RL agent evades the rule. Thus, the number of times a rule was triggered during the training run indicates how strong the rule is, and so is used as a proxy metric for rule strength. In one embodiment, the strength of the rule is expressed relative to the strengths of other rules active in the environment, for example as shown and described herein. This relative strength of scenario, as discussed in further detail herein, provides a first metric of the strength of monitoring.
Rule strength may also be defined by the time (expressed in steps) required to complete the goal in conjunction with the number of intermediate stops needed to complete the goal. Accordingly, in one embodiment, the processor (i) retrieves the number of steps taken to successfully transfer the amount in an optimal episode, and (ii) parses the recorded steps to determine the number of intermediate accounts used to transfer the money in the optimal episode. The tuple of these two values expresses an overall strength of monitoring that is not specifically attributed to any particular scenario. This overall monitoring strength, as discussed in further detail herein provides a second metric of the strength of monitoring.
Once the processor has thus completed determining strength of monitoring of the simulated monitored system based on the recorded training episodes, processing at process block 925 completes, and processing continues to process block 930.
At process block 930, the processor automatically modifies the scenarios in the monitored system in response to the determined strength, for example as described in further detail herein.
In one embodiment, the automatic modification of the scenarios is a change or adjustment to thresholds of existing rules, that is, of the scenarios that are already deployed and operating in the monitored system. In one embodiment, to adjust threshold values of the scenarios, the processor generates a set of possible values for a threshold value set. The processor retrieves an optimal sequence of actions by the RL agent (that is, an optimal training episode). The processor replaces the threshold values of the scenario applied in the optimal training episode with alternative threshold values drawn from the set of possible values for the threshold value set. The processor then applies the modified scenario to the optimal training episode, and records the number of alerts for the modified scenario in connection with the alternative threshold values applied in the modified scenario. The processor replaces the threshold values in the scenario and applies the newly modified scenario the optimal training episode repeatedly to identify a threshold value set that results in a highest number of alerts and identify a threshold value set that results in a lowest number of alerts. The processor partitions the range of values between the threshold values for the highest alerting scenario and lowest alerting scenario into a set of intervals. The processor automatically selects a threshold value division that has the strongest alerting but does not result in an excessive (beyond a pre-determined threshold number) amount of cumulative alerts to be the modified threshold values of the scenario.
Thus, as discussed above, the automatic modification of the scenarios also includes adjusting a threshold of an existing scenario based on strength of the adjusted scenario and a number of cumulative alerts resulting from the adjusted scenario, and deploying the adjusted scenario into the monitored system. For example, the processor automatically locates and replaces the existing scenario in deployed scenarios 282 with the adjusted scenario that has the modified threshold values.
In one embodiment, the automatic modification of the scenarios is a removal of a redundant scenario. A scenario may be considered “redundant” where the scenario's alerting is highly correlated with alerting of another scenario, as may be shown by the recorded learning activity of the RL agent. Thus, in one embodiment, the automatic modification of the scenarios also includes determining that an existing scenario in the simulated monitored system in the environment is redundant, and automatically removing the existing scenario from the monitored system in response to the determination that the existing rule is redundant, for example as discussed in further detail herein. In one embodiment, the processor identifies extent of correlation between alerts of different scenarios, compares the extent of correlation with a threshold indicating excessive correlation, and automatically decommissions and removes the redundant scenario from the monitored system.
In one embodiment, in addition to (or in one embodiment, as an alternative to) automatic modification of the scenarios, the processor may automatically modify (or tune) transaction constraints for account types or transaction channels (also referred to as products) in the monitored system. In one embodiment, this automatic modification of transaction constraints may be performed for different customer segments (for example, customer segments of a bank or other financial institution). In one embodiment, this automatic modification of the transaction constraint includes adjusting a limit on a number or a cumulative amount for transactions involving an existing combination of account type and channel for a customer segment. For example, this adjustment and selection of segment may be based on an estimated chance of using that account type and/or channel for laundering. In one embodiment, this automatic modification of the transaction constraint includes deploying the adjusted constraints into the monitored system for application to the specific customer segment.
In one embodiment, a transaction constraint of a product may be modified and deployed as follows. A usage frequency (that is, a measure of how often a product is used) of a product in successful attempts to evade or circumvent scenarios in a simulation. Where the product is used more frequently than expected (based, for example on a pre-selected percentage threshold), the system will automatically tighten the transaction constraints (for example, a withdrawal limit) to make monitoring stronger. In one embodiment, the system automatically tightens the transaction constraints by generating a new or updated value for the transaction constraint. The generation of the new or updated value for the transaction constraint will perform an analysis and provide a specific suggestion of the extent to which the constraint value should change, and will show the impact of that change on the system's strength and the product's usage frequency. For example, the system will may automatically determine a new or updated value for the transaction constraint that, if applied, would cause the usage frequency to be at or below the expected level. The system will present new or updated value for the transaction constraint to the user (for example, in a GUI) for acceptance or rejection.
Once the processor has thus completed automatically modifying the scenarios in the monitored system in response to the determined strength, processing at process block 930 completes, and processing continues to END block 935, where process 900 ends.
In one embodiment, the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein enables the automatic identification of weaknesses or loopholes in the overall transaction monitoring system followed by automatic modification to remedy the identified weaknesses and close the identified loopholes. Prior solutions do not support this functionality.
In one embodiment, use of the RL agent to evaluate transaction monitoring systems as shown and described herein allows a user to determine the impact of introducing a new product by adding the product to the environment and assessing whether the adversarial agent can use this product to evade existing rules more easily (for example, in the AML context, to move money more easily) without actually deploying the rule into a live transaction environment. The user can then adjust existing rules or add new rules until, the RL agent is satisfactorily restrained by the rules or no longer able to evade rules using the product. This rule can then be directly and automatically deployed in production. Without the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein, a proposed rule must be piloted for an extensive period of time (for example, over 6 months), a large volume of suspicious activity alerts must be manually reviewed, and thresholds must be selected and the rule deployed in production. With the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein, the time taken to evaluate the effect of new products on the monitoring system is reduced from over 6 months to a few days.
In one embodiment, use of the RL agent to evaluate transaction monitoring systems allows the strength of the system to be tested against an entity that is actively trying to evade the system, rather than against entities that are simply moving money around and just happen to trigger the rule. This provides a far superior measure of the strength of individual rules and of overall system strength.
In one embodiment, use of the RL agent to evaluate transaction monitoring systems as shown and described herein enables more faithful quantification of the incremental value of a rule to the overall monitoring system. Without the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein, institutions have to quantify value of rules using just the effectiveness metric, which has attribution and other data issues as described elsewhere herein.
In one embodiment, use of the RL Agent to evaluate transaction monitoring systems as shown and described herein enables identification of specific account types or channels a money laundered might abuse. The system is further able to recommend changes to thresholds or recommend new scenarios that can plug these loopholes.
In one embodiment, use of the reinforcement learning agent to evaluate transaction monitoring systems as shown and described herein automatically develops a rule or policy for evading existing rules which can then be automatically implemented as a rule indicating suspicious activity in the transaction monitoring system.
The systems, methods, and other embodiments described herein can improve the functionality of Oracle Financial Services Crime and Compliance Management cloud service, NICE Actimize, SAS, FICO, Quantexa, Feedzai, and other software services used for financial crime prevention by introducing an adversarial RL agent that automatically evaluates the strength of monitoring rules and automatically adjusts scenario thresholds to close loopholes and thereby restrain or prevent malicious or criminal activity.
In general, computer-executable instructions such as software instructions are designed to be executed by one or more suitably programmed processor accessing memory, such as by accessing CPU or GPU resources. These software instructions may include, for example, computer-executable code and source code that may be compiled into computer-executable code. These software instructions may also include instructions written in an interpreted programming language, such as a scripting language.
In a complex system, such instructions may be arranged into program modules with each such module performing a specific task, process, function, or operation. The entire set of modules may be controlled or coordinated in their operation by a main program for the system, an operating system (OS), or other form of organizational platform.
In one embodiment, one or more of the components described herein are configured as modules stored in a non-transitory computer readable medium. The modules are configured with stored software instructions that when executed by at least a processor accessing memory or storage cause the computing device to perform the corresponding function(s) as described herein.
In one embodiment, the present system (such as monitoring system 205) is a computing/data processing system including a computing application or collection of distributed computing applications for access and use by other client computing devices associated with an enterprise (such as the client computers 245, 250, 255, and 260 of enterprise network 215) that communicate with the present system over a network (such as network 210). The applications and computing system may be configured to operate with or be implemented as a cloud-based network computing system, an infrastructure-as-a-service (IAAS), platform-as-a-service (PAAS), or software-as-a-service (SAAS) architecture, or other type of networked computing solution. In one embodiment the present system provides at least one or more of the functions disclosed herein and a graphical user interface to access and operate the functions.
In one embodiment, RL agent for evaluation of transaction monitoring systems logic 1030 or the computing system 1000 is a means (such as, structure: hardware, non-transitory computer-readable medium, firmware) for performing the actions described. In some embodiments, the computing device may be a server operating in a cloud computing system, a server configured in a Software as a Service (SaaS) architecture, a smart phone, laptop, tablet computing device, and so on.
The means may be implemented, for example, as an ASIC programmed to perform RL-agent-based evaluation of transaction monitoring systems. The means may also be implemented as stored computer executable instructions that are presented to computer 1005 as data 1040 that are temporarily stored in memory 1015 and then executed by processor 1010.
RL agent for evaluation of transaction monitoring systems logic 1030 may also provide means (e.g., hardware, non-transitory computer-readable medium that stores executable instructions, firmware) for performing RL-agent-based evaluation of transaction monitoring systems.
Generally describing an example configuration of the computer 1005, the processor 1010 may be a variety of various processors including dual microprocessor and other multi-processor architectures. A memory 1015 may include volatile memory and/or non-volatile memory. Non-volatile memory may include, for example, ROM, PROM, EPROM, EEPROM, and so on. Volatile memory may include, for example, RAM, SRAM, DRAM, and so on.
A storage disk 1035 may be operably connected to the computer 1005 by way of, for example, an input/output (I/O) interface (for example, a card or device) 1045 and an input/output port 1020 that are controlled by at least an input/output (I/O) controller 1047. The disk 1035 may be, for example, a magnetic disk drive, a solid-state disk drive, a floppy disk drive, a tape drive, a Zip drive, a flash memory card, a memory stick, and so on. Furthermore, the disk 1035 may be a CD-ROM drive, a CD-R drive, a CD-RW drive, a DVD ROM, and so on. The memory 1015 can store a process 1050 and/or data 1040 formatted as one or more data structures, for example. The disk 1035 and/or the memory 1015 can store an operating system that controls and allocates resources of the computer 1005.
The computer 1005 may interact with, control, and/or be controlled by input/output (I/O) devices via the input/output (I/O) controller 1047, the I/O interfaces 1045 and the input/output ports 1020. The input/output devices include one or more displays 1070, printers 1072 (such as inkjet, laser, or 3D printers), and audio output devices 1074 (such as speakers or headphones), text input devices 1080 (such as keyboards), a pointing and selection device 1082 (such as mice, trackballs, touchpads, touch screens, joysticks, pointing sticks, stylus mice), audio input devices 1084 (such as microphones), video input devices 1086 (such as video and still cameras), video cards (not shown), disk 1035, network devices 1055, and so on. The input/output ports 1020 may include, for example, serial ports, parallel ports, and USB ports.
The computer 1005 can operate in a network environment and thus may be connected to the network devices 1055 via the I/O interfaces 1045, and/or the I/O ports 1020. Through the network devices 1055, the computer 1005 may interact with a network 1060. Through the network 1060, the computer 1005 may be logically connected to remote computers 1065. Networks with which the computer 1005 may interact include, but are not limited to, a LAN, a WAN, a cloud, and other networks.
Data can be stored in memory by a write operation, which stores a data value in memory at a memory address. The write operation is generally: (1) use the processor to put a destination address into a memory address register; (2) use the processor to put a data value to be stored at the destination address into a memory data register; and (3) use the processor to copy the data from the memory data register to the memory cell indicated by the memory address register. Stored data can be retrieved from memory by a read operation, which retrieves the data value stored at the memory address. The read operation is generally: (1) use the processor to put a source address into the memory address register; and (2) use the processor to copy the data value currently stored at the source address into the memory data register. In practice, these operations are functions offered by separate software modules, for example as functions of an operating system. The specific operation of processor and memory for the read and write operations, and the appropriate commands for such operation will be understood and may be implemented by the skilled artisan.
Generally, in some embodiments, references to storage or storing indicate storage as a data structure in memory or storage/disks of a computing device (such as memory 1015, or storage/disks 1035 of computing device 1005 or remote computers 1065).
Further, in some embodiments, a database associated with the method may be included in memory. In a database, the storage and retrieval functions indicated may include the self-explanatory ‘create,’ ‘read,’ ‘update,’ or ‘delete’ data (CRUD) operations used in operating a database. These operations may be initiated by a query composed in the appropriate query language for the database. The specific form of these queries may differ based on the particular form of the database, and based on the query language for the database. For each interaction with a database described herein, the processor composes a query of the indicated database to perform the unique action described. If the query includes a ‘read’ operation, the data returned by executing the query on the database may be stored as a data structure in a data store, such as data store 230, or in memory.
In another embodiment, the described methods and/or their equivalents may be implemented with computer executable instructions. Thus, in one embodiment, a non-transitory computer readable/storage medium is configured with stored computer executable instructions of an algorithm/executable application that when executed by a machine(s) cause the machine(s) (and/or associated components) to perform the method. Example machines include but are not limited to a processor, a computer, a server operating in a cloud computing system, a server configured in a Software as a Service (SaaS) architecture, a smart phone, and so on). In one embodiment, a computing device is implemented with one or more executable algorithms that are configured to perform any of the disclosed methods.
In one or more embodiments, the disclosed methods or their equivalents are performed by either: computer hardware configured to perform the method; or computer instructions embodied in a module stored in a non-transitory computer-readable medium where the instructions are configured as an executable algorithm configured to perform the method when executed by at least a processor of a computing device.
While for purposes of simplicity of explanation, the illustrated methodologies in the figures are shown and described as a series of blocks of an algorithm, it is to be appreciated that the methodologies are not limited by the order of the blocks. Some blocks can occur in different orders and/or concurrently with other blocks from that shown and described. Moreover, less than all the illustrated blocks may be used to implement an example methodology. Blocks may be combined or separated into multiple actions/components. Furthermore, additional and/or alternative methodologies can employ additional actions that are not illustrated in blocks. The methods described herein are limited to statutory subject matter under 35 U.S.C § 101.
The following includes definitions of selected terms employed herein. The definitions include various examples and/or forms of components that fall within the scope of a term and that may be used for implementation. The examples are not intended to be limiting. Both singular and plural forms of terms may be within the definitions.
References to “one embodiment”, “an embodiment”, “one example”, “an example”, and so on, indicate that the embodiment(s) or example(s) so described may include a particular feature, structure, characteristic, property, element, or limitation, but that not every embodiment or example necessarily includes that particular feature, structure, characteristic, property, element or limitation. Furthermore, repeated use of the phrase “in one embodiment” does not necessarily refer to the same embodiment, though it may.
A “data structure”, as used herein, is an organization of data in a computing system that is stored in a memory, a storage device, or other computerized system. A data structure may be any one of, for example, a data field, a data file, a data array, a data record, a database, a data table, a graph, a tree, a linked list, and so on. A data structure may be formed from and contain many other data structures (e.g., a database includes many data records). Other examples of data structures are possible as well, in accordance with other embodiments.
“Computer-readable medium” or “computer storage medium”, as used herein, refers to a non-transitory medium that stores instructions and/or data configured to perform one or more of the disclosed functions when executed. Data may function as instructions in some embodiments. A computer-readable medium may take forms, including, but not limited to, non-volatile media, and volatile media. Non-volatile media may include, for example, optical disks, magnetic disks, and so on. Volatile media may include, for example, semiconductor memories, dynamic memory, and so on. Common forms of a computer-readable medium may include, but are not limited to, a floppy disk, a flexible disk, a hard disk, a magnetic tape, other magnetic medium, an application specific integrated circuit (ASIC), a programmable logic device, a compact disk (CD), other optical medium, a random access memory (RAM), a read only memory (ROM), a memory chip or card, a memory stick, solid state storage device (SSD), flash drive, and other media from which a computer, a processor or other electronic device can function with. Each type of media, if selected for implementation in one embodiment, may include stored instructions of an algorithm configured to perform one or more of the disclosed and/or claimed functions. Computer-readable media described herein are limited to statutory subject matter under 35 U.S.C § 101.
“Logic”, as used herein, represents a component that is implemented with computer or electrical hardware, a non-transitory medium with stored instructions of an executable application or program module, and/or combinations of these to perform any of the functions or actions as disclosed herein, and/or to cause a function or action from another logic, method, and/or system to be performed as disclosed herein. Equivalent logic may include firmware, a microprocessor programmed with an algorithm, a discrete logic (e.g., ASIC), at least one circuit, an analog circuit, a digital circuit, a programmed logic device, a memory device containing instructions of an algorithm, and so on, any of which may be configured to perform one or more of the disclosed functions. In one embodiment, logic may include one or more gates, combinations of gates, or other circuit components configured to perform one or more of the disclosed functions. Where multiple logics are described, it may be possible to incorporate the multiple logics into one logic. Similarly, where a single logic is described, it may be possible to distribute that single logic between multiple logics. In one embodiment, one or more of these logics are corresponding structure associated with performing the disclosed and/or claimed functions. Choice of which type of logic to implement may be based on desired system conditions or specifications. For example, if greater speed is a consideration, then hardware would be selected to implement functions. If a lower cost is a consideration, then stored instructions/executable application would be selected to implement the functions. Logic is limited to statutory subject matter under 35 U.S.C. § 101.
An “operable connection”, or a connection by which entities are “operably connected”, is one in which signals, physical communications, and/or logical communications may be sent and/or received. An operable connection may include a physical interface, an electrical interface, and/or a data interface. An operable connection may include differing combinations of interfaces and/or connections sufficient to allow operable control. For example, two entities can be operably connected to communicate signals to each other directly or through one or more intermediate entities (e.g., processor, operating system, logic, non-transitory computer-readable medium). Logical and/or physical communication channels can be used to create an operable connection.
“User”, as used herein, includes but is not limited to one or more persons, computers or other devices, or combinations of these.
While the disclosed embodiments have been illustrated and described in considerable detail, it is not the intention to restrict or in any way limit the scope of the appended claims to such detail. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the various aspects of the subject matter. Therefore, the disclosure is not limited to the specific details or the illustrative examples shown and described. Thus, this disclosure is intended to embrace alterations, modifications, and variations that fall within the scope of the appended claims, which satisfy the statutory subject matter requirements of 35 U.S.C. § 101.
To the extent that the term “includes” or “including” is employed in the detailed description or the claims, it is intended to be inclusive in a manner similar to the term “comprising” as that term is interpreted when employed as a transitional word in a claim.
To the extent that the term “or” is used in the detailed description or claims (e.g., A or B) it is intended to mean “A or B or both”. When the applicants intend to indicate “only A or B but not both” then the phrase “only A or B but not both” will be used. Thus, use of the term “or” herein is the inclusive, and not the exclusive use.