Anomaly alert system for cyber threat detection

Information

  • Patent Grant
  • 12126636
  • Patent Number
    12,126,636
  • Date Filed
    Tuesday, December 29, 2020
    4 years ago
  • Date Issued
    Tuesday, October 22, 2024
    2 months ago
Abstract
Disclosed herein is a method for use in detection of anomalous behavior of a device of a computer system. The method is arranged to be performed by a processing system. The method includes deriving values, m1, . . . , mN, of a metric, M, representative of data associated with the device; modeling a distribution of the values; and determining, in accordance with the distribution of the values, the probability of observing a more extreme value of the metric than a given value, in, of the metric, wherein the probability is used to determine whether the device is behaving anomalously. Also disclosed is an equivalent computer readable medium and anomalous behavior detection system.
Description
PRIORITY

This application claims the benefit of priority under 35 USC 120 from U.S. patent application Ser. No. 16/878,347, filed May 19, 2020, titled ‘ANOMALY ALERT SYSTEM FOR CYBER THREAT DETECTION,’ which claims the benefit of priority under 35 USC 120 from U.S. patent application Ser. No. 15/425,906, titled “ANOMALY ALERT SYSTEM FOR CYBER THREAT DETECTION,” filed on Feb. 6, 2017, and issued as granted U.S. Pat. No. 10,701,093 on Jun. 30, 2020, which claims the benefit of Great Britain Application No. GB 1602309.5 filed Feb. 9, 2016, the entire contents of which are hereby incorporated by reference for all purposes.


FIELD

An unsupervised anomaly detection algorithm and its application to the field of cyber threat detection is disclosed. More specifically, but not exclusively, a method for calculating the probability that a device is behaving anomalously is disclosed.


BACKGROUND

As of late 2015 the issue of cyber attacks has, after a series of high profile and damaging hacks, become one of the leading security concerns for both corporations and nation states. As a result the field of cyber security has become increasingly important. Traditional approaches to cyber security rely on signature based approaches where a system is built that looks for behaviors that match those of previously seen attacks. However, these methods fail to offer protection against so called zero-day attacks where an adversary uses a previously unknown exploit to compromise a computer or network.


Traditional deterministic approaches are reliant on the assumption that the difference between what is legitimate activity and what is illegitimate activity can be defined. An expanding set of corporate policy and rules have been written to identify client programs as either compliant or not compliant. However, such deterministic approaches require a vast amount of effort to be spent in constantly updating these rules and signatures, in an attempt to stay up to date with the changing threat environment. The definition of what is legitimate is based on what is known about past attacks. For each successful intrusion, a new rule is written, the signature is updated and the next time that same threat presents itself, access is denied or challenged. This method is effective in defending against known threats that have already been identified. However, it is incapable of responding to fresh threats that are constantly presenting either through minor adjustments to existing vectors or more significant evolution of attack methods. Consequently, current threat detection and prevention systems are still being compromised and are unable to keep out threats.


Furthermore, as the technical defenses that protect our data have become more sophisticated, attackers have increasingly turned their attention to the softest part of the network, the user. Socially-engineered attacks account for over 85% of espionage threat, and were the fastest-growing attack vector of 2012. Attackers use subtle and sophisticated methods to manipulate human users to unwittingly install attacks on their behalf, and traditional technical defenses are rendered impotent within a process where a legitimate user has decided to click on a link in a ‘weaponized’ email or visited a familiar yet now compromised website. These new forms of attack make the problem of detecting threats even harder.


SUMMARY

A cyber threat detection system for computer networks is disclosed. More specifically, a cyber threat detection system that incorporates both a method for detecting potentially malicious network activity and a method for representing the output of anomaly detection algorithms to non-expert users is disclosed.


The inputs of the system may be measurements of network activity which may be generated by a network traffic monitoring system that is capable of extracting the meta-data of packets moving across the network. These measurements of network activity may typically be quantities such as number of packets sent between two endpoints, volume of data transferred, number of connections established etc.


The system may work in several stages. In the first stage the measurements of network activity may be processed to produce behavioral metrics. Two different types of metric may be computed:

    • Metrics that are simple functions of past and present values of the measurements of the network activity. These may be; the raw measurements, moving averages/exponentially weighted averages of the measurements, well known mathematical functions of the measurements such as square root and logarithm and moving averages/exponentially weighted averages of well known mathematical functions of the measurements.
    • Metrics that are the outputs of anomaly detection algorithms applied to the first type of metric. Some examples of anomaly detection algorithms used are; one class support vector machine (SVM), local outlier factor and probabilistic outlier modelling.


The first type of metrics may be referred to as network metrics and the second type as derived metrics.


In the second stage of the system time series data of each individual behavioral metric may be analyzed and a mathematical model of what is considered to be normal behavior for that metric may be constructed for each device on the network. The third stage of the system may comprise analyzing the activity of each network device in real time to detect anomalous behavior. This may be done by first processing the new network activity measurement of each device to compute the values of the corresponding behavioral metrics. These values may then be analyzed to see how anomalous the value of each metric is. Finally the levels of anomalousness of the values of each behavioral metric of a device may be combined to produce a measure of the overall anomalousness of the behavior of each device. Network system administrators/security officers may be sent alerts about any device whose behavior is determined to be sufficiently anomalous. The outputs of the machine learning algorithms can be technical in nature and difficult for someone without sufficient mathematical expertise to interpret, therefore, a method of using the weight of evidence of a posterior probability of anomalous behavior to represent the significance of a result is disclosed.


In summary, a method for use in detection of anomalous behavior of a device of a computer system, the method arranged to be performed by a processing system is disclosed, the method comprising: deriving values, m1 . . . , mN, of a metric, M, representative of data associated with the device where N denotes the number of available observations of the metric; modelling a distribution of the values; and determining, in accordance with the distribution of the values, the probability of observing a more extreme value of the metric than a given value, m, of the metric, wherein the probability is used to determine whether the device is behaving anomalously.


The probability of observing a more extreme value may be the probability of observing a greater value than the given value, m, when the given value is greater than a suitable quantile point of the values, m1, . . . , mN; and/or wherein the probability of observing a more extreme value is the probability of observing a smaller value than the given value, m, when the given value is less than a suitable quantile point of the values, m1 . . . , mN.


The method may further comprise determining, in accordance with the probability of observing a more extreme value, and a probabilistic model of the device, a posterior probability of the given value, m, being the result of anomalous behavior of the device, wherein the posterior probability is used to determine whether the device is behaving anomalously.


The method may yet further comprise: determining posterior probabilities for one or more given values, of one or more of a plurality of metrics, Mi, wherein the metrics, Mi, iϵ{1, . . . , n}, are representative of data associated with the device; and in accordance with the posterior probabilities for given values, mi determining an overall posterior probability of the device being in an anomalous state, wherein the overall posterior probability is used to determine whether the device is behaving anomalously.


The probabilistic model may be a Bayesian model.


The metrics, Mi, may be assumed to be statistically dependent, the statistical dependencies modelled using copulas.


The method may comprise calculating transformed variables, z1, . . . , zn, wherein the transformed variables are such that z1, . . . , zn−1(P(M1>m1)), . . . , Φ−1(P(Mn>mn)) wherein Φ denotes a cumulative distribution function of the standard normal distribution and P(Mi>mi) is the probability of observing a greater value than the given value, mi.


The method may comprise calculating transformed variables, z1, . . . , zn, wherein the transformed variables are such that: z1, . . . , zn−1(P(M1<m1)), . . . , Φ−1(P(Mn<mn)) wherein Φ denotes a cumulative distribution function of the standard normal distribution and P(Mi<mi) is the probability of observing a smaller value than the given value, mi.


A logarithm of the Bayes factor, log






(


P


(
A
)



1
-

P


(
A
)




)





may be used to describe a measure of anomalousness of the device, where P(A) is the posterior probability or overall posterior probability.


The measure of anomalousness of the device may be determined relative to a reference measure of anomalousness. The measure of anomalousness of the device may be attenuated above a given level. The distribution of the values of the metric may be modelled using extreme value theory. The distribution of the values of the metric may be modelled as a generalized Pareto, Gumbel or Fréchet distribution. The probabilities may be modelled using a peaks over thresholds method. The data associated with the device may comprise network traffic data of the computer system. Anomaly detection may be performed using a subset, M1, . . . , Mn′, of the metrics, M1, . . . , Mn, where n′≤n.


The subset, M1, . . . , Mn′, of the metrics, M1, . . . , Mn, where n′≤n, may be chosen by removing values for which P(Mi>mi) exceeds a threshold probability, where P(Mi>mi) is the probability of Mi>mi.


The subset, M1, . . . , Mn′, of the metrics, where M1, . . . , Mn, where n′≤n, may be chosen by removing values for which P(Mi<mi) exceeds a threshold probability, where P(Mi<mi) is the probability of Mi<Mi.


The posterior probability that the given value m of the metric M is the result of anomalous behavior of the device, PM(A), may be given by:








P
M



(
A
)


=


π


(
A
)





π


(
N
)




P


(

M
>
m

)



+

π


(
A
)









where π(A) and π(N) denote prior probabilities that the given value, m, of the metric, M, is the result of anomalous or normal behavior of the device, respectively, and P(M>m) is the probability of M>m.


The posterior probability that the given value m of the metric M is the result of anomalous behavior of the device, PM(A), may be given by:








P
M



(
A
)


=


π


(
A
)





π


(
N
)




P


(

M
<
m

)



+

π


(
A
)









where π(A) and π(N) denote prior probabilities that the given value, m, of the metric, M, is the result of anomalous or normal behavior of the device, respectively, and P(M<m) is the probability of M<m.


The combined posterior probability that the device is in an anomalous state, Pd(A), may be given by:








P
d



(
A
)


=

1
-





π


(
N
)




P


(


M
i

>

m
i


)






π


(
N
)




P


(


M
i

>

m
i


)



+

π


(
A
)











where it π(A) and π(N) denote prior probabilities that the given value, mi, of the metric, Mi, is the result of anomalous or normal behavior of the device, respectively, and P(Mi>mi) is the probability of Mi>mi.


The combined posterior probability that the device is in an anomalous state, Pd(A), may be given by:








P
d

(
A
)

=

1
-





π

(
N
)



P

(


M
i

<

m
i


)





π

(
N
)



P

(


M
i

<

m
i


)


+

π

(
A
)










where π(A) and π(N) denote prior probabilities that the given value, mi, of the metric, Mi, is the result of anomalous or normal behavior of the device, respectively, and P(Mi≤<m) is the probability of Mi<mi.


The combined posterior probability that the device is in an anomalous state, Pd (A), may be given by:








P
d

(
A
)

=

1
-




i
=
1

n




π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)










where Pσ(i) denotes

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1)),


Z denotes the transformed variables, z1, . . . zn, σ denotes a permutation of the indexes i, {1, . . . n}, and π(A) and π(N) denote prior probabilities that the given value, mi, of the metric, Mi, is the result of anomalous or normal behavior of the device.


The permutation of indexes i, {1, . . . , n}, may maximize the value of Pd(A). The suitable quantile point may be the median.


In another arrangement, a method for use in detection of anomalous behavior of a device of a computer system is provided. The method is arranged to be performed by a processing system, may comprise: deriving values, m1, . . . , mN, of a metric, M, representative of data associated with the device; optionally modelling a distribution of the values; and further optionally determining, in accordance with the distribution of the values, the probability of a given value, m, being exceeded, P(M>m), wherein the probability is used to determine whether the device is behaving anomalously.


Alternatively, a method for use in detection of anomalous behavior of a device of a computer system, the method arranged to be performed by a processing system, may comprise: deriving values, m1, . . . , mN, of a metric, M, representative of data associated with the device; optionally modelling a distribution of the values; and optionally determining, in accordance with the distribution of the values, the probability of observing a more extreme value than a given value, m, wherein the probability is used to determine whether the device is behaving anomalously; further optionally, wherein the probability of observing a more extreme value is the probability of observing a greater value than the given value, m, when the given value is greater than a suitable quantile point of the values, m1, . . . , mN; and/or wherein the probability of observing a more extreme value is the probability of observing a smaller value than the given value, m, when the given value is less than a suitable quantile point of the values, m1, . . . , mN. A suitable quantile point may be the median.


When the probability of observing a more extreme value than a given value, in, is the probability of observing a greater value than the given value when the given value is greater than a suitable quantile point of the values, m1, . . . , mN, the suitable quantile point may be the median, the 75% quartile or the 90% quartile.


According to another aspect of the claimed invention, there is provided a computer readable medium comprising computer readable code operable, in use, to instruct a computer to perform any method disclosed herein.


According to another aspect of the claimed invention, there is provided an anomalous behavior detection system comprising a processor, and a memory comprising computer readable code operable, in use, to instruct the processor to perform any method disclosed herein.


When the probability of observing a more extreme value than a given value, in, is the probability of observing a smaller value than the given value when the given value is smaller than a suitable quantile point of the values, m1, . . . , mN, the suitable quantile point may be the median, the 25% quartile or the 10% quartile.


Values may be considered to be extreme if they are unusually small or unusually large. Values may be considered to be unusually small if, for example, they fall far below a suitable quantile point. Values may be considered to be unusually large if they fall far above a suitable quantile point. An observation or given value in of some metric M may be considered to be extreme if either of the tail probabilities

P(M>m),P(M<m)


are sufficiently small. Depending on the size of the network, sufficiently small may be if either of the tail probabilities are below some value in the range of 10−2 to 10−7.





BRIEF DESCRIPTION OF THE DRAWINGS

Arrangements will now be described with reference to the drawings in which:



FIG. 1 illustrates a network of computer systems 100 using an anomalous behavior detection system; and



FIG. 2 illustrates an example of a high level structure of an anomalous behavior detection system.





Throughout the description and the drawings, like reference numerals refer to like parts.


SPECIFIC DESCRIPTION

An anomalous behavior detection system will now be disclosed. First, a method of modelling the distribution of values of metrics, using extreme value theory, is disclosed. The metrics are representative of data associated with a device of a computer system, such as a network of computers. The distribution is then used to calculate the survival probabilities of observations of values of the metric. The survival probability is the probability of observing a more extreme value than the observed value, for example, the probability of a large value being exceeded or vice versa. A probabilistic model of the device of the computer system is then described. Subsequently, a method of calculating the probability that the device is behaving abnormally is disclosed, wherein the probability is calculated in accordance with observed given values and the probabilistic model. Furthermore, a method of using copulas to describe the dependencies between metrics is described.



FIG. 1 illustrates a network of computer systems 100 using an anomalous behavior detection system. The system depicted by FIG. 1 is a simplified illustration which is provided for ease of explanation.


The network 100 comprises a first computer system 10 within a building, which uses the anomalous behavior detection system to detect anomalous behavior and thereby attempt to prevent threats to computing devices within its bounds. The first computer system 10 comprises three computers 1, 2, 3, a local server 4, and a multifunctional device (MFD) 5 that provides printing, scanning and facsimile functionalities to each of the computers 1, 2, 3. All of the devices within the first computer system 10 are communicatively coupled via a Local Area Network 6. Consequently, all of the computers 1, 2, 3 are able to access the local server 4 via the LAN 6 and use the functionalities of the MFD 5 via the LAN 6.


The LAN 6 of the first computer system 10 is connected to the Internet 20, which in turn provides computers 1, 2, 3 with access to a multitude of other computing devices including server 30 and second computer system 40. Second computer system 40 also includes two computers 41, 42, connected by a second LAN 43.


In this arrangement, computer 1 on the first computer system 10 has the anomalous behavior detection system and therefore runs the anomalous behavior detection method for detecting anomalous behavior of the first computer system. As such, it comprises a processor arranged to run the steps of the process described herein, memory required to store information related to the running of the process, as well as a network interface for collecting the required information. This method shall now be described in detail with reference to FIG. 1.


The computer 1 builds and maintains a dynamic, ever-changing model of the ‘normal behavior’ of each device within the system 10, based on the distribution of metrics. The approach is based on a Bayesian probabilistic model, described in more detail below, and monitors all interactions, events and communications within the system 10—which computer is talking to which, files that have been created, networks that are being accessed.


For example, computer 2 is based in a company's San Francisco office and operated by a marketing employee who regularly accesses the marketing network, usually communicates with machines in the company's U.K. office in second computer system 40 between 9.30 a.m. and midday, and is active from about 8.30 a.m. until 6 p.m. The same employee virtually never accesses the employee time sheets, very rarely connects to the company's Atlanta network and has no dealings in South-East Asia. The anomalous behavior detection system takes all the information that is available relating to this employee and establishes a ‘pattern of life’ for that person, which is dynamically updated as more information is gathered. The ‘normal’ model is used as a moving benchmark, allowing the system to spot behavior of a device that seems to fall outside of this normal pattern, and flags this behavior as anomalous, requiring further investigation.


The high level structure of the anomaly alert system is illustrated in FIG. 2. A network traffic monitor 110 extracts meta-data of packets moving across a network 100.


In the next stage the measurements of network activity are processed to produce behavior metrics 120. Two different types of metric may be computed: network metrics 130 and derived metrics 140. These are fed to the anomaly alert system 200.


In the next stage, historical data 150 of each individual behavior metric may be analyzed. A mathematical model of what is considered to be normal behavior 170 for that metric is constructed for each device on the network from historical data. The third stage of the system comprises receiving new observations 160 and analyzing the new observations of the activity of each network device in real time 180 to detect anomalous behavior. This is done by first processing the new network activity measurement of each device to compute the values of the corresponding behavioral metrics. These values are then analyzed to see how anomalous the value of each metric is. Finally the levels of anomalousness of the values of each behavioral metric of a device are combined to produce a measure of the overall anomalousness of the behavior of each device. Network system administrators/security officers 210 may be sent alerts 190 about any device whose behavior is determined to be sufficiently anomalous.


The anomaly alert system consists of at least two innovations:

    • a method for detecting anomalies in datasets.
    • an approach to visualizing probabilities that allows a user to easily rank the importance of different alerts and control the rate of false alerts.


To begin, an explanation of the behavioral metrics 120, which form the input of the anomaly alert system 200, will be given.


Computation of the Behavioral Metrics

The behavioral metrics are computed from data sampled by the network traffic monitoring system. As described above there are two types of metric, network metrics and derived metrics. The network metrics may include:

    • Total volume of data flowing from a device in a given time interval.
    • Total volume of data flowing to a device in a given time interval.
    • Number of connections from a device to other devices on the network in a given time interval.
    • Number of connections to a device from other devices on the network in a given time interval.
    • Number of connections from a device to other devices outside the network in a given time interval.
    • Number of connections to a device from other devices outside the network in a given time interval.
    • Number of DNS requests made by a device in a given time interval.
    • Number of multicasts made by a device in a given time interval.
    • Number of broadcasts made by a device in a given time interval.
    • Number of attempts made by a device to connect to closed ports on other devices in a given time interval.
    • Number of server message block (SMB) read requests made by a device in a given time interval.
    • Number of SMB write requests made by a device in a given time interval.
    • Number of failed SMB requests made by a device in a given time interval.
    • Number of attempts at authentication (e.g. Kerberos) made from a device in a given time interval.
    • Number of failed attempts at authentication (e.g. Kerberos) made from a device in a given time interval.
    • Square root transforms of any of the above metrics.
    • Logarithmic transforms of the form log(a+⋅) for any a>0 of any of the above metrics.


The derived metrics are the results of anomaly detection algorithms applied to subsets of the network metrics. Anomaly detection algorithms may include:

    • One class SVM.
    • Local outlier factor.
    • Probabilistic outlier modelling. In this method a mixture model or kernel density estimate is used to model the density of the observations. The density of new observations is then computed using this model and used to give an estimate of how anomalous the new observation is. In practice the reciprocal of the density may be used as this gives a score that increases with more anomalous (i.e. lower density) observations.
    • Markov transition models.


The network and derived metrics form the inputs of the threat alert system that is detailed in the remaining sections.


A Bayesian Framework for Anomaly Detection

A systematic framework for detecting anomalous behavior in network devices will now be disclosed.


The problem of detecting anomalous behavior of network devices given the values of a collection of real valued metrics M1, . . . , mn for each device is considered. The framework for anomaly detection is based on the idea that users of anomaly detection systems may be looking to be alerted to values of metrics that are extreme in some way. If the data is real valued then extreme must mean either unusually large or unusually small. Values may be considered to be unusually small if, for example, they fall far below a suitable quantile point. Values may be considered to be unusually large if they fall far above a suitable quantile point. It follows that an observation or given value m of some metric M is anomalous if either of the tail probabilities

P(M>m),P(M<m)

are sufficiently small. Depending on the size of the network, sufficiently small may mean if the tail probabilities are below some value in the range of 10−2 to 10−7. To simplify the mathematics the anomaly detection system will only consider tail probabilities of the form

P(M>m).  (1)


Tail probabilities of the form

P(M<m)

may also be considered or alternatively can be incorporated by looking instead at the tail probability

P(−M>−m)


It may be preferable to consider tail probabilities of the form P(M>m) when an observation m is greater than a suitable quantile point of the value of the metric M, and consider tail probabilities of the form P(M<m) when an observation m is less than a suitable quantile point the value of the metric M.


Before one can apply the above insight in a systematic manner one must overcome the following technical difficulty. To be able to compute the tail probabilities (1) an estimate of the distribution of the metric M which will typically be derived from historical observations of its values is needed. However when computing (1) in the context of anomaly detection the most significant parts of the distribution of M may be those far in the tails, typically well outside the range of any historical data points. Thus to be able to use (1) effectively a method for extrapolating the tails of a distribution beyond the range of the available set of observations is needed. To achieve this, extreme value theory is used. In particular, the method of Peaks Over Thresholds (POT) is used for estimating tail probabilities and quantiles from observed data.


Below, a brief overview of extreme value theory is given. Later a method for using the POT method to compute tail probabilities of the form (1) is detailed. Then a method for computing the probability that an observation in of a single metric M was generated by anomalous behavior given the tail probabilities (1) is detailed. Then a method for computing the probability that a device is in an anomalous state given the values of a collection of behavioral metrics M1, . . . , Mn is disclosed. Finally, the ideas of these preceding sections are tied together and a framework for detecting anomalous behaviors in real valued data is detailed.


A Brief Introduction to the Theory of Extreme Values

The theory of extreme values may be used for modelling the probabilities of events that lie far into the tails of a distribution, typically beyond the range of any empirical data. Extreme value theory shows that under suitable conditions the probabilities of extreme events can be related to members of the family of generalized extreme value distributions defined by the cumulative distribution functions








F
ξ

(
x
)

=

{




exp

(

-


(

1
+

ξ

x


)



-
1

/
ξ



)





if


ξ


0






exp

(

-

exp

(
x
)


)





if


ξ

=
0










where 1+ξx>0 and is a modelling parameter that must be selected in a data dependent fashion. In particular it can be shown that for any probability P that lies in the maximal domain of attraction of a member of the family of generalized extreme value distributions the exceedance probabilities of P can be described in the following manner.


Let X be a random variable with distribution P and let Pu=P(X−u|X≥u) denote the conditional distribution of X−u given that the value of X exceeds an arbitrary threshold, u. If P belongs to the maximal domain of attraction of a member of the family of generalized extreme value distributions then it can be shown that







lim

u





P
u






belongs to the family of generalized Pareto distributions (GPDs) with cumulative distribution functions








F

ξ
,
σ


(
x
)

=

{




1
-


(

1
+

ξ


x
/
σ



)



-
1

/
ξ







if


ξ


0






1
-

exp

(


-
x

/
σ

)






if


ξ

=
0










where

x≥0 if ξ≥0,
0≤x≤−σ/ξ if ξ<0.


This result motivates the POT method to modelling the tails of a distribution. Given a random variable X with distribution P and a sequence of observations x1, . . . , xK ordered so that x1< . . . <xK, the tail of the distribution can be modelled in the following manner.


1. Choose a suitable 1≤k≤K.


2. Estimate the probability P(X>xk) by








K
-
k

K

.




3. Model the conditional probability P(X−xk|X>xk) by fitting a GPD to the observations xk+1, . . . , xK.


4. For any x, estimate P(X>x) by using the empirical distribution if x≤xk and using the estimates of P(X>xk) and P(X−xk|X>xk) computed in steps 2 and 3 above if x>xk.


The key to POT modelling is the choice of k. A method for using the POT method to compute tail probabilities of observations will now be presented.


An Algorithm for Computing Tail Probabilities of Metrics

A method for using the POT method to compute tail probabilities of the form (1) for some real valued metric M will now be presented. In order to make the ideas in this section rigorous the following assumption is made.


Assumption 1 The distribution of the metric M belongs to the maximal domain of attraction of an extreme value distribution.


Under the conditions of this assumption one can compute the tail probabilities for a metric M in the following manner.


Algorithm 1 Assume that Assumption 1 holds.


Model Fitting


1. Given a set of observations mi, . . . , mN of the metric M use a suitable POT fitting method to find

    • a threshold u.
    • an estimate {circumflex over (P)}(M>u) of the tail probability (1).
    • an estimate {circumflex over (ξ)},{circumflex over (σ)} of the parameters of the GPD that describes the conditional distribution P(M−u|M>u).


Anomaly Detection

1. Given an observation m

    • compute the tail probability P(M>m) using the empirical distribution of m1, . . . , mN if m≤u and

      {circumflex over (P)}(M>u)F{circumflex over (ξ)},{circumflex over (σ)}(m−u)

      otherwise.
    • return

      P(M>m)

      as a measure of the anomalousness of the value of m.


The observation in may or may not have been used to model the distribution of m1, . . . , mN. That is to say, in may or may not belong to m1 . . . , mN. It may be preferable to model the tail probabilities (1) using a restricted set of the set of GPDs. In many cases one may want to assume that the probabilities P(M>u) belong to either the Gumbel or Frëchet family of distributions (equivalent to assuming that ξ≥0). Moreover when computing the distribution of the tail probabilities (1) it may be desirable to avoid having the estimates of the tail parameters skewed by any outliers in the observations. This may be done by either discarding a certain fraction of the largest observations or by employing some kind of M-estimator.


A Bayesian Algorithm for Computing Anomaly Probabilities from Tail Probabilities

A method for computing the probability that an observation in of a metric M was generated by anomalous behavior given the tail values (1) will now be presented.


This method is based on the following probabilistic model. Given an observation in of a metric M the behavior that generated it can be either anomalous or normal. Let π(N) and π(A) denote the prior probabilities that the value in is the result of normal or anomalous behavior respectively. Later, a method for selecting the values of the priors in the context of network anomaly detection is described. For the moment it will be assumed that they have been given sui generis.


Given the priors it π(N) and π(A) one can then derive the posterior probability, i.e. the conditional probability that is assigned after the relevant evidence or background is taken into account, of the behavior that generated the value of M being normal or anomalous respectively using Bayes theorem as follows. Given an event E the posterior probabilities of the generating behavior being normal or anomalous are












P
M

(
N
)

=



π

(
N
)



P

(

E
|
N

)





π

(
N
)



P

(

E
|
N

)


+


π

(
A
)



P

(

E
|
A

)










P
M

(
A
)

=




π

(
A
)



P

(

E
|
A

)





π

(
N
)



P

(

E
|
N

)


+


π

(
A
)



P

(

E
|
A

)




.






(
2
)








where P(E|N) and P(E|A) denote the probabilities of the event E given that the generating behavior is normal or anomalous respectively. In light of the discussion above a natural choice of event E may be the set of all possible behaviors such that the value of M is greater than the observed value m.


From this it immediately follows that

p(E|N)=P(M>m).  (3)

Note that this formulation gives meaning to the statement that the tail probabilities (1) measure the significance of a value of a metric M. To derive a value for P(E|A), the following argument is made.


The probability P(M>m|A) for some m∈custom character can be thought of as the probability that M>m given the class of all possible models of anomalous behavior. Formally, this could be expressed by saying that










P

(


M
>
m

|
A

)

=




Ω



p

(

x
>
m

)



μ

(

d

p

)






Ω


μ

(

d

p

)







(
4
)








where Ω is the space of probability measures on custom character and μ is a positive measure defined on Ω. If μ was a finite measure on Ω then it would follow that

limm→∞P(M>m|A)=0

which would imply that the anomaly model would fail to explain the full set of possible anomalies. Since this is clearly unsatisfactory it must follow that the measure μ is not finite but σ-finte. If μ is σ-finite then ensuring that (4) remains well defined requires delicate care. Essentially what one has to do is define P(M>m|A) as a limit of the form










lim

ι









Ω
i




p

(

x
>
m

)



μ

(

d

p

)







Ω
i



μ

(
dp
)







(
5
)








where Ω1, . . . is a monotonically increasing sequence of subsets of Ω such that μ(Ωi)<∞ for all i and lim→∞Ωi=Ω. However the limit in (5) is only well defined if it does not depend on the choice of the sequence Ω1, . . . . This is only possible if for any real number m there exists a real number ym∈[0,1] such that for all ε>0

μ(p∈Ω|p(x>m)∉[ym−ε,ym+ε])<∞.

It follows from this that (5) may define an improper probability distribution, i.e. a probability distribution whose cumulative distribution function F has the property that









lim

x


-





F

(
x
)


>

0



and
/
or








lim

x





F

(
x
)


<

1
.







This allows a mathematical form to be given to the intuition that the anomaly model should be agnostic as to which type of anomaly is more likely. Formally, this requirement can be expressed as

P(M>m|A)=P(M>n|A)

for all m,n∈custom character from which it follows that

P(M>m|A)=c  (6)

for all m∈custom character for some constant c∈(0,1]. However note that that when the results in (2), (3) and (6) are combined, the constant c can be absorbed into the priors π(N) and π(A) and hence it can always be assumed that P(E|A)=1. This gives the following algorithm for computing the posterior probability of the value of a behavioral metric being anomalous


Algorithm 2 Let π(N) and π(A) denote the prior probabilities that the behavior generating an observed value of the metric M is normal or anomalous respectively. Then the posterior probabilities that the underlying behavior generating an observation m is normal or anomalous are given by









P
M

(
N
)

=



π

(
N
)



P

(

M
>
m

)





π

(
N
)



P

(

M
>
m

)


+

π

(
A
)









P
M

(
A
)

=



π

(
A
)




π

(
N
)



P

(

M
>
m

)


+

π

(
A
)



.







The tail probabilities P(M>m) can be computed using Algorithm 1.


A Bayesian Framework for Computing Anomaly Probabilities for Network Devices

In this section the problem of computing the probability that a network device is behaving anomalously given the values of a collection of real valued behavioral metrics M1, . . . , Mn, is considered. First, one option for what it means for a device to be behaving anomalously is defined.


Definition 1 A network device d is behaving anomalously if and only if one or more of the observed values of the metrics M1, . . . , Mn (more specifically one or more of the underlying behaviors generating the values of these metrics) are anomalous.


Note that this definition explicitly acknowledges the GIGO (garbage-in-garbage-out) principle, that is to say, no matter how good the post-processing, an anomaly detection system is ultimately no better than the features that it analyses.


To simplify the exposition, first the method in the special case where the metrics are statistically independent will be described.


Computing Anomaly Probabilities of Network Devices Using Independent Metrics

The following assumption is made.


Assumption 2 The metrics M1, . . . , Mn are statistically independent.


Under the conditions of Assumption 2, Definition 1 leads to an algorithm for computing the probability that a device is in an anomalous state. For a device d let Pd(N) and Pd(A) denote the probabilities that it is in a normal or anomalous state respectively. Furthermore for each i let PiM(N) and PiM(A) denote the probabilities that the behavior generating the value of metric M is normal or anomalous respectively. Then from Definition 1 and Assumption 2 it follows that

Pd(N)=ΠPiM(N),
Pd(A)=1−ΠPiM(N)

The anomaly probabilities PiM(A) can all be computed using Algorithm 2. This leads to the following algorithm for fusing the outputs of multiple independent anomaly detection algorithms:


Algorithm 3 Assume Assumption 2 holds. For each i let π(N) and π(A) denote the prior probabilities that the behavior generating the value of a behavioral metric Mi is normal or anomalous respectively. Moreover let Pd (N) and Pd(A) denote the probabilities that device d is in a normal or anomalous state respectively. Then given observations m1, . . . mn the probabilities Pd (N) and Pd(A) can be computed using the formula












P
d

(
N
)

=





π

(
N
)



P

(


M
i

>

m
i


)





π

(
N
)



P

(


M
i

>

m
i


)


+

π

(
A
)





,




P
d

(
A
)

=

1
-





π

(
N
)



P

(


M
i

>

m
i


)





π

(
N
)



P

(


M
i

>

m
i


)


+

π

(
A
)










(
7
)








with the quantities

P(Mi>mi)

estimated using the method detailed in Algorithm 1.


Computing Anomaly Probabilities of Network Devices Using Possibly Dependent Metrics

Earlier a method for computing the probability that a network device is behaving anomalously given the values of a collection of statistically independent metrics was described. An algorithm that allows the same objective to be achieved when the assumption of statistical independence is dropped will now be described.


It is first observed that the quantities P(Mi>mi) are themselves uniform random variables. Using U to denote the random variable P(Mi>mi) and noting that

P(Ui≤P(Mi>mi))=P(Mi>mi)

it seems natural to replace the quantities P(Mi>mi) in (7) with the quantities

P(Ui≤P(Mi>mi)|U1=P(M1>m1), . . . ,Ui−1=P(Mi−1>mi−1)  (8)

to account for the dependencies between them. However to ensure that any significant anomalies are not ‘explained away’ by conditioning on other less significant exceedance probabilities, a permutation σ of {1, . . . , n} such that the reordering of the metrics given by M′i=Mσ(i) maximizes the value of Pd(A) in (7) should first be found. This is computationally expensive. An alternative method of doing this is using a greedy procedure whereby the permutation σ is chosen so that it has the property that

P(U′i≤P(M′i>m′i)|U′1=P(M′1>m′1), . . . ,U′i−1=P(M′i−1>m′i−1)≤P(Ukk≤P(M′k>m′k)|U′1=P(M′1>m′1), . . . ,U′i−1=P(M′i−1>m′i−1))  (9)

for all k∈{i+1, . . . , n}. In practice one may want to compute (7) using only a subset of the random variables Ui that are below some threshold probability. This may reduce processing time or memory requirements.


In order to put this into practice it is first necessary to be able to efficiently compute the conditional probabilities (8). This requires a suitable model of the dependencies between the different metrics. A key aspect of this method is to use the concept of copulas to model these dependencies. This may allow for efficient modelling of these dependencies and so reduce processing time or memory requirements. A brief review of copulas will now be presented.


Modelling Dependencies Using Copulas

A copula C is a joint cumulative distribution function

C(u1, . . . ,un)=P(U1≤u1, . . . ,Un≤un)

of a collection of random variables Up . . . , Un with uniform marginal distributions. The theoretical foundation of the use of copulas is Sklar's theorem which states that every multivariate cumulative distribution function

F(z1, . . . ,zn)=P(Z1≤z1, . . . ,Zd≤zn)

of a collection of random variables Z1, . . . , Zn can be expressed in terms of the marginals Fi(zi)=P(Zi≤zi) as

F(z1, . . . ,zn)=C(F1(z1), . . . ,Fn(zn))

where C is a suitable copula.


The power of the copula method is that there are a wide range of parametric families of copulas which together provide users of copulas with a way of modelling a broad range of different statistical dependencies. A suitable choice of copula for modelling the dependencies between the exceedance probabilities of different behavioral metrics will now be given.


A Suitable Choice of Copula

Ideally, a copula should be both effective at capturing dependencies and allow for efficient computation of the conditional probabilities (8). One copula that fits both these criteria is the Gaussian copula

CRGauss(u1, . . . ,un)=ΦR−1(u1), . . . ,Φ−1(un))  (10)

where Φ is the cumulative distribution function of the standard univariate normal with mean zero and variance one and ΦR is the cumulative distribution function of the multivariate normal distribution with standard normal marginals and correlation matrix R


When fitting the parameters of this model it may be desirable to be careful to avoid introducing spurious correlations in the correlation matrix R. To achieve this model sparsity a lasso penalty may be imposed on the off diagonal coefficients of R. In practice it may be necessary to allow for random errors in the computation of the metrics Mi due to computational issues such as the network traffic monitor dropping packets. As a result when fitting R a suitably regularized version of the empirical correlation matrix may be used.


To find the coefficients of R under the lasso penalty the ISTA algorithm with backtracking which is outlined below in Algorithm 4 is used.


Algorithm 4 (Backtracking ISTA) Given two positive definite matrices A and B, a penalty A and a penalty matrix P define

F(M)=tr(AM)+tr(M−1B)+λ∥P*M∥1

where * denotes elementwise multiplication and








Q
L

(


M
1

,

M
2


)

=


tr

(


A

-
1




M
2


)

+

tr

(


M
2

-
1



B

)

+



(


M
1

-

M
2


)

T



(

A
-


M
2

-
1



B


M
2

-
1




)


+


L
2







M
1

-

M
2




2


+

λ






P
*

M
1




1

.








Let S denote the soft thresholding operator defined by

S(U,V)i,j=sgn(Ui,j)(|Ui,j|−Vi,j)+

for any two matrices U, V. Then the solution to the minimization problem






arg


min
M



F

(
M
)






can be solved in the following manner


1. Initialize the estimate of M with M0=A.


2. Repeat until convergence

    • Find the smallest nonnegative integer k such that







F

(

S

(



M
i

-


1

2
k




(

A
-


M
i

-
1



B


M
i

-
1




)



,



log

N



2
k


N



P


)

)




Q

1

2
k



(


S

(



M
i

-


1

2
k




(

A
-


M
i

-
1




BM
i

-
1




)



,



log

N



2
k


N



P


)

,

M
i



)







    • Set Mi+1 equal to









S

(



M
i

-


1

2
k




(

A
-


M
i

-
1



B


M
i

-
1




)



,



log

N



2
k


N



P


)




This leads to the following procedure for fitting the parameters of the copula (10). First, given a sequence (u1,1, . . . , u1,n), . . . , (uN,1, . . . , uN,n) of observations of the uniform random variables whose dependency structure is to be modelled, compute the sequence of transformed variables













(


z

1
,
1


,
...

,

z

1
,
n



)

=

(



Φ

-
1


(

u

1
,
1


)

,
...

,


Φ

-
1


(

u

1
,
n


)


)
















(


z

N
,
1


,
...

,

z

N
,
n



)

=


(



Φ

-
1


(

u

N
,
1


)

,
...

,


Φ

-
1


(

u

N
,
n


)


)

.









Then use backtracking ISTA (Algorithm 4), applied to a regularized version of the empirical correlation matrix to obtain a sparse estimate of the correlation matrix R.


Putting all these steps together leads to the following parameter fitting algorithm.


Algorithm 5


Model Fitting Given a regularization parameter 0<δ<1, a lasso penalty λ>0 and a sequence (u1,1, . . . , u1,n), . . . , (uN,1, . . . , uN,n) of historical observations of the uniform random variables whose dependency structure is to be modelled


1. Compute the sequence of transformed variables













(


z

1
,
1


,
...

,

z

1
,
n



)

=

(



Φ

-
1


(

u

1
,
1


)

,
...

,


Φ

-
1


(

u

1
,
n


)


)
















(


z

N
,
1


,
...

,

z

N
,
n



)

=

(



Φ

-
1


(

u

N
,
1


)

,
...

,


Φ

-
1


(

u

N
,
n


)


)









where Φ denotes the cumulative distribution function of the standard normal distribution and let Z denote the matrix of transformed observations








(




z

1
,
1








z

1
,
n


















z

N
,
1








z

N
,

n







)





2. Compute the empirical correlation matrix






Σ
=



Z
T


Z

N






and the regularized empirical correlation matrix Σδ=(1−δ)Σ+δI where I denotes the n×n identity matrix.


3. Initialize the estimate of R by

R0δ

Until convergence repeat







R

i
+
1


=

arg



min
M


{


t


r

(


R
i

-
1



M

)


+

t


r

(


M

-
1




Σ
δ


)


+

λ





P
*
M



1



}








where P is the penalty matrix with zeros on the diagonal and ones everywhere else and where the solution to the minimization problem is computed using Backtracking ISTA (Algorithm 4).


Remark 1 Least squares models are known to be sensitive to outliers. The above procedure can be made robust by replacing the observations u⋅,i with their ranks and then setting the transformed variables z⋅,i to be the corresponding quantile points.


In the anomaly detection phase, given a set of observations u1, . . . , un of the random variables U1, . . . , Un those observations that exceed some threshold Pthresh are discarded to obtain a restricted set of observations ũ1, . . . , ũn′ with n′≤n. This may reduce processing time or memory requirements. Later it is discussed how pthresh can be chosen in a data driven way.


Given this restricted set of observations, (7) can then be computed by estimating the conditional probabilities (8) applied to the restricted set of observations Ũ1, . . . , Ũn′ with

P(Ũi≤ũi11, . . . ,Ũi−1i−1)=P(Zi≤zi|Z1=z1, . . . ,Zi−1=zi−1)  (11)

where the Zi denote the transformed variables

Z1, . . . ,Zn′−1(Ũ1), . . . ,Φ−1(Ũd)

and then computing (7) using (8) with the ordering specified by (9). This leads to the following anomaly detection algorithm.


Algorithm 6 Let R denote the estimate of the correlation matrix of the Gaussian copula (10) obtained by using Algorithm 5, let the exceedance probability threshold pthresh be given and let π(N) and π(A) denote the prior probabilities that the behavior generating the value of a metric Mi is normal or anomalous respectively.


Anomaly Detection Given observations u1, . . . , un


1. Discard all observations that exceed the threshold pthresh to get a new restricted set of observations ũ1, . . . , ũn′, n′≤n.


2. Compute the restricted set of transformed variables

z1, . . . ,zn′−1(ũ1), . . . ,Φ−1(ũn′).


3. Compute R′, the correlation matrix of the restricted set of transformed variables z1, . . . zn′.


4. Find the permutation σ of {1, . . . , n′} which has the property that for all i∈{1, . . . , n′}

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))≤P(Zσ(j)≤zσ(j)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))  (12)

for all j∈{i+1, . . . , n′}.


5. Estimate the posterior probabilities Pd(N) and Pd(A) by









P
d

(
N
)

=




i
=
1


n






π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)










P
d

(
A
)

=

1
-




i
=
1


n






π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)











where Pσ(i) denotes

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1)).


Detecting Anomalous Behavior in Network Devices Using Statistically Dependent Metrics

By combining the preceding ideas the following general method for computing the probability that a device is in an anomalous state given measurements of a collection of behavioral metrics can be obtained.


Algorithm 7 Assume that one has a set of behavioral metrics M1, . . . Mn and let π(N) and π(A) denote the prior probabilities that the behavior generating the value of a metric Mi is normal or anomalous respectively, pthresh denote the exceedance probability threshold, 0<δ<1 denote the regularization parameter and λ>0 the lasso penalty.


Model Fitting Given an historical sequence of observations of the values of the metrics M1, . . . Mn


1. Compute the sequence of exceedance probabilities













(


P

(


M
1

>

m
1


)

,
...

,

P

(


M
n

>

m
n


)


)

1















(


P

(


M
1

>

m
1


)

,
...

,

P

(


M
n

>

m
n


)


)

N







2. Compute the sequence of transformed variables













(


z

1
,
1


,
...

,

z

1

n



)

=


(



Φ

-
1


(

P

(


M
1

>

m
1


)

)

,
...

,


Φ

-
1


(

P

(


M
n

>

m
n


)

)


)

1
















(


z

N
,
1


,
...

,

z

N
,
n



)

=


(



Φ

-
1


(

P

(


M
1

>

m
1


)

)

,
...

,


Φ

-
1


(

P

(


M
n

>

m
n


)

)


)

N









where Φ denotes the cumulative distribution function of the standard normal distribution and let Z denote the matrix of transformed observations








(




z

1
,
1








z

1
,
n


















z

N
,
1








z

N
,

n







)






The tail probabilities P(Mi<mi) may be used in place of the tail probabilities P(Mi>mi).


3. Compute the empirical correlation matrix






Σ
=



Z
T


Z

N






and the regularized empirical correlation matrix Σδ=(1−δ)Σ+δI where I denotes the n×n identity matrix.


4. Initialize the estimate of R by

R0δ

Until convergence repeat







R

i
+
1


=

arg



min
M


{


t


r

(


R
i

-
1



M

)


+

t


r

(


M

-
1




Σ
δ


)


+

λ





P
*
M



1



}








where P is the penalty matrix with zeros on the diagonal and ones everywhere else and where the solution to the minimization problem is computed using Backtracking ISTA (Algorithm 4).


Anomaly Detection Let R denote the estimate of the correlation matrix of the Gaussian copula that describes the dependencies of the exceedance probabilities P(Mi>mi) computed in the model fitting step. Given observations m1, . . . , mn


1. Calculate the exceedance probabilities

P(M1>m1), . . . ,P(Mn>mn).


2. Discard all observations such that the exceedance probability P(Mi>mi) exceeds the threshold pthresh to get a new restricted set of observations {tilde over (m)}1, . . . , {tilde over (m)}n′, n′≤n.


3. Compute the restricted set of transformed variables

z1, . . . zn′−1(P({tilde over (M)}1>{tilde over (m)}1)), . . . ,Φ−1(P({tilde over (M)}n′>{tilde over (m)}n′)).


4. Compute R′, the correlation matrix of the restricted set of transformed variables z1, . . . zn′.


5. Find the permutation σ of {1, . . . , n′} which has the property that for all i∈{1, . . . n′}

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))≤P(Zσ(j)≤zσ(j)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))  (13)

for all j∈{i+1, . . . , n′}.


6. Estimate the posterior probabilities Pd (N) and Pd(A) by









P
d

(
N
)

=




i
=
1


n






π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)










P
d

(
A
)

=

1
-




i
=
1


n






π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)











where Pσ(i) denotes

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1)).


A Bayesian Algorithm for Anomaly Detection

The ideas in the sections above will now be tied together and an algorithm for detecting anomalous behavior in network devices based on monitoring a collection of behavioral metrics will be detailed.


Algorithm 8 Assume that one has a set of behavioral metrics M1, . . . , Mn and that the conditions of Assumption 1 hold. Let π(N) and π(A) denote the prior probabilities that the behavior generating the value of a behavioral metric is normal or anomalous respectively, pthresh denote the exceedance probability threshold, 0<δ<1 denote the regularization parameter and λ>0 the lasso penalty.


Model Fitting Given an historical sequence of observations of the values of the metrics M1, . . . Mn


1. for each i use a suitable POT fitting method to find

    • a threshold ui.
    • an estimate {circumflex over (P)}(mi>ui) of the tail probabilities (1).
    • an estimate ξii of the parameters of the GPD that describes the conditional distribution P(Mi−ui|Mi>ui).


2. Let










(


P

(


M
1

>

m
1


)

,
...

,

P

(


M
n

>

m
n


)


)

1












(


P

(


M
1

>

m
1


)

,
...

,

P

(


M
n

>

m
n


)


)

N








denote the sequence of values of exceedance probabilities obtained by applying the POT models obtained in step S to the historical sequence of observations of the values of the metrics M1, . . . , Mn.


3. Compute the sequence of transformed variables










(


z

1
,
1


,
...

,

z

1
,
n



)

=


(



Φ

-
1


(

P

(


M
1

>

m
1


)

)

,
...

,


Φ

-
1


(

P

(


M
n

>

m
n


)

)


)

1













(


z

N
,
1


,
...

,

z

N
,
n



)

=


(



Φ

-
1


(

P

(


M
1

>

m
1


)

)

,
...

,


Φ

-
1


(

P

(


M
n

>

m
n


)

)


)

N









where Φ denotes the cumulative distribution function of the standard normal distribution and let Z denote the matrix of transformed observations







(




z

1
,
1








z

1
,
n


















z

N
,
1









z

N
,
n


·




)






4. Compute the empirical correlation matrix






Σ
=



Z
T


Z

N






and the perturbed empirical correlation matrix Σδ=(1−δ)Σ+δI where I denotes the n×n identity matrix.


5. Initialize the estimate of R by

R0δ

Until convergence repeat







R

i
+
1


=

arg

min
M


{


t


r

(


R
i

-
1



M

)


+

t


r

(


M

-
1




Σ
δ


)


+

λ





P
*
M



1



}







where P is the penalty matrix with zeros on the diagonal and ones everywhere else and where the solution to the minimization problem is computed using Backtracking ISTA (Algorithm 4).


Anomaly Detection Let R denote the estimate of the correlation matrix of the Gaussian copula that describes the dependencies of the exceedance probabilities P(Mi>mi) computed in the model fitting part of the system. Given observations m1, . . . , mn of the behavioral metrics M1, . . . , Mn


1. For each i compute the tail probability P(Mi>mi) using the empirical distribution of the historical observations of Mi if mi≤ui and

{circumflex over (P)}(Mi>ui)F{circumflex over (ξ)}i,{circumflex over (σ)}i(mi−ui)

otherwise.


2. Discard all observations such that the exceedance probability P(Mi>mi) exceeds the threshold pthresh to get a new restricted set of observations {tilde over (m)}1, . . . , {tilde over (m)}n′, n′≤n.


3. Compute the restricted set of transformed variables

z1, . . . ,zn′−1(P({tilde over (M)}1>{tilde over (m)}1)), . . . Φ−1(P({tilde over (M)}n′>{tilde over (m)}n′)).


4. Compute R′, the correlation matrix of the restricted set of transformed variables z1, . . . zn′.


5. Find the permutation σ of {1, . . . , n′} which has the property that for all i∈{1, . . . , n′}

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))≤P(Zσ(j)≤zσ(j)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))  (14)

for all j∈{i+1, . . . n′}.


6. Estimate the posterior probabilities Pd(N) and Pd(A) by











P
d

(
N
)

=




i
=
1


n







π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)












P
d

(
A
)

=

1
-




i
=
1


n







π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)













where Pσ(i) denotes

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1)).


A Method for Representing Bayesian Posterior Probabilities

An approach to representing probabilities that allows the outputs of Bayesian anomaly detection algorithms to be presented to users in an intuitive and easily understandable form is now provided. The difficulty with using posterior probabilities to assess the level of anomalousness of events and how this difficulty may be overcome by using the so called weight of evidence will first be discussed. Then how one may use the weight of evidence to build a framework for representing probabilities that allows the user of an anomaly alert system to easily rank the level of anomalousness of different alerts and identify those which require further action is considered. Furthermore this framework provides a natural way for the user to specify and control the rate of false alerts.


The Weight of Evidence of a Posterior Probability

In order to understand the difficulties the users of a Bayesian anomaly alert system may face in interpreting its output consider the following scenario. Suppose that an anomaly alert system assigns prior probabilities π(N) and π(A) to the chances of a device being in a normal or anomalous state respectively. The posterior probability that the device is in an anomalous state given the observation of some event E will then be given by










P

(

A
|
E

)

=




π

(
A
)



P

(

E
|
A

)





π

(
N
)



P

(

E
|
N

)


+


π

(
A
)



P

(

E
|
A

)




=


1




π

(
N
)



P

(

E
|
N

)




π

(
A
)



P

(

E
|
A

)



+
1


.






(
15
)








Now consider how the posterior p(A|E) varies with the Bayes factor








P

(

E
|
A

)


P

(

E
|
N

)


.





Suppose that the value of the Bayes factor is such that the corresponding posterior P(A|E) is equal to 0.99. An increase of the Bayes factor by a factor of 10 will cause the value of the posterior to increase to roughly 0.999. Similarly an increase of the Bayes factor by a factor of 100 will cause the value of the posterior to increase to only approximately 0.9999. Clearly it is the case that the larger the posterior probability the more difficult it is to differentiate between the significance of different alerts.


It follows from the above discussion that the natural measure of anomalousness is not the posterior but the Bayes factor








P

(

E
|
A

)


P

(

E
|
N

)


.





The question men is what scaling to use to represent the Bayes factor. Intuitively one would expect a change in the Bayes factor by a factor of 10 to lead to the same change in the level of significance of the alert regardless of the actual absolute values of the Bayes factor. Therefore one way of representing the level of anomalousness to the user of an anomaly alert system is to report the so called weight of evidence








log
10

(


P

(

E
|
A

)


P

(

E
|
N

)


)

.





How the weight of evidence may be used to build a framework for representing and interpreting probabilities generated by anomaly alert systems will now be discussed.


A Weight of Evidence Based Alert Framework

Recall from (15) that the posterior probability of an entity being anomalous is determined by the quantity









π

(
N
)



P

(

E
|
N

)




π

(
A
)



P

(

E
|
A

)



.





Thus to determine the level of anomalousness one needs to know the value of the prior probabilities. However in practice the user of an anomaly alert system does not need the absolute level of anomalousness of each event but instead wishes only to be able to identify those alerts which are most significant. It follows that what is important is the relative weight of evidence of any pair of events. From (15) it follows that the relative weight of evidence of any two events E and E′ is









log
10

(


P

(

E
|
A

)


P

(

E
|
N

)


)

-


log
10

(


P

(


E


|
A

)


P

(


E


|
N

)


)


=




log
10

(


π

(
A
)


π

(
N
)


)

+


log
10

(


P

(

E
|
A

)


P

(

E
|
N

)


)

-


log
10

(


π

(
A
)


π

(
N
)


)

-


log
10

(


P

(


E


|
A

)


P

(


E


|
N

)


)


=



log
10

(



π

(
A
)



P

(

E
|
A

)




π

(
N
)



P

(

E
|
N

)



)

-



log
10

(



π

(
A
)



P

(


E


|
A

)




π

(
N
)



P

(


E


|
N

)



)

.








The key observation is that the relative weight of evidence is independent of the choice of priors and so presents a way of comparing the relative importance of different events in a Bayesian context which is independent of the underlying modelling assumptions. Thus, while in the system described above, the prior probabilities are needed to compute the overall probability of a device being anomalous as described (see algorithm 8 and related preceding algorithms for example), the weight of evidence based method describes a way to give scores to events without ever having to compute or know the prior probabilities π(N) and π(A).


It would not be practical for the user of a system to have to compare every pair of alerts. Instead what one could do would be to compare the strength of each alert to some reference strength. Since a user is likely to only be interested in alerts that exceed the reference strength one can then choose the reference strength to achieve a desired false positive rate. In order to formalize this, the following assumption will be made.


Assumption 3


1. The consumer of the output of the anomaly alert system can tolerate (on average) no more than Nfp false positives per day.


Using the conditions in Assumption 3 the following algorithm can be formulated.


Algorithm 9 Assume the conditions of Assumption 3 hold.

    • 1. Given a sequence of historical observed events E1, . . . , EN compute the average number of events per day Neld.


2. Compute the







1
-


N
fp


N
eld



-
th





empirical quantile of the posterior anomaly probabilities P(A|E1), . . . , P(A|EN). Denote this quantity P(A)ref.


3. Given a new event E compute the relative weight of evidence of P(A|E) with respect to the reference strength P(A)ref. Denote this quantity by Rwoe(P(A|E),P(A)ref).


4. Return to the user the quantity max(Rwoe(P(A|E),P(A)ref),0) to measure the significance of event E.


Finally it is observed that since many users may be using the significance score mostly to decide whether or not an event merits further attention it often makes sense to attenuate the significance score when it exceeds some level beyond which further investigation is inevitable. This can be done by either hard thresholding or by soft thresholding using the rescaled logistic function










S

(
t
)

=



1
-

e

-
t




1
+

e

-
t




.





(
16
)








Moreover such output can then be rescaled to give the user a value lying in some easily interpreted range. In particular one can linearly map the thresholded significance score to the interval [0,100] thus presenting the user with a ‘percentage’ score of how anomalous an event is.


Algorithm 10 Assume the conditions of Assumption 3 hold.


1. Choose a scale α and a cutoff β such that α,β∈(0, ∞).


2. Given a sequence of historical observed events E1, . . . , EN compute the average number of events per day Neld.


3. Compute the







1
-


N
fp


N
eld



-
th





empirical quantile of the posterior anomaly probabilities P(A|E1), . . . ,P(A|EN). Denote this quantity P(A)ref.


4. Given a new event E compute the relative weight of evidence of P(A|E) with respect to the reference strength P(A)ref. Denote this quantity by Rwoe(P(A|E), P(A)ref).


5. Compute Rwoe+(P(A|E), P(A)ref)=max(Rwoe(P(A|E),P(A)ref),0).


6. Return to the user either







-
the



quantity



α
(


min

(



R

w

o

e

+

(


P

(

A
|
E

)

,


P

(
A
)


r

e

f



)

,
β

)

β

)





or

    • the quantity where






aS
(



R

w

o

e

+

(


P

(

A
|
E

)

,


P

(
A
)


r

e

f



)

β

)





S is the logistic function defined in (16)


to measure the significance of event E.


An Anomaly Alert System for Cyber Threat Detection

In this section the ideas of the preceding sections are combined to describe an anomaly alert system for detecting cyber threats in computer networks. The anomaly alert system consists of three main parts; a model fitting system, the anomaly detection system and a user alert system.


The following example assumptions are made about the environment in which the anomaly alert system is to be deployed (other sets of assumptions may also be used):

    • There is a computer network with a number of devices to be monitored for anomalous behavior.
    • The data about the network traffic being generated by these devices is being collected by a network traffic monitoring system.
    • The output of the network monitoring system is used to generate for each device a set of behavioral metrics M1, . . . , Mn. the behavioral metrics may be either network metrics or derived metrics.
    • Historical values of the metrics are available to the system for training.
    • New values of the behavioral metrics are fed into the system in real time for anomaly detection and alerting.
    • The user of the anomaly alert system may tolerate (on average) a fraction of false positives no greater than p, 0<p<1.
    • The user of the anomaly alert system has a cutoff β for alert strengths and desires to see the strength of alerts displayed on a scale [0, α] for some α,β>0.


Specific descriptions of each of the three parts of the anomaly alert system will now be given.


Model Fitting System 170

It is assumed that historical observations 150 of the behavioral metrics M1, . . . , Mn for all the devices on the network are available.


1. For each metric Mi use a suitable POT fitting method to find

    • a threshold ui.
    • an estimate {circumflex over (P)}(Mi>ui) of the tail probabilities (1).
    • an estimate {circumflex over (ξ)}i,{circumflex over (σ)}i of the parameters of the GPD that describes the conditional distribution P(Mi−ui|Mi>ui).


When fitting the parameters of the POT method the following may be taken into consideration.

    • For some metrics one may want to model the tail probabilities (1) using a restricted set of the set of GPDs. In particular when the values that a metric can take are unbounded one may want to assume that the probabilities P(M>ui) belong to either the Gumbel or Fréchet family of distributions (equivalent to assuming that ξ>0).
    • When computing the distribution of the tail probabilities (1) care must be taken to avoid having the estimates of the tail parameters skewed by any outliers in the observations. This can be done by employing some kind of M-estimator. Alternatively, this may be achieved by discarding a fixed number of the largest observations or a fixed fraction of the largest observations where the choice of the above is user driven.
    • One may model the tail probabilities (1) separately for some devices. As well as this one may wish to group certain subsets of the network devices together and build a single model for the tail probabilities of the devices in the subset based on the union of the observations of the metric for each individual device in the group. The groups may be manually specified by a user, may be created by grouping all devices of a certain type e.g. all desktops on a subnet or may be determined algorithmically by applying a clustering algorithm to some feature set.


2. Compute the sequence of values of exceedance probabilities










(


P

(


M
1

>

m
1


)

,
...

,

P

(


M
n

>

m
n


)


)

1












(


P

(


M
1

>

m
1


)

,
...

,

P

(


M
n

>

m
n


)


)

N








obtained by applying the POT models obtained in step 1 to the historical sequence of observations of the values of the metrics M1, . . . , Mn, where N denotes the number of observations of the metrics available to the model fitting part of the system. These may be obtained in one of two ways.

    • Cross validation. In this approach the set of historical observations of the metrics S is split into K disjoint sets. For each set of observations Sk, 1≤k≤K, the parameters of the POT models are computed as detailed above using the remaining observations S\Sk and then used to compute the values P(Mi>mi) for the observations in Sk. Doing this for all sets S1, . . . , SK gives a collection of observations of P(Mi>mi) that may be used to model their dependency relationship.
    • Using historical values of the P(Mi>mi). In this approach one simply records the values of the random variables P(Mi>mi) for some time window after the parameters of the POT models were last computed. These values can then be used to model the dependency relationships.


The cross validation approach may be more computationally expensive whereas the second approach may increase the memory requirements of the system. If CPU usage rather than memory is the most commonly encountered resource constraint, the second method listed above may be used.


3. Compute the sequence of transformed variables










(


z

1
,
1


,
...

,

z

1
,
n



)

=


(



Φ

-
1


(

P

(


M
1

>

m
1


)

)

,
...

,


Φ

-
1


(

P

(


M
n

>

m
n


)

)


)

1













(


z

1
,
1


,
...

,

z

1
,
n



)

=


(



Φ

-
1


(

P

(


M
1

>

m
1


)

)

,
...

,


Φ

-
1


(

P

(


M
n

>

m
n


)

)


)

N









where Φ denotes the cumulative distribution function of the standard normal distribution and let Z denote the matrix of transformed observations







(




z

1
,
1








z

1
,
n


















z

N
,
1









z

N
,
n


·




)






4. Compute the empirical correlation matrix






Σ
=



Z
T


Z

N






and the regularized empirical correlation matrix Σδ=(1−δ)Σ+δI where I denotes the n×n identity matrix. The regularization parameter δ should take values in (0,1). In practice δ=0.1 may be used.


5. Initialize the estimate of R by

R0δ

Until convergence repeat







R

i
+
1


=

arg

min
M


{


t


r

(


R
i

-
1



M

)


+

t


r

(


M

-
1




Σ
δ


)


+

λ





P
*
M



1



}







where P is the penalty matrix with zeros on the diagonal and ones everywhere else, where λ>0 is a user chosen lasso penalty, and where the solution to the minimization problem is computed using Backtracking ISTA (Algorithm 4).


6. Let Nfp be the user specified daily false positive rate.

    • From the number of historical observations of the metrics M1, . . . , Mn compute the expected number of observations per day Nold.
    • Choose








π

(
N
)

=

1
-


N
fp


N
old






and




π

(
A
)

=



N
fp


N
old


.








    • Set the reference anomaly posterior P(A)ref to be equal to the









1
-


N
fp


N
old







-th quantile of the distribution of the random variable









1
-





π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)








(
17
)








where σ is as defined in (13) and where Pσ(i) denotes P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . , Zσ(i−1)=zσ(i−1)) and where z1, . . . zM are the transformed variables defined in (11) with the dependency structure described by the Gaussian copula (10) with correlation matrix R as computed in the previous step.


The quantiles of (17) can be estimated by Monte Carlo simulation in order to find an estimate of the exact value of the reference posterior P(A)ref. Alternatively if Nfp<<Nold then by using the Bonferroni correction principle and approximating R by the identity matrix it follows that







P

(


(

1
-





π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)





)

>

n

n
+
1



)

=



N
fp


N
old


.






where σ is as defined in (13) and where Pσ(i) denotes P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . , Zσ(i−1)=zσ(i−1))


Optionally,






n

n
+
1






can be used as an approximation to the reference posterior to avoid exact computation of the quantiles of (17).


7. Select the exceedance probability threshold pthresh so that the corresponding posterior is negligible. In practice pthresh may be set equal to απ(A) for some α∈[10,100].


Anomaly Detection System 180

Let R be the Gaussian copula correlation matrix computed by the model fitting part of the system. Given values m1, . . . mn of the behavioral metrics M1, . . . Mn for a device d. These may be new observations 160.


1. Find the POT models that correspond to device d and for each i compute the tail probability P(Mi>mi) using the empirical distribution of the historical observations of Mi if mi≤ui and

{circumflex over (P)}(Mi>ui)Fξii(mi−ui)

otherwise.


2. Discard all observations such that the exceedance probability P(Mi>mi) exceeds the threshold pthresh to get a new restricted set of observations {tilde over (m)}1, . . . ,{tilde over (m)}n′, n′≤n.


3. Compute the restricted set of transformed variables

z1, . . . ,zn′−1(P({tilde over (M)}1>{tilde over (m)}1)), . . . Φ−1(P({tilde over (M)}n′>{tilde over (m)}n′)).


4. Compute R′, the correlation matrix of the restricted set of transformed variables z1, . . . zn′.


5. Find the permutation σ of {1, . . . , n′} which has the property that for all i∈{1, . . . n′}

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))≤P(Zσ(j)≤zσ(j)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1))  (18)

for all j∈{i+1, . . . n′}.


6. Estimate the posterior probabilities Pd (N) and Pd(A) by











P
d

(
N
)

=




i
=
1


n






π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)












P
d

(
A
)

=

1
-




i
=
1


n






π

(
N
)



P

σ

(
i
)






π

(
N
)



P

σ

(
i
)



+

π

(
A
)













where Pσ(i) denotes

P(Zσ(i)≤zσ(i)|Zσ(1)=zσ(1), . . . ,Zσ(i−1)=zσ(i−1)).


7. Post the value Pd (A) to the user alert system.


User Alert System 190


Given a posterior anomaly probability Pd(A) for a device.


1. Compute the relative weight of evidence of Pd (A) with respect to the reference posterior anomaly probability P(A)ref








R

w

o

e


(



P
d

(
A
)

,


P

(
A
)


r

e

f



)

=



log
10

(



P
d

(
A
)


1
-


P
d

(
A
)



)

-



log
10

(



P

(
A
)


r

e

f



1
-


P

(
A
)


r

e

f




)

.






2. Return to the user 210 the anomaly score






αS
(


max

(



R

w

o

e


(



P
d

(
A
)

,


P

(
A
)


r

e

f



)

,
0

)

β

)





where S is the rescaled logistic function defined in (16).


The various methods described above may be implemented by a computer program product. The computer program product may include computer code arranged to instruct a computer or an arrangement of computers to perform the functions of one or more of the various methods described above. The computer program and/or the code for performing such methods may be provided to an apparatus, such as a computer, on a computer readable medium or computer program product. The computer readable medium may be transitory or non-transitory. The computer readable medium could be, for example, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, or a propagation medium for data transmission, for example for downloading the code over the Internet. Alternatively, the computer readable medium could take the form of a physical computer readable medium such as semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disc, and an optical disk, such as a CD-ROM, CD-R/W or DVD.


An apparatus such as a computer may be configured in accordance with such code to perform one or more processes in accordance with the various methods discussed herein. Such an apparatus may take the form of a data processing system. Such a data processing system may be a distributed system. For example, such a data processing system may be distributed across a network.

Claims
  • 1. An anomaly detection system and anomaly alert system for cyber threat detection, comprising: a processor; anda non-transitory computer readable medium including one or more models that use machine learning algorithms,wherein the processor performs multiple stages of analysis on network activities associated with a plurality of devices communicatively coupled to the anomaly detection system to determine whether at least a network activity of the network activities is anomalous, the multiple stages of analysis comprises (1) producing behavioral metrics based on metrics associated with network activity, (2) analyzing behavioral metrics associated with each device of the plurality of devices to generate one or more models representing normal behavior by each device of the plurality of devices including a first device, and (3) determining whether the network activity by at least the first device is anomalous based on determining whether a computed value associated with a behavior metric correspond to the network activity exceeds a value representing that the first device is behaving anomalously, andwherein the anomaly alert system is configured to cooperate with the anomaly detection system to send one or more alerts to, at least, network system administrators and/or security officers, at least, about a device of the plurality of devices whose behavior is determined to be anomalous, andwherein the multiple stages of analysis are used to control a rate of false alerts based on both (i) a relative weight of evidence determined as a ratio between a probability of the device being in an anomalous state given observation of the network activity being an event and a probability of the device being in a normal state given the observation of the event and (ii) a reference strength configured to be selected by a user to achieve a desired false positive rate.
  • 2. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, wherein the anomaly detection system is configured to operate in one of the multiple stages of analysis, after a determination of what data is indicative of normal behavior for the normal pattern of life, and determine whether the behavioral metric identifies that an anomaly will occur, andwhere a network traffic monitoring system is configured to take in and process metrics of, at least, network activity to produce the behavioral metrics under analysis.
  • 3. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, where the anomaly detection system is configured to apply mathematical operations in the multiple stages of analysis on the behavioral metrics to detect an anomaly.
  • 4. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, where the anomaly detection system is configured to detect anomalous behavior; and thereby, attempt to prevent cyber threats to, at least, one or more computing devices, where the one or more models are configured to maintain what is considered to be normal behavior for the behavioral metric and each model of the one or more models is constructed on a per each device basis, on a network from historical data.
  • 5. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, where the anomaly detection system is configured to build and maintain a dynamic, ever-changing model of the normal behavior of each device based on a distribution of metrics, where a first model of the one or more models that use machine learning algorithms is a first dynamic, ever-changing model of the normal behavior of a first device.
  • 6. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, where the anomalous behavior detection system is also configured to take in information that is available relating to a person and establish a pattern of life for that person, which is dynamically updated as more information is gathered to allow the anomalous behavior detection system to spot behavior of a first device that the person is using, which seems to fall outside of the normal pattern of life for that person, and flag this spotted behavior as anomalous.
  • 7. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, where the anomaly detection system is configured to measure of the anomalousness of a first device relative to a reference measure of anomalousness above a given level, where a distribution of the values is modeled.
  • 8. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, where the anomaly alert system is further configured to map a thresholded significance of an alert to a significance score mostly to decide whether or not an event merits further attention.
  • 9. The anomaly detection system and anomaly alert system for cyber threat detection of claim 1, where the anomaly detection system is configured to apply anomaly detection algorithms to subsets of network metrics being one of the metrics associated with the network activity, where the subset is based on the union of the observations of the metric for each individual device in a group, where the group is at least one of i) specified by a user, ii) created by grouping all devices of a certain type, and iii) be determined by applying a clustering algorithm.
  • 10. A method for detecting cyber threats by a system including an anomaly detection system and anomaly alert system, the method comprising: producing one or more models that use machine learning algorithms conducting multiple stages of analysis including (1) producing behavioral metrics based on metrics associated with network activity,(2) analyzing behavioral metrics associated with each device of a plurality of devices accessible to the anomaly detection system to generate a corresponding plurality of models representing a normal pattern of life for each device of the plurality of devices including a first device, and(3) determining whether a network activity by at least the first device is anomalous based on determining whether a computed value associated with a behavior metric corresponding to the network activity exceeds a value that represents the first device is behaving anomalously,configuring the anomaly alert system to cooperate with the anomaly detection system to send one or more alerts to, at least, network system administrators or security officers, at least, about any device whose behavior is determined to be sufficiently anomalous, andwherein the multiple stages of analysis are used to control a rate of false alerts based on both (i) a relative weight of evidence determined as a ratio between a probability of the device being in an anomalous state given observation of the associated with the network activity being an event and a probability of the device being in a normal state given the observation of the event and (ii) a reference strength and a user can choose a first reference strength to achieve a desired false positive rate.
  • 11. The method of claim 10, further comprising: configuring the anomaly detection system to operate in one of the multiple stages of analysis, after a determination of what data is indicative of normal behavior for the normal pattern of life, then a check to detect whether an anomaly will occur, andconfiguring a network traffic monitoring system to take in and process metrics of, at least, network activity to produce behavioral metrics.
  • 12. The method of claim 10, further comprising: configuring the anomaly detection system to apply multiple mathematical operations in the stages of analysis on the behavioral metrics to detect the anomalous behavior.
  • 13. The method for the anomaly detection system and anomaly alert system for cyber threat detection of claim 10, further comprising: configuring the anomalous behavior detection system to detect the anomalous behavior; and thereby, attempt to prevent cyber threats to, at least, one or more computing devices, where the one or more models are configured to maintain what is considered to be normal behavior for that metric, which is constructed on a per each device basis, on a network from historical data.
  • 14. The method of claim 10, further comprising: configuring the anomaly detection system to build and maintain a dynamic, ever-changing model of the normal behavior of each device within a network based on a distribution of metrics, where a first model of the one or more models that use machine learning algorithms is a first dynamic, ever-changing model of the normal behavior of a first device.
  • 15. The method of claim 10, further comprising: configuring the anomaly detection system to take in information that is available relating to a person and establish a pattern of life for that person, which is dynamically updated as more information is gathered to allow the anomalous behavior detection system to spot behavior of a first device that the person is using, which seems to fall outside of the normal pattern of life for that person, and flag this spotted behavior as anomalous.
  • 16. The method of claim 10, further comprising: configuring the anomaly detection system to measure of anomalousness of a first device relative to a reference measure of anomalousness above a given level, where a distribution of the values is modeled.
  • 17. The method for the anomaly detection system and anomaly alert system for cyber threat detection of claim 10, further comprising: configuring the anomaly alert system to map a thresholded significance of an alert to a significance score mostly to decide whether or not an event merits further attention.
  • 18. The method of claim 10, further comprising: configuring the anomaly detection system to apply anomaly detection algorithms to subsets of the network metrics, where the subset is based on the union of the observations of the metric for each individual device in a group, where the group is at least one of i) specified by a user, ii) created by grouping all devices of a certain type, and iii) be determined by applying a clustering algorithm.
Priority Claims (1)
Number Date Country Kind
1602309 Feb 2016 GB national
US Referenced Citations (112)
Number Name Date Kind
6078851 Sugitani Jun 2000 A
6154844 Touboul et al. Nov 2000 A
6950773 Gross Sep 2005 B1
6965968 Touboul Nov 2005 B1
7307999 Donaghey Dec 2007 B1
7418731 Touboul Aug 2008 B2
7448084 Apap et al. Nov 2008 B1
8312540 Kahn et al. Nov 2012 B1
8819803 Richards et al. Aug 2014 B1
8879803 Ukil et al. Nov 2014 B2
8966036 Asgekar et al. Feb 2015 B1
9043905 Allen et al. May 2015 B1
9106687 Sawhney et al. Aug 2015 B1
9185095 Moritz et al. Nov 2015 B1
9213990 Adjaoute Dec 2015 B2
9401925 Guo et al. Jul 2016 B1
9462009 Kolman et al. Oct 2016 B1
9516039 Yen et al. Dec 2016 B1
9516053 Muddu et al. Dec 2016 B1
9641544 Treat et al. May 2017 B1
9705914 Di Pietro Jul 2017 B2
9712548 Shmuell et al. Jul 2017 B2
9727723 Kondaveeti et al. Aug 2017 B1
10268821 Stockdale Apr 2019 B2
10419466 Ferguson Sep 2019 B2
10581902 Krishtal Mar 2020 B1
10701093 Dean Jun 2020 B2
20020186698 Ceniza Dec 2002 A1
20030070003 Chong et al. Apr 2003 A1
20040083129 Herz Apr 2004 A1
20040167893 Matsunaga et al. Aug 2004 A1
20050065754 Schaf et al. Mar 2005 A1
20060242706 Ross Oct 2006 A1
20070118909 Hertzog et al. May 2007 A1
20070294187 Scherrer Dec 2007 A1
20080005137 Surendran et al. Jan 2008 A1
20080109730 Coffman et al. May 2008 A1
20090106174 Battisha et al. Apr 2009 A1
20090254971 Herz et al. Oct 2009 A1
20100009357 Nevins et al. Jan 2010 A1
20100095374 Gillum et al. Apr 2010 A1
20100125908 Kudo May 2010 A1
20100235908 Eynon et al. Sep 2010 A1
20100299292 Collazo Nov 2010 A1
20110093428 Wisse Apr 2011 A1
20110213742 Lemmond et al. Sep 2011 A1
20110261710 Chen et al. Oct 2011 A1
20120016633 Wittenstein Jan 2012 A1
20120096549 Amini et al. Apr 2012 A1
20120137367 Dupont et al. May 2012 A1
20120209575 Barbat et al. Aug 2012 A1
20120210388 Kolishchak Aug 2012 A1
20120216282 Pappu Aug 2012 A1
20120284791 Miller et al. Nov 2012 A1
20120304288 Wright et al. Nov 2012 A1
20130091539 Khurana et al. Apr 2013 A1
20130110761 Viswanathan May 2013 A1
20130198119 Eberhardt, III et al. Aug 2013 A1
20130198840 Drissi et al. Aug 2013 A1
20130254885 Devost Sep 2013 A1
20140007237 Wright et al. Jan 2014 A1
20140041028 Ramsey Feb 2014 A1
20140074762 Campbell Mar 2014 A1
20140165207 Engel et al. Jun 2014 A1
20140215618 Amit Jul 2014 A1
20140325643 Bart et al. Oct 2014 A1
20150067835 Chari et al. Mar 2015 A1
20150081431 Akahoshi et al. Mar 2015 A1
20150161394 Ferragut et al. Jun 2015 A1
20150163121 Mahaffey et al. Jun 2015 A1
20150172300 Cochenour Jun 2015 A1
20150180893 Im et al. Jun 2015 A1
20150207696 Zhang Jul 2015 A1
20150213358 Shelton et al. Jul 2015 A1
20150286819 Coden et al. Oct 2015 A1
20150310195 Ballor et al. Oct 2015 A1
20150319185 Kirti Nov 2015 A1
20150341379 Lefebvre Nov 2015 A1
20150363699 Nikovski Dec 2015 A1
20150379110 Marvasti et al. Dec 2015 A1
20150381646 Lin Dec 2015 A1
20160062950 Brodersen et al. Mar 2016 A1
20160065604 Chen et al. Mar 2016 A1
20160078365 Baumard Mar 2016 A1
20160112443 Grossman Apr 2016 A1
20160149941 Thakur et al. May 2016 A1
20160164902 Moore Jun 2016 A1
20160173509 Ray et al. Jun 2016 A1
20160241576 Rathod et al. Aug 2016 A1
20160261465 Gupta Sep 2016 A1
20160299938 Malhotra Oct 2016 A1
20160352768 Lefebvre et al. Dec 2016 A1
20160359695 Yadav Dec 2016 A1
20160373476 Dell'Anno et al. Dec 2016 A1
20170024660 Chen Jan 2017 A1
20170063907 Muddu et al. Mar 2017 A1
20170063910 Muddu et al. Mar 2017 A1
20170063911 Muddu et al. Mar 2017 A1
20170063912 Muddu et al. Mar 2017 A1
20170126718 Baradaran May 2017 A1
20170169360 Veeramachaneni et al. Jun 2017 A1
20170220801 Stockdale et al. Aug 2017 A1
20170230391 Ferguson et al. Aug 2017 A1
20170230392 Stockdale Aug 2017 A1
20170251012 Stockdale et al. Aug 2017 A1
20170270422 Sorakado Sep 2017 A1
20180027006 Zimmermann et al. Jan 2018 A1
20180167402 Scheidler et al. Jun 2018 A1
20180248902 Dãnilã-Dumitrescu Aug 2018 A1
20190028557 Modi Jan 2019 A1
20200244673 Stockdale Jul 2020 A1
20210273958 McLean Sep 2021 A1
Foreign Referenced Citations (7)
Number Date Country
2922268 Sep 2015 EP
2001031420 May 2001 WO
2008121945 Oct 2008 WO
2013053407 Apr 2013 WO
2014088912 Jun 2014 WO
2015027828 Mar 2015 WO
2016020660 Feb 2016 WO
Non-Patent Literature Citations (8)
Entry
Abdallah Abbey Sebyala et al., “Active Platform Security through Intrusion Detection Using Naive Bayesian Network for Anomaly Detection,” Department of Electronic and Electrical Engineering, 5 pages, University College London, Torrington Place, England, United Kingdom.
Marek Zachara et al., “Detecting Unusual User Behavior to Identify Hijacked Internet Auctions Accounts, ” Lecture Notes in Computer Science, 2012, vol. 7465, Springer, Berlin, Heidelberg, Germany.
United States Patent and Trademark Office, Non-Final Office Action, Jan. 12, 2022, 22 pages.
United States Patent and Trademark Office, Non-Final Office Action, Jul. 30, 2019, 12 pages.
United States Patent and Trademark Office, Final Office Action, Apr. 19, 2019, 12 pages.
United States Patent and Trademark Office, Non-Final Office Action, Aug. 31, 2018, 12 pages.
European Search Report, European Patent Office, Apr. 13, 2017, 7 pages.
Examination Report Under Section 18(3), Intellectual Patent Office, 3 pp. Jul. 5, 2021.
Related Publications (1)
Number Date Country
20210120027 A1 Apr 2021 US
Continuations (2)
Number Date Country
Parent 16878347 May 2020 US
Child 17137193 US
Parent 15425906 Feb 2017 US
Child 16878347 US