Embodiments of the present invention relate to risk assessment using Poisson Shelves.
In fraud prevention, it desirable to not only determine if certain transactions are at risk, but to also do so in an accurate and automated fashion. Suppose a customer service center records the number of times a particular phone number calls per day. If the same number calls multiple times over a series of days, is this activity deemed unusual and risky? What criteria should a company apply to automatically determine if calls from one number are more or less risky than other calls? How should a company treat future calls from a risky number? These are the kinds of questions that must be answered daily by security engineers.
Published methods on unsupervised fraud detection span many disciplines, and generally center around clustering and pattern identification [Phua et al., 2010]. More recent surveys of fraud detection methods such as [Lata et al., 2015] contain very few active unsupervised methods. SmartSifter is the most similar to our multivariate methodology, where a mixture model is used to combine different modes in the cumulative data. SmartSifter is primarily used for discovering financial fraud [Yamanishi et al., 2004].
Accordingly, the present invention is directed to risk assessment using Poisson Shelves that obviates one or more of the problems due to limitations and disadvantages of the related art.
Herein, we consider relevant works to our topic and why there is a need for our technique. We then follow with a methodology, considering both the univariate and multivariate cases, where we describe how to obtain partition values, to detect shelves, and what are considered extreme outliers given a shelf. We then apply our technique to IVR call datasets. We finally discuss the implications of our results.
In accordance with the purpose(s) of this invention, as embodied and broadly described herein, this invention, in one aspect, relates to a computer program product comprising computer executable code embodied in a non-transitory computer readable medium that, when executing on one more computing devices performs a method of performing risk assessment using count data. The method includes modeling the count data using a Poisson distribution; calculating a threshold value, ω; partitioning the count data based on the threshold ω; determining a number of surviving records from among the portioned count data based on the threshold ω; identifying at least one shelf in the surviving records; and defining outliers for risk assessment according to the at least one the shelf.
In another aspect, the invention relates to a computer program product of identifying outliers for risk assessment using count data “Records” having y values. The method of this aspect includes computing a sample mean {circumflex over (λ)} of y values in Records; calculating threshold value ω={circumflex over (λ)}+n√{circumflex over (λ)}, from n=0 to nmax, where n is the number of standard deviation units in ω; for every ω, computing a number of surviving records according to |{r∈Records:r[y]>ω}|; identifying at least one shelf in surviving data by identifying an abrupt variation in generative parameters of a sequence of data; and defining outliers for further risk assessment according to {r∈Records:r[y]>{circumflex over (λ)}+n*√{circumflex over (λ)}}.
In yet another aspect, the invention relates to a computer program product of identifying outliers for risk assessment in multivariable count data having a first count variable xi and a second count variable yi. The method of this aspect includes calculating a mixture of independent Poissons: calculating a threshold value ω for every combination of mixture component c and dimension i; identifying at least one shelf in surviving data by identifying an abrupt variation in generative parameters of a sequence of data; defining outliers in component c; and providing a visual representation of the outliers.
In accordance with the purpose(s) of this invention, as embodied and broadly described herein, this invention, in one aspect, a method of performing risk assessment using count data including modeling the count data using a Poisson distribution; calculating a threshold value, ω; partitioning the count data based on the threshold ω; determining a number of surviving records from among the portioned count data based on the threshold ω; identifying at least one shelf in the surviving records; and defining outliers for risk assessment according to the at least one the shelf.
In yet another aspect, the invention relates a method of identifying outliers for risk assessment using count data “Records” having y values, the method including computing a sample mean {circumflex over (λ)} of y values in Records; calculating threshold value ω={circumflex over (λ)}+n√{circumflex over (λ)}, from n=0 to nmax, where n is the number of standard deviation units in ω; for every ω, computing a number of surviving records according to I|{r∈Records:r[y]>ω}|; identifying at least one shelf in surviving data by identifying an abrupt variation in generative parameters of a sequence of data; and defining outliers for further risk assessment according to {r∈Records:r[y]>{circumflex over (λ)}+n*√{circumflex over (λ)}}.
In yet another aspect, the invention relates to a method of identifying outliers for risk assessment in multivariable count data having a first count variable xi and a second count variable yi, the method including calculating a mixture of independent Poissons: calculating a threshold value ω for every combination of mixture component c and dimension i; identifying at least one shelf in surviving data by identifying an abrupt variation in generative parameters of a sequence of data; defining outliers in component c; and providing a visual representation of the outliers.
Additional advantages of the invention will be set forth in part in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. The advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the appended claims. It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the invention, as claimed.
Further embodiments, features, and advantages of the risk assessment using Poisson Shelves, as well as the structure and operation of the various embodiments of the risk assessment using Poisson Shelves*, are described in detail below with reference to the accompanying drawings.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only, and are not restrictive of the invention as claimed.
The accompanying figures, which are incorporated herein and form part of the specification, illustrate risk assessment using Poisson Shelves. Together with the description, the figures further serve to explain the principles of the risk assessment using Poisson Shelves described herein and thereby enable a person skilled in the pertinent art to perform and use risk assessment using Poisson Shelves.
Reference will now be made in detail to embodiments of the risk assessment using Poisson Shelves with reference to the accompanying figures The same reference numbers in different drawings may identify the same or similar elements.
It will be apparent to those skilled in the art that various modifications and variations can be made in the present invention without departing from the spirit or scope of the invention. Thus, it is intended that the present invention cover the modifications and variations of this invention provided they come within the scope of the appended claims and their equivalents.
A method for determining the risk of a record using event frequency is described herein. An example applying the method to an example phone call problem is also described herein. The method is to help fraud and security analysts build systems using frequency in determining when future events may present risk. This method provides easy understanding and visualization for fraud and security analysts that may not have extensive background in statistics and outlier detection methodologies. The technique described herein may be categorized as a pattern recognition algorithm for detecting classes of data that appear to connote risk.
The intuition behind uncovering risk via frequency is best highlighted with a simple example. Consider every credit card transaction to be an event. Over a period of time, say an hour, we may expect to see several transactions for a single, given card. However, if 50 to 100 transactions occur for this card in that hour, the card may be at risk for fraud. Thus, counting the number of events is an intuitive way to determine risk. This intuition may be used to generate a rule for revealing risky records. As another example, consider
The methodology described herein involves modeling these counts using a Poisson distribution and considering various thresholds for partitioning the data. The partitions are based on the mean and standard deviation of the data and also incorporate user choice, as what is considered fraudulent may differ from application to application. Records that are greater than a threshold value are considered surviving records, and plotting threshold parameters against the number of surviving records reveals distinct, shelf-like behavior. We exploit this phenomena to identify extreme outliers in detecting possible cases of fraud. We also modify and apply this methodology for multivariate datasets.
Truly risky calls are rare, and we want to minimize false positives. Thus, we must take special care in classifying the risk of individual calls. For example, suppose that 1 out of 1000 of the calls truly exhibit risky characteristics. Furthermore, suppose there exists a method that we can use to classify risk of calls from a given number with an accuracy of 98% with a false positive rate of 1%. Using this method to classify whether or not a given phone number is risky, what are the chances that the phone number is actually risky? Applying Bayes' Law:
There is less than a ten percent likelihood that a given phone number identified as at risk for fraud is actually at risk under the assumptions given above.
Traditional classification methods (such as decision trees or SVMs) alone can thus be problematic, potentially causing a high likelihood of false positives. The technique described herein provides another level of assessment to pinpoint risky data before application of traditional classification methods of uncovering risk.
The technique described herein involves modeling count data using a Poisson distribution. Partition values are generated using the mean, standard deviation, and user choice. Because a Poisson distribution is used, the mean and variance are equivalent. By counting and plotting the number of data points greater than certain partition values (which we call surviving records), a distinct shelf-like pattern may emerge, which is the basis for our methodology. We begin by considering the univariate case and expand into multivariate data, as described below.
A random variable X has a Poisson distribution with parameter λ>0 if X can have integer values x=0, 1, 2, . . . with probability:
A feature of the Poisson distribution is that the mean (λ) is equivalent to the variance. That is:
E(X)=var(X)=λ
Counting events that occur independently over some period of time is typically modeled using the Poisson distribution. The phone call example discussed above can be modeled using a Poisson distribution.
A process satisfying the following three assumptions:
We will use the parameter from the Poisson distribution, which we obtain from the sample mean of the dataset. Let N represent the number of samples in the time period of interest and xi be a datapoint. We calculate {circumflex over (λ)} by:
We partition the data based on a threshold value, ω:
ω=λ+n×stdev(X)=λ+n√{square root over (λ)}
where n=0, 1, 2, . . . is a standard deviation (stdev) multiplier and is user chosen. By varying the value of n, we can determine the number of data points greater than ω. See Table 1 for the number of surviving records given n for a sample dataset.
Table 1 shows the number of surviving records given n for the sample dataset in
If we plot n against the number of surviving records (see
We define an outlier as a data point that survives after the first shelf. Shelves can be detected by computing the probability distribution of the length of a current “run”. For example, one could consider n=0 to n=26 to be one run and n=27 to n=45 to be another run. At n=27, a changepoint has occurred, where a changepoint is an abrupt variation in the generative parameters of a sequence of data. Herein, we use a Student's t-distribution and the concepts in [Adams and MacKay, 2007] to determine changepoints in our data, however, any suitable method may be used to identify changepoints as used herein, including concept drift detection techniques.
Not every run may be equivalent to a shelf. A linear regression analysis on log counts could be performed to determine if the slope of a run is below a certain threshold. A shelf and its length can also be specified via trial and error or by the user per the needs of the application. For example, a user could argue that, although short, a shelf occurs from n=24 to n=26. One could experiment with different Student's t-distribution parameters or with different members of the exponential distribution family entirely to detect shelves setting the application. Other distributions besides a Student's t-distribution can and should be considered and may be more applicable to survival graphs.
The method described herein can be applied to any univariate count of events satisfying the requirements of a Poisson process. An example, as applied to the phone numbers is described below. We call a function that returns the final n* value of the first detected shelf given a list of n's and corresponding numbers of surviving records shelfDetect( ).
Let Records be defined as follows:
Records={(x, y): phone # x calls y times}
To determine outliers:
1. Compute {circumflex over (λ)}, the sample mean of the y values in Records;
2. From n 0 to nmax, calculate ω={circumflex over (λ)}+n√{circumflex over (λ)};
3. For every ω, compute the # of surviving records:
|{r∈Records:r[y]>ω}|
4. Run shelfDetect( ) to get n*
5. Outliers are defined as:
{r∈Records:r[y]>{circumflex over (λ)}+n*√{circumflex over (λ)}}
An aspect of risk detection is the ability to evaluate the interdependency of multiple count variables. This is a complex problem because multivariate distributions for count data have behaviors that can be difficult to analyze and understand or have severe restrictions. For example, multivariate count models where the marginal distributions are Poisson can only apply to situations where there are positive dependencies between the variables. According to the technique described herein, regardless of the number of multivariate dimensions, a graph of n against the number of surviving records can be produced, as shown in
In [Inouye et al., 2017], several classes of multivariate distributions derived from the univariate Poisson are introduced. The first class where the marginal distributions are Poisson can apply to situations where there are positive dependencies between the variables. Negative relationships are always a possibility in real-world datasets, potentially restricting the use of this option. The second class involves a mixture of independent Poissons:
where x=[x1, x2, . . . xd], d is the dimension of the data, λ=[λ1, λ2, . . . λd] is a vector where λi is the parameter of the Poisson distribution for xi, and g(λ) is the mixing distribution. As we have counting data, we work in the domain of positive, real numbers, notated as R++.
Poisson mixture generalizations allow for positive and negative variable dependencies as opposed to Poisson marginal distributions. They can also model overdispersion where the variance of the data is larger than the mean, a common feature in real world data.
Typically, expectation-maximization is used to refine the parameters of the mixture model, iterating until convergence. For every combination of mixture component c and dimension i, ω can be calculated:
ωic={circumflex over (λ)}ic+n√{square root over ({circumflex over (λ)})}ic
to create the survival graphs like in
Applying this procedure to the phone numbers example once more, let Records now be a set containing elements of the form (x, y1, y2, . . . yd) where phone number x is associated with yi count data. For example, y1 could be how many times phone number x called in the time period, and y2 could be how many social security numbers are referenced by phone number x. Let Recordsc represent the records in component c. An outlier in a component c is then defined as:
{r∈Recordsc:∃i s.t. r[yi]>λic+n*ic√{square root over (λic)}}
where yi is the ith dimension of count data, and n*ic is the final n value of the first detected shelf in the ith dimension for component c.
The methods described herein can be applied to historical call records to surface phone numbers that may have been (or are being) used for fraudulent access to a company's systems. As an example, let's look at the anonymized output of an IVR system servicing a financial company containing 16,819 phone numbers. Historical calls are accumulated and counted in the various columns of data. Some example values appear in Table 2.
Negative relationships are present, deterring use of marginal Poisson distributions in [Inouye et al., 2017].
We apply the process described herein to the data in Table 2 and plot the number of surviving records for every field given n where n is the number of standard deviation units in ω. Survival plots for every field are available in
We focus on the AcctCnt field for now and use [Adams and MacKay, 2007] to determine change points in our data. Using the Python implementation of [Adams and MacKay, 2007] on AcctCnt, the posterior probability (P(rt|x1:t)) of the current run rt's length at each step (xi for i=1. . . t) can be displayed, using a logarithmic color scale (see
Two runs appear to dominate in the second visual of
For AcctCnt, this gives rise to 1 outlier record; this particular phone number has called over 120 times in the span of 1 month! The surviving data past the first shelf exhibits extreme values that are in the long tail of the assumed Poisson distribution, and, thus, are candidates for risk of fraudulent or other aberrant usage.
Looking now at the multivariate case by considering all fields in dataset 1, we begin by fitting the data in Table 2 to a Poisson mixture model using the Python library Pomegranate [Schreiber, 2017]. As we wish to learn distribution parameters entirely from data, we use the from_samples class method which runs k-means to initialize the components. Returned clusters are used to initialize all parameters of the distributions. Thus, we are using a multivariate Gaussian for the mixing distribution, g(λ). [Steyn, 1976] also used multivariate Gaussians for the mixing distribution to provide more flexibility on the correlation structure.
To determine the number of components in the mixture model, the log-likelihood is graphed in
At roughly 10 components, the log-likelihood begins to plateau. We choose 20 components and use posterior probabilities to predict the most likely component which generated each sample. With Pomegranate, this is efficient, taking 56.78 seconds on a laptop with an Intel Core i7-4710MQ CPU @ 2.50 GHz, 16 GB of RAM, running Ubuntu 16.04. The distribution of components is displayed in
As an additional experiment and sanity check on the mixture model, we performed principal component analysis (PCA) to reduce the number of dimensions to 3 and grayscale the points based on the component the point belongs to in
We then use the parameters of the mixture model to determine cv thresholds for every dimension and component. Recall that ωic={circumflex over (λ)}ic+n√{circumflex over (λ)}ic, where {circumflex over (λ)}ic is the parameter of the Poisson distribution for dimension i and component c. Once survival graphs are created for every component and dimension, run shelfDetect( ). A point is an outlier if at least one of its dimensions i contains a shelf and has records surviving the first shelf (r[yi]>{circumflex over (λ)}ic+n*ic√{circumflex over (λ)}ic). Note that n*ic is the final n value of the first detected shelf in the ith dimension and component c.
Then all points in component 15 that have Auth3Cnt values greater than λAuth3Cn̂t, comp 15+2*(λAuth3Cn̂t, comp 15)1/2 are also outliers, and they may be different than the outliers discovered using Auth4Cnt.
We consider another dataset from an IVR system servicing a financial company containing 103,823 phone numbers over the course of a month. This dataset contains several fields not present in the dataset discussed above, and their definitions are provided in Table 3.
The differences between this dataset and the one discussed above highlight advantages of the present methodology. Although both datasets are generated by accumulating call data to an IVR from external phone numbers, they have different IVR call tree structures. A call tree determines the path callers traverse and the exit points available to them. Call trees can be very complex and vary widely in their functionalities. However, the shelf method is the same regardless of the call data collected by the IVR system and the structure of the call tree. This makes the present method useful for discovering risk in a wide variety of datasets and call tree structures. Another difference between the two datasets is that all correlations between the fields in this second dataset are positive, opening up the possibility of class 1 methods (marginal Poisson distributions) in the [Inouye et al., 2017] paper.
In the multivariate case, we once again analyze log-likelihood plots to determine the number of components (10) and use posterior probabilities to assign points to components. The survival graphs in the univariate and multivariate are provided in
We have demonstrated the existence of shelves and have shown that the records that survive the first shelf (phone numbers that exhibit relatively unusual activity) represent outliers compared to the expected regular distribution of calls according to the Poisson assumption.
In some cases, no shelf exists. In these cases, one of two things is true: (1) either the distribution of survivors is very “thin” (i.e., no survivors exhibit extreme counts) or (2) there is a relatively continuous slow drop in the number of survivors as we increase n.
In the first case, our method may not identify any extreme behavior and so, in turn, won't identify any risk in those calls. If the calls still contain risk, then it must be surfaced in a different way. In the second case, we may be missing risk and an addition to our algorithm to analyze the slope of the survivor counts as n changes may be provided to account for very small but continuous-looking shelves in the data.
The data may also exhibit multiple shelves. The algorithm and method presented herein picks the first shelf of a given length, but could be modified to look for the longest shelf, the last shelf of a given length, or provide a selection of such methods for an analyst. The point of picking the first matching shelf is to capture the initial significant deviation from the assumed distribution of survivors. This is a simple and consistent way of separating data that may belong to a different distribution that connotes risk, but the method is not so limited.
We used a mixture model to represent the dependencies between variables of the call data. There are other methods for generating multivariate distributions from count data that could be used in the present process. One interesting method is to use copulas to model the dependencies between the marginal parameters like in [Inouye et al., 2017]. Another possible methodology is to create a series of bivariate Poisson distributions over the call data and look for dependencies that match the marginal distributions.
Other possibilities include acquiring and applying this method to count data in a different domain. We have call data represented as examples herein, but other types of count data could be analyzed using the methodologies described herein. Also, different default distributions besides a Poisson may be used. If the data exhibits strong overdispersion, a negative binomial distribution may be more appropriate as the relationship between the mean and variance can be better controlled. In addition, other distributions instead of a Student's t-distribution may be used for determining shelves, but may be selected depending on whether the graphs, like
We have presented a method for determining potentially risky examples in count data. This method may be unsupervised and provides visual feedback on the results of the algorithm. In the examples provided herein, this method is demonstrated by application to data collected from IVR (Integrated Voice Recognition) systems in the financial industry and to call counts and other parameters related to the IVR call tree specification. In cases where shelves were found, we were able to isolate groups of outlier phone numbers that exhibited behavior indicative of fraud risk. In conjunction with other fraud and risk detection methods, we believe that this method is a powerful addition to a telephone fraud detection system.
The method disclosed herein is novel in the following ways:
The present method differs from others by focusing on a simple algorithm for segregating survival data. The focus is not on calculating the mixture of distributions in the data like Smartsifter, but, instead, on providing tools for security engineers to identify and evaluate sources of potentially fraudulent activity.
Throughout this application, various publications may have been referenced. The disclosures of these publications in their entireties are hereby incorporated by reference into this application in order to more fully describe the state of the art to which this invention pertains:
[Adams and MacKay, 2007] Adams, R. P. and MacKay, D. J. (2007). Bayesian online changepoint detection. arXiv preprint arXiv:0710.3742.
[Inouye et al., 2017] Inouye, D. I., Yang, E., Allen, G. I., and Ravikumar, P. (2017). A review of multivariate distributions for count data derived from the poisson distribution. Wiley Interdisciplinary Reviews: Computational Statistics, 9(3):e1398.
[Kulick, 2016] Kulick, J. (2016). Bayesian changepoint detection. https ://github.com/hildensia/bayesian_changepoint_detection.
[Lata et al., 2015] Lata, L. N., Koushika, I. A., and Hasan, S. S. (2015). A comprehensive survey of fraud detection techniques. International Journal of Applied Information Systems, 10(2):26{32.
[Phua et al., 2010] Phua, C., Lee, V., Smith, K., and Gayler, R. (2010). A comprehensive survey of data mining-based fraud detection research. arXivpreprint arXiv:1009.6119.
[Rodriguez, 2007] Rodriguez, G. (2007). Poisson models for count data. acesso, 10(1):2014.
[Schreiber, 2017] Schreiber, J. (2017). Pomegranate: fast and exible probabilistic modeling in python.
The Journal of Machine Learning Research, 18(1):5992{5997.
[Steyn, 1976] Steyn, H. (1976). On the multivariate poisson normal distribution. Journal of the American Statistical Association, 71(353):233{236.
[Yamanishi et al., 2004] Yamanishi, K., Takeuchi, J.-I., Williams, G., and Milne, P. (2004). On-line unsupervised outlier detection using_nite mixtures with discounting learning algorithms. Data Mining and Knowledge Discovery, 8(3):275{300}.
While various embodiments of the present invention have been described above, it should be understood that they have been presented by way of example only, and not limitation. It will be apparent to persons skilled in the relevant art that various changes in form and detail can be made therein without departing from the spirit and scope of the present invention. Thus, the breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
This application is a non-provisional patent application claiming priority to Provisional Patent Application Ser. No. 62/740,821, filed Oct. 3, 2018 which is hereby incorporated by this reference in its entirety as if fully set forth herein.
Number | Date | Country | |
---|---|---|---|
62740821 | Oct 2018 | US |