Method of Analyzing a Scenario Represented as Elements of a Tensor Space, and Scored Using Tensor Operators

Information

  • Patent Application
  • 20130325784
  • Publication Number
    20130325784
  • Date Filed
    May 29, 2013
    11 years ago
  • Date Published
    December 05, 2013
    11 years ago
Abstract
A mathematical model to represent multiple role events of a threat scenario, and a methodology to score the events given the data or evidence contained in a knowledge base is provided. The multiple role event can include any action encompassed by an independent clause having multiple syntactical roles (subject, object, location, etc . . . ) and containing multiple entities (person A, person B, object C, place D, etc . . . ). Multiple role events are represented as elements of a tensor space, and are scored using tensor operators built from the semantic graph associated with the knowledge base.
Description
BACKGROUND OF THE INVENTION

The present invention pertains to the art of analyzing hypothetical scenarios that can be described by narrative text and, more particularly, to analyzing a hypothetical scenario based on a knowledge base of narrative text containing information describing evidence for various events that may be part of a hypothetical scenario and organizing the events and information in a format that may be statistically analyzed using mathematical tools. The mathematical tools include representing both the information contained in the knowledge base and the hypothetical scenarios in a tensor format allowing associating a bounded positive number, the score, to hypothetical scenarios given the evidence contained in the knowledge base.


Currently, several nations are facing threats from violent actions taken against them from foreign countries, international terrorists and/or internal organizations that resort to violent actions. In order to counteract or prevent these violent acts, organizations, such as government agencies and in some cases corporations, employ analysts to try to predict when such violent actions may occur.


Generally, the organizations start by collecting information about suspected groups. Such information may be gathered from several sources. For example, computer based communications, such as E-mails, may be intercepted and the contents or a summaries of the E-mails stored. Telephone intercepts may be translated and also stored, usually as narrative text. Other information may come from police reports describing the results of searches or people that have been arrested. In some cases, reports may come from military units that capture people or computers having information of interest. In each case, threat analysts usually express scenarios as narrative text using written language. Each entry will generally describe basic information about an event. Specifically, the entry often will include an entity who committed certain acts, what they did, when they did it, where the acts took place, etc. However, the entries and other evidence are often fragmentary and not organized in a meaningful way.


While such information may be useful directly and each narrative report may provide valuable information, often truly useful information needed to predict a violent action may only become apparent when information from various different sources is cross-referenced and analyzed together. Even then the task of figuring out if the information is directed to one or more distinct events is particularly difficult. Collecting and organizing information from a large number of sources and converting the information into a format that can be easily analyzed has proven to be a difficult task of interest in developing tools that predict the likelihood a certain event will or has occurred.


U.S. Pat. No. 7,225,122 proposes a method for analyzing computer communications to produce indications and warnings of dangerous behavior. The method includes collecting a computer-generated communication, such as an E-mail, and parsing the collected communication to identify categories of information that may be indicative of the author's state of mind. When the system identifies an author who represents a threat, then appropriate action may be taken. However, the method only focuses on electronic communications and determining the state of mind of an author. The method does not address any other predictors of when and where a violent event may occur. Also, the method does not organize the information in a format that may be statistically analyzed by mathematical tools. Instead, the method focuses on using Weintraub algorithms to profile psychological states of an author.


U.S. Patent Application Publication No. 2007/0061758 discloses a method for processing natural language so that text communications may be displayed as diagrammatic representations. This patent document does not address pulling information from different sources and organizing the information.


As can be seen from the above discussion, there exists a need in the art for a method providing a structural representation of a scenario that takes narrative text from various sources and produces a format that may be statistically analyzed with mathematical tools and more particularly to develop mathematical tools and algorithms that allow analysts to effectively anticipate events given fragmentary evidence stored in a knowledge base represented by a semantic graph and to assign a score or probability to each event to determine a probability of its occurrence.


SUMMARY OF THE INVENTION

The present invention is directed to a method for providing a scoring of events described in narrative text communications to rank the relative likelihood that a particular event will or has occurred given information in a knowledge base. The method includes collecting evidence as narrative text and store the evidence in a knowledge base as a list of triples “subject-relation-object”. All the items in a knowledge base that are either subjects and/or objects are referred here as entities. A vector space X having a dimension equal to the number of entities in the knowledge base is defined by associating each basis vector with one, and only one, entity in the knowledge base. The relationships among the entities in the knowledge base, described by the subject-relation-attribute triples, are then represented by a weighted symmetric matrix A acting on the vector space, that is A: X→X. The events in a hypothetical scenario are represented as independent clauses, each of which has one, and only one, verb identifying the type of the event. Typically, in each event, an entity conducts an action that is described by the verb, e.g., “Mario Rossi lives at University Drive.” A tensor space H=Xcustom-characterXcustom-character . . . custom-characterX is built from vector space X, and used to represent the events of a hypothetical scenario as tensors. A tensor operator T: H→H, capturing the relationships among the entities of the knowledge base, is built from the adjacency matrix A: X→X, and used to score events. In one embodiment, scoring an event relatively to an event class (defined as a set of events containing the event being scored) includes defining a score as a tensor scalar product between the tensor describing the event and the tensor describing the event class, with a metric induced by the tensor operator. In another embodiment, scoring an event against itself includes calculating a scalar product of the event with itself, with a metric induced by the tensor operator.


Additional objects, features and advantages of the present invention will become more readily apparent from the following detailed description of preferred embodiments when taken in conjunction with the drawings wherein like reference numerals refer to corresponding parts in the several views.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a flow chart showing a method of analyzing a scenario according to a preferred embodiment of the invention;



FIG. 2 shows an example of a knowledge base of people, places, objects and actions;



FIG. 3 shows a vector space R6 with an vector associated with each entity;



FIG. 4 shows an adjacency matrix A generated based on the knowledge base in FIG. 2;



FIG. 5 shows and example of creating a Laplacian matrix L by subtracting the adjacency matrix A of FIG. 3 from a diagonal matrix D;



FIG. 6 shows a covariance matrix V;



FIG. 7 shows a Resistance matrix R;



FIG. 8 shows a conductance matrix C; and



FIG. 9 is a diagram of a system with computers connected to the internet for implementing the method of FIG. 1.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

With initial reference to FIG. 1, there is shown a flow chart depicting a method 10 according to a preferred embodiment of the invention. In order to apply mathematical tools to perform statistical inference, such as ranking the relative likelihood that certain events in a threat scenario will occur given a certain set of evidence described by entries expressed by analysts as narrative text, the scenario must first be represented in a simplified organized manner as detailed below. A knowledge base is built to capture the evidence collected by analysts as narrative text. A syntactic model is established to represent the events in a hypothetical scenario. The syntactic model captures the literary meaning or denotation, but disregards the poetic suggestive meaning or connotation. Also, the model avoids the redundancy inherent in written language.


A first step 20 in method 10 is to collect narrative text reports containing information about any number of scenarios of interest. As noted above, such text reports may be gathered from several sources. For example, computer based communications, such as E-mails, may be intercepted and the contents or a summary of each E-mail may be stored. Telephone intercepts may be translated and also stored, usually as narrative text. Other information may come from police reports describing the results of searches or data on people that have been arrested. In some cases, reports may come from military units that capture people or computers having information of interest. Regardless of the source in each case, a narrative report is produced. This information is referred to as “facts” or “evidence.”


The evidence, represented as narrative text, is then organized in a knowledge base in the form of a list of triples: “subject-relation-object”. An ontology is developed to specify all the allowable types of triples in the knowledge base, and the narrative text is then organized into triples according to the ontology. The ontology and the list of triples constitute the knowledge base. The items represented as “subject” and/or “attribute” in the triples are referred to as “entities;” and to the items represented as “relation” in the triples as “relations.” At step 30, the information or facts in the groups of words are represented as subject-relation objection triples, e.g., Mario Rossi lives at 2932 University Drive. At step 40, the triples are then aggregated to form a knowledge base.


At step 50, a semantic graph of the knowledge base is generated. An example is shown in FIG. 2 which represents a semantic graph 52 of the knowledge base generated in step 40. Semantic graph 52 shows entities 61-66 arranged to show how entities 61-66 are related to one another. The text has been broken down into simple triplets including a subject, a predicate and an object. Essentially, the narrative text is coded into a mathematical format. FIG. 2 includes six entities 61-66 which can either be a subject or an object. In this case, semantic graph 52 shows Mario Rossi 61, Guiseppe Bianchi 62, Select Gourmet Food 63, 2932 University Drive 64, 1176 Floyd Avenue 65 and a phone number 66, i.e., (555) 555-####. Semantic graph 52 shows several triplets of subject, predicate and object. Semantic graph 52 is subject to not only mathematical analysis but is also readable by a human observer. By inspection, one can tell that Mario Rossi 61 owns Select Gourmet Food 63. One can also tell that Mario Rossi 61 owns a phone number 66, i.e., (555) 555-####, located at 2932 University Drive 64 where he lives. Phone number 66 is located at 1176 Floyd Avenue 65 and Giuseppe Bianchi 62 lives at 2932 University Drive 64.


Once the narrative has been organized, as shown in FIG. 2, in order to define mathematical operations on the data we associate a vector space X at step 100 to the knowledge base by means of a bijective map from the entities of the knowledge base onto the canonical basis of the vector space X as shown at 175 in FIG. 3. If a knowledge base contains n entities, the corresponding vector space will have dimension n.


An adjacency matrix is then formed, such as, adjacency matrix A shown in FIG. 4, capturing the “topology” of the relationships among entities. In adjacency matrix A, all entities 61-66 shown in FIG. 2 have been placed above the first row and before the first column. Where there is a connection between two entities a number, 1 if the matrix in un-weighted, or any number greater than 0 if the matrix is weighted, is entered in the appropriate location in adjacency matrix A. A single connection is shown as a 1 and multiple connections are shown with higher numbers. No connection is shown as a zero or no entry. For example, there are two connections between Mario 61 and 2932 University Drive 64, thus a “2” is placed in the adjacency matrix at 4,1 and 1,4. Semantic graph 52 shown in FIG. 2 can also be represented as simply six nodes with lines connected between them. An example of such an adjacency graph formed of nodes and lines is shown in FIG. 3, which will be discussed in more detail below. The links between nodes can also be rated, for example, the “2” provided in adjacency matrix A of FIG. 4, between Mario 61 and University Drive 64 indicates double the weight of the connection compared to the connection between Mario 61 and Select Gourmet Food 63.



FIG. 5 shows a diagonal matrix D: X→X formed by adding all the values found in each row and placing the sum of the values along the diagonal. The connection between Mario and Foods, Unidrive×2, Floyd Ave and the phone add up to 5 so 5 is placed in the 1,1 position and so on. The Laplacian matrix L: X→X, L=D−A, is simply found by subtracting the adjacency matrix from the diagonal matrix at step 160. In mathematical terms the matrices are written as follows:







A
ij

=


A
ji

=

{








w
ij

>
0

,




node





i





connected





to





node





j






0
,



otherwise









D
ij


=

{








k
=
1

n



A
ik


,




i
=
j






0
,



otherwise











Matrix A is called the weighted adjacency matrix (the values wij are positive weights measuring the “strength” of the relationship between connected nodes), and the diagonal matrix D is the degree matrix.


Several measures of connectedness between pairs of entities can be built from the pseudo-inverse of the Laplacian matrix at step 180. It is well known that the Laplacian matrix associated with a graph is singular, so either a “penalized” inverse or a pseudo-inverse are considered at step 180. The inverse of the penalized Laplacian is defined as L(ρ)=D−ρA, where 0<ρ<1 is the penalty factor, while the pseudo inverse considered is the Moore-Penrose pseudo inverse. The inverse of the Laplacian matrix is interpreted as the covariance matrix associated with the entities in the knowledge base and is used as a measure of connectedness. For the tensor scoring approach, a more preferred metric of connectedness or closeness is the conductance matrix C, defined at step 200 as







C
ij

=

{




0
,




i
=
j








(


L
ii


+

L
jj


-

L
ij


-

L
ji



)


-
1


,




i

j









where L′ indicates the Moore-Penrose pseudo inverse of the Laplacian matrix L.


By letting X=R6 be the vector space associated with the knowledge base Kat step 100 and indicating with B={e1, . . . , e6} the canonical basis of R6, a bijective map from K to X is realized by associating every entity of K with every element of B, namely

    • Mariocustom-charactere1
    • Giuseppecustom-charactere2
    • Gourmet Foodcustom-charactere3
    • UniDrivecustom-charactere4
    • FloydAvecustom-charactere5
    • Phonecustom-charactere6


These elements may also be represented as vectors as shown at 175 in FIG. 3. Suppose that the event: “Mario or Giuseppe move from UniDrive to FloydAve” is to be analyzed in a tensor space at step 120. This linear representation preferably handles both AND logic between entities and OR logic. This can be realized by considering the tensor for example at step 140 as follows:

  • MoveEventSpace=Subjectcustom-characterLocationFromcustom-characterLocationTo=R6custom-characterR6custom-characterR6 and representing the move event as








(


b
1

+

b
2


)



b
4



b
5







Mario





OR





Giuseppe





AND




UniDrive




AND




FloydAve







Having represented the multiple role event as an element of a tensor space H, a bilinear operator is built q: Hcustom-characterH→R which takes a pair of events x, y∈H and returns a non negative real number, the score at step 220. The operator q is preferably used in two ways:

    • 1) To score an event x against itself, q(x,x), which can be interpreted as the “event variance”, measuring the “self-energy” of the event induced by the semantic graph;
    • 2) To score an event x against another event y, q(x,y), which can be interpreted as the “event covariance”, measuring the “interaction energy” of two events induced by the semantic graph.


By requiring the function q to be linear in each of its two arguments, q is represented as a scalar product






q(x,y)=(x,Ty)


where T: H→H is a tensor linear operator refer to as the scoring operator. In the move event space defined above, T is a tensor with 6 indices (2 indices for each of the 3 roles), and the score for the move event is written as







(

x
,
Ty

)

=




i
,
j





x
i



T
ij



y
j







where i=(i1,i2,i3) and j=(j1,j2,j3) are multi indices, having as many components as many roles are in the event.


Let X be an n dimensional space over R with canonical basis B={e1, . . . , e6}, and let






H
=


X

X



X




m





times







be a tensor space of total order m (representing a space of events with m syntactical roles). An event x∈H can be thought as a multi array






x
=





i
1

=
1

n














i
1

=
1

n




x


i
1









i
m





(


e

i
1










e

i
m



)









The values xi1 . . . im∈R are the component of event tensor x associated with basis vector ei1 . . . im=ei1custom-character . . . custom-charactereim. A subset of E⊂H that is of interest in the representation of events, is the set of tensor events x having the form





x=x1custom-character . . . custom-characterxm


where xj∈X for every j=1, . . . , m. E is referred to as the space of pure events. Expanding each vector xj over the canonical basis that is






x
j
=x
j1
e
1
+ . . . +x
jn
e
n,


each component xij is interpreted as the “compatibility” of entity i to participate to the event x in the role j. Each event x∈E⊂H is univocally determined by the matrix of coefficient xij where j∈{1, . . . , m} indicates the role and i∈{1, . . . , n} indicates the entity, via the factorization formula






x
=



x
1









x
m


=


(




i
=
1

n




x

1

i




e
i



)









(




i
=
1

n




x

m





i




e
i



)







The tensor scalar product (x,y)H between two tensors x,y∈E is easily computed as








(

x
,
y

)

H

=



(


x
1

,

y
1


)









(


x
m

,

y
m


)


=




j
=
1

m







(




i
=
1

n




x
ji



y
ij



)







requiring n×m operations. Notice that each (xj,yj) is the usual Euclidean scalar product in the vector space X.


A graph metric measuring the “connectedness” between pairs of entities is represented by a matrix M with non-negative entries. A preferable choice at step 200 is M=C, where C is the conductance matrix, shown in FIG. 8. Based on an m order event space






H
=


X

X



X




m





times







a simple class of scoring tensors at step 220





T: H→H


can be defined by the action on the basis vectors ei1 . . . im:=ei1custom-character . . . custom-charactereim as





(ei1 . . . im,Tej1 . . . jm)H=(ei1,Mej1) . . . (eim,Mejm)≡Mi1j1 . . . Mimjm


By bi-linearity










q


(

x
,
y

)


=




(

x
,
Ty

)

H







=







i
1

=
1

n














i
1

=
1

n







j
1

=
1

n














j
m

=
1

n




x


i
1









i
m





y


j
1









j
m





q


(


e


i
1









i
m



,

e


j
1









j
m




)















=







i
1

=
1

n














i
1

=
1

n







j
1

=
1

n














j
m

=
1

n




x


i
1









i
m





y


j
1









j
m




















M


i
1



j
1





M


i
2



j
2











M


i
m



j
m











This formula simplifies if the tensors x,y belong to the space of pure events E⊂H. In this case x=x1custom-character . . . custom-characterxm, y=y1custom-character . . . custom-characterym, and we have







q


(

x
,
y

)


=





j
=
1

m







(


x
j

,

My
j


)


=




j
=
1

m







(




i
=
1

n






k
=
1

n




x

j
,
i




M
ik



y

j
,
k





)







Consider now a non-negative pure event w∈E






w
=


(




i
=
1

n




w

1

i




e
i



)





(




i
=
1

n




w

m





i




e
i



)






The event class of w is defined as the pure event k∈K defined by






κ
=



κ
1









κ
m


=


(




i
=
1

n




I


(


w

1

i



0

)




e
i



)





(




i
=
1

n




I


(


w

m





i



0

)




e
i



)







Let ∘: Hcustom-characterH→H indicate the Hadamard product defined by





(x∘y)i1 . . . im=xi1 . . . imyi1 . . . im


For each tensor basis event b=ei1custom-character . . . custom-charactereim such that b∘k=b, we say that b belongs to the class k, and we define the score of b relative to the event class k with compatibility w as






[


b




κ
;
w

]


=



(


w

b

,

s
κ


)

H



(


w

κ

,

s
κ


)

H







(notice that w∘K=w by definition of K) where the scoring tensor sk is defined by






s
k
=M(k1+ . . . +kmcustom-character . . . custom-characterM(k1+ . . . +km)


Notice that the scoring tensor sk is of the form sk=vcustom-character . . . custom-characterv, where v=M(k1+ . . . +km) is a vector. By definition the score of the entire class K is equal to 1, so that






[


κ




κ
;
w

]


=




(


w

κ

,

s
κ


)

H



(


w

κ

,

s
κ


)

H


=
1






Since by hypothesis M has non-negative entries, then for every base event b belonging to the class k (that is, for every base event b such that b∘k=b) yields





0≦[b|k; w]≦[k|k; w]=1.


Considering that the score [b|k; w] is linear in b, we may interpret [b|k; w] as the “probability” of a base event b to occur, relative to the event class k with compatibility w,


An example of using these techniques is based on the knowledge base shown in FIG. 2. As described above with reference to FIGS. 4 and 5, an adjacency matrix A may be created and, from the equation L=D−A, the Laplacian matrix is calculated. From that point the pseudo-inverse of the Laplacian matrix V=L′ is calculate at step 180 as shown in FIG. 6. A resistance matrix Rij is defined as Rij=Vii+Vij−Vij−Vji and is shown in FIG. 7. A conductance matrix, where Cij=1/Rij if i is not equal to j and 0 otherwise, is calculated at step 200 and shown in FIG. 8. Preferably the conductance matrix is used to score events in a hypothetical scenario.


As shown in FIG. 9, a system for implementing the method shown in FIG. 1 in accordance with a preferred embodiment of the present invention includes an analyst's computer system 810 which can be connected to one or more other computer systems 812 over an electronic communications link, such as the internet 814. As illustrated in FIG. 9, analyst's computer system 810 includes an input-output unit 820 for transmitting and receiving digital information to or from internet 814. Likewise, each computer system 812 is also set up to contact the internet 814 through an input-output unit 845 and preferably hosts websites 816 in a memory 818. Computer 810 typically has a monitor 854, a central processing unit 855, some type of memory 856 and a keyboard 857. Typically, when in use, analyst's computer 842 utilizes an operating system, such as Macintosh®, Unix® or Windows® which controls the basic operations of the computing machine. Additionally, specialized applications, such as a web browser, would be used to interpret the various protocols of internet 814 into an understandable interface for a computer user, namely the analyst. The knowledge base is preferably stored in memory 856. Various specific pieces of software used to complete the method steps of algorithm 10 shown in FIG. 1 reside in memory 856,


Based on the above, it should be readily apparent the method of the present invention provides an efficient way for an analyst to score events in a knowledge base and determine the likelihood of these events occurring. Although described with reference to preferred embodiments of the invention, it should be readily understood that various changes and/or modifications can be made to the invention without departing from the spirit thereof. For instance, while Allen's algebra rules are noted as a way to indicate time relationships between events, other known ways of noting time relationships could be used. In general, the invention is only intended to he limited by the scope of the following claims.

Claims
  • 1. A computer implemented method for scoring a relative likelihood that a hypothetical event in a scenario is to occur, the method comprising: collecting narrative text communications, each communication including a group of words, regarding evidence related to the scenario;building a tensor space to represent events or classes of events of the scenario;building a tensor operator measuring a connectedness or closeness of entities in the scenario into the hypothetical event; andscoring each event or classes of events by using the tensor operator to rank the relative likelihood of each event to occur relative to a class of events.
  • 2. The method according to claim 1, wherein scoring events includes defining a score as a tensor scalar product between two tensors representing events or classes of events.
  • 3. The method according to claim 1 further comprising organizing the evidence contained in the narrative text into a knowledge base as one or more triples with each triple including a subject, a relation and an object, according to a given ontology
  • 4. The method according to claim 3, wherein scoring events includes defining a score by: developing an adjacency matrix Aij;calculating a Laplacian matrix Lij of the adjacency matrix;calculate a pseudo-inverse Vij of the Laplacian matrix;calculate a resistance matrix Rij=Vii+Vjj−Vij−Vji;calculate a conductance matrix Cij=1/Rij if i is not equal to j and 0 otherwise; andusing the conductance matrix to build a tensor operator to score events given the evidence contained in the knowledge base.
  • 5. The method according to claim 3 further comprising associating a vector space to the knowledge base by associating each entity with a basis vector, an entity being either a subject or an object in one of the one or more triples in the knowledge base.
  • 6. The method according to claim 5 further comprising representing one of the one or more triples in the knowledge base in a semantic graph and building a symmetric weighted adjacency matrix representing an undirected topology of the semantic graph.
  • 7. The method according to claim 6 further comprising using the adjacency matrix as a linear operator onto the vector space associated with the knowledge base.
  • 8. The method according to claim 7 further comprising building a Laplacian matrix associated with the adjacency matrix and taking a pseudo-inverse of the Laplacian matrix.
  • 9. The method according to claim 8 further comprising using the pseudo-inverse of the Laplacian matrix to build graph-metrics measuring the connectedness or closeness between the entities in the knowledge base.
  • 10. The method according to claim 9 wherein building a tensor operator measuring the connectedness or closeness of entities in the scenario into the hypothetical event includes using a metric obtained from the pseudo inverse of the Laplacian.
  • 11. The method according to claim 10 further comprising developing a syntactical model.
  • 12. The method according to claim 11 wherein developing the syntactical model includes representing the events of a hypothetical scenario as independent clauses, each of which has only one verb, and represents an event including sets of entities.
  • 13. The method according to claim 12 wherein the entity is performing an action.
  • 14. The method according to claim 12 wherein the entity is a source of an action.
  • 15. The method according to claim 12 wherein the entity is a destination of the action.
  • 16. The method according to claim 12 wherein the entity is an object of an action.
  • 17. The method according to claim 12 wherein the entity is an instrument used to carry out an action.
  • 18. The method according to claim 12 wherein the entity provides spatial and temporal information, about an action.
CROSS REFERENCE TO THE RELATED APPLICATION

The present application claims the benefit of U.S. Provisional Patent Application Ser. No. 61/652,703, filed on May 29, 2013, entitled “Method of Analyzing a Threat Scenario Represented as Elements of a Tensor Space, and Scored Using Tensor Operators,” the contents of which are hereby incorporated by reference.

Provisional Applications (1)
Number Date Country
61652703 May 2012 US