Indexing of large scale patient set

Information

  • Patent Grant
  • 11860902
  • Patent Number
    11,860,902
  • Date Filed
    Wednesday, June 26, 2019
    5 years ago
  • Date Issued
    Tuesday, January 2, 2024
    a year ago
  • CPC
    • G06F16/285
    • G06F16/13
    • G06F16/2228
    • G06F16/2246
    • G06F16/278
    • G16H10/60
    • G16H50/70
    • G06F16/31
    • G06F16/316
  • Field of Search
    • US
    • 707 737000
    • CPC
    • G06F16/285
    • G06F16/2246
    • G06F16/2228
    • G06F16/278
    • G06F16/13
    • G06F16/316
    • G06F16/31
    • G16H10/60
    • G16H50/70
    • G16H10/30
  • International Classifications
    • G06F16/27
    • G06F16/28
    • G06F16/13
    • G06F16/22
    • G16H10/60
    • G16H50/70
    • G06F16/31
    • Disclaimer
      This patent is subject to a terminal disclaimer.
      Term Extension
      263
Abstract
Systems and methods for indexing data include formulating an objective function to index a dataset, a portion of the dataset including supervision information. A data property component of the objective function is determined, which utilizes a property of the dataset to group data of the dataset. A supervised component of the objective function is determined, which utilizes the supervision information to group data of the dataset. The objective function is optimized using a processor based upon the data property component and the supervised component to partition a node into a plurality of child nodes.
Description
BACKGROUND

The present invention relates to data indexing and retrieval and more particularly to data indexing and retrieval of similar patients from massive patient electronic medical records.


With the rapid development of information technologies, a tremendous amount of data has become readily available in various application domains. This big data era presents challenges for many conventional data analytic tools, platforms and systems. In medical research, electronic medical records (EMR) have gained in popularity to include massive amounts of patient medical information. The ability to analyze big data in modern healthcare systems is important in the improvement of the quality of care delivery.


Patient similarity evaluation aims at estimating the clinical affinity and diagnostic proximity of patients. Many medical applications are based upon patient similarity evaluation, such as risk stratification and comparative effectiveness research. However, existing approaches for patient similarity evaluation are inefficient in handling massive amounts of data.


SUMMARY

A method for indexing data includes formulating an objective function to index a dataset, a portion of the dataset including supervision information. A data property component of the objective function is determined, which utilizes a property of the dataset to group data of the dataset. A supervised component of the objective function is determined, which utilizes the supervision information to group data of the dataset. The objective function is optimized using a processor based upon the data property component and the supervised component to partition a node into a plurality of child nodes.


A computer readable storage medium comprises a computer readable program for indexing data. The computer readable program when executed on a computer causes the computer to perform the following steps. An objective function is formulated to index a dataset, a portion of the dataset including supervision information. A data property component of the objective function is determined, which utilizes a property of the dataset to group data of the dataset. A supervised component of the objective function is determined, which utilizes the supervision information to group data of the dataset. The objective function is optimized using a processor based upon the data property component and the supervised component to partition a node into a plurality of child nodes.


A system for indexing data includes a formulation module configured to formulate an objective function to index a dataset stored on a computer readable storage medium, a portion of the dataset including supervision information. A data property module is configured to determine a data property component of the objective function which utilizes a property of the dataset to group data of the dataset. A supervision module is configured to determine a supervised component of the objective function which utilizes the supervision information to group data of the dataset. An optimization module is configured to optimize the objective function based upon the data property component and the supervised component to partition a node into a plurality of child nodes.


These and other features and advantages will become apparent from the following detailed description of illustrative embodiments thereof, which is to be read in connection with the accompanying drawings.





BRIEF DESCRIPTION OF THE DRAWINGS

The disclosure will provide details in the following description of preferred embodiments with reference to the following figures wherein:



FIG. 1 is a block/flow diagram showing a high level application in accordance with one illustrative embodiment;



FIG. 2 is a block/flow diagram showing a system/method for data indexing in accordance with one illustrative embodiment; and



FIG. 3 is a block/flow diagram showing a system/method for data indexing in accordance with one illustrative embodiment.





DETAILED DESCRIPTION

In accordance with the present principles, systems and methods of data indexing are provided. An objective function is formulated to index a dataset, which may include patient medical information. A portion of the dataset includes supervision information identifying data pairs that are similar and dissimilar. The remaining portion of the dataset does not include supervision information.


The objective function includes a data property component and a supervision component. A tradeoff parameter is also included to balance the contributions from each component. The data property component utilizes a property of the dataset to group patients for all of the dataset (i.e., both supervised and unsupervised). In one embodiment, the data property component is determined by maximizing the variance of the dataset. Maximizing variance may include, e.g., principal component analysis and maximum variance unfolding. In another embodiment, the data property component is determined by separating clusters to form two balanced data clusters around the median of the projected data. The supervision component utilizes the supervision information to group patients using the supervised portion of the dataset. In one embodiment, the supervision component is determined by minimizing the pairwise distances for similar data pairs while maximizing the pairwise distances for dissimilar data pairs. In another embodiment, supervision component is determined by treating the projection of the dataset as a linear prediction function. Other embodiments of the data property component and the supervision component are also contemplated.


The objective is optimized based on the determined data property component and the supervision component to partition a node into a plurality (e.g., 2) of children nodes. The optimization is recursively performed on each node to provide a binary space partitioning tree. Advantageously, the present principles provide for a more robust and accurate indexing tree without a significant increase in search time and tree construction time.


As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.


Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.


A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.


Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing. Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).


Aspects of the present invention are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.


These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks. The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.


The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the blocks may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.


Referring now to the drawings in which like numerals represent the same or similar elements and initially to FIG. 1, a block/flow diagram showing a high level diagram 100 of an application of the present principles is illustratively depicted in accordance with one embodiment. The diagram 100 shows an exemplary application of the present principles in a physician decision support system to identify similar patients from a query patient. It should be understood that the present principles are not limited to patient similarity applications or medical applications. Other applications are also contemplated within the scope of the present principles.


A patient database 102 is used to initialize a patient similarity 104. Patient database may include, e.g., Electronic Medical Records (EMR), which may be big data. An initial patient similarity is deployed to evaluate similar patients based on unprocessed data of the patient database 102. An optimized data partitioning 106 is then performed in accordance with the present principles. Advantageously, the inventive optimized data partitioning provides a semi-supervised framework to learn each data partition, which leverages both expert knowledge and data properties and characteristics. These learned partitions will be used for constructing the indexing tree. Based on the optimized data partitioning, the patient similarity is refined 108. Node purity threshold checking 110 is performed to compare the initial patient similarity with the refined patient similarity to evaluate the optimized data partitioning. Other evaluation techniques are also contemplated, such as, e.g., retrieval precision. If node purity does not pass, optimized data partitioning 106 is repeated. If node purity does pass, an indexing tree is generated 112. The index tree may be used in a physician decision support system 114 to retrieve similar patients 118 from a query patient 116.


Referring now to FIG. 2, a block/flow diagram of a system for data indexing 200 is illustratively depicted in accordance with one embodiment. A data indexing system may include a workstation or system 202. System 202 preferably includes one or more processors 208 and memory 210 for storing applications, modules, medical records and other data. The memory 210 may include a variety of computer readable media. Such media may include any media that is accessible by the system 202, and includes both volatile and non-volatile media, removable and non-removable media.


System 202 may include one or more displays 204 for viewing. The displays 204 may permit a user to interact with the system 202 and its components and functions. This may be further facilitated by a user interface 206, which may include a mouse, joystick, or any other peripheral or control to permit user interaction with the system 202 and/or its devices. It should be understood that the components and functions of the system 202 may be integrated into one or more systems or workstations.


System 202 may receive an input 212, which may include a patient database 214. Patient database 214 may include medical information for a set of patients and may be big data. For patient database 214, the set of patients is represented as custom character={xi}i=1n, where xicustom characterd is the i-th data vector. X∈custom characterd×n is used to represent the entire dataset, where the i-th column vector corresponds to the sample xi. The goal is to build a tree structure to index the data points so that the nearest neighbors of a query vector q can be rapidly found. In medical scenarios, the data vectors in custom character include patient profiles (e.g., EMRs) in the patient database and q is the profile of a query patient.


Patient database 214 preferably includes some pairwise supervision information on custom character in terms of must- and cannot-links. For instance, if patient i and j are similar to each other, then a must-link is placed between xi and xj. Similarly, if patient i and j are dissimilar to each other, a cannot-link is placed between them. A must-link set custom character is constructed by collecting all data pairs with must-links, and a cannot-link set C is constructed by collecting all data pairs with cannot-links. It is assumed that there are a total of l data points with pairwise labels represented as Xlcustom characterdxl, where each data point in Xl has at least one must- or cannot-link. Other forms of supervision information are also contemplated.


The data partitioning system 202 constructs binary space partitioning trees. From the root, the data points in custom character are split into two halves by a partition hyperplane, and each half is assigned to one child node. Then each child node is recursively split in the same manner to create the tree.


Memory 210 may include formulation module 215 configured to formulate an objective function to index a dataset. At each node, the partition hyperplane w is determined by optimizing the objective of equation (1) as follows:

custom character(w)=custom character(w)+λcustom character(w)  (1)

where custom character(w) is some supervised term involving expert knowledge and custom character(w) is a pure data-dependent term without integrating any medical supervision. The supervision component custom character(w) and the data property component custom character(w) may be constructed using different implementations, according to user preferences or other factors. The objective of equation (1) may also include a constant λ as a tradeoff parameter to balance the contributions from each term.


Formulation module 215 includes data property module 216 configured to construct the data property component custom character(w) of the objective of equation (1) using all of the dataset (i.e., both supervised and unsupervised portions), but does not integrate the supervision information. Constructing custom character(w) may include maximizing the data variance after projection or maximally separating the data clusters in its intrinsic space. The projection refers to the inner product of the data matrix X and the learned partition hyperplane w, which corresponds to the projected coordinates of X on the direction of w. Other implementations of maximizing the data variance are also contemplated.


Variance maximization 218 is configured to maximize the data variance after projection. The goal of this type of approach is to find the direction under which the variance of the projected data is maximized such that the binary partition of those directions will more likely produce a balanced tree. Therefore the constructed tree will not be as deep so that the nearest neighbors of a query data point can be quickly found.


In one embodiment, variance maximization 218 includes performing principal component analysis (PCA). PCA obtains the eigenvector from the data covariance matrix with the largest corresponding eigenvector. Suppose the data set has been centralized. custom character(w) can be constructed as in equation (2):

custom character(w)=wTXXTw.  (2)


In another embodiment variance maximization 218 includes performing maximum variance unfolding (MVU). MVU maximizes the overall pairwise distances in the projected space by maximizing equation (3):













(
w
)


=




ij




(



w
T



x
i


-


w
T



x
j



)

2


=


w
T



X


(


n





I

-

ee
T


)




X
T


w



,




(
3
)








where I is the order n identify matrix, and e is the n-dimensional all-one vector.






I
-


i
n



ee
T







is the data centralization matrix such that







X


(

I
-


1
n



ee
T



)




X
T






is equivalent to the data covariance matrix. Thus, the MVU of custom character(w) and the PCA of custom character(w) are the same up to a scaling factor. Other implementations of variance maximization 218 are also contemplated.


Cluster separation 220 is configured to maximally separate the data clusters in intrinsic space. Cluster separation 220 seek a projection direction under which the two balanced data clusters can be formed and equally distributed on the two sides of the median of the projected data. In other embodiments, data clusters may be distributed around other statistics measures, such as, e.g., the mean or weighted mean. Data clusters can be obtained by minimizing the following objective of equation (4):












(
w
)


=







X
i



𝒢
1


,


X
i



𝒢
2






w
ij


=


w
T



X


(

D
-
W

)




X
T


w






(
4
)








where custom character and custom character are the two data clusters. W∈custom charactern×n is the data similarity matrix with its (i, j)-th entry computed as

Wij=exp(−α∥xi−xj2).  (5)


D∈custom charactern×n is a diagonal matrix with DiijWij. One point to note is that custom character(w) is minimized, instead of maximized. A potential bottleneck for constructing custom character(w) is that an n×n data similarity matrix W is to be computed, as well as do matrix multiplication on X and D−W, which could be very time consuming when n is huge.


Formulation module 215 also includes supervision module 222 configured to construct the expert supervision term custom character(w) of the objective of equation (1) using the supervised portion of the data set. The construction of custom character(w) incorporates experts' supervision information on the data (i.e., leveraging the knowledge contained in custom character and C). Supervision module 222 may include projection perspective and prediction perspective. Other embodiments are also contemplated.


In one embodiment, the supervision term custom character(w) is constructed by projection perspective 224. Projection perspective 224 treats w as a pure projection that maps the data onto a one-dimensional space. After the projection, the goal is to have the data pairs in custom character be distributed as compact as possible, while the data pairs in C are distributed as scattered as possible. One straightforward criterion is to minimize the overall pairwise distances for the data pairs in custom character while maximizing the overall distances for the data pairs in C by minimizing the objective of equation (6).










=




1









(



w
T



x
i


-


w
T



x
j



)

2


-


1
C







(


x
i

,

x
j


)


𝒞





(



w
T



x
i


-


w
T



x
j



)

2




=




ij





(



w
T



x
i


-


w
T



x
j



)

2



S

proj
ij




=


w
T




X
l



(

E
-
S

)




X
l
T


w




,




(
6
)








where S is an l×l matrix and its (i, j)-th entry is provided as










S
ij

=

{





1





,





if






(


x
i

,

x
j


)










-

1


𝒞




,





if






(


x
i

,

x
j


)



𝒞






0
,



otherwise








(
7
)








and |⋅ | denotes the cardinality of a set. E is an l×l diagonal matrix with EiijSij.


In another embodiment, the expert supervision term custom character(w) is constructed by prediction perspective 226. Prediction perspective treats the projection as a linear prediction function ƒ(x), such that the sign of ƒ(x) indicates the class of x. If it is assumed that the data in each node are centralized, then the bias b in ƒ(x) can be neglected such that ƒ(x)=wTx. The supervised term custom character under prediction perspective may be provided as follows:









=




1








w
T



x
i



x
j
T


w

-


1


𝒞









(


x
i

,

x
j


)


𝒞





w
T



x
i



x
j
T


w




=




w
T

(



1








x
i



x
j
T


-


1


𝒞









(


x
i

,

x
j


)


𝒞





x
i



x
j
T





)


w

=


w
T



X
l



SX
l
T


w







(
8
)








where S∈custom characterl×l is a symmetric matrix with its (i,j)-th entry provided as in equation (7).


Note that the above unsupervised components custom character, custom character and supervised component custom character apply maximization, while unsupervised component custom character and supervised component custom character apply minimization. To combine both components to form a semi-supervised scheme, the sign of the tradeoff parameter λ is adjusted to achieve consistence. For instance, if custom character is used as the data property component and custom character as the supervision component, equation (1) can be rewritten as in equation (9):












𝒥
=


𝒥

𝒮
pred


+

𝒥

𝒰
PCA









=



w
T



(


XSX
T

+

λ






XX
T



)



w








=


w
T


Aw


,







(
9
)








where A=XSXT+λXXT is a constant matrix absorbing both data property and supervision information. In this example, the coefficient λ is nonnegative.


Memory 210 also includes optimization module configured to optimize the objective of equation (1) based on the construction of the data property component custom character(w) and the supervision component custom character(w). No matter what the choices of custom character(w) and custom character(w) are, the final objective custom character can always be rewritten in the form of custom character=wTAw, as shown in one of the examples in equation (10). The matrix A∈custom characterd×d is some matrix having different concrete forms depending on the specific choices of both supervised and unsupervised components.

maxwwTAw
s.t.wTw=1.  (10)


Equation (10) becomes a Rayleigh Quotient optimization problem, and the optimal solution w* can be obtained as the eigenvector of A whose corresponding eigenvalue is the largest (or smallest if a minimization problem is formed). Optimal partitioning is performed over the patient data for a given definition of patient similarity. Patient similarity may include any distance metric in the projected space, such as, e.g., the Euclidean distance. The similarity measure is different for each partition because of the different projections. Optimization is performed to recursively partition the patient database 214 until the sub-patient population becomes more homogenous (i.e., the projected patient vectors are more similar to each other), or the size of the population reaches a threshold value (e.g., 1 percent of the entire patient population). The optimization of the objective of equation (1) results in an indexing tree 232 of the patient database 214, which may be part of output 230.


The space and time complexities of the data partitioning system 202 have been analyzed. For space complexity, the data median for each node is stored for partitioning, which has O(n) space. Moreover, additional storage is utilized to store the projection for each node, resulting in a complexity of O(dn). Thus, the complete space complexity is O((d+1)n).


The computational cost of the data partitioning system 202 lies in the following aspects: 1) construction of the matrix A over the entire dataset; 2) extracting the projections by eigen-decomposition; and 3) computing the projected points. Here, the time cost for calculating custom character is omitted since it is assumed that l<<n for general semi-supervised settings. Specifically, it takes O(nd2) to compute the data covariance matrix (as in variance maximization 218) or O(n2d) to compute data similarity matrix (as in cluster separation 220). To decompose a matrix custom character with the size d×d to derive the principal projections, it takes O(d3). Finally, given the learned projection, it takes O(nd) to perform the multiplication to derive the one dimension projected points. Note that the above time complexity is estimated for the upper bound since as the recursive partition goes on, each node reduces exponentially.


Performance of the indexing approaches discussed above may be evaluated by node purity and retrieval precision. Other evaluation approaches are also contemplated.


Node purity measures the label consistency of the data points contained in individual tree nodes. Node purity may be expressed as in equation (11).










Purity


(
e
)


=


max
c







x
i


e

,


l
i

=

c



/



e










(
11
)








where e is the set of data points in a node on the indexing tree and |e| is its cardinality. |xi∈e,li=c| indicates the number of data points in e with the same class label c. The computed node purity for leaf nodes is called leaf purity, which directly reflects the search accuracy.


For a given query data point x, its nearest neighbors can be found by traversing x over the tree from the root node to the leaf node. The retrieval precision for the query x is provided in equation (12).

Precision(x)=|xi∈e(x),li=l(x)|/ |e(x)|  (12)

where e(x) is the set of nearest neighbors of x, which is obtained from the leaf node which x falls in. Let l(x) indicate the label of x. Then |xi∈e(x),li=l(x)| is the number of data points in e(x) with the same label as x.


Referring now to FIG. 3, a block/flow diagram showing a method for data indexing is illustratively depicted in accordance with one embodiment. In block 302, an objective function is formulated to index a dataset. The dataset may include patient medical information, such as, e.g., EMR. A portion of the dataset includes supervision information while the remaining portion does not include supervision information. Supervision information may include pairwise must-links and cannot-links. Must-links identify a pair of data (e.g., patient) that are similar to each other. Cannot-links identify a pair of data that are dissimilar to each other. The objective function includes a supervised component, which only use the supervised portion of the data along with their supervision information, and a data property component, which uses both supervised and unsupervised data. The objective function also includes a tradeoff parameter to balance the contributions of the supervised component and the data property component.


In block 304, a data property component of the objective function is determined. The data property component utilizes a property of the dataset to group data of the dataset. The data property component uses both supervised and unsupervised portions of the dataset, but does not integrate any of the supervision information. The data property component may be determined by maximizing the variance 306 or separating clusters 308. Other methods are also contemplated.


In one embodiment, in block 306, the data property component is determined by maximizing the variance of the dataset. The variance of the projected data is maximized such that the binary partition produces a balanced tree. Variance maximization may include applying Principal Component Analysis (PCA) to obtain the eigenvector from the data covariance matrix with the largest corresponding eigenvector. Variance maximization may also include applying maximum variance unfolding to maximize overall pairwise distances, which is mathematically equivalent to PCA. Other methods of variance maximization are also contemplated.


In another embodiment, in block 308, the data property component is determined by equally distributing data clusters around the median of the dataset. Other statistical measures may also be applied, such as, e.g., mean, weighted mean, etc. Clusters are separated such that two balanced data clusters are formed and equally distributed around the median of the projected data.


In block 310, a supervised component of the objective function is determined. The supervised component utilizes the supervision information to group data of the dataset.


In one embodiment, in block 312, the supervised component is determined by projection perspective. The goal of projection perspective is to distribute similar data pairs as compact as possible while distributing dissimilar data pairs as scattered as possible. Projection perspective includes minimizing pairwise distances of data identified as similar by the supervision information and maximizing pairwise distances of data identified as dissimilar by the supervision information.


In another embodiment, in block 314, the supervised component is determined by prediction perspective. The projections of patient vectors of the dataset can be viewed as linear predictions of their corresponding outcomes.


In block 316, the objective function is optimized based on the data property component and the supervised component to partition a node into a plurality of child nodes. Preferably, the plurality of child nodes is two child nodes. In block 318, the objective function is recursively optimized at each node to provide a binary space partitioning tree. Partitioning is recursively performed until the sub-patient population becomes more homogeneous or the size of the population reaches a threshold.


Having described preferred embodiments of a system and method for indexing of large scale patient set (which are intended to be illustrative and not limiting), it is noted that modifications and variations can be made by persons skilled in the art in light of the above teachings. It is therefore to be understood that changes may be made in the particular embodiments disclosed which are within the scope of the invention as outlined by the appended claims. Having thus described aspects of the invention, with the details and particularity required by the patent laws, what is claimed and desired protected by Letters Patent is set forth in the appended claims.

Claims
  • 1. A method for indexing data, comprising: determining a data property component of an objective function for indexing a dataset, the data property component configured to utilize a property of the dataset for grouping data of the dataset, and being determined by maximizing a variance of the dataset to reduce computational costs during the indexing, the maximizing a variance comprising applying a principal component analysis (PCA) comprising determining an eigenvector from a data covariance matrix with a largest corresponding eigenvector and maximum variance unfolding (MVU) forming an inner product of a data matrix;determining a supervised component of the objective function which utilizes supervision information from the dataset to group data of the dataset; andrecursively optimizing the objective function using a processor based upon the data property component and the supervised component to partition a node into a plurality of child nodes.
  • 2. The method as recited in claim 1, wherein the recursive optimizing the objective function comprises recursive optimization of the objective function at each node to provide a binary space partitioning tree.
  • 3. The method as recited in claim 1, wherein the maximizing the variance includes applying both the principal component analysis and the maximum variance unfolding.
  • 4. The method as recited in claim 1, wherein the determining the data property component includes clustering data around a median of the dataset.
  • 5. The method as recited in claim 1, wherein the determining the supervised component includes minimizing pairwise distance of similar data identified by the supervision information and maximizing pairwise distance of dissimilar data identified by the supervision information.
  • 6. The method as recited in claim 1, wherein the determining the supervised component includes applying the dataset as a linear prediction function.
  • 7. The method as recited in claim 1, wherein the objective function includes a tradeoff parameter to balance contributions from the data property component and the supervision component.
  • 8. The method as recited in claim 1, wherein the supervision information includes must-links indicating pairs of data that are similar to each other and cannot-links indicating pairs of data that are dissimilar to each other.
  • 9. The method as recited in claim 1, wherein the dataset includes patient medical information.
  • 10. The method as recited in claim 1, wherein the objective function includes a tradeoff parameter to balance contributions from the data property component and the supervision component.
  • 11. The method as recited in claim 1, wherein the determining the data property component includes applying the maximum variance unfolding by forming a projection as an inner product of a data matrix and a learned partition hyperplane and maximizing overall pairwise distances in a projected space.
  • 12. The method as recited in claim 1, Wherein the determining the data property component includes applying the maximum variance unfolding such that a binary partition produces a balanced tree.
  • 13. The method as recited in claim 12, wherein applying the maximum variance unfolding comprises finding directions under which a projected data variance is maximized such that the binary partition of the directions increases a likelihood of producing the balanced tree.
  • 14. A method for indexing data, comprising: formulating an objective function to index a dataset, a portion of the dataset including supervision information;determining a data property component of the objective function which utilizes a properly of the dataset to group data of the dataset, the data property component being determined by maximizing a variance of the dataset by applying a principal component analysis (PCA) and maximum variance unfolding (MVU) to reduce computational costs during the indexing, the maximizing the variance comprising applying the PCA comprising determining an eigenvector from a data covariance matrix with a largest corresponding eigenvector and MVU forming an inner product of a data matrix;determining a supervised component of the objective function which utilizes the supervision information to group data of the dataset; andrecursively optimizing the objective function using a processor based upon the data property component and the supervised component to partition a node into a plurality of child nodes.
  • 15. The method as recited in claim 14, the recursively optimizing the objective function comprises recursive optimization of the objective function at each node to provide a binary space partitioning tree.
  • 16. The method as recited in claim 14, wherein the supervision information includes must-links indicating pairs of data that are similar to each other and cannot-links indicating pairs of data that are dissimilar to each other.
  • 17. A method for indexing data, comprising: determining a data property component of an objective function for indexing a dataset, the data property component configured to utilize a property of the dataset to group data of the dataset, and being determined by maximizing a variance of the dataset by applying a principal component analysis (PCA) and maximum variance unfolding (MVU) to reduce computational costs during the indexing, the maximizing the variance comprising applying the PCA, the applying the PCA comprising determining an eigenvector from a data covariance matrix with a largest corresponding eigenvector and MVU forming an inner product of a data matrix;determining a supervised component of the objective function which utilizes supervision information to group data of the dataset; andrecursively optimizing the objective function using a processor based upon the data property component and the supervised component to partition a node into a plurality of child nodes.
  • 18. The method as recited in claim 17, the recursively optimizing the objective function comprises recursive optimization of the objective function at each node to provide a binary space partitioning tree.
  • 19. The method as recited in claim 17, wherein the supervision information includes must-links indicating pairs of data that are similar to each other and cannot-links indicating pairs of data that are dissimilar to each other.
US Referenced Citations (36)
Number Name Date Kind
6505205 Kothuri Jan 2003 B1
8676805 Long et al. Mar 2014 B1
8738610 Anderson May 2014 B2
9563644 Castillo Feb 2017 B1
20020107858 Lundahl Aug 2002 A1
20030145014 Minch Jul 2003 A1
20030176931 Pednault Sep 2003 A1
20050157908 Matsugu Jul 2005 A1
20050180639 Trifonov Aug 2005 A1
20060104484 Bolle May 2006 A1
20060251324 Bachmann Nov 2006 A1
20070100880 Buscema May 2007 A1
20070288417 Aggarwal Dec 2007 A1
20080114800 Gazen May 2008 A1
20080137921 Simon Jun 2008 A1
20080143718 Ray Jun 2008 A1
20080154817 Tesauro Jun 2008 A1
20090099985 Tesauro Apr 2009 A1
20090129673 Simon May 2009 A1
20090259406 Khadhraoui Oct 2009 A1
20100094824 Pennington Apr 2010 A1
20100114900 Anderson May 2010 A1
20100262373 Khadhraoui Oct 2010 A1
20120041277 Ebadollahi Feb 2012 A1
20120054184 Masud Mar 2012 A1
20120078955 Boguraev Mar 2012 A1
20120117076 Austermann May 2012 A1
20120130771 Kannan et al. May 2012 A1
20120159393 Sethi Jun 2012 A1
20120265736 Williams Oct 2012 A1
20130132310 Lespinats May 2013 A1
20130282721 McCloskey et al. Oct 2013 A1
20130325759 Rachevsky et al. Dec 2013 A1
20140095490 Sun Apr 2014 A1
20140095512 Sun Apr 2014 A1
20140337353 Hicket et al. Nov 2014 A1
Foreign Referenced Citations (3)
Number Date Country
2007214360 Mar 2008 AU
1207464 May 2002 EP
2030131 Mar 2009 EP
Non-Patent Literature Citations (19)
Entry
Notice of Allowance for U.S. Appl. No. 13/967,062 dated Dec. 28, 2018, 13 pages.
Office Action dated Mar. 13, 2015 for U.S. Appl. No. 13/967,062.
Bentley, J., et al. “Multidimensional Binary Search Trees Used for Associative Searching” Communications of the ACM. vol. 18. No. 9. Sep. 1975. pp. 509-517.
Gionis, A., et al. “Similarity Search in High Dimensions Via Hashing” Proceedings of 25th International Conference on Very Large Data Bases. Sep. 1999. pp. 518-529.
Gong, Y., et al. “Iterative Quantization: A Procrustean Approach to Learning Binary Codes” 2011 IEEE Conference on Computer Vision and Pattern Recognition. Jun. 2011. pp. 817-824.
Kulis, B., et al. “Learning to Hash With Binary Reconstructive Embeddings” 23rd Annual Conference on Neural Information Processing Systems 2009. Dec. 2009. pp. 1-9.
Liu, T., et al. “An Investigation of Practical Approximate Nearest Neighbor Algorithms” Neural Information Processing Systems, NIPS 2004. Dec. 2004. (8 Pages).
Liu, W., et al. “Supervised Hashing With Kernels” IEEE Conference on Computer Vision and Pattern Recognition. Jun. 2012. pp. 2074-2081.
Ng, A., et al. “On Spectral Clustering: Analysis and an Algorithm” In Advances in Neural Information Processing Systems. 2001. (8 Pages).
Omohundro, S. “Efficient Algorithms With Neural Network Behavior” Complex Systems, vol. 1, No. 2. 1987. pp. 273-347.
Shakhnarovich, G., et al. “Nearest-Neighbor Methods in Learning and Vision: Theory and Practice” Massachusetts Institute of Technology, The MIT Press. 2005. (26 Pages).
Sun, J., et al. “Localized Supervised Metric Learning on Temporal Physiological Data” 2010 20th International Conference on Pattern Recognition. Aug. 2010. (4 Pages).
Uhlmann, J. “Satisfying General Proximity/Similarity Queries With Metric Trees” Information Processing Letters, vol. 40, No. 4. Nov. 1991. pp. 175-179.
Wang, F., et al. “Integrating Distance Metrics Learned From Multiple Experts and Its Application in Patient Similarity Assessment” Proceedings of the Eleventh SIAM International Conference on Data Mining. Apr. 2007. pp. 59-70.
Wang, J., et al. “Semi-Supervised Hashing for Large Scale Search” IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 6, No. 1. Jan. 2010. pp. 1-14.
Wang, J., et al. “Sequential Projection Learning for Hashing With Compact Codes” Proceedings of the 27th International Conference on Machine Learning. Jun. 2010. (8 Pages).
Wang, F., et al. “Two Heads Better Than One: Metric+Active Learning and Its Applications for It Service Classification” 2009 9th IEEE International Conference on Data Mining. Dec. 2009. pp. 1022-1027.
Weinberger, K., et al. “Unsupervised Learning of Image Manifolds by Semidefinite Programming” Proceedings of the 2004 IEEE Computer Society Conference on Computer Vision and Pattern Recognition. Jun./Jul. 2004. (9 Pages).
Zhang, D., et al. “Composite Hashing With Multiple Information Sources” Proceedings of the 34th International ACM SIGIR Conference on Research and Development in Information Retrieval. Jul. 2011. (10 Pages).
Related Publications (1)
Number Date Country
20190317951 A1 Oct 2019 US
Continuations (2)
Number Date Country
Parent 14750216 Jun 2015 US
Child 16453165 US
Parent 13719427 Dec 2012 US
Child 14750216 US