Analyzing behavior in light of social time

Information

  • Patent Grant
  • 11783216
  • Patent Number
    11,783,216
  • Date Filed
    Friday, November 6, 2020
    4 years ago
  • Date Issued
    Tuesday, October 10, 2023
    a year ago
Abstract
A relational event history is determined based on a data set, the relational event history including a set of relational events that occurred in time among a set of actors. Data is populated in a probability model based on the relational event history, where the probability model is formulated as a series of conditional probabilities that correspond to a set of sequential decisions by an actor for each relational event, where the probability model includes one or more statistical parameters and corresponding statistics. A baseline communications behavior for the relational event history is determined based on the populated probability model, and departures within the relational event history from the baseline communications behavior are determined.
Description
FIELD

The present application relates to statistically modeling social behavior.


BACKGROUND

Descriptive statistics may be used to quantitatively describe a collection of data gathered from several sources, in order summarize features of the data, and electronic communications generate data trails that can be used to formulate statistics. Email records, for example, may be parsed to identify a sender of an email, a topic or subject of the email, and one or more recipients of the email. Similarly, phone records provide information that may be used to identify a caller and a recipient of a phone call.


Descriptive statistics are not developed on the basis of probability theory and, as such, are not used to draw conclusions from data arising from systems affected by random variation. Inferential statistics, on the other hand, are based on probability theory and are used to draw conclusions from data that is subject to random variation.


Social behavior, such as communications behavior, may involve uncertainty. In this case, inferential statistics, either alone or in combination with descriptive statistics, may therefore be applied to data reflecting the social behavior to draw inferences about such behavior.


SUMMARY

According to one general implementation, a relational event history is determined based on a data set, the relational event history including a set of relational events that occurred in time among a set of actors. Data is populated in a probability model based on the relational event history, where the probability model is formulated as a series of conditional probabilities that correspond to a set of sequential decisions by an actor for each relational event, and where the probability model includes one or more statistical parameters and one or more corresponding statistics. A baseline communications behavior for the relational event history is determined based on the populated probability model, the baseline including a first set of values for the one or more statistical parameters. Departures within the relational event history from the baseline communications behavior are then determined.


In one aspect, the one or more corresponding statistics relate to one or more of senders of relational events, modes of relational events, topics of relational events, or recipients of relational events.


In another aspect, determining departures from the baseline communications behavior within the relational event history includes determining a second set of values for the statistical parameters based on one or more subsets of the relational events included in the relational event history, and comparing the second set of values for the statistical parameters to the first set of values. In some examples, comparing the second set of values for the statistical parameters to the first set of values includes determining a hypothesis regarding communications behavior within the relational event history and testing the hypothesis using the second set of values. In some examples, testing the hypothesis using the second set of values includes computing a value of a test statistic based on the second set of values and using the test statistic to determine the departures from the baseline communications behavior. In some examples, determining the hypothesis regarding communications behavior within the relational event history includes selecting a set of predictions regarding differences in communications behavior with respect to one or more of the statistical parameters over a period of time.


In a further aspect, determining the relational event history includes extracting data from the data set, transforming the extracted data, loading the transformed data, and enriching the loaded data.


In another aspect, determining the relational event history includes determining a subset of actors included in the set of actors, where at least one decision included in the set of sequential decisions comprises selecting a recipient of the relational event from the subset of actors. In some examples, determining the relational event history includes, receiving one or more user inputs, outputting a graphical analysis of the baseline communications behavior based on the user inputs, and outputting one or more graphical analyses of the departures from the baseline communications behavior based on the user inputs.


Other implementations of these aspects include corresponding systems, apparatus, and computer programs, configured to perform the described techniques, encoded on computer storage devices.


The details of one or more implementations of the subject matter described in this specification are set forth in the accompanying drawings and the description below. Other potential features, aspects, and advantages of the subject matter will become apparent from the description, the drawings, and the claims.





DESCRIPTION OF DRAWINGS


FIG. 1 is a diagram of an example of a system that analyzes a relational event history.



FIG. 2 is a flowchart of an example of a process for analyzing a relational event history.



FIG. 3 is a flowchart of an example of a process for determining a baseline communications behavior for a relational event history.



FIG. 4 is a flowchart of another example of a process for determining a baseline communications behavior for a relational event history.



FIG. 5 is a flowchart of an example of a process for modeling a set of sequential decisions made by a sender of a communication in determining recipients of the communication.



FIG. 6 is a flowchart of an example of a process for determining a statistic using a decay function.



FIG. 7 is a flowchart of an example of a process for analyzing social behavior.



FIGS. 8-23 provide examples of user interfaces and of data visualizations that may be output to user.





Like reference symbols in the various drawings indicate like elements.


DETAILED DESCRIPTION

Because communications behavior is complex, and because the decisions involved in one actor sending a communication to another are typically not predictable in advance, the drawing of intelligent inferences from a set of communications-related data can benefit from the development and fitting of a probability model (a mathematical model that is probabilistic in nature). Once a model is developed and fit to a data set, statistical methods can be used to detect patterns, changes, and anomalies in communications behavior, and to test related hypotheses.


One way to approach modeling of communications between actors is to formulate a probability density function as a series of conditional probabilities that can be represented by decisions made sequentially. More specifically, for each relational event (e.g., a communications event occurring at a moment in time among a finite set of actors) in a set of relational events, the probability of the event's occurrence can be decomposed such that it is the product of the probabilities of each of at least four sequential decisions made by the event's initiating actor: (1) a decision to send a communication at a point in time; (2) a decision as to a mode or channel of the communication; (3) a decision as to a topic or content of the communication; and (4) one or more decisions as to one or more recipients of the communication. Although other sequences are possible (e.g., omitting consideration of the topic of the communication, or considering the recipient in advance of the mode), the sequence of sender, mode, topic, and recipient(s) can be useful, in appropriate cases, from a computational standpoint.


Due to the heterogeneity of time-related aspects of communications modeling (e.g., communication patterns differ between work days and weekends), modeling time directly may be difficult. As such, a proportional hazards model, similar to the Cox model, may be employed, so that the “risk” of a specific relational event occurring is relative to other possible relational events, which allows for the prediction of which events are most likely to occur next, but not specifically when. Within the model, the decisions of an actor to send a communication, and as to the mode, topic, and recipient(s) of the communication, may depend on any relational event that occurred prior to the communication, as well as on covariates that can take exogenous information (e.g., data other than communications data) into account. As such, for each sequential decision related to an event, a multinomial logit distribution may be used to model the probabilities of the discrete choice problem presented by the decision, where the primary factors affecting the probability of an event's occurrence are a set of statistics (also referred to as effects) that describe the event in question.


An arbitrary number of statistics can be included in the model, and the types of statistics included may form the basis for the kinds of inferences that can be drawn from the model. The statistics may be based in social network theory, and may relate to one or more of senders, modes, topics, or recipients of relational events. A “trigger” effect, for example, relates to the tendency of an actor to communicate based on the recency of a received communication, while a “broken record” effect relates to an overall tendency to communicate about a topic. The statistics (or effects) may be a scalar value. In some cases, a coefficient (referred to as a statistical parameter or effect value) is multiplied by these statistic values within the model. The statistical parameter may therefore indicate the statistic's effect on event probabilities.


Once the statistics to include in the model have been chosen, the model can be populated based on a relational event history that is determined from a data set. Using the populated model, a baselining process may be employed to determine communications behavior that is “normal” for a given relational event history. This baseline includes a set of effect values (statistical parameters) that correspond to the statistics included in the model. This baseline and the populated model can be used to determine departures from the normal communications behavior.


In this way, a probability model fitted to a relational event history derived from event and other data may be used to identify patterns, changes, and anomalies within the relational event history, and to draw sophisticated inferences regarding a variety of communications behaviors.



FIG. 1 is a diagram of an example of a system that analyzes a relational event history. The system 100 includes data sources 101 and 102, data normalizer 103, inference engine 107, and user interface (“UI”) 108. The data normalizer 103 may be used to determine relational event history 104 and covariate data 105, and the inference engine 107 may be used to determine model 106, and to draw inferences from the model. Data sources 101 and 102 may be connected to data normalizer 103 through a network, and normalizer 103, inference engine 107, and UI 108 may interface with other computers through the network. The data sources 101 and 102 may be implemented using a single computer, or may instead be implemented using two or more computers that interface through the network. Similarly, normalizer 103, inference engine 107, and UI 108 may implemented using a single computer, or may instead be implemented using two or more computers that interface through the network.


Inference engine 107 may, for example, be implemented on a distributing computing platform in which various processes involved in drawing inferences from a relational event history and a set of covariates are distributed to a plurality of computers. In such an implementation, one or more computers associated with the inference engine 107 may access a relational event history, a set of covariates that have been formatted by normalizer 103, and a set of focal actors whose communications behavior will be the subject of analysis. Each of the computers may use the accessed data to perform a portion of the computations involved in populating the model 106, determining a baseline, and/or determining departures from the baseline.


For example, in some implementations, the model may include a set of event statistics, or effects, that impact the probability of events. In this case, to populate the model, each of the computers may perform a portion of the computations involved in determining these event statistics, as well as determining the probabilities of the events. Also, for example, in some implementations determining a baseline may involve determining a set of effect values, which are coefficients that are multiplied by the event statistics in the model 106, and accordingly describe the impact of each effect on event probabilities. The process of determining the effect values may involve a maximum likelihood estimation in which each of the computers perform a portion of the computations involved.


Data source 101 may contain data that relates to communications events. The data may have originated from one or more sources, may relate to one or more modes of communication, and may be stored in one or more formats. Data source 101 may, for example, store email records, phone logs, chat logs, and/or server logs. Data source 101 may be, for example, a digital archive of electronic communications that is maintained by an organization, the archive containing data related to communications involving actors associated with the organization.


Data source 102 may contain additional data that, although not directly related to communications events, may nevertheless prove valuable in drawing inferences from a relational event history. Data source 102 may, for example, store information relating to an organization and its personnel, such as organizational charts, staff directories, profit and loss records, and/or employment records. Data source 102 may be, for example, a digital archive that is maintained by an organization, the archive containing data relating to the operations of the organization.


Data normalizer 103 may be used to load, extract, parse, filter, enrich, adapt, and/or publish event data and other data accessed through one or more data sources, such as data sources 101 and 102. Specifically, event data that is received from data source 101 may be normalized to determine a relational event history 104, the normalization process resulting in clean, parsed relational data with disambiguated actors that maps to the categories of decisions included in a probability model 106. An email, for example, may be parsed to reveal the sender, topic, mode, recipient(s), and timestamp of the email, and that data may be used to generate a relational event that corresponds to the email in relational event history 104.


Normalization of the data accessed from data source 101 may involve processing the data so as to produce a relational event history 104 in which, to the extent possible, each event is described using a uniform set of characteristics, regardless of the mode of communication involved in the event and the format in which the event data is stored in data source 101. Each event in the event history may be include a “sender” (otherwise referred to as an ego below), which is the actor responsible for initiating the event, a “recipient(s)” (otherwise referred to as an alter below), which is the actor(s) that received the event, a mode identifying the mode of the event, and a timestamp indicating the time that the occurred. For example, a phone record may result in a relational event that includes the actor responsible for initiating the call (sender), the actor that received the call (recipient), the mode identifying the event as a phone call, and a timestamp indicating the time that the call was made. Other characteristics used to describe an event in relational event history 104 may include, for example, a unique identifier for the event, a duration indicating a length of the event, a type indicating the manner in which data relating to the event was formatted in data source 101, a unique identifier for a digital archive from which the event was accessed, and one or more fields related to enrichment attributes (e.g., additional data describing an actors involved in the event, such as job titles).


Data that is received from data source 102 may be normalized by data normalizer 103 in order to produce covariate data 105. Covariates are exogenous variables that may be involved in effects and that may be included in probability model 106. A public company using a probability model to analyze communication patterns might, for example, include the company's daily stock price as a covariate in the model, in order to shed light on the relationship between the price and communications between employees and outsiders. An individual covariate may be a global variable that occurred at or during a particular time for all actors in a relational event history (e.g., relating to an audit), may instead be a dyadic variable that occurred at or during a particular time for a pair of actors in the model (e.g., a supervisor-staff member relationship that existed between two employees), or may be an actor variable that occurred at or during a particular time for a specific actor (e.g., a salary).


As explained above, the inference engine 107 populates probability model 106 based on relational event history 104 and covariate data 105, the model having been formulated as a series of conditional probabilities that correspond to sequential decisions by actors, and including one or more statistical parameters and corresponding statistics that may relate to one or more of senders, modes, topics, or recipients of relational events.


Inference engine 107 may also determine a baseline communications behavior for the model 106, based on the populated model Inference engine 107 may, for example, determine a set of effect values through a maximum likelihood process, the determined values indicating the impact of the effects on event probabilities. The inference engine 107 may also determine departures from the baseline by determining a second set of values for the effects based on one or more subsets of the relational events included in relational event history 104, and comparing the second set of effect values to the first set of values.


UI 108 may be used to receive inputs from a user of system 100, and may be used to output data to the user. A user of the system may, for example, specify data sources to be used by normalizer 103 in determining relational history 104 and covariate data 105. The user may also provide inputs indicating which actors, modes, topics, covariates, and/or effects to include in model 106, as well as which subsets of the relational event history should be analyzed in determining departures from the baseline. UI 108 may provide the user with outputs indicating a formulation of model 106, a determined baseline for the model 106, and one or more determinations as to whether and how the subsets of relational event history being analyzed differ from the baseline. UI 108 may also provide the user with additional views and analyses of data so as to allow the user to draw additional inferences from the model 106.


In more detail, UI 108 may provide to the user, based on probability model 106, a determined baseline, and/or one or more determined departures from the baseline, textual and/or graphical analyses of data that uncover patterns, trends, anomalies, and change in the data. UI 108 may, for example, enable a user to form a hypothesis regarding the data by selecting one or more effects, covariates, and/or sets of focal actors, and curves may be displayed based on the user's hypothesis, where the curves indicate periods of time in which communications behavior is normal, as well as periods of time in which communications behavior is abnormal. Other visualizations of the data, such as summations of communications behavior involving particular actors, modes, and/or topics, may be provided by UI 108


Curves displayed to the user through UI 108 may correspond to an actor, to a subset of actors, and/or to all actors in the relational event history. Color coding may be used to indicate periods of time in which communications behavior is normal, and periods of time in which communications behavior is abnormal. A user may be able to select between varying levels of sensitivity through which normality and abnormality are determined, and UI 108 may dynamically update as selection of sensitivity occurs.


Multiple curves, each representing different effects or covariates, may be displayed by UI 108 in an overlapping fashion, and the curves may be normalized and smoothed. The curves may be displayed in two dimensions, where the x axis is associated with time, and where the y axis is associated with properties of effects and/or covariates. UI 108 may display icons and/or labels to indicate effects, covariates, or actors to which curves correspond. UI 108 may further display labels within the two dimensional field in which the curves are plotted, the labels indicating exogenous events or providing other information.


UI 108 may also enable a user to zoom in to the displayed curves in order to view a display of events at a more granular level, with information pertaining to the displayed events being presented through icons that may be color-coded according to mode, and that may be sized to indicate, for example, a word count or length of conversation. UI 108 may also provide access to individual communications related to events. UI 108 may, for example, display an individual email in response to a user selection or zoom.


In response to a user selection, UI 108 may also display, for a particular actor, behavioral activity over time. The behavioral activity may be displayed, for example, in a polar coordinate system, where the radial coordinates of points in the plane correspond to days, and where angular coordinates correspond to time slices within a particular day.


In more detail, each point plotted in the plane may correspond to a particular communications event, and may be color coded to indicate a mode of communication or other information. Points plotted in the plane may be located on one of several concentric circles displayed on the graph, and the circle on which a point is located may indicate a day on which the communication took place, while the position of the point on the circle may indicate a time slice (e.g., the hour) in which the communication took place. A user may be able to select a communication event that is plotted on the graph to obtain content. For example, a user may click or hover over a point that indicates an SMS message in order to retrieve the text of the SMS message.


In some implementations of UI 108, a polar graph indicating behavioral activity over time may be animated, enabling a user to “fly through” a visual representation of behavioral activity over particular periods of time, where the circles and events presented for a particular period of time correspond to the days within that period, and where the period displayed dynamically shifts in response to user input.



FIG. 2 is a flowchart of an example of a process 200 for analyzing a relational event history. The process 200 may be implemented, for example, using system 100, although other systems or configurations may be used. In such an implementation, one or more parts of the process may be executed by data normalizer 103 or inference engine 107, which may interface with other computers through a network. Data normalizer 103 may retrieve data involved in the process, such as data used in determining a relational event history or covariates, from one or more local or remote data sources, such as data sources 101 and 102.


Process 200 begins when data normalizer 103 accesses event and/or other data from data sources 101 and 102 (201). After accessing the event and/or other data, the data normalizer 103 normalizes the accessed data, determining a relational event history 104 and covariate data 105 (203).


The process of normalizing event and other data and determining a relational event history and covariates may involve, among other things, extracting event data from accessed data, transforming the extracted data to a state suitable for populating the probability model 106, and enriching the transformed data with additional information gathered from other data sources. The accessed event data may, for example, include an email sent by one actor to two others, the email relating to a topic specified in the probability model 106. The data normalizer 103 may parse the email to extract a time stamp, a sender, a topic, and recipients. Extracted data may then be transformed by data normalizer 103, resulting in relational data with disambiguated actors that maps to the categories of decisions included in a probability model 106. The data normalizer 103 may then enrich the transformed data by, for example, scraping one or more websites to obtain additional data relating to the sender or recipients. The enriched data representing a relational event corresponding to the email may then be added to relational event history 104. The data normalizer 103 may perform similar operations in the process of producing covariate data 105.


A probability model 106 may be populated by inference engine 107 based on the relational event history 104 and covariate data 105 (205). In some implementations, the probability model 106 is formulated as a series of conditional probabilities that correspond to a set of sequential decisions by an actor. For each event, the set of sequential decisions includes a decision to send a communication, a decision as to amode of the communication, a decision as to a topic of the communication, and one or more decisions as to recipients of the communication. A multinomial logit distribution can be used to model the probabilities of the discrete choice problem presented by each decision, with the primary factors affecting the probability of an event occurring are a set of event statistics (also referred to as effects), which are based in social network theory. For example, a woman's probability of emailing her boss may be different if she has received 4 emails from clients within the past 24 hours than if she has received none. Likewise, a man may be more or less likely to make a phone call depending on the number of people who have called him recently.


The model's multinomial logit distribution may include a coefficient that is multiplied by these event statistic values and therefore describes the statistic's effect on event probabilities. This coefficient may be referred to as an effect value or a statistical parameter. Effects may be formulated using backward looking statistics, such as time-decayed sums of recent events of certain types, or the last event that was received by the ego (sender) in question, which may be referred to as participation shifts.


In more detail, a relational event history custom character, such as relational event history 104, may include relational events that occur at moments in time among a finite set of actors. The composition of this set of actors may depend on time t, and is denoted custom character(t). Any ordered pair of actors is called a dyad, and relational events are denoted as tuples, where:

    • the sender of the event, also called the ego, is represented by i∈custom character(t),
    • the mode of the event is represented by m∈custom character,
    • the topic of the event is represented by b∈custom character,
    • the recipients of the event, also called the alters, are represented by the set of j∈custom charactercustom character(t), and
    • the timestamp of the event is represented by t∈[0, ∞).


For notational convenience, a number of functions are defined for an event e:

    • m(e) refers to the mode of event e,|
    • b(e) refers to the topic of event e,
    • custom character(e) refers to the alters of event e, and
    • τ(e) refers to the timestamp of event e.
    • i(e) refers to the ego of e,


A strictly ordered set of these relational events constitutes a relational event history, which may be represented through use of the shorthand notation:

ε={e∈ε:τ(e)<t},


The event history is an endogenous variable Other, exogenous variables (i.e., covariates) may also be included in the probability model, and these covariates may be partitioned into three types:

    • 1. global covariates that h|ave the same value for all actors and relationships. The global covariates are denoted by the set custom character. A covariate Wαcustom character is a function that maps a timestamp t to a real value Wα(t).
    • 2. actor covariates that are permitted different values for each actor. The actor covariates are denoted by the set χ. A covariate Xα∈χ is a function that maps a timestamp/actor pair (i, t) to a real value Xα(i, t).
    • 3. dyadic covariates that are permitted different values for each dyad. The dyadic covariates are denoted by the set custom character. A covariate Yαcustom character is a function that maps a timestamp/dyad pair (i, j, t) to a real value Yα(i, j, t).


Typically, covariates will have a time domain equal to the relational event history. The combination of the relational event history and the covariates constitutes a dataset that may be denoted:

custom character=(ε, custom character, χ, custom character)


A probability density representing the probability of the occurrence of each relational event in the relational event history and based on the dataset may be denoted:

ƒ(ε|custom character, χ, custom character, custom character0, θ)

where custom character0 denotes all information before t=0 and θ is a statistical parameter


The probabilities may be conditioned on all prior events and information, including an initial state t=0, such that the probability density may be rewritten:







f

(



|
𝒲

,
𝒳
,
𝒴
,

𝒵
0

,
θ

)

=




e





f

(


e
|



τ

(
e
)



,
𝒲
,
𝒳
,
𝒴
,

𝒵
0

,
θ

)






For practical reasons, it may be beneficial to restrict the conditional densities such that only covariate information known at time t can influence the probabilities of event occurrence. Accordingly, the probability density can be simplified by requiring that:

ƒ(e|ετ(e), custom character, χ, custom character, custom character0, θ)=ƒ(e|custom characterτ(e), θ)


The probability density may be decomposed into a series of conditional probabilities that correspond to a set of sequential decisions by an actor:

ƒ(e|custom characterτ(e), θ)=ƒ(i(e), τ(e)|custom characterτ(e), θ)×
ƒ(m(e)|i(e), τ(e), custom characterτ(e), θ)×
ƒ(b(e)|i(e), τ(e), m(e), custom characterτ(e), θ)×
ƒ(custom character(e)|i(e), τ(e), m(e), b(e), custom characterτ(e), θ)


The conditional probabilities included in this version of the model consist of:

    • the joint ego/interarrival density ƒ(i(e), τ(e)| . . . ), which describes the |process by which the ego (i.e. sender) of an event waits some time and then decides to send an email,
    • the mode density ƒ(m(e)| . . . ), which describes the process of the ego choosing to communicate (e.g. by email or by phone),
    • the topic density ƒ(b(e)| . . . ), which describes the process of ego deciding to communicate about one of some finite set of topics,
    • and the alter density ƒ(custom character(e)| . . . ) which describes the process of the ego deciding to communicate with some set of alters (i.e. recipients).


The ego/interarrival density, which describes a process by which an ego chooses to initiate an event following a most-recent event, can be modeled using a semi-parametric approach in the spirit of the Cox proportional hazards model:


Suppose that t* is the time of the most recent event to occur, or 0 if none yet occurred. We assume that, for all egos i∈custom character(t) and for all interarrival times t∈(0, ∞) until the next event, that

ƒ(i, t|custom charactert*+t, θ)=λ0(t)×exp ϕI(i|custom charactert*, θ).


Notably, the function ϕI, which models the probability density that the next event to occur after t* entails ego i sending an event after a holding time of t, does not depend on the interarrival time t, and therefore cannot incorporate information accumulated since the last event. Moreover, the baseline hazard rate λ0(t) depends on neither ego i nor the interarrival time t. As such, the hazards between all candidate egos are proportional:








f

(


i
a

,

t
|




t
*

+
t



,
θ

)


f

(


i
b

,

t
|




t
*

+
t



,
θ

)


=


exp



ϕ
I

(



i
a

|



t
*



,
θ

)



exp



ϕ
I

(



i
b

|



t
*



,
θ

)







For convenience, a linear form for ϕI may be used:

ϕI(i|custom charactert*, θ)=αTsI(i, custom charactert*)

    • where sI(i, custom charactert*) is a statistic and α⊂θ.


This form allows the baseline hazard rate to be ignored in modeling, as estimation entails only a partial likelihood. Thus, the optimal parameter θ can be found by maximizing, over the relational event history, the probability density that the ego for each event would send an event, as opposed to the other actors:







P

(



i

(
e
)

=


i
*

|



τ

(
e
)




,
θ

)

=


exp



ϕ
I

(



i
*

|



τ

(
e
)



,
θ

)






i


𝒩

(

τ

(
e
)

)




exp



ϕ
I

(


i
|



τ

(
e
)



,
θ

)








The fact that the function ϕI does not depend on the interarrival time t, and therefore cannot incorporate information accumulated since the last event, necessitates a further assumption regarding covariate values. Namely, that changes to covariate values occur only at moments when events occur. More formally:


given an event history ε, a covariate ζ, a|nd two time points t and t+dt≥t, if there exists no e∈ε such that τ(e)∈(t, t+dt], then ζ(t)=ζ(t+dt).


The incorporation of the passage of time into the impact of an event on future events may modeled through a decay function using the following general form:







s

(

t
,


)

=




{

e


ϵε
:


Ψ
I

(

e
,


)



}




δ

(

t
,

τ

(
e
)


)










where




Ψ
I

(

e
,


)



is


called


a


predicate

,


and


describes


criteria


by


which


a







subset


of


events


is


selected






Effects that evaluate an actor's decision to initiate a communication may be referred to as “ego effects.” It possible to develop effects that depend on either or both of the relational event history and covariates. Ego effects that depend on the relational event history may include the activity ego selection effect and the popularity ego selection effect, both of which quantify the amount of communications that have recently been sent to (popularity) or sent by (activity) the candidate ego i*, where recency is determined by specifying the effects through predicates:

    • the activity ego selection effect

      ΨI(e, i*)={i*=i(e)}
    • the popularity ego selection effect

      I(e, i*)={i*∈custom character(e)}


Ego effects that depend on covariates may include the actor covariate ego selection effect and the indegree dyadic covariate ego selection effect:

    • the actor covariate ego selection effect for actor covariate xα
      (sI(i*, custom charactert)=xα(i*),
    • and the indegree dyadic covariate ego selection effect for dyadic covariate yα








s
I

(


i
*

,


t


)

=




j

ϵ𝒩

t






y
a

(

j
,

i
*


)

.






The mode density, which describes the process of the ego choosing one of a finite set of modes, can be represented through a conditional distribution:

ƒ(m(e)|i(e), τ(e), custom characterτ(e), θ)


A model for the selection of a mode by the ego is the multinomial logit, or discrete choice distribution:







f

(


m

(
e
)

=


m
*

|



)

=


exp



ϕ
M

(


m
*

,


)






m

ϵ





exp



ϕ
M

(

m
,


)








For convenience, a linear form for ϕM may be used:

ϕM(m*, . . . )=βTsM(m*, . . . )

    • where sM (m*, . . . ) is a statistic and β⊂θ


Effects that evaluate the ego's decision as to the method of communication may be referred to as “mode effects.” Mode effects may include the relay mode selection effect, which quantifies a selected ego i's tendency to contact other actors through a candidate mode m* that was recently used by other actors to contact i, and the habit mode selection effect, which quantifies a selected ego i's tendency to contact other actors through a candidate mode m* that i recently used to contact other actors:

    • the relay mode selection effect

      ΨM(e, m*, i)={m*=m(e), i∈custom character(e)}
    • the habit mode selection effect

      ΨM(e, m*, i)={m*=m(e), i=i(e)}.


The topic density, which describes the process of the ego choosing one of a finite set of topics, given a previous choice of mode, can be represented through a conditional distribution:

ƒ(t(e)|m(e), i(e), τ(e), custom characterτ(e), θ)


As with selection of a mode, the selection of a topic by the ego can be modeled using a multinomial logit, or discrete choice distribution, the selected mode being introduced into the topic distribution as a covariate:







f

(


b

(
e
)

=


b
*

|



)

=


exp



ϕ
B

(


b
*

,


)






b

ϵ




(

τ

(
e
)

)





exp



ϕ
B

(

b
,


)








For convenience, a linear form ϕB for may be used:

ϕB(b, . . . )=γTsB(b, . . . )

    • where sB(b, . . . ) is a statistic and γ⊂θ


Effects that evaluate the ego's decision as to the topic of communication may be referred to as “topic effects.” Topic effects may include the relay topic selection effect, which quantifies a selected ego i's tendency to communicate with other actors about a candidate topic b* that recently appeared in communications sent to i by other actors, and the habit mode selection effect, which quantifies a selected ego i's tendency to communicate with other actors about a candidate topic b* that recently appeared in communications sent by i to other actors:

    • the relay topic selection effect

      ΨB(e, b*, . . . )={b*=b(e), m=m(e), i=j(e)}
    • the habit topic selection effect

      ΨB(e, b*, . . . )={b*=b(e), m=m(e), i=i(e)}


The alter density, which describes the process of the ego choosing to communicate with a set of alters, given previous choices of mode and topic, can be represented through a conditional distribution:

ƒ(custom character(e)|b(e), m(e), i(e), τ(e), custom characterτ(e), θ)


Notably, the size of the outcome space of possible alter sets custom character(e) can be enormous, even for a small custom character. The size of this set |custom character(e)| is stochastic and lies on the interval [1, custom characterτ(e)). For each size |custom character(e)| on this interval, we have:







(







"\[LeftBracketingBar]"


𝒩

τ

(
e
)




"\[RightBracketingBar]"


-
1








"\[LeftBracketingBar]"


𝒥

(
e
)



"\[RightBracketingBar]"





)






As such, the dimensionality of the outcome space is:









a
=
1



𝒩

τ

(
e
)


-
1



(







"\[LeftBracketingBar]"


𝒩

τ

(
e
)




"\[RightBracketingBar]"


-
1





a



)





To avoid practical problems associated with the enormity of the outcome space of possible alter sets, custom character may be modeled as an ordered set, such that the ego adds actors into the alter set alter-by-alter:








𝒥

(
e
)

=

{


j
1

,

j
2

,


,

j



"\[LeftBracketingBar]"


𝒥

(
e
)



"\[RightBracketingBar]"




}







𝒥
*

(
a
)

=

{



0



a
=
1






{


j
1

,

j
2

,


|

,

j

a
-
1



}




a
>
1










Modeled in this way, the density may be decomposed:







f

(


𝒥

(
e
)

|


)

=




a
=
1




"\[LeftBracketingBar]"


𝒥

(
e
)



"\[RightBracketingBar]"




f

(



j
a

|


𝒥
*

(
a
)


,


)






Each element in the decomposition of the density may be modeled using a multinomial logit, or discrete choice distribution:







f

(



j
*

|


𝒥
*

(
a
)


,


)

=


exp



ϕ
J

(


j
*

,


𝒥
*

(
a
)

,


)






j

ϵ




(


i

(
e
)

,


𝒥
*

(
a
)


)




exp



ϕ
J

(

j
,


𝒥
*

(
a
)

,


)








In the modeling of the elements, the alter risk set custom character(α) defines the choices of alter available to an ego for the alter selection decision at hand. One way of characterizing the alter risk set is:









(

i
,


𝒥
*

(
a
)


)

=

{





𝒩

τ

(
e
)



\

i






𝒥
*

(
a
)

=








𝒩

τ

(
e
)



\



𝒥
*

(
a
)




else










    • where we denote the choice of j*=i(e) as the choice to not add any more alters into the set custom character(e).





Decomposing the model for alter selection in this way makes it possible to specify ϕJ in a linear form:

ϕJ(j, custom character*(α), . . . )=ηTsJ(j, custom character*(α), . . . )

    • where sJ(j, custom character*, (α), . . . ) is a statistic and η⊂θ


Effects that evaluate the ego's decision(s) as to the recipient(s) of a communication may be referred to as “alter effects.” It possible to develop alter effects that depend on either or both of the relational event history and covariates. Alter effects that depend on the relational event history may include the fellowship alter effect and the repetition alter effect:

    • the Fellowship Alter Effect

      ΨJ(e, j*, custom character*(α), . . . )={i∪j*∪custom character*(α)⊆i(e)∪custom character(e)}
    • and the Repetition Alter Effect

      ΨJ(e, j*, custom character*(α), . . . )={i=i(e), j*∈custom character(e)}.


Alter effects that do not depend on the relational event history may include the activity alter effect and the actor covariate alter effect:

    • the Activity Alter Effect

      sJ(j*, custom character*(α), . . . )=1−custom character{i(e)=j*}
    • where custom character{i(e)=j*} is the indicator function,
    • and the Actor Covariate Alter Effect

      sJ(j*, custom character*(α), . . . )=(1−custom character{i(e)=j*})X{j*, τ(e)}
    • where X{j*, τ(e)} is the value of the actor covariate X for actor j* at time τ(e).


In some situations, it may be advantageous to restrict the model to a set of focal actors custom character(t), a subset of actors in the relational event history:

εF={e∈ε:i(e)∈custom character(τ(e))}


These situations can arise, for example, when there is a need for analysis of communications involving only a subset of actors in the relational event history, or when the relational event history includes complete data for one subset of actors but not for another. In these situations, instead of drawing inference using the joint probability of the entire event history, the joint probability of all events sent by the focal actors may be modeled. The joint probability density of all events sent by focal actors may be written:







f

(




F

|



\



F



,
𝒲
,
𝒳
,
𝒴
,


0

,
θ

)

=




e


ϵℱ

(

τ

(
e
)

)





f

(


e
|



τ

(
e
)



,
𝒲
,
𝒳
,
𝒴
,


0

,
θ

)






In this distribution, all events that are initiated by non-focal actors are regarded as exogenous.


Following the population of the probability model 106 based on the relational event history 104 and covariate data 105, a baseline of communications behavior is determined (207). For example, in a situation in which the model described with respect to operation 205 is used, a baseline may be determined by estimating the effect values (statistical parameters). The estimated effect values represent the baseline communications behavior because they indicate the impact of the corresponding effect (statistic) on the event probabilities.


The effect values may be estimated, for instance, through maximum likelihood methods. The Newton-Raphson algorithm, for example, may be used. The Newton-Raphson algorithm is a method of determining a maximum likelihood through iterative optimization of parameter values that, given a current set of estimates, uses the first and second derivatives of the log likelihood function about these estimates to intelligently select the next, more likely set of estimates. Through the Newton-Raphson method, which may be performed, for example, using a distributed computing platform, a converged estimate of each effect value included in the probability model may be obtained.


Departures from the baseline of communications behavior may be determined (209). For instance, the baseline can be considered normal communications behavior, and deviations from the baseline can be considered abnormal, or anomalous behaviors. In models in which the baseline is represented by effect values estimated based on the relational event history, anomalous behaviors may be detected by comparing effect values for subsets (also referred to as pivots) of the relational event history to the baseline values in order to determine whether, when, or where behavior deviates from the norm.


A pivot may, for example, include only events involving a specific actor during a specific time period, only events involving a specific set of topics, or only events involving a specific subset of actors. If, for example, the baseline reveals that actors in the relational event history typically do not communicate between midnight and 6:00 AM, a particular actor initiating 30 events during those hours over a particular period of time might be considered anomalous. As another example, if one subset of actors typically communicates by email, but the majority of communications between actors in the subset during a specific time frame are phone calls, the switch in mode might be considered anomalous.


Effect values may be determined for a pivot using the same methods employed in determining the baseline, for example, through use of the Newton-Raphson method. Pivot-specific effect values may be referred to as “fixed effects.”


Comparison of the fixed effects to the baseline may allow for estimation of the degree to which the communications behavior described by a particular pivot departs from normality. Other, more involved inferences may also be drawn. For example, it is possible to determine whether a fixed effect has high or low values, is increasing or decreasing, or is accelerating or decelerating. Further, it is possible to determine whether or how these features hang together between multiple fixed effects. Analyses of this nature may be performed through a hypothesis-testing framework that, for example, employs a score test to compare an alternative hypothesis for one or more effect values to a null hypothesis (i.e., the baseline).



FIG. 3 is a flowchart of an example of a process for determining a baseline communications behavior for a relational event history. The process 300 may be implemented, for example, using system 100. In such an implementation, one or more parts of the process may be executed by inference engine 107, which may interface with other computers through a network. Inference engine 107 may, for example, send or receive data involved in the process to and from one or more local or remote computers.


Assuming that the relational event history 104 and covariate data 105 contain enough information to compute probabilities of all events in the dataset, estimation of the baseline may be performed using a maximum likelihood method.


In more detail, it is possible to estimate effect values through maximum likelihood methods such as the Newton-Raphson method. Newton-Raphson is a method of iterative optimization of parameter values that, given a current set of estimates, uses the first and second derivatives of the log likelihood function about these estimates to intelligently select the next, more likely set of estimates. When applied in determining a baseline for the probability model 106, the Newton-Raphson method may use the first and second derivatives of the log likelihood function about a set of estimated effect values in order to select the next, more likely set of estimated effect values, with the goal of maximizing the “agreement” of the probability model 106 with the relational event history 104 and covariate data 105 on which the model 106 is based. Convergence of a set of effect values may be considered to have occurred when a summation across all events of the first derivative of the log likelihood function about the currently estimated effect values is approximately zero, and when the summation across all events of the second derivative of the log likelihood function about the currently estimated effect values meets or exceeds a threshold of negativity.


The joint probability of the relational event history ε may be adapted into a log likelihood that can be maximized numerically via Newton-Raphson:







L

(

θ
|


)

=




e

ϵ






log


f

(


e
|

𝒵

τ

(
e
)



,
θ

)







The method begins with an initial parameter estimate {circumflex over (θ)}0 (301). First and second derivatives of the log likelihood with respect to θ may be derived (303):








V

(

θ
|


)

=




L

(

θ
|


)




θ









(

θ
|


)

=

-




2


L

(

θ
|


)





θ
2









The initial parameter estimate {circumflex over (θ)}0 may be refined iteratively through update steps, in which first and second derivatives are evaluated at {circumflex over (θ)}i for each event (305) and then summed across all events (307) in order to arrive at a new parameter estimate {circumflex over (θ)}i+1 (309):








θ
^


i
+
1


=




θ
^



i


+



V


θ
^

i

T

(

θ
|


)







θ
^

x


-
1


(

θ
|


)



|





Update steps may continue until optimization converges on a value (311). The converged value is the maximum likelihood estimate {circumflex over (θ)}, which has an estimated covariance matrix that is the inverse of the second derivative matrix evaluated at {circumflex over (θ)}0:

{circumflex over (Σ)}{circumflex over (θ)}=custom character{circumflex over (θ)}−1(θ|custom character)


In a system 100 in which inference engine 107 is implemented on a distributed computing platform, the process of determining a baseline may involve distribution of the model 106 to a plurality of computers associated with inference engine 107, each of which is involved in computing the maximum likelihood estimate {circumflex over (θ)} through the Newton-Raphson algorithm. Different computers may, for example, evaluate first and second derivative values for different events, with those evaluated derivatives then being summed. In such an implementation, an individual computer to which the model is distributed may evaluate first and second derivatives for a single event (305) during each update of Newton-Raphson, and may report the evaluations to a central computer that sums the first and second derivatives across all events (307), and that forms a new parameter estimate based on the result of summing the first and second derivatives (309).


As explained above, each of the conditional distributions in the probability model 106 may be formulated as a multinomial logit. For purposes of deriving first and second derivatives that may be used in determining a baseline through the Newton-Raphson method, the following multinomial distribution, featuring a random variable X with an outcome space χ and an arbitrary statistic s(x), may be considered:







f

(

X
=

x
|
θ


)

=


exp


θ
T



s

(
x
)







x
a


𝒳



exp


θ
T



s

(

x
a

)








The log likelihood of this distribution may be denoted:












(

X
=

x
|
θ


)

=


log


f

(

X
=

x
|
θ


)








=




θ
T



s

(
x
)


-

log






x
u


𝒳



exp


θ
T



s

(

x
a

)












The first derivative of g is:














(

X
=

x
|
θ


)

=







(

X
=

x
|
θ


)




θ








=







θ



θ
T



s

(
x
)


-





θ


log






x
a


𝒳



exp


θ
T



s

(

x
a

)











=



s

(
x
)

-






x
a


𝒳




s

(

x
a

)


exp


θ
T



s

(

x
a

)








x
a


𝒳



exp


θ
T



s

(

x
a

)











=



s

(
x
)

-


E
θ



{

s

(
X
)

}












    • where Eθ{s(X)} is the expectation of the statistic s(X) with respect to the random variable X given the parameter θ.





Note that the expectation of a random variable y with domain Y and probability density p(y) is calculated by:









y

Y



yp

(
y
)





In deriving the first derivative of g, note that y=s(xα) and p(y) is the multinomial distribution ƒ(X=x|θ), which allows for the final simplification.


The second derivative of g is:














(

X
=

x
|
θ


)

=





2





(

X
=

x
|
θ


)

T





θ
2









=






θ




(


s

(
x
)

-


E
θ



{

s

(
X
)

}



)

T








=



-




θ





E
θ




{

s

(
X
)

}

T








=


-




X

𝒳







θ



f

(

X
=

x
|
θ


)




s

(
X
)

T











Note the relationship between f and the first derivative of g:














(

X
=

x
|
θ


)

=





log



f

(

X
=

x
|
θ


)




θ








=



1

f

(

X
=

x
|
θ


)







f

(

X
=

x
|
θ


)




θ











so that











θ



f

(

X
=

x
|
θ


)


=


f

(

X
=

x
|
θ


)







(

X
=

x
|
θ


)






Incorporating this relationship allows for further derivation:














(

X
=

x
|
θ


)

=


-




X

𝒳




f

(

X
=

x
|
θ


)







(

X
=

x
|
θ


)




s

(
X
)

T










=



-

E
θ


|

{






(

X
=

x
|
θ


)




s

(
X
)

T


}








=



-

E
θ




{


(


s

(
X
)

-


E
θ



{

s

(
X
)

}



)




s

(
X
)

T


}








=




-

E
θ




{


s

(
X
)




s

(
X
)

T


}


-


E
θ



{


[


E
θ



{

s

(
X
)

}


]




s

(
X
)

T


}









=




-

E
θ




{


s

(
X
)




x

(
X
)

T


}


-


E
θ



{

s

(
X
)

}



E
θ




{

s

(
X
)

}

T









=



-

Cov
θ




{

s

(
X
)

}










Covθ{s(X)} is the covariance matrix of s(X) given θ


It can be observed that:












Cov
θ



{





(

X
=

x
|
θ


)

}


|

=



Cov
θ



{


s

(
X
)

-


E
θ



{

s

(
X
)

]



}








=



E
θ



{


(


s

(
X
)

-


E
θ



{

s

(
X
)

}



)




(


s

(
X
)

-


E
θ



{

s

(
X
)

}



)

T


}








=



E
θ



{



s

(
X
)




s

(
X
)

T


-

2


E
θ



{

s

(
X
)

}




s

(
X
)

T


+












E
θ



{

s

(
X
)

}



E
θ




{

s

(
X
)

}

T


}






=




E
θ



{


s

(
X
)




s

(
X
)

T


}


-


E
θ



{

s

(
X
)

}



E
θ




{

s

(
X
)

}

T









=



-

Cov
θ




{

s

(
X
)

}









Giving:














(


X
-
x

|
θ

)

=



-

Cov
θ




{

s

(
X
)

}








=



-

Cov
θ




{





(

X
=

x
|
θ


)

}









Because each of the ego, mode, topic, and alter distributions are multinomial logits, these results can be applied when determining the baseline using the Newton-Raphson method.



FIG. 4 is a flowchart of another example of a process 400 for determining a baseline communications behavior for a relational event history. The process 400 may be implemented, for example, using system 100. In such an implementation, one or more parts of the process may be executed by inference engine 107, which may interface with other computers through a network. Inference engine 107 may, for example, send or receive data involved in the process to and from one or more local or remote computers.


The process 400 may be used when the order in which recipients are selected by the sender is unknown. As indicated above, in the situation in which the sender of a communication may select multiple recipients for the communication, the sender's choice of which recipients to include may be best modeled as a set of sequential decisions involving an order in which recipients are added by the sender to the communication, rather than a single decision. A single email, for example, may be addressed to multiple recipients, and the sender of the email may add each recipient in sequence.


As a result, a model, such as the one described with respect to operation 205 above, may model the choice of recipients as a sequential set of decisions. In this case, the model may be used without issue when the order of the selection of the recipients is known. However, in some cases, the recipients may be known, but not the order, which may present a missing data problem if the model is to be employed.


More formally, when attempting to determine a baseline, it may be the case that, for each event e, an unordered set of chosen alters custom character(e) is known, but custom character(e), denoting an ordered set of alters representing the sequence in which alters were chosen, is not known. In such a case, custom character(e), denoting the set of all possible ordered sets custom character(e) satisfying the requirement that the sequence of alter selections in custom character(e) could have yielded the observed custom character(e) is also not known, which presents a missing data problem.


To estimate {circumflex over (θ)} in such a situation, the expectation maximization (EM) algorithm may be employed. The algorithm consists of two steps that may be executed iteratively until {circumflex over (θ)} converges. Performing EM using probability model 106 involves calculation of expectations of quantities that depend on the missing sequences of alter choices. In general, evaluation of the expectation of a function h(custom character(e), custom characterτ(e), θ) may be performed using:








E
θ



{

h

(


𝒥

(
e
)

,



τ

(
e
)


,
θ

)

}


=





𝒥

(
e
)



𝒥

(
e
)





f

(



𝒥

(
e
)

|

𝒜

(
e
)


,



τ

(
e
)


,
θ

)



h

(


𝒥

(
e
)

,



τ

(
e
)


,

|
θ


)













where


density




"\[LeftBracketingBar]"


f
(

𝒥

(
e
)




"\[RightBracketingBar]"




𝒜

(
e
)


,



τ

(
e
)


,
θ

)



is


the


probability


of


the


alter








selection


sequence



𝒥

(
e
)



given


that


the


set



𝒜

(
e
)



is









ultimately



chosen
.






During a maximization step, a single update of the Newton-Raphson algorithm is conducted by summing the expected first and second derivatives across all events:

{circumflex over (θ)}i+1={circumflex over (θ)}i+E{circumflex over (θ)}i{VT(θ|custom character)}[E{circumflex over (θ)}i{custom character(θ|custom character)}]−1


New parameter estimates can be formed based on the result of summing the first and second derivatives, and the EM process may be repeated until convergence of {circumflex over (θ)}i is achieved.


The most practically difficult part of the EM process is computing expectations of the form:








E
θ



{

h

(


𝒥

(
e
)

,



τ

(
e
)


,
θ

)

}


=





𝒥

(
e
)



𝒥

(
e
)





f

(



𝒥

(
e
)

|

𝒜

(
e
)


,



τ

(
e
)


,
θ

)



h

(


𝒥

(
e
)

,



τ

(
e
)


,

|
θ


)







Two approaches may be taken, depending on the size of custom character(e), which is given by:

|custom character(e)|=|custom character(e)|!


When the number of actors in the unordered set of alters is below a threshold number (e.g., of size 5 or less), analytical estimation may be feasible and therefore performed. Noting that:








f

(



𝒥

(
e
)

|

𝒜

(
e
)


,



τ

(
e
)


,
θ

)

=


f

(


𝒥

(
e
)

,


𝒜

(
e
)

|



τ

(
e
)



,
θ

)


f

(



𝒜

(
e
)

|



τ

(
e
)



,
θ

)







and



𝒥

(
e
)




𝒜

(
e
)






f

(


𝒥

(
e
)

,


𝒜

(
e
)

|



τ

(
e
)



,
θ

)

=

f

(



𝒥

(
e
)

|



τ

(
e
)



,
θ

)






Since







f

(



𝒜

(
e
)

|



τ

(
e
)



,
θ

)

=





𝒥

(
e
)



𝒥

(
e
)




f

(



𝒥

(
e
)

|



τ

(
e
)



,
θ

)






It is possible to directly evaluate







f

(



𝒥

(
e
)

|

𝒜

(
e
)


,

𝒵

τ

(
e
)


,
θ

)

=


f

(



𝒥

(
e
)

|

𝒵

τ

(
e
)



,
θ

)


f

(



𝒜

(
e
)

|

𝒵

τ

(
e
)



,
θ

)






However, when the number of actors in the undordered set of alters is above a threshold number, analytical evaluation may be practically infeasible. Instead, numerical techniques, such as Markov chain Monte Carlo (MCMC) simulation, may be used to approximate the expectation.


To conduct maximum likelihood estimation with EM, an initial parameter estimate {circumflex over (θ)}0 made (401), and first and second derivatives are derived (403). Prior to performing the expectation step, a determination may be made as to whether the number of possible ordered alter sets, custom character, is above a threshold (404). If custom character is below the threshold, EM may proceed with the expectation being evaluated analytically (404). If, on the other hand, custom character, is above the threshold, MCMC is used to determine the expectation through simulation (406).


In the first case, in which custom character is below the threshold, expected first and second derivatives (custom character) and custom character, respectively) are evaluated for all events (405). A single update of the Newton-Raphson algorithm is conducted by summing the expected first and second derivatives across all events (407), and new parameter estimates are formed based on the result of summing the first and second derivatives (409). The EM process may then be repeated until convergence of {circumflex over (θ)}i is achieved (411).


In the second case, in which custom character is above the threshold, the expected first and second derivatives are determined for each event through simulation. For example, application of a numerical technique such as MCMC may be employed to conduct the simulation (406).


A Markov chain is a stochastic process involving transitions between states, where the conditional probability distribution of future states of the process depends only on the present state, and not on the preceeding sequence of states. For example, given a process with a set of two possible states i and j, the process is a Markov chain if the probability that the process will transition from a present state i to a next state j depends only on the present state i, and not on the states that preceded the present state. Many Markov chains feature what is called an equilibrium distribution, such that, from the present state, the probability that, after a sufficient number of transitions, the process will be in a specific state no longer changes from one transition to the next. If, for example, the probability of the process being in state i after n transitions is p, and the probability of the process being in state i after any number of transitions after n is also p, then the Markov chain can be said to have an equilibrium distribution.


Monte Carlo methods are computational algorithms that randomly sample from a process, and Markov chain Monte Carlo methods involve sampling from a Markov chain constructed such that the target distribution is the Markov chain's equilibrium distribution. After a sufficient number of transitions, draws taken from the Markov chain will appear as if they resulted from the target distribution. By taking the sample average of draws, values for quantities of interest can be approximated.


MCMC may be used to approximate expectations of quantities that depend on a missing sequence of alter choices. In more detail, MCMC may be used to sample draws of possible ordered sets of alters, custom character, from the density custom character, which is the probability of the alter selection sequence custom character given that the set of undordered alters custom character(e) is chosen. Draws may be sampled in the following way:







Let




𝒥

(
1
)


(
e
)



be


an


arbitrary


sequence


containing


the


elements


of




𝒜

(
e
)

.

For



each


desired



(

i
-
th

)



sample




𝒥

(
i
)


(
e
)


,


execute


the


following



steps
:



1.

Draw


a


new


sequence




𝒥
*

(
e
)





(
e
)



at


uniform



random
.



𝒥
*

(
e
)




is


called


the



proposal
.

2.



Evaluate


the


acceptance


proability



π
i





=

max


{

1
,


f

(



𝒥
*

(
e
)

,


𝒜

(
e
)

|

𝒵

τ

(
e
)



,
θ

)


f

(



𝒥

(
i
)


(
e
)

,


𝒜

(
e
)

|

𝒵

τ

(
e
)



,
θ

)



}












3.

With


probability



π
i


,


set



𝒥

(
i
)



=

𝒥
*


,


otherwise


set



𝒥

(
i
)



=


𝒥

(

i
-
1

)


.







Because the sample sets custom character(e) are approximately distributed ƒ(custom character(e)|custom character(e), custom characterτ(e), θ), it is possible to calculate the expectation, using a sample size N, by the ergodic average:








E
θ



{

h

(


𝒥

(
e
)

,

𝒵

τ

(
e
)


,
θ

)

}







i
=
1

N


h

(



𝒥

(
i
)


(
e
)

,

𝒵

τ

(
e
)


,
θ

)






Having calculated the expectation, expected first and second derivatives can be determined for all events (406). A single update of the Newton-Raphson algorithm is conducted by summing the expected first and second derivatives across all events (408), and new parameter estimates are formed based on the result of summing the first and second derivatives (410). The EM process may then be repeated until convergence of {circumflex over (θ)}i is achieved (412).



FIG. 5 is a flowchart of an example of a process 500 for modeling a set of sequential decisions made by a sender of a communication in determining recipients of the communication. The process 500 may be implemented, for example, using system 100. In such an implementation, one or more parts of the process may be executed by inference engine 107, which may interface with other computers through a network. Inference engine 107 may, for example, send or receive data involved in the process to and from one or more local or remote computers.


As explained above, in some situations, the alter risk set introduced earlier, which defines the choices of alter available to an ego for the alter selection decision at hand, can become extremely large, leading to computational complexity. As such, in a situation in which a sender of a communication (i.e. ego) may select multiple recipients (i.e. alters) for the communication, the sender's choice of which recipients to include may be best modeled as a set of sequential decisions involving an order in which recipients are added by the sender to the communication, rather than as a single decision. The model may be further refined by considering the sender's choice of which recipients to include as involving a two-stage decision process, whereby the sender first considers a social context in which to communicate, and then chooses recipients of the communication from a set of actors belonging to the social context. For example, in a situation in which potential recipients of the sender's communication appear in multiple social contexts or settings, the set of sequential decisions described above may include, for at least some of the events, one or more social context selection decisions, and one or more additional decisions as to which recipients in a selected social context(s) to include.


In more detail, a sender of a communication may interact with other actors in a variety of contexts, and both the sender and the other actors with whom the sender interacts may be categorized as belonging to specific social contexts or settings. A primary setting, for example, may include actors who belong to an organization or who engage in related activities, while another setting may include actors who have interacted, or who have the potential to interact, at a specific time and/or place.


A sender of a communication may, for example, choose to communicate with actors in a primary setting or in a meeting setting, with one set of potential recipients (e.g., a set including the sender's coworkers and clients) corresponding to the primary setting, and another set of potential recipients (e.g., a set including meeting attendees) corresponding to the meeting setting. In some instances, social contexts or settings may be mutually exclusive, with each potential recipient being modeled as belonging to only one context or setting. In other instances, actors categorized as belonging to one social context or setting may be categorized as belonging to others as well (e.g., a potential recipient may be both a coworker of the sender and a meeting attendee, in which case the potential recipient could be categorized as belonging to both the primary and meeting settings).


As such, for each communication event, a sender of the communication corresponding to the event may select a social context in which to communicate, prior to determining which potential recipients to communicate with, and the model may be formulated such that the calculation of probabilities associated with the sender's decisions takes this selection into account (501).


In more detail, a primary alter risk set custom character consisting of potential recipients belonging to a primary social context, and a meeting alter risk set custom character consisting of potential recipients belonging to a meeting social context, may be defined differently, and the sender of the communication may select one of the primary or meeting social contexts prior to sending a communication. If, for example, the primary social context involves actors with whom the sender has recently been in contact, the primary alter risk set custom character may be defined using a sliding window λ.


More formally, the set of actors with whom an ego i has been involved in at least one event occuring on the interval custom character may be written:

custom character(i, t, t0)={j∈custom charactert:|{e∈εt:{i, j}|⊆i(e)∪custom character(e), τ(e)≥t0}|>0}


In this case, the primary alter risk set custom character can be defined, given some sliding window λ, as:









𝒫

(

i
,


𝒥
*

(
a
)

,
t

)

=

{





𝒫

(

i
,
t
,

t
-
λ


)








𝒥
*

(
a
)

=







i



𝒫

(

i
,
t
,

t
-
λ


)


\



𝒥
*

(
a
)





else








Given this definition of the primary alter risk set custom character, the meeting alter risk set custom character may be defined such that the primary and meeting settings are mutually exclusive and collectively exhaustive:

custom characterM(i, custom character*(α), t)=custom character|(t)\custom characterp(i, custom character*(α), t)


Other definitions of the primary alter risk set custom character and the meeting alter risk set custom character are, of course, possible.


Based on the selection of the social context, the sender may make one or more additional decisions as to which recipients within the selected social context with whom to communicate. After selecting a primary social context, for example, the sender may determine a set of recipients for the communication by selecting one or more potential recipients from the primary alter risk set custom character, using a primary evaluation function (503). Alternately, after selecting another social context, the sender may determine a set of recipients for the communication by selecting one or more potential recipients from within the other social context, using another evaluation function (505).


The evaluation functions used to calculate probabilities associated with the sender's decisions as to recipients may differ depending on the selected social context, the differences reflecting the different ways in which the actor scrutinizes potential recipients in each setting. In the primary setting, for example, alter selection may occur in the same way described above with reference to FIG. 2, while a different evaluation function may be used for alter selection in the meeting setting. Alter selection in the meeting setting may involve, for example, choosing at uniform random a potential recipient who is in the meeting setting but who is not in the primary setting or the current alter set, and then evaluating whether to include the chosen potential recipient in the current alter set using an evaluation function that is specific to the meeting setting.


More formally, the probability density function for this example may be written:







f

(



𝒥

(
e
)

|

τ

(
e
)


,


)

=





j
*



𝒥

(
e
)




{




κ
·


f
P

(



j
*

|


𝒥
*

(
a
)


,

τ

(
e
)

,


)






j
*





P

(

i
,


𝒥
*

(
a
)

,

τ

(
e
)


)








(

1
-
κ

)

·


f
M

(



j
*

|


𝒥
*

(
a
)


,

τ

(
e
)

,


)






j
*





M

(

i
,


𝒥
*

(
a
)

,

τ

(
e
)


)












where

    • κ is the probability that ego i choo|ses to communicate within her primary setting,
    • ƒP is the probability density of adding j* to the alter set (given j* is in ego's primary setting),
    • custom characterp is the primary alter risk set corresponding to ego's primary setting,
    • ƒM is the probability density of adding j* to the alter set (given j* is in ego's meeting setting),
    • and custom characterM is the meeting alter risk set corresponding to ego's meeting setting.


The primary alter selection distribution ƒP included in the probability density function may differ in only minor ways from the alter selection distribution presented above. Specifically, the primary alter evaluation function ϕJP may be used, and the alters available for selection may be limited to those belonging to the primary alter risk set custom character, such that the primary alter selection distribution ƒP may be written:








f
P

(


j
*

|


)

=


exp



ϕ
JP

(


j
*

,


𝒥
*

(
a
)

,


)






j




JP

(


i

(
e
)

,


𝒥
*

(
a
)

,

τ

(
e
)


)




exp



ϕ
JP

(

j
,


𝒥
*

(
a
)

,


)








The meeting alter selection distribution ƒM may differ from the primary alter selection distribution ƒP. The meeting alter selection distribution ƒM may, for example, include two conditionally independent probabilities: a first probability that a member j* of the meeting setting is selected for evaluation, and a second probability that, conditioned on j* being selected for evaluation, j* is added into the alter set.


A probability that a member j* of the meeting setting is selected for evaluation for inclusion in the alter risk set, where selection between members of the meeting setting is at uniform random, may take the form:

|custom characterJM(i(e), custom character*(α), τ(e))|−1


The probability that a selected member j* is added into the alter set may take the form of a simple logit, where there are only two alternatives (to add j* to the alter set, or to not to add j* to the alter set):







exp



ϕ
JM

(


j
*

,


)



1
+

exp



ϕ
JM

(


j
*

,


)







As such, the meeting alter selection distribution ƒM may be written:








f
M

(


j
*

|


)

=





"\[LeftBracketingBar]"




JM

(


i

(
e
)

,


𝒥
*

(
a
)

,

τ

(
e
)


)



"\[RightBracketingBar]"



-
1


·


exp



ϕ
JM

(


j
*

,


)



1
+

exp



ϕ
JM

(


j
*

,


)









Employing, dependent on social context, different evaluation functions to calculate probabilities associated with a sender's decisions as to recipients of a communication, as described above, enables the social context(s) in which communications occur to be taken into account when modeling communications behavior.



FIG. 6 is a flowchart of an example of a process 600 for determining a statistic using a decay function. The process 600 may be implemented, for example, using system 100. In such an implementation, one or more parts of the process may be executed by inference engine 107, which may interface with other computers through a network. Inference engine 107 may, for example, send or receive data involved in the process to and from one or more local or remote computers.


The likelihood of an event's occurrence may depend on other events that have occurred in the past. The likelihood of a child calling her mother, for example, may increase if the mother recently attempted to call the child. The impact of past events on the likelihood of a future event may vary, however, depending on the relative distance of the events in terms of time. For example, a man may be more likely to respond to a voicemail left one day ago, than to a voicemail left one year ago.


When modeling social behavior, the impact of past relational events on the probability of a future relational event may be taken into account, and the reliability of the probability model may be enhanced by taking into account only those relational events that occurred within a certain time frame, and/or by discounting the impact of past relational events in proportion to their distance from the future relational event in terms of time. The concept of time may be considered in terms of, for example, clock time and/or social time. For example, when clock time is used, the amount of time since a previous event may be used to weight the relevance of the prior event. As another example, when social time is used, a number of relational events occurring between a past relational event and a future relational event may be used, for example, to weight the relevance of the past relational event.


In more detail, a decay function may be used within a model, or within a statistic included in a model, to incorporate the idea that relational events that occurred far in the past are less relevant for purposes of prediction than relational events that occurred recently.


As noted above, the incorporation of the passage of time into the impact of an event on future events may be modeled through a decay function using the following general form:







s

(

t
,


)

=




{

e



:


Ψ
I

(

e
,


)



}



δ

(

t
,

τ

(
e
)


)










where




Ψ
I

(

e
,


)




is


called


a


predicate


,

and


describes





criteria


by


which


a


subset


of


events


is


selected





In words, a statistic s may be determined based on a selected subset of relational events, where the subset of relational events is selected according to a predicate Ψ (601). Each selected event may then be weighted using a decay function δ (603), and the statistic s may be determined based on the weighted events by, for example, summing the weighted events (605).


The predicate Ψ describing criteria by which the subset of events is selected may vary depending on the statistics. The activity ego selection effect, for example, is a statistic that is defined through its predicate, where the predicate indicates that only those relational events e that have been sent by the ego i will be selected for inclusion in the subset. The predicate of another statistic, the popularity ego selection effect, instead specifies that only those relational events that have been sent to the ego i will be selected for inclusion in the subset.

    • the activity ego selection effect

      ΨI(e, i*)={i*=i(e)}
    • the popularity ego selection effect

      ΨI(e, i*)={i*∈custom character(e)}


The form of the decay function δ used to determine a statistic s determines the manner in which the relational events contained within the selected subset of relational events are weighted, where the weight of a relational event indicates the impact of the relational event on the probability of a future relational event's occurrence. An exponential decay function may be used, for example, to model the relevance of a first relational event for purposes of predicting the occurrence of a second relational event when the relevance is inversely proportional to the time that has passed since the first relational event's occurrence. Given some increasing value Δ, the value of an exponentially decaying quantity δ may be determined, for example, using the following exponential decay function:

δ(x, ρ)=exp{−ρΔ}


According to this function, the value of the quantity δ monotonically decreases in Δ when ρ>0. In nature, for example, values that decay in this way include masses of radioactive materials. The rate of decay is linear in the amount of quantity δ remaining:










δ

(

Δ
,
ρ

)




Δ


=


-
ρ




δ

(

Δ
,
ρ

)






In other words, the more positive the decay parameter ρ is, the more quickly the quantity δ decreases in Δ.


When modeling the relevance of a relational event to the occurrence of a future relational event, Δ can be considered to be an abstract representation of the passage of time:

For Δ∈[0, ∞) and ρ>0, δ(Δ, ρ)∈(0, 1]


Modeled in this way, when no time elapses, i.e. Δ=0, the relevance of an event is 1, and as Δ→∞, the relevance of an event approaches 0. When ρ=0, the relevance of an event is always 1, regardless of the amount of time Δ that has elapsed, and when ρ increases, the relevance of the event will approach 0 as time passes.


Δ can be used in different ways to model the passage of time from one event occuring at time t0 to another event occuring at time t1>t0. The simplest way to operationalize the passage of time through Δ is to use clock time, i.e. t1−t0, which yields a time decay function:

δ(t1−t0, ρ).


A disadvantage of using clock time in modeling the relevance of relational events, however, is that relevance will decay at the same rate without regard for social context. The relevance of a relational event will decay, for example, at the same rate in the middle of the night as it will during the middle of the workday. The concept of social time that progresses only when communications occur, rather than based on the passage of clock time, can be incorporated into the model by focusing on events occurring after t0 and at or before t1, events in the set:

ε(t0,t1]={e∈ε:τ(e)>t0, τe≤t1}


(t0,t1]|, i.e., the number of events occurring εt0,t1], may be used to operationalize the passage of social time, yielding an event-wise decay function:

δ(|ε(t0,t1]|, ρ).


When used to determine a statistic s based on a selected subset of relational events, the event-wise decay function renders the amount of clock time occuring between selected events irrelevant: instead of assigning weights to the selected events based on the passage of clock time, the event-wise decay function assigns weights to events based on the order in which they occurred. Specifically, the weights assigned by the event-wise decay function to a series of selected events vary such that each selected event has a higher weight than the event occuring after it in time, and a lower weight than the event occuring before it in time. Thus, when the event-wise decay function is used, it is the occurrence of events, rather than the passage of time, that matters for purposes of determining the relevance of a relational event.


The criteria for determining relevance may also be restricted to focus on the social time of a particular actor, i. A participating event-wise decay function, for example, may be formulated:

δ(#p(i, t0, t1), ρ) where
#p(i, t0, t1)=|{e∈ε(t0,t1]:∈i(e)∪custom character(e)}|


Like the event-wise decay function, the participating event-wise decay function renders the amount of clock time occuring between selected events irrelevant, because the weights assigned to events by the participating event-wise decay function vary based on the order in which events occurred. However, when the participating event-wise decay function is used, the weight assigned to a first selected event will match the weight assigned to a second selected event occuring after the first selected event in time, if the particular actor i did not participate in the second selected event. If, on the other hand, the actor i did participate in the second selected event (as, e.g., a sender or a receiver), the first selected event will have a higher weight than the second selected event. As such, when the participating event-wise decay function is used, it is the occurrence of events involving the actor i, rather than the passage of time, that matters for purposes of determining the relevance of a relational event.


The criteria for determining relevance may be further restricted so as to require, for example, that, for social time to elapse, the actor i must have been the sender of an event. A sending event-wise decay function may be formulated:

δ(#s(i, t0, t1), ρ) where
#s(i, t0, t1)=|{e∈ε(t0,t1]:i=i(e)}|


When the sending event-wise decay function is used, the weights assigned to events vary based on the order in which events occurred. However, a weight assigned to a first selected event by the sending event-wise decay function will match the weight assigned to a second selected event occuring after the first selected event in time, if the actor i did not send the second selected event. Alternatively, if the actor i did send the second selected event, the first selected event will have a higher weight than the second selected event. Thus, when the sending event-wise decay function is used, it is the occurrence of events sent by the actor i, rather than the passage of time, that matters for purposes of determining the relevance of a relational event.


Any of the exemplary decay functions described above may be used to determine a statistic s that is included in a probability model. The statistic s may be determined, for example, based on a selected subset of relational events, where the subset of relational events is selected according to a predicate Ψ that is specific to the statistic s (601). Each selected event may then be weighted using a decay function (603), and the statistic s may be determined based on the weighted events (605). The weighted events may be summed, for example, in order to produce a value for s.



FIG. 7 is a flowchart of an example of a process for analyzing social behavior. The process 700 may be implemented, for example, using system 100. In such an implementation, one or more parts of the process may be executed by inference engine 107, which may interface with other computers through a network. Inference engine 107 may, for example, send or receive data involved in the process to and from one or more local or remote computers.


A probability model that is populated based on a relational event history may be used to identify patterns, changes, and anomalies within the relational event history, and to draw sophisticated inferences regarding a variety of communications behaviors. As explained above, a baselining process may be used with a model to determine communications behavior that is “normal” for a given relational event history. The resulting baseline includes a set of effect values (statistical parameters) that correspond to the statistics included in the model. Once determined, the baseline can be employed to detect departures from normal communications behavior.


In more detail, the statistical parameters obtained through the baselining process can form the basis for follow on analysis; in practical terms, pinning down normality during the baselining process makes it possible to detect abnormality, or anomalous behaviors, in the form of deviations from the baseline. Effect values for subsets of the relational event history (“pivots”) may be compared to the baseline values in order to determine whether, when, and/or how behavior deviates from the norm. A pivot may, for example, include only relational events involving a specific actor during a specific time period, and effect values for a pivot (“fixed effects”) may be used to create an alternative hypothesis that can be compared with a null hypothesis, the baseline, through a hypothesis-testing framework that, for example, employs a score test.


Hypothesis testing may allow for estimation of the degree to which the communications behavior described by a particular pivot departs from normality. Other, more involved inferences may also be drawn. For example, it is possible to determine whether a fixed effect has high or low values, is increasing or decreasing, or is accelerating or decelerating. Further, it is possible to determine whether or how these features hang together between multiple fixed effects.


Thus, and as is explained in more detail below, social behavior may be analyzed by selecting a subset of relational events, the subset containing pivots (701), estimating values for corresponding fixed effects (703), determining an alternative hypothesis (705), and testing the alternative hypothesis against the null hypothesis, the baseline (707).


Selection of subsets of relational events (701) may be arbitrary, or may instead be driven by the particular individuals and/or behaviors that are the subjects of analysis. Recalling the popularity ego selection effect described above, an analyst may wish to determine based on a relational event history, for example, whether a particular actor's popularity increased over a particular period of time, in which case the relational events selected for inclusion in the subset of relational events may include relational events that occurred during the particular period of time, and in which the particular actor was a participant.


In more detail, a set Ξ={ξ1, ξ2, . . . } includes pivots ξi⊆ε that are selected subsets of the relational event history, and hypothesis testing my be performed in order to determine whether statistical parameters corresponding to effects being evaluated over the pivots are homogenous over the entire relational event history ε, or if they are instead heterogeneous, differing for some elements of the subset Ξ.


As described above, a statistical parameter may be denoted θ=(α, β, γ, η), where α denotes ego effects, β denotes mode effects, γ denotes topic effects, and η denotes alter effects. In order to account for heterogeneity of effects between pivots, the model may be elaborated, to allow a set of statistical parameters Ω to vary across events. In the elaborated model, the set of statistical parameters may be denoted Ω=(ω1, . . . , ω|Ξ|), where ωi corresponds to a i-th level pivot ξi. An i-th level pivot may, for example, contain a subset of relational events in which a particular actor i was a participant. Parameters may depend on events, such that:








θ
i

(
e
)

=

{




ω
i




e


ξ
i







θ
0



else








Notably, ωi0 yields a pivot-homogenous specification. A model in which ωi0 may be referred to as a restricted model, and a model in which ωi is a free parameter may be referred to as an unrestricted model.


Having selected a subset of the relational event history for analysis, parameter estimation may be performed (703). Although it is possible to estimate effect values for a pivot using the same methods employed in determining the baseline, doing so may be computationally costly and ultimately unnecessary. As such, a single step of the Newton-Raphson algorithm may be employed, starting from the baseline values, and calculating the next, more likely effect values for the pivot. These pivot-specific next, most likely effect values are the fixed effects.


In more detail, fitting the restricted model results in a maximum likelihood estimate {circumflex over (θ)}0 for the restricted model, a score contribution for each event custom character, evaluated at {circumflex over (θ)}0, and a Fisher information contribution for each event, custom character, evaluated at {circumflex over (θ)}0.


The maximum likelihood estimate, score contributions, and Fisher information contributions may be used to execute a single Newton-Raphson step, to estimate ωi. Pivots may be indexed by i and, for each pivot, a score contribution custom character, and an information contribution custom character may be calculated, so as to produce a one-step estimator that can be used to test hypotheses about the pivots, where:









V


θ
^

0


(

θ
|

ξ
i


)

=




e


ξ
i





V


θ
^

0


(

θ
|
e

)











θ
^

0


(

θ
|

ξ
i


)

=




e


ξ
i








θ
^

0


(

θ
|
e

)








ω
^

i

=



θ
^

0

+



V


θ
^

0

T

(

θ
|

ξ
i


)







θ
^

0


-
1


(

θ
|

ξ
i


)








Estimates for fixed effects can be used to infer departures from usual behavior by constructing hypotheses about them, and each fixed effect value may correspond to a particular relational event included in the subset of relational events. A hypothesis may include predictions regarding heterogeneity of fixed effects over pivots, as well as temporal differencing of fixed effects.


Temporal differencing of a fixed effect may be defined over three levels: Δit, the value of the fixed effect over a particular time period, velocity, Δ′it, the first difference of the fixed effect with respect to time, and acceleration, Δ″it, the second difference of the fixed effect with respect to time. Predictions may be made regarding, for example, the popularity of a particular individual within a particular time period, a rate at which the popularity of the individual increased or decreased over the particular time period, and as to whether the rate of change in popularity increased or decreased over the particular time period.


As described above, Ξ may be defined as a set of pivots ξit, where each ξit is a subset of events pertaining to a particular actor i that occurred during a particular time period t. If ωit∈Ω is a fixed effect for the i-th pivot level over the t-th time interval, the levels of temporal differencing may be defined:

Δitit
Δ′itit−ωi(t−1)
Δ″it=Δ′it−Δ′i(t−1)


Hypotheses involving the levels Dit=(Δit, Δ′it, Δ″it) and a weight vector q the weights in the vector reflecting predictions regarding temporal differencing, may be formed, where Dit and q are both row vectors. Specifically, a one-side null hypothesis H0, predicting homoegeneity of effects over the pivots, and an alternative hypothesis, H1, predicting heterogeneity, may be formed:

H0:qDitT=0
H1:qDitT>0


The weighting vector q enables discretion over the kinds of behavioral anomalies that may be detected through hypothesis testing, where values in the vector q reflect predictions regarding temporal differencing. A negative value for the velocity of an effect that is included in the weighting vector q, for example, indicates a prediction that the effect decreased over the time interval, while a positive value indicates a prediction that the effect increased over the interval. A value of zero would indicate a prediction that no change in the effect occurred over the time interval. Thus, a prediction that a particular actor was popular over a particular time period, that the popularity of the actor increased over the time interval, and that the rate of increase of the popularity of the actor over the time interval increased, for example, would be reflected in the weighting vector q by positive values for each of value, velocity, and acceleration of the popularity ego effect.


Following the determination of hypotheses, the hypotheses may be tested in order to determine departures from baseline communications behavior using a scalar test statistic Θ, which may be computed based on the fixed effect values (707):






Θ
=


qD
it
T



Var
(

qD
it
T

)







Given Cov{Dit}, the covariance matrix of Dit, the variance of qDitT has the form:

Var{qDitT}=qCov{Dit}qT


Thus, the test statistic Θ has an approximately standard normal null distribution, which permits easy testing of the null hypothesis H0. Evaluations of expectations within the covariances are performed using the maximum likelihood estimate {circumflex over (θ)}.


Given the fixed effect estimates that were determined via execution of a single step of the Newton Raphson algorithm, estimation of Dit is straightforward. Given the fixed effect estimates, Cov{Dit} may be estimated by partitioning Cov{Dit} into blocks that may be derived separately and that are expressed in terms of covariances of the fixed effects estimates (i.e., Cov{ωit}):







Cov
(

D
it

)

=

[




Cov


{

Δ
it

}





Cov



{


Δ
it

,

Δ
it



}

T





Cov



{


Δ
it

,

Δ
it



}

T







Cov


{


Δ
it

,

Δ
it



}





Cov


{

Δ
it


}





Cov



{


Δ
it


,

Δ
it



}

T







Cov


{


Δ
it

,

Δ
it



}





Cov


{


Δ
it


,

Δ
it



}





Cov


{

Δ
it


}





]





Estimation of the covariances may be accomplished through their relationship to the observed Fisher information matrix. For any two fixed effects estimates {circumflex over (ω)}a, {circumflex over (ω)}b, the intersection of their corresponding pivots ξa, ξb may be denoted:

ξ*a∩ξb


Computation of the observed Fisher information, which yields an estimator for Cov{{circumflex over (ω)}a, {circumflex over (ω)}b} that may be used in evaluating custom character, may be performed:











θ
^

0


(*
)


(

θ
|

ξ
i


)

=




e


ξ
*








θ
^

0


(

θ
|
e

)






Having estimated covariances of the fixed effect estimates, the scalar test statistic Θ may be calculated and used to test the null hypothesis H0 through a simple score test, in which the value of the scalar test statistic is compared to the null hypothesis. If the result of the simple score test is equal to or less than zero, there is no confidence in the alternative hypothesis, indicating that the predictions with regard to the heterogeneity that are reflected in the weighting vector q may be wrong. Alternatively, if the result of the simple score test is positive, then there is some level of confidence that the predictions are correct, with a larger positive values indicating a greater degree of confidence. Thus, if the score test results in a positive value, the alternative hypothesis will have been confirmed with some degree of confidence, which in turn indicates that communications behavior varied from the baseline with regard to the selected pivots and effects, and that the predictions regarding the anomolous communication behavior that underlie the alternative hypothesis are correct.



FIGS. 8-23 provide examples of interfaces and data visualizations that may be output to a user, for example, using UI 108 of system 100. UI 108 may be used to receive inputs from a user of system 100, and may be used to output data to the user. A user of the system may, for example, specify data sources to be used by normalizer 103 in determining relational history 104 and covariate data 105. The user may also provide inputs indicating which actors, modes, topics, covariates, and/or effects to include in model 106, as well as which subsets of the relational event history should be analyzed in determining departures from the baseline. UI 108 may provide the user with outputs indicating a formulation of model 106, a determined baseline for the model 106, and one or more determinations as to whether and how the subsets of relational event history being analyzed differ from the baseline. UI 108 may also provide the user with additional views and analyses of data so as to allow the user to draw additional inferences from the model 106.


UI 108 may provide to the user, based on probability model 106, a determined baseline, and/or one or more determined departures from the baseline, textual and/or graphical analyses of data that uncover patterns, trends, anomalies, and change in the data.



FIG. 8, for example, includes an example interface 801 that enables a user to translate business questions into hypotheses for testing data in a relational event history. In more detail, a hypothesis dashboard 802 may enable a user to form a hypothesis regarding communications behavior by selecting one or more effects from a list of possible effects, and one or more covariates from a list of possible covariates. The selection may occur by dragging and dropping the effects and covariates from one or more windows or spaces listing possible effects and/or covariates into a window or space defining the hypothesis, and a user may be able to further select properties of a selected effect or covariate by interacting with buttons or text corresponding to the desired properties. Descriptions of the effects, covariates, and properties may be displayed for the user in response to detection of hovering, and a textual description 803 of the hypothesis may be dynamically formed and displayed to the user as effects, covariates, and properties are selected by the user. Alternatively, or in addition, the user may manually enter a textual description of the hypothesis being formed.



FIG. 9 includes example visualizations 901 and 902, which include, respectively, curves 903 and 904 that may be generated based on statistical analysis of data in a relational event history and then displayed to a user. The displayed curves may be formed, for example, based on the effects and covariates included in the user's hypothesis, and the effects included in the hypothesis may be used in a baselining process that results in a determination of normality. Following the determination of a baseline of communications behavior, anomalous (i.e. abnormal) behavior may be inferred in the form of deviations from the baseline over period of time.


The curves displayed to the user may correspond to an actor, to a pair of actors, and/or to all actors in a relational event history, and may indicate periods of time in which communications behavior is normal, and periods of time in which communications behavior is abnormal. The indication may be provided, for example, through color coding, in which periods of normal behavior are assigned one color, and in which periods of abnormal behavior are assigned another color. UI 108 may enable a user to select between varying levels of sensitivity through which normality and abnormality are determined, and the visualizations displayed to the user may dynamically update as selection of sensitivity occurs.


Multiple curves, each representing a different effect or covariate, may be displayed in an overlapping fashion, and the curves may be normalized and smoothed. The curves may be displayed in two dimensions, where the x axis is associated with time, and where the y axis is associated with properties of the effects.


UI 108 may display icons and/or labels to indicate effects, covariates, or actors to which a curve corresponds, as well as text identifying effects, covariates, or actors to which a curve corresponds. The user interface may further display labels within the two dimensional field in which the curves are plotted, the labels indicating exogenous events or providing other information.


A user may select an actor or actors, and the selection may result in curves corresponding to individual effects and/or covariates being displayed for the selected actor or actors, and lines corresponding to multiple effects and/or covariates being displayed for unselected actors. A user may also be able to “zoom in” to the displayed curves in order to view a display of events at a more granular level, with information pertaining to the displayed events being presented through icons that are color-coded according to mode, and that are sized to indicate, for example, a word count or length of a conversation. UI 108 may also provide access to individual communications related to events. UI 108 may, for example, display an individual email in response to a user selection or zoom.



FIG. 10 includes an example visualization in which, in response to a user selection, UI 108 displays, for a particular actor, behavioral activity over time. The behavioral activity may be displayed, for example, in a polar coordinate system, where the radial coordinates of points in the plane correspond to days, and where angular coordinates correspond to time slices within a particular day.


In more detail, each point plotted in the plane, for example, point 1002, may correspond to a particular communications event, and may be color coded to indicate a mode of communication or other information. Points plotted in the plane may be located on one of several concentric circles displayed on the graph, and the circle on which a point is located may indicate a day on which the communication took place, while the position of the point on the circle may indicate a time slice (e.g., the hour) in which the communication took place. A user may be able to select a communication event that is plotted on the graph to obtain content. For example, a user may click or hover over a point that, like 1002, indicates an email message in order to retrieve the text of the email message.


In some implementations of UI 108, a polar graph indicating behavioral activity over time may be animated, enabling a user to “fly through” a visual representation of behavioral activity over particular periods of time, where the circles and events presented for a particular period of time correspond to the days within that period, and where the period displayed dynamically shifts in response to user input.



FIG. 11 includes example visualizations 1101, 1102, and 1103 in which UI 108 displays, for a plurality of actors, behavioral activity over time. For example, as shown in visualizations 1101, 1102, and 1103, UI 108 may display, for a particular actor or for a combination of actors, communications information in a matrix. For each day and time slice, an icon may represent the communication or communications that took place, with the size of the icon indicating communications volume. Icon 1104, for example, is larger than icon 1105, and therefore indicates a greater volume of communications.


Multiple modes of communication may be displayed at a particular point in the matrix. This may be accomplished through the use of a color coding system in which each mode of communication is assigned a color, and in which icons of varying size and color are generated based on the number of communications of each mode that occurred during a given period of time. When color coding is used, the generated icons may be displayed in overlapping fashion, providing the user with a visual representation of the number and type of communications that occurred at a particular data and period of time.


UI 108 may enable a user to select a communication event that is shown in the matrix to obtain content, and the matrix may be animated to show different days and time periods in response to user input. A user may, for example, “scroll through” the matrix.



FIG. 12 includes example visualizations 1201, 1202, and 1203 in which UI 108 displays, for a particular actor or for a combination of actors, data corresponding to multiple modes of communication, where icons of varying size or bars of varying length are generated based on the number of communications of each mode that occurred during a given period of time. The particular modes that are displayed and the granularity of the display may be determined by a user, as shown at 1204.


UI 108 may enable a user to interact with an icon to obtain additional information regarding communications events that occurred during a given period of time, and the user may interact with a displayed communication event in order to obtain content. Selection of a particular email, for example, may result in display of the email's text, as depicted in visualization 1202.



FIG. 13 depicts example visualizations 1301, 1302, and 1303, in which UI 108 displays, for a particular actor, a summary of communications of various modes over a period time, as well bibliographic information and information pertaining the actor's relationships with other actors in the relational event history.


The summary of communications may be provided as in visualization 1301, for example, in which multiple two-dimensional curves that correspond to different modes of communication are plotted in graph 1304, in which the x axis is associated with time, and in which the y axis is associated with a number of communications events.


UI 108 may display information pertaining to the actor's relationships in the form of a quad chart, such as chart 1305, where points that represent individual relationship dyads including the actor are plotted on the chart, and where one axis of the chart is associated with numbers of communications sent to the actor by the other actors in each dyad, and where the other axis of the chart is associated with numbers of communications sent by the actor to the other actors in each dyad. A listing of strong relationships (e.g., relationships involving the highest amount of communications activity) may also be included.



FIG. 14 includes example visualizations 1401 and 1402, in which UI 108 displays, for a particular actor, a comprehensive view of the actor's communications and other behavior over a particular period of time. UI 108 may display, as in 1401, a view of communications and transactions over a period of time, provided with context and with user-specified filters.


UI 108 may include, as in 1402, a “crosshair” 1403 that provides context with regard to a relational event's position within a relational event history, and with regard to trends and other factors. The user may interact with the crosshair 1403 through, for example, side-to-side and up-and-down swiping. Content may be updated as the crosshair is moved, the content including key and calendar events, trends, and geospatial locations.



FIG. 15 provides example visualization 1501, in which UI 108 displays, for a corpus of communications data corresponding to a relational event history, a multimodal synthesis of relational and other events involving a particular actor. UI 108 may present information pertaining to communications and to other events, and may chart the occurrence of the events over time. UI 108 may provide, for example, a detailed “replay” 1502 of information pertaining to events that involved the actor and that took place on a particular day.



FIG. 16 provides example visualization 1601, in which UI 108 displays radial graphs of behavioral characteristics pertaining to an actor. Characteristics that may be graphed include, for example, relationships, key words used, and modes of communication. Graph 1602, for example, displays percentages of communications that occurred through each of three modes, while graph 1603 displays percentages of communications that are characterized as either incoming or outgoing. Radial graphs may also measure and compare elements relating to an actor's position in a network and/or to overall communication tendencies.



FIG. 17 includes example visualization 1701, in which UI 108 displays a comprehensive view 1702 of the history and attributes of stock data and performance, for comparison with an actor's activity. Like stock data, other external data may be compared to relational events or to the relational history of a particular actor, for purposes of correlation and investigation.



FIG. 18 includes example visualizations 1801, 1802, and 1803, in which UI 108 displays, for a corpus of communications data corresponding to a relational event history, a frequency of usage of a particular word or phrase. UI 108 may, for example, plot word usage with respect to time, and may indicate individual communications in which the word was used. The interface may further identify actors who used the word, and through what mode, as indicated at 1804.



FIG. 19 provides example visualization 1901, in which UI 108 combines graphics with an interactive word-tree 1902 that acts as a search filter. The interactive word-tree may be used, for example, to sift through a corpus of communications data for instances of the use of a particular word or phrase.



FIG. 20 includes example visualizations 2001 and 2002. 2001 depicts a particular interface of UI 108 in which line graphs are displayed overlaid with word trending based on frequency counts of numbers of documents containing a user-specified word. The frequency counts may be taken over a period of time (e.g., daily). 2002 depicts a particular interface of UI 108 in which each relational event appears in a plot that enables a user to scroll through email or other relational event content. Distinct coloration may be used to indicate the particular event to which presently-viewed content corresponds, and colors of events may change as the user scrolls from event to event.



FIG. 21 provides example visualization 2101, in which UI 108 pairs a display of a network diagram 2102, the diagram being produced based on communication thresholds, with a communications quad chart 2103 and with corresponding measures of strengths of relationships that include directionality of communication.



FIG. 22 includes example visualizations 2201, 2202, and 2203, which indicate analyses of a corpus of communications data that may be performed using system 100. As explained in detail above, system 100 may be used to pose a question, and to create a hypothesis that might indicate an answer to that question. The hypothesis may be expressed in terms of a language of behavioral effects, and hypothesis testing may identify individuals who have exhibited behavior that relates to the hypothesis. As shown at 2204, for example, UI 108 has employed shading to illustrate a degree to which each the behavior of each identified individual deviates from the norm.


Similarly, in 2202, graphs are used to illustrate variance in an individual's behavior, in contrast to the norm, over time. Events may be represented in a graph by a vertical line, such as line 2205, providing context for behavioral changes. Quarterly earnings for a company, for example, may be indicated in a graph.


Communications content may be overlaid in a graph, as in 2203, with each communication event represented as icon. Each email sent or received by an individual in question may be represented, for example, by a blue or brown dot, the color indicating whether the email was sent or received. A user may be able to click on or otherwise interact with a dot to view additional information relating to the corresponding communication. For example, a user may be able to view the textual content of an email that was sent by a particular actor.



FIG. 23 includes example visualizations 2301, 2302, and 2303, which indicate further analyses of a corpus of communications data that may be performed using system 100. Irregularity Heat Map—Abnormal content and communications activity, aggregated by day, may be visualized, and shading may be used to indicate a degree or an amount of abnormal or irregular activity that occurred on a given day. As 2301 indicates, abnormal content and communications activity, aggregated by day, may be visualized by UI 108, and shading may be used to indicate a degree or an amount of abnormal or irregular activity that occurred on a given day.


Tendencies of individual actors to contact other actors may also be visualized, as in 2302. A tendency of internal actors to email external individuals, for example, may be visualized for a given time period, with actors ranked in order of number of emails sent to the actor, or received by the actor, involving external contacts. A count of external emails for each actor may be expressed in the graph, and an event may be overlaid to provide context.


The popularity of terms in a corpus of communications, and their frequency of use over time, may also be presented by UI 108, as shown in 2303. A table 2304 identifying the first times at which words were used in a collection of emails may be paired, for example, with an illustration of usage trends for the words.


A number of implementations have been described. Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the disclosure.


For example, elements of different implementations described herein may be combined to form other implementations not specifically set forth above. Elements may be left out of the systems, processes, computer programs, etc. described herein without adversely affecting their operation. Furthermore, various separate elements may be combined into one or more individual elements to perform the functions described herein.


In addition, the logic flows depicted in the figures do not require the particular order shown, or sequential order, to achieve desirable results. In addition, other steps may be provided, or steps may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Accordingly, other implementations not specifically described herein are within the scope of the following claims.

Claims
  • 1. A method for creating a relational event history comprising: receiving data from a data source, the data source providing information regarding an event;determining a relational event history from the data set, the relational event history comprising an event that occurred at a particular time by an actor, the event being strictly ordered with other events enacted in time by a set of actors, the strict ordering providing the relational event history; and,populating, based on the relational event history, data in a probability model, the probability model being formulated as a series of conditional probabilities that correspond to a set of sequential decisions by the actor and the set of actors of the other events, the probability model including a statistical parameter and a corresponding statistic;determining, based on the populated probability model, a baseline behavior for the relational event history, the determining the baseline behavior being based upon the statistical parameter and the corresponding statistic; and,using the relational event history to determine whether behavior associated with the event represents a departure from the baseline behavior.
  • 2. The method of claim 1, wherein: the determining the relational event history comprises providing extracted data from the data to provide extracted data, transforming the extracted data to provide transformed data, loading the transformed data to provide loaded data and enriching the loaded data.
  • 3. The method of claim 1, wherein: the event and the each of the other events comprise a respective set of characteristics.
  • 4. The method of claim 3, wherein: the respective set of characteristics comprise at least one of information regarding a sender, information regarding a recipient, information regarding a mode of the event and information indicating a time the event occurred.
  • 5. The method of claim 3, wherein: the set of characteristics comprise at least one of a unique identifier of the event, information regarding a duration of the event, information regarding formatting of the event in the data source.
  • 6. The method of claim 1, further comprising: determining a subset of actors, at least one decision included in the set of sequential decisions comprising selecting a recipient of a relational event from the subset of actors.
  • 7. A system comprising: a processor;a data bus coupled to the processor; anda non-transitory, computer-readable storage medium embodying computer program code for creating a relational event history, the non-transitory, computer-readable storage medium being coupled to the data bus, the computer program code interacting with a plurality of computer operations and comprising instructions executable by the processor and configured for: receiving data from a data source, the data source providing information regarding an event;determining a relational event history from the data set, the relational event history comprising an event that occurred at a particular time by an actor, the event being strictly ordered with other events enacted in time by a set of actors, the strict ordering providing the relational event history; and,populating, based on the relational event history, data in a probability model, the probability model being formulated as a series of conditional probabilities that correspond to a set of sequential decisions by the actor and the set of actors of the other events, the probability model including a statistical parameter and a corresponding statistic;determining, based on the populated probability model, a baseline behavior for the relational event history, the determining the baseline behavior being based upon the statistical parameter and the corresponding statistic; and,using the relational event history to determine whether behavior associated with the event represents a departure from the baseline behavior.
  • 8. The system of claim 7, wherein: the determining the relational event history comprises providing extracted data from the data to provide extracted data, transforming the extracted data to provide transformed data, loading the transformed data to provide loaded data and enriching the loaded data.
  • 9. The system of claim 7, wherein: the event and the each of the other events comprise a respective set of characteristics.
  • 10. The system of claim 9, wherein: the respective set of characteristics comprise at least one of information regarding a sender, information regarding a recipient, information regarding a mode of the event and information indicating a time the event occurred.
  • 11. The system of claim 7, wherein: the set of characteristics comprise at least one of a unique identifier of the event, information regarding a duration of the event, information regarding formatting of the event in the data source.
  • 12. The system of claim 7, wherein the instructions are further configured for: determining a subset of actors, at least one decision included in the set of sequential decisions comprising selecting a recipient of a relational event from the subset of actors.
  • 13. A non-transitory, computer-readable storage medium embodying computer program code, the computer program code comprising computer executable instructions configured for: receiving data from a data source, the data source providing information regarding an event;determining a relational event history from the data set, the relational event history comprising an event that occurred at a particular time by an actor, the event being strictly ordered with other events enacted in time by a set of actors, the strict ordering providing the relational event history; and,populating, based on the relational event history, data in a probability model, the probability model being formulated as a series of conditional probabilities that correspond to a set of sequential decisions by the actor and the set of actors of the other events, the probability model including a statistical parameter and a corresponding statistic;determining, based on the populated probability model, a baseline behavior for the relational event history, the determining the baseline behavior being based upon the statistical parameter and the corresponding statistic; and,using the relational event history to determine whether behavior associated with the event represents a departure from the baseline behavior.
  • 14. The non-transitory, computer-readable storage medium of claim 13, wherein: the determining the relational event history comprises providing extracted data from the data to provide extracted data, transforming the extracted data to provide transformed data, loading the transformed data to provide loaded data and enriching the loaded data.
  • 15. The non-transitory, computer-readable storage medium of claim 13, wherein: the event and the each of the other events comprise a respective set of characteristics.
  • 16. The non-transitory, computer-readable storage medium of claim 15, wherein: the respective set of characteristics comprise at least one of information regarding a sender, information regarding a recipient, information regarding a mode of the event and information indicating a time the event occurred.
  • 17. The non-transitory, computer-readable storage medium of claim 13, wherein: the set of characteristics comprise at least one of a unique identifier of the event, information regarding a duration of the event, information regarding formatting of the event in the event data source.
  • 18. The non-transitory, computer-readable storage medium of claim 13, wherein the computer executable instructions are further configured for: determining a subset of actors, at least one decision included in the set of sequential decisions comprising selecting a recipient of a relational event from the subset of actors.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. application Ser. No. 16/432,414, filed Jun. 5, 2019, now U.S. Pat. No. 10,832,153, issued Nov. 10, 2020, which is a continuation of U.S. application Ser. No. 15/399,147, filed Jan. 5, 2017, now U.S. Pat. No. 10,776,708, issued Sep. 15, 2020, which is continuation of U.S. application Ser. No. 14/148,346, filed Jan. 6, 2014, now U.S. Pat. No. 9,542,650, issued Jan. 10, 2017, which claims the benefit of U.S. Provisional Application No. 61/771,611, filed Mar. 1, 2013, U.S. Provisional Application No. 61/771,625, filed Mar. 1, 2013, U.S. Provisional Application No. 61/772,878, filed Mar. 5, 2013, U.S. Provisional Application No. 61/803,876, filed Mar. 21, 2013, and U.S. Provisional Application No. 61/820,090, filed May 6, 2013. All of these prior applications are incorporated by reference in their entirety.

US Referenced Citations (251)
Number Name Date Kind
6072875 Tsudik Jun 2000 A
6678693 Shiraishi Jan 2004 B1
7107447 Sanin et al. Sep 2006 B2
7694150 Kirby Apr 2010 B1
7725565 Li et al. May 2010 B2
7813944 Luk et al. Oct 2010 B1
7933960 Chen et al. Apr 2011 B2
8181253 Zaitsev et al. May 2012 B1
8312064 Gauvin Nov 2012 B1
8424061 Rosenoer Apr 2013 B2
8484066 Miller et al. Jul 2013 B2
8490163 Harsell et al. Jul 2013 B1
8713633 Thomas Apr 2014 B2
8776168 Gibson et al. Jul 2014 B1
8826443 Raman et al. Sep 2014 B1
8892690 Liu et al. Nov 2014 B2
8990930 Burrell et al. Mar 2015 B2
9015812 Plattner et al. Apr 2015 B2
9015847 Kaplan et al. Apr 2015 B1
9043905 Allen et al. May 2015 B1
9053124 Dornquast et al. Jun 2015 B1
9128995 Fletcher et al. Sep 2015 B1
9137318 Hong Sep 2015 B2
9166999 Kulkarni et al. Oct 2015 B1
9223972 Vincent et al. Dec 2015 B1
9246941 Gibson et al. Jan 2016 B1
9262722 Daniel Feb 2016 B1
9298726 Mondal et al. Mar 2016 B1
9342553 Fuller May 2016 B1
9369433 Paul et al. Jun 2016 B1
9485266 Baxley et al. Nov 2016 B2
9542650 Lospinoso et al. Jan 2017 B2
9596146 Coates et al. Mar 2017 B2
9609010 Sipple Mar 2017 B2
9665854 Burger et al. May 2017 B1
9692762 Barkan et al. Jun 2017 B2
9755913 Bhide et al. Sep 2017 B2
9762582 Hockings et al. Sep 2017 B1
9798883 Gil et al. Oct 2017 B1
9935891 Stamos Apr 2018 B1
9977824 Agarwal et al. May 2018 B2
10096065 Little Oct 2018 B2
10108544 Duggal et al. Oct 2018 B1
10187369 Caldera et al. Jan 2019 B2
10210283 Broz et al. Feb 2019 B2
10235285 Wallace Mar 2019 B1
10237298 Nguyen et al. Mar 2019 B1
10270794 Mukeiji et al. Apr 2019 B1
10275671 Newman Apr 2019 B1
10282702 Paltenghe et al. May 2019 B2
10284601 Bar-Menachem et al. May 2019 B1
10320813 Ahmed et al. Jun 2019 B1
10341391 Pandey et al. Jul 2019 B1
10417454 Marom et al. Sep 2019 B1
10417653 Milton et al. Sep 2019 B2
10419428 Tunnell et al. Sep 2019 B2
10432669 Badhwar et al. Oct 2019 B1
10545738 Jaeger et al. Jan 2020 B1
10579281 Cherubini et al. Mar 2020 B2
10713934 Sayavong et al. Jul 2020 B2
10769908 Burris et al. Sep 2020 B1
10917319 Scheib et al. Feb 2021 B2
11061874 Funk et al. Jul 2021 B1
20020112015 Haynes Aug 2002 A1
20020123865 Whitney et al. Sep 2002 A1
20040034582 Gilliam et al. Feb 2004 A1
20040044613 Murakami et al. Mar 2004 A1
20050120025 Rodriguez et al. Jun 2005 A1
20050198099 Motsinger et al. Sep 2005 A1
20050273850 Freund Dec 2005 A1
20060048209 Shelest et al. Mar 2006 A1
20060053476 Bezilla et al. Mar 2006 A1
20060112111 Tseng et al. May 2006 A1
20060117172 Zhang et al. Jun 2006 A1
20060129382 Anand et al. Jun 2006 A1
20060195905 Fudge Aug 2006 A1
20060206449 Fletcher et al. Sep 2006 A1
20060225124 Kolawa et al. Oct 2006 A1
20070043703 Bhattacharya et al. Feb 2007 A1
20070121522 Carter May 2007 A1
20070225995 Moore Sep 2007 A1
20070234409 Eisen Oct 2007 A1
20080168002 Kagarlis et al. Jul 2008 A1
20080168135 Redlich et al. Jul 2008 A1
20080168453 Hutson et al. Jul 2008 A1
20080198453 LaFontaine et al. Aug 2008 A1
20080244741 Gustafson et al. Oct 2008 A1
20090006888 Bernhard et al. Jan 2009 A1
20090177979 Garbow et al. Jul 2009 A1
20090182872 Hong Jul 2009 A1
20090228474 Chiu et al. Sep 2009 A1
20090300712 Kaufmann et al. Dec 2009 A1
20100024014 Kailash et al. Jan 2010 A1
20100057662 Collier et al. Mar 2010 A1
20100058016 Nikara et al. Mar 2010 A1
20100094767 Miltonberger Apr 2010 A1
20100094818 Farrell et al. Apr 2010 A1
20100107255 Eiland et al. Apr 2010 A1
20100146622 Nordstrom et al. Jun 2010 A1
20100205224 Palanisamy et al. Aug 2010 A1
20100228656 Wasserblat et al. Sep 2010 A1
20100235495 Petersen et al. Sep 2010 A1
20100275263 Bennett et al. Oct 2010 A1
20110061093 Korkus et al. Mar 2011 A1
20110167105 Ramakrishnan et al. Jul 2011 A1
20110307957 Barcelo et al. Dec 2011 A1
20120046989 Baikalov et al. Feb 2012 A1
20120047575 Baikalov et al. Feb 2012 A1
20120079107 Williams et al. Mar 2012 A1
20120110087 Culver et al. May 2012 A1
20120137367 Dupont et al. May 2012 A1
20120210158 Akiyama et al. Aug 2012 A1
20120259807 Dymetman Oct 2012 A1
20120290215 Adler et al. Nov 2012 A1
20130013550 Kerby Jan 2013 A1
20130054433 Giard et al. Feb 2013 A1
20130055367 Kshirsagar et al. Feb 2013 A1
20130081141 Anurag Mar 2013 A1
20130097662 Pearcy et al. Apr 2013 A1
20130102283 Lau et al. Apr 2013 A1
20130104236 Ray et al. Apr 2013 A1
20130132551 Bose et al. May 2013 A1
20130174259 Pearcy et al. Jul 2013 A1
20130205366 Luna et al. Aug 2013 A1
20130238422 Saldanha Sep 2013 A1
20130290598 Fiske et al. Oct 2013 A1
20130297729 Suni et al. Nov 2013 A1
20130305358 Gathala et al. Nov 2013 A1
20130317808 Kruel et al. Nov 2013 A1
20130320212 Valentino et al. Dec 2013 A1
20130340035 Uziel et al. Dec 2013 A1
20140075004 Van Dusen et al. Mar 2014 A1
20140096215 Hessler Apr 2014 A1
20140173727 Lingafelt et al. Jun 2014 A1
20140199663 Sadeh-Koniecpol et al. Jul 2014 A1
20140205099 Christodorescu et al. Jul 2014 A1
20140214938 Bhatt et al. Jul 2014 A1
20140283075 Drissel et al. Sep 2014 A1
20140325634 Iekel-Johnson et al. Oct 2014 A1
20140356445 Little Dec 2014 A1
20150082430 Sridhara et al. Mar 2015 A1
20150113646 Lee et al. Apr 2015 A1
20150154263 Boddhu et al. Jun 2015 A1
20150161386 Gupta et al. Jun 2015 A1
20150199511 Faile, Jr. et al. Jul 2015 A1
20150199629 Faile, Jr. et al. Jul 2015 A1
20150205954 Jou et al. Jul 2015 A1
20150215325 Ogawa Jul 2015 A1
20150220625 Cartmell et al. Aug 2015 A1
20150256550 Taylor et al. Sep 2015 A1
20150269383 Lang et al. Sep 2015 A1
20150286819 Coden et al. Oct 2015 A1
20150288709 Singhal et al. Oct 2015 A1
20150324559 Boss et al. Nov 2015 A1
20150324563 Deutschmann et al. Nov 2015 A1
20150326613 Devarajan et al. Nov 2015 A1
20150350902 Baxley et al. Dec 2015 A1
20150356488 Eden et al. Dec 2015 A1
20160021117 Harmon et al. Jan 2016 A1
20160036844 Kopp et al. Feb 2016 A1
20160078362 Christodorescu et al. Mar 2016 A1
20160092774 Wang et al. Mar 2016 A1
20160105334 Boe et al. Apr 2016 A1
20160117937 Penders et al. Apr 2016 A1
20160147380 Coates et al. May 2016 A1
20160164922 Boss et al. Jun 2016 A1
20160224803 Frank et al. Aug 2016 A1
20160226914 Doddy et al. Aug 2016 A1
20160232353 Gupta et al. Aug 2016 A1
20160247158 Kolotinsky Aug 2016 A1
20160261621 Srivastava et al. Sep 2016 A1
20160277360 Dwyier et al. Sep 2016 A1
20160277435 Salajegheh et al. Sep 2016 A1
20160286244 Chang et al. Sep 2016 A1
20160300049 Guedalia et al. Oct 2016 A1
20160308890 Weilbacher Oct 2016 A1
20160330219 Hasan Nov 2016 A1
20160330746 Mehrabanzad et al. Nov 2016 A1
20160335865 Sayavong et al. Nov 2016 A1
20160371489 Puri et al. Dec 2016 A1
20170032274 Yu et al. Feb 2017 A1
20170053280 Lishok et al. Feb 2017 A1
20170063888 Muddu et al. Mar 2017 A1
20170070521 Bailey et al. Mar 2017 A1
20170104790 Meyers et al. Apr 2017 A1
20170116054 Boddhu et al. Apr 2017 A1
20170155669 Sudo et al. Jun 2017 A1
20170171609 Koh Jun 2017 A1
20170230418 Amar et al. Aug 2017 A1
20170255938 Biegun et al. Sep 2017 A1
20170279616 Loeb et al. Sep 2017 A1
20170286671 Chari et al. Oct 2017 A1
20170331828 Caldera et al. Nov 2017 A1
20170149815 Bolgert Dec 2017 A1
20180004948 Martin et al. Jan 2018 A1
20180007069 Hunt et al. Jan 2018 A1
20180018456 Chen et al. Jan 2018 A1
20180024901 Tankersley et al. Jan 2018 A1
20180025273 Jordan et al. Jan 2018 A1
20180027006 Zimmermann et al. Jan 2018 A1
20180081661 Gonzalez del Solar et al. Mar 2018 A1
20180082307 Ochs et al. Mar 2018 A1
20180091520 Camenisch et al. Mar 2018 A1
20180107528 Vizer et al. Apr 2018 A1
20180121514 Reisz et al. May 2018 A1
20180139227 Martin et al. May 2018 A1
20180145995 Roeh et al. May 2018 A1
20180150570 Broyd et al. May 2018 A1
20180191745 Moradi et al. Jul 2018 A1
20180191766 Holeman et al. Jul 2018 A1
20180191857 Schooler et al. Jul 2018 A1
20180204215 Hu et al. Jul 2018 A1
20180232111 Jones et al. Aug 2018 A1
20180232426 Gomez et al. Aug 2018 A1
20180234434 Viljoen Aug 2018 A1
20180248863 Kao et al. Aug 2018 A1
20180276541 Studnitzer et al. Sep 2018 A1
20180285363 Dennis et al. Oct 2018 A1
20180288063 Koottayi et al. Oct 2018 A1
20180295141 Solotorevsky Oct 2018 A1
20180332062 Ford Nov 2018 A1
20180336353 Manadhata et al. Nov 2018 A1
20180341758 Park et al. Nov 2018 A1
20180341889 Psalmonds et al. Nov 2018 A1
20180349221 Harutyunyan et al. Dec 2018 A1
20180349684 Bapat et al. Dec 2018 A1
20190014153 Lang et al. Jan 2019 A1
20190034625 Ford et al. Jan 2019 A1
20190034813 Das et al. Jan 2019 A1
20190036969 Swafford et al. Jan 2019 A1
20190052660 Cassidy et al. Feb 2019 A1
20190095478 Tankersley et al. Mar 2019 A1
20190158503 Bansal et al. May 2019 A1
20190174319 Backholm et al. Jun 2019 A1
20190222603 Yang Jul 2019 A1
20190289021 Ford Sep 2019 A1
20190294482 Li et al. Sep 2019 A1
20190311105 Beiter et al. Oct 2019 A1
20190354703 Ford Nov 2019 A1
20190356688 Ford Nov 2019 A1
20190356699 Ford Nov 2019 A1
20190387002 Ford et al. Dec 2019 A1
20190387003 Ford et al. Dec 2019 A1
20190392419 Deluca et al. Dec 2019 A1
20200034462 Narayanaswamy et al. Jan 2020 A1
20200036740 Ford Jan 2020 A1
20200065728 Wilson et al. Feb 2020 A1
20200077265 Singh et al. Mar 2020 A1
20200089692 Tripathi et al. Mar 2020 A1
20200117546 Wong et al. Apr 2020 A1
20200334025 Wang et al. Oct 2020 A1
Foreign Referenced Citations (1)
Number Date Country
WO-2019153581 Aug 2019 WO
Non-Patent Literature Citations (26)
Entry
Marinescu, Cloud Computing and Computer Clouds, University of Central Florida, 2012, pp. 1-246 (Year: 2012).
Sean Barnum, Standardized Cyber Threat Intelligence Information with the Structured Threat Information eXpression (STIX) Whitepaper v1.1 (Feb. 20, 2014).
Xiang Sun et al., Event Detection in Social Media Data Streams, IEEE International Conference on Computer and Information Technology; Ubiquitous Computing and Communications; Dependable, Automatic and Secure Computing; Persuasive Intelligence and Computing, pp. 1711-1717, Dec. 2015.
Mesaros et al., Latent Semantic Analysis in Sound Event Detection, 19th European Signal Processing Conference (EUSIPCO 2011), pp. 1307-1311, 2011.
Crandall et al., Inferring Social Ties from Geographic Coincidences, PNAS, vol. 107, No. 52, 2010, pp. 22436-22441, 2010.
Ross et al., Bully Prevention in Positive Behavior Support, Journal of Applied Behavior Analysis, 42(4), pp. 747-759, 2009.
Matt Klein, How to Erase Your iOS Device After Too Many Failed Passcode Attempts, https://www.howtogeek.com/264369/ how-to-erase-your-ios-device-after-too-many-failed-passcode-attempts/, Jul. 28, 2016.
Github, The Z3 Theorem Prover, retrieved from internet May 19, 2020, https://github.com/Z3Prover/z3.
John Backes et al., Semantic-based Automated Reasoning for AWS Access Policies using SMT, 2018 Formal Methods in Computer Aided Design (FMCAD), Oct. 30-Nov. 2, 2018 https://d1.awsstatic.com/Security/pdfs/Semantic_Based_Automated_Reasoning_for_AWS_Access_Policies_Using_SMT.pdf.
Singh et al., Container-Based Microservice Architecture for Cloud Applications, International Conference on Computing, Communication and Automation (ICCCA2017), 2017.
L. F. Lafuerza et al., Exact Solution of a Stochastic Protein Dynamics Model with Delayed Degradation, Phys. Rev. E 84, 051121, Nov. 18, 2011, pp. 1-8.
Zoubin Ghahramani, Bayesian nonparametrics and the probabilistic approach to modelling, Philosophical Transactions A of the Royal Society, vol. 371 Issue: 1984, Published Dec. 31, 2012, pp. 1-20.
Elena Zheleva et al., Higher-order Graphical Models for Classification in Social and Affiliation Networks, NIPS 2010 Workshop on Networks Across Disciplines: Theory and Applications, Whistler BC, Canada, 2010, pp. 1-7.
Varun Chandola et al., Anomaly Detection: A Survey, ACM Computing Surveys, vol. 41, No. 3, Article 15, Jul. 2009, pp. 15.1-58.1.
Judea Pearl, The Causal Foundations of Structural Equation Modeling, Technical Report R-370, Computer Science Department, University of California, Los Angeles, also Chapter 5, R. H. Hoyle (Ed.), Handbook of Structural Equation Modeling, New York, Guilford Press, Jun. 4, 2012, pp. 68-91.
Yueh-Hsuan Chiang, Towards Large-Scale Temporal Entity Matching, Dissertation Abstract, University of Wisconsin-Madison, 2013.
Furong Li, Linking Temporal Records for Profiling Entities, 2015, SIGMOD '15 Proceedings of the 2015 ACM SIGMOD International Conference on Management of Data, pp. 593-605, https://users.soe.ucsc.edu/˜tan/papers/2015/modf445-li.pdf.
Peter Christen et al., Adaptive Temporal Entity Resolution on Dynamic Databases, Apr. 2013, http://users.cecs.anu.edu.au/˜Peter.Christen/publications/christen2013pakdd-slides.pdf.
Wikipedia, Categorical Distribution, edited Jul. 28, 2018, https://en.wikipedia.org/wiki/Categorical_distribution.
Wikipedia, One-Hot, edited May 22, 2018, https://en.wikipedia.org/wiki/One-hot.
Marinescu, Dan C., Cloud Computing and Computer Clouds, University of Central Florida, 2012, pp. 1-246.
Sanjeev Goyal et al., Attack, Defence and Contagion in Networks, The Review of Economic Studies, vol. 81, Issue 4, Oct. 2014, pp. 1518-1542, https://doi.org/10.1093/restud/rdu013 (2014).
S. Chambi et al., Better bitmap performance with Roaring bitmaps, arXiv:1402.6407v10 [cs.DB] (Mar. 15, 2016).
Jianguo Wang et al., An Experimental Study of Bitmap Compression vs. Inverted List Compression, SIGMOD 2017: Proceedings of the 2017 ACM Int'l Conf. on Management of Data, pp. 993-1008 (May 2017).
Barrere et al., Vulnerability Assessment in Autonomic Networks and Services: A Survey, IEEE, Aug. 30, 2013, vol. 16, issue. 2, pp. 988-1004.
Burns et al., Automatic Management of Network Security Policy, IEEE, Jun. 14, 2001, pp. 12-26.
Related Publications (1)
Number Date Country
20210056453 A1 Feb 2021 US
Provisional Applications (5)
Number Date Country
61771625 Mar 2013 US
61803876 Mar 2013 US
61771611 Mar 2013 US
61772878 Mar 2013 US
61820090 May 2013 US
Continuations (3)
Number Date Country
Parent 16432414 Jun 2019 US
Child 17091088 US
Parent 15399147 Jan 2017 US
Child 16432414 US
Parent 14148346 Jan 2014 US
Child 15399147 US