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 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 rule-based and non-rule-based models.
There is currently no way to automatically test the effectiveness of transaction monitoring systems. There is currently no way to automatically assess if the strength of the overall monitoring system is affected by the introduction of new financial products. There is no mechanism in place to automatically reveal weaknesses in an overall monitoring system.
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 measurement of monitoring system strength using simulated episodes of reinforcement learning (RL) agent actions. In one embodiment, an RL agent is trained to evade a monitoring system. The RL agent is then used to simulate an episode of actions and resulting alert states under the monitoring system. The episode of actions and alert states shows how resistant the monitoring system is to adversarial action, and provides a measure of strength of the monitoring system.
In one embodiment, a simulation-based monitoring strength measurement system measures monitoring system strength on a basis of resistance to adversarial action by an RL agent that has been trained to evade the monitoring system. In one embodiment, the actions by the RL agent and the resulting alerts states of the monitoring system may be simulated by sampling actions from the RL agent and then evaluating the actions with scenarios of the monitoring system to determine if an alert is triggered. The sequence of simulated actions and results (or episode) provides proxy metrics for measuring overall strength of the monitoring system, for example time taken to complete the task and intermediate accounts used to complete the task. In one embodiment, a simulation-based monitoring strength measurement system as shown and described herein provides a tool for measurement of monitoring system strength on a consistent basis—resistance to adversarial action by an RL agent trained to evade the monitoring system—where measurement on a consistent basis was not previously possible.
The simulation-based monitoring strength measurement system and its components are one example implementation of an RL agent for evaluation of monitoring systems, as shown and described herein in further detail. In one embodiment, the components of simulation-based monitoring strength measurement 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, the simulation-based monitoring strength measurement method 100 is implemented and performed by monitoring system 205 of
At process block 110, the processor trains a reinforcement learning agent to learn a policy that evades one or more scenarios of a monitoring system while completing a task. In one embodiment, the policy that guides or controls the actions of the RL agent is trained or adjusted to choose actions in furtherance of a task or goal that do not trigger scenarios which are configured to inhibit, hinder, prevent, or otherwise thwart the task. In one embodiment, an RL agent evades a scenario when the RL agent performs an action in furtherance of the task without triggering or causing an alert under the scenario. In one embodiment, the processor trains the RL agent to learn a policy that chooses actions that advance toward completion of the task, but do not trigger scenario alerts.
In one embodiment, the policy is a mapping of states of the RL agent to actions available to the agent. In one embodiment, the policy weights actions available in a state to favor one action over another. For example, the weights attached to actions available in a state may be transition values that indicate expected cumulative benefit of taking a particular action from the state at a particular time step. In one embodiment, these transition values are adjusted in the training process so that the RL agent consistently chooses actions that do not trigger alerts (for example as shown and described in further detail herein). In one embodiment, the policy is stored as a data structure including the transition values for each state over a range of time.
In one embodiment, the processor trains the RL agent by iteratively (i) executing the RL agent to explore an environment by choosing actions through a series of states, (ii) calculating a reward that is based on completing the task and not triggering alerts, and (iii) adjusting the policy governing choice of actions to increase the cumulative reward or benefit. In one embodiment, training of the RL agent is complete when the policy causes the performance of the RL agent to converge on a maximum cumulative award. Further details on training of the RL agent are discussed herein, for example under the heading “Example Architecture—Training Algorithm.”
Processing at process block 110 then completes, and processing continues at process block 115. At the completion of process block 110, the trained RL agent has learned a policy that selects actions toward completing the task that evade and do not trigger alerts under the one or more scenarios. In one embodiment, the trained RL agent will therefore perform well, consistently circumventing the monitoring system. For example, the trained RL agent may take at or near a minimum number of actions to accomplish a given task without alerts. In one embodiment, steps taken by the trained RL agent will therefore form a consistent basis for measuring the strength of the monitoring system. Thus, in one embodiment, the output policy from the training of the RL agent may be used to generate simulated episodes that can serve as a measure of monitoring system strength. This is an alternative to using episodes recorded during the training of the RL agent itself as the measure of monitoring system strength.
At process block 115, the processor samples the policy to simulate an episode of steps taken by the reinforcement learning agent. In one embodiment, for each step of an episode, an action that the RL agent would take at that step is retrieved from the policy. For example, the action may be selected from a probability distribution of actions available for a current state of the RL agent and a current time step. In one embodiment, the RL agent executes the action so the state of the RL agent is updated to a new state resulting from performing the action, and so the time step is incremented. In one embodiment, the new state is evaluated by the scenarios to determine whether the new state of the RL agent causes any one or more of the scenarios to determine that an alert should be presented. In one embodiment, the processor appends a row or other record (or data structure) for the action and resulting alert statuses of the scenarios for the current time step to an episode (or other data structure). In one embodiment, this process is repeated in a loop until an episode is completed by either completing the task or reaching a cap or other threshold on the number of time steps in an episode.
In one embodiment, the sampling of the policy is a selection of an action based on probabilities assigned to each action from a given state (such as the current state) by a model or table that encodes the policy. In one embodiment, the transition dynamics are deterministic: when an action is taken, the next state is known with certainty. In one embodiment, the values for selecting actions available at a given state at a given time step may be expressed as a probability distribution indicating probabilities that the RL agent will choose a particular one of the available actions. For example, actions with higher probabilities (representing higher expected cumulative benefit) will have similarly high likelihoods of being chosen, while actions with lower probabilities (representing lower expected cumulative benefit) will have similarly low likelihoods of being chosen. Thus, the probability distribution shows the relative expected cumulative benefits for the available actions available from a state. The probability distribution may be referred to as an action distribution.
In one embodiment, the sampling of the policy is a selection of an action based on a transition probability distribution for the current state. Thus, in one embodiment, the transition dynamics are non-deterministic. In one embodiment, the actions have a likelihood of selection proportional to their transition value.
In one embodiment, sampling the policy includes selecting a random action from a probability distribution for a particular state and time step. In one embodiment, the probability distribution favors selection of those actions with highest expected cumulative benefit. Because triggered alerts significantly reduce the cumulative benefit by applying a significant penalty for alerts in the reward function (as discussed in further detail herein), the probability distribution favors selection of those actions that do not lead to alerts. In one embodiment, the transition values for actions that trigger alerts are very small, and therefore actions that trigger alerts are highly unlikely to be chosen by the sampling. Actions that do not trigger alerts have relatively higher probabilities, and actions that do not trigger alerts are proportionately more likely to be chosen.
In one embodiment, the sampling is not a random sampling from the probability distribution. In one embodiment, the actions that the RL agent would choose are those that have the highest probabilities. In one embodiment, therefore, the sampling includes identifying the highest point in the probability distribution for a given state and time step, and selecting the associated action.
In one embodiment, once an action is selected from the probability distribution, the RL agent executes the action to reach a new state for the RL agent. The new state describes an environment in which the action has just been performed. In one embodiment, the new state may or may not satisfy thresholds or conditions of scenarios that lead to alerts.
In one embodiment, the processor evaluates the new state with the scenarios to determine their alert status or state as to whether or not thresholds or conditions of the scenarios are satisfied to trigger an alert. In one embodiment, a scenario is evaluated by retrieving values considered in the scenario from the environment and/or state of the RL agent, and then executing the comparisons or other features of the scenario using the retrieved values in order to determine whether or not an alert is triggered. For example, balance values of an account from a prior state to the new state may be retrieved, and compared against a threshold change amount in order to determine if a rapid movement of funds alert is triggered. In one embodiment, all scenarios of the monitoring system are evaluated at each time step. In this way, the resulting alert states may be recorded for each time step of an episode.
In one embodiment, the processor then creates a record (such as a row of a data structure) for the current time step. In one embodiment, the record includes an indication of the action taken by the RL agent. In one embodiment, the record includes an alert state for each of the one or more scenarios. The alert state indicates whether or not the action caused each scenario to alert. In one embodiment, the record includes the state of the RL agent. The state of the RL agent indicates, for example, account identifiers and associated balances or other environmental factors following the action. The processor then appends the record to an episode data structure, with the record being placed following a sequence of records for previous steps.
In one embodiment, the steps of selection of an action, execution of the action, evaluation of the results, and appending a record are repeated by the processor until the episode is completed. With the appending of the record of an action and resulting alerts for a final state and time step to the episode, processing at process block 115 then completes, and processing continues at process block 120. In one embodiment, at the completion of process block 115, an episode is created that is a sequence of states and actions is created. In one embodiment, information from the episode may be used as a proxy metric for the strength of the monitoring system.
At process block 120, the processor analyzes the steps taken in the episode to measure a strength of monitoring in the monitoring system. In one embodiment, the number of steps in (or length of) the episode may be a proxy metric for the strength of the monitoring system. For example, the longer or more time steps the RL agent takes to complete its task without triggering scenarios, the stronger the monitoring system is. In one embodiment, this number of time steps may be averaged over multiple episodes simulated from the learned policy. In one embodiment, the number of intermediate accounts used between the originating account and the destination account may be a proxy metric for the strength of the monitoring system. For example, the more intermediate accounts that the RL agent uses to complete its task without triggering scenarios, the stronger the monitoring system is. In one embodiment, this number of intermediate accounts may be averaged over multiple episodes simulated from the learned policy.
In one embodiment, the percentage of the task successfully completed by the agent before the first alert in the episode may be a proxy metric for the strength of the monitoring system. For example, the more of a task that the RL agent may get done before triggering a scenario, the weaker the monitoring system. In one embodiment, where the task is transferring funds from an originating account to a destination account, the percentage of the funds that are placed in the destination account before an alert is generated may be the proxy metric. In one embodiment, the proxy metric for strength is 100% minus the percentage of the amount placed in the target or destination account before an alert is generated in an episode. In one embodiment, this percentage may be averaged over multiple episodes simulated from the learned policy. Thus, the more units (for example, units of money) transferred by the RL agent without an alert, the weaker the monitoring system, and in this way, strength can be measured as 100% less the percentage of units transferred to the destination without alert.
In one embodiment, the RL agent may fail to learn a policy that completes the full task (for example, transfers the full amount) within a reasonable time. Accordingly, on one embodiment, the percentage of the task successfully completed (such as percentage of funds transferred into a destination account) before a threshold number of steps or cap is reached may be a proxy metric for the strength of the monitoring system. For example, the more of a task that the RL agent may get done before running out of available steps in an episode, the weaker the monitoring system. Thus, the percentage of the task that is completed upon reaching the threshold number of steps serves as the measure of monitoring strength. In one embodiment, this percentage may be averaged over multiple episodes simulated from the learned policy.
In one embodiment, a combination of one or more of length of episode, number of intermediate accounts, and percentage of task completed before triggered alert or cap on number of steps is used together as a metric of overall monitoring strength. Note that these measures of strength of the monitoring system are measures of a particular configuration of the monitoring system. The configuration of the monitoring system may include choice of the particular scenarios that are deployed (or not deployed) in the monitoring system, the various threshold values selected for the scenarios, as well as the choice of account types and their corresponding limits on transactions.
In one embodiment, the processor may count the number of steps in the episode in order to determine the length of the episode. In one embodiment, the processor may retrieve the value for the time step of the final record of the episode in order to determine the length of the episode. In one embodiment, the processor may use the length of the episode as a measure of monitoring system strength. In one embodiment, the processor may use the length of the episode as the basis for the measure of monitoring system strength. For example, in one embodiment, the processor may sample multiple episodes from the policy of the RL agent (as discussed above), determine the length of the episodes, and find an average (mean or median) length of the episodes, and use the average length of the episodes as a measure of monitoring system strength.
In one embodiment, the processor may parse the records of the steps in the episode to identify and count the number of intermediate accounts used by the RL agent in the course of the episode. For example, in one embodiment, the records include account identifiers for receiving or transferee accounts in every action. The processor tallies each account identified in an action other than the originating account and the destination account. Individual accounts are only counted once, no matter how many times they are used over the course of an episode. Thus, the processor determines a number of intermediate accounts used over the course of an episode for transfer from originating account to destination account. The processor may use the number of intermediate accounts used for transfer from originating account to destination account as another measure of monitoring system strength.
In one embodiment, the processor may parse the records of the steps in the episode to identify a percentage of the task completed before cutoff by generation of an alert in the episode. For example, in one embodiment where the task is transfer of an amount from an originating account to a destination account, the records may include values for balances of accounts. The records may include balance values for the originating account and the destination account. In one embodiment, the processor retrieves the initial balance of the originating account at the beginning of the episode, for example from the record for the initial step of the episode. In one embodiment, the processor identifies a latest step immediately preceding the step in which the first alert is triggered, and retrieves the balance of the destination account at the latest step. In one embodiment, the processor then divides the balance of the destination account at the latest step by the initial balance to find the percentage of the task completed. The processor may use the percentage of the task completed before alert as another measure of monitoring system strength to resist adversarial action. In one embodiment, the measure of monitoring system strength may be 100% minus the percentage of task completed (e.g., percentage transferred to destination account) before an alert, as discussed above.
In one embodiment, the processor may parse the records of the steps in the episode to identify a percentage of the task completed before cutoff by reaching a threshold, cap on steps, or timeout that limits the maximum length of an episode. As discussed above, the records may include values for balances of accounts, and the processor may retrieve these balances. In one embodiment, the processor retrieves the initial balance of the originating account in the first step of the episode and the final balance of the destination account at the final step of the episode. The final balance is divided by the initial balance to find the percentage of the task completed by the end of an episode. The processor may use the percentage of the task completed by the time that a maximum episode length is reached as another measure of monitoring system strength to resist adversarial action. In one embodiment, the measure of monitoring system strength may be 100% minus the percentage of task completed before the end of the episode, as discussed above.
In one embodiment, resistance to adversarial action by an RL agent that has been trained to evade the monitoring system is a consistent basis for measuring monitoring strength. Where an RL agent is trained until the RL agent behavior converges on optimal behavior for evading—that is, not triggering alerts while performing tasks in—a particular configuration of the monitoring system, multiple episodes for completing a task will be performed in a similar way. This demonstrates the consistency of RL agent behavior as a metric.
In one embodiment, an RL agent trained to evade one configuration of a monitoring system performs a particular task in one way, while an RL agent trained to evade another configuration of a monitoring system might perform the particular task in another way. In one embodiment, to provide metrics of monitoring strength of different monitoring system configurations, an RL agent will need to be trained on a monitoring system having the configuration for which the RL agent will be simulating episodes.
In one embodiment, despite the fact that an RL agent is trained for a specific configuration of monitoring system, the metrics that they provide form a consistent basis for measuring monitoring system strength because the RL agent for each specific configuration of monitoring system is trained until RL agent behavior converges on an optimal way to complete the task without triggering scenarios of the specific configuration of monitoring system. In short, the RL agents perform in an efficient and effective way to accomplish their tasks under their separate monitoring systems. Therefore, the length of an episode, the number of unique intermediate accounts used in episode, the percentage of task completed before alert, and the percentage of task completed at maximum episode length are all consistent measures of resistance of a monitoring system to adversarial action. In one embodiment, the measure of resistance is moreover a measure of resistance to a good—that is, effective and efficient—adversarial strategy to achieve the task while remaining undetected by scenarios. In one embodiment, this is due to the training of the RL model until its performance converges on a maximum, thus training of the RL agent to behave in an optimal way to evade the scenarios while completing the task. Thus, in one embodiment, the good strategy may be a best strategy to achieve the task that is not outperformed by other strategies.
Processing at process block 120 then completes, and processing continues at process block 125. In one embodiment, at the completion of process block 120, the processor has determined the length of an episode, determined a number of unique intermediate accounts used in the episode, and a percentage of task completed before cutoff (due to alert or reaching maximum episode length). These may be used as a measure of monitoring system strength. For example, length of episode reflects the amount of time that that the monitoring system can delay a good RL agent strategy to achieve the task without alerts. And, for example, number of unique intermediate accounts reflects the complexity required for the good RL agent strategy to achieve the task without alerts. Length of episode (also referred to herein as time taken to transfer), number of intermediate accounts used for transfer, and percentage of task completed before cutoff are consistent metrics that allow for meaningful comparison between two (or more) monitoring system configurations. The difference (if any) between RL-agent performance of the same task under two (or more) different configurations of monitoring system indicates the difference in monitoring strength of the two (or more) configurations of the monitoring system.
At process block 125, the processor presents the strength of monitoring in an interface. In one embodiment, the interface is a user interface for presenting the strength of monitoring to a user. In one embodiment, the interface is a programming interface for presenting the strength of monitoring to other computing modules.
In one embodiment, the processor presents the strength of monitoring in a graphical user interface for viewing by the user. For example, the strength of monitoring may be presented as a point 540 plotted against a time taken to transfer money axis 545 and a number of intermediate accounts axis 550 overall monitoring strength visualization 530, as shown and described in further detail herein with reference to visual analysis GUI 500. Or for example, the strength of monitoring for performing one task may be shown similarly plotted in an overall monitoring strength plot 635 along with strength of monitoring for performing another task to allow the user to visually see the relative strength of the monitoring system against the two tasks, as shown and described in further detail herein with reference to scalability analysis GUI 600. Or, in another example, a strength of monitoring for one configuration of monitoring system may be shown plotted along with a strength of monitoring for another configuration of monitoring system in an overall monitoring strength visualization to allow the user to visually see the difference in monitoring strength between the two configurations.
In one embodiment, the processor presents the strength of monitoring values to other computing system components through an application programming interface (API) such as a REST API. The length of episode (time taken to transfer), number of intermediate accounts, and percentage of task completed before cutoff (due to alert or reaching maximum episode length) may be provided individually, or together, in response to an API request.
Processing at process block 125 then completes, and processing continues to END block 130, where method 100 completes. In one embodiment, following completion of method 100, the processor has produced one or more metrics for the strength of the monitoring system in thwarting prohibited activity. Therefore, in one embodiment, the strength of a monitoring system may be measured and quantified on consistent bases: how long it takes an RL agent to get past the monitoring system while executing a good strategy to do so, how complex a good strategy to get past the monitoring system is in terms of discrete intermediate accounts involved, and/or how much of a task the RL agent can complete before further actions are cut off by an alert or by reaching a cap on episode length. Each of these metrics may form or be the basis of a dimension of an overall metric of monitoring system strength.
In one embodiment, the step of sampling the policy to create an episode of steps taken by the reinforcement learning agent (as shown and described above with reference to process block 115) includes a step of selecting an action from a current probability distribution of available actions for a current state of the reinforcement learning agent, wherein the current probability distribution favors a subset of the available actions that do not trigger an alert under the one or more scenarios. The step of sampling the policy to create an episode of steps taken by the reinforcement learning agent also includes a step of executing the action to move the reinforcement learning agent into a new state. The step of sampling the policy to create an episode of steps taken by the reinforcement learning agent also includes a step of evaluating the new state with the one or more scenarios to determine alert states of the one or more scenarios resulting from the random action. The step of sampling the policy to create an episode of steps taken by the reinforcement learning agent further includes a step of appending a record of the action and the alert states to the episode as a step.
In one embodiment, the processor repeats the steps of selecting the action, executing the action, evaluating the new state, and appending the record until one or more of (i) the task is completed, (ii) an alert is triggered under the one or more scenarios, or (iii) a number of steps in the episode exceeds a threshold. In one embodiment, the task is fully completed without triggering an alert under the one or more scenarios. In one embodiment, the task is partially completed before triggering an alert, and the processor continues to select the action, execute the action, evaluate the new state, and append the record following the triggered alert until the task is completed in order to generate the episode. In one embodiment, the task is partially completed before triggering an alert, and the processor ceases to select the action, execute the action, evaluate the new state, and append the record following the triggered alert. In one embodiment, the threshold is a cap on the length of an episode. In one embodiment, the value selected for the cap indicates an amount of delay in completing the task that is a satisfactory amount of time to thwart completion of the task. For example, where the monitoring system is monitoring a financial transaction system, a delay of 90 time steps, where a time step represents one day, may be an acceptable amount of time to delay a money laundering activity from being completed.
In one embodiment, the step of training the reinforcement learning agent to learn the policy that evades the one or more scenarios of the monitoring system while completing the task (as shown and described above with reference to process block 110) further comprises configuring probability distributions of available actions for states of the reinforcement learning agent to favor actions that do not trigger an alert under the one or more scenarios. In one embodiment the probability distributions are adjusted after training episodes during RL agent training based on expected cumulative reward. As discussed herein, alerts cause a significant negative impact on the reward function. For example, actions with lower expected cumulative reward have their selection probability values decreased, and actions with higher expected cumulative reward have their selection probability values increased, thus configuring the probability distributions of actions to favor actions that do not trigger an alerts. Thus, in one embodiment, the processor may configure probability distributions of the available actions for the states through adjustments to the selection probabilities of the actions.
In one embodiment, the step of analyzing the steps taken in the episode to measure the strength of monitoring in the monitoring system (as shown and described above with reference to process block 120) includes determining a number of steps in the episode.
In one embodiment, the step of analyzing the steps taken in the episode to measure the strength of monitoring in the monitoring system (as shown and described above with reference to process block 120) includes determining a number of accounts used for transfer in the episode.
In one embodiment, the monitoring system monitors a financial transaction system, the task is transferring an amount of funds from an originating account into a destination account, and the one or more scenarios include at least one of a rapid movement of funds, high-risk geography, significant cash, or ATM anomaly scenario, as shown and described in further detail herein. For example, in one embodiment, the processor further monitors a financial transaction system with the monitoring system; transfers an amount of funds from an originating account into a destination account to complete the task; and evaluates an action by the reinforcement learning agent with the one or more scenarios, wherein the one or more scenarios include at least one of a rapid movement of funds, high-risk geography, significant cash, or ATM anomaly scenario.
In one example embodiment, the monitoring system is a system configured to monitor a financial transaction system, and the RL agent is configured to operate as an artificial money launderer. In this example, the policy learned by the money laundering RL agent includes, for each state, a probability distribution over a set of fund transfer actions. In this example, an episode is a sequence of states and actions taken to launder funds. Once the policy has been learned, multiple episodes can be sampled from the policy, as follows.
In one example embodiment, the task is to transfer a target amount of funds from an originating account to a destination account. In a first or initial state (SO) of the RL agent, the entire target amount to be transferred to the destination account is in the originating account. This state (SO) is the initial state of an episode. The RL agent then samples an action using the probability distribution over the set of fund transfer actions for the current state. The sampled action is then executed to move the RL agent to a new state resulting from the action. The combination of sampled action and new state are then appended to the current episode.
Where, in the new state, either all funds have been transferred to the destination account without raising any scenario alerts OR the length of the episode exceeds a pre-specified threshold, the current episode is marked complete, and the sampling, execution, appending loop is stopped. Otherwise, the loop continues to repeat until an episode is completed. This loop may be repeated to create multiple episodes.
Additional detail on simulated episode sampling in the context of an example method 900 for RL agent evaluation of monitoring systems is provided herein under the heading “Example Method—Simulated Episode Sampling.”
While details are discussed herein with reference to measuring the strength of financial monitoring systems, in one embodiment, the simulation-based monitoring strength measurement systems and methods described herein may be applied to measuring the monitoring strength of alert-based monitoring systems generally.
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 GUls, 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 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 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, and triggering an alert. 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. 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 GUls, 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) one or more scenarios is triggered by an action of the reinforcement learning agent. (iii) 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, 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.0 § 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.0 § 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.