System and method for detecting generalized space-time clusters
A system for detecting clusters in space and time using input data on occurrences of a phenomenon and characteristics at a plurality of locations and times comprises an expectation generation module determining expected occurrences of a phenomena, and an occurrence modeling module determining actual occurrences of the phenomena. The system further comprises a search module searching the expected occurrences and the actual occurrences for a plurality of candidate solutions, wherein each solution is represented as a set of points in the three-dimensional space, and wherein each point corresponds to a location at a time. The system comprises a convex container module determining at least one solution corresponding to a selected convex container shape from the plurality of candidate solutions, and a solution evaluation module determining a strength metric for each solution determined by the convex container module, the search module selecting a dominant cluster in the input data.
Latest IBM Patents:
This invention was developed under Government Contract (DARPA Project F30602-01-C-0184). The U.S. Government has rights to this patent application.
BACKGROUND OF THE INVENTION1. Field of Invention
The present invention relates to modeling space-time data, and more particularly to detecting three-dimensional convex clusters in space and time for a phenomenon.
2. Discussion of Related Art
Detection of clusters in space and time, called space-time clusters, is an important function in various domains. For example, detection of such clusters is an important part of the investigation of disease outbreaks in the domain of epidemiology and public health. Other domains of application include medical imaging, urban planning and reconnaissance. The notion of what constitutes a cluster depends on the domain. For example, the spatial scan statistic as described in the paper “A spatial scan statistic” by Martin Kulldorff in Communications in Statistics: Theory and Methods, Volume 26, Number 6, 1997, is widely used in the epidemiology and public health domain. Other models of clustering might be appropriate in other domains.
Methods for detecting clusters may be developed depending on the clustering notion used. For example, the use of the scan statistic implies that earlier hierarchical approaches (see for example, “Automatic subspace clustering of high dimensional data for data mining applications” by R. Agrawal, J. Gehrke, D. Gunopulos, and P. Raghavan in Proceedings of the ACM-SIGMOD International Conference on Management of Data, 1998) to clustering cannot be applied. An example of a system that may handle the spatial scan statistic model for clustering is the SaTScan system. SaTScan may be used to detect space-time clusters with a cylindrical shape, representing a circular region in space for the entire duration of an interval in time.
SUMMARY OF THE INVENTIONThe cylindrical shape may not represent clusters that shrink or grow with time. Also, it may not represent movement of the phenomenon over time. The exhaustive search based on a grid that is utilized by systems like SaTScan may not be extended to more general shapes. Therefore, a need exists for a system that at least may detect generalized space-time clusters that model such characteristics of the underlying phenomenon.
A system for detecting clusters in space and time using input data on occurrences of a phenomenon and characteristics at a plurality of locations and times includes an expectation generation module, an occurrence modeling module, a search module, a convex container module, and a solution evaluation module.
The expectation generation module determines expected occurrences of a phenomena at a plurality of locations and a plurality of times, and the occurrence modeling module determines actual occurrences of the phenomena at a plurality of locations and a plurality of times. The search module searches the expected occurrences and the actual occurrences for a plurality of candidate solutions. Each solution is represented as a set of points in the three-dimensional space, wherein each point corresponds to a location at a time. The convex container module determines at least one solution corresponding to a selected convex container shape from the plurality of candidate solutions, and the solution evaluation module determines a strength metric for each solution determined by the convex container module, the search module selecting a solution having a desirable strength, wherein the solution having the desirable strength indicates a dominant cluster in the input data.
The search module selects a strongest solution as determined by the solution evaluation module.
A cache module may be included to save the solutions having the desired shape determined by the convex container module for previously examined sets of points.
The input data on occurrences of a phenomenon include counts and times of the occurrences of the phenomenon at the locations in a time period. The input data on characteristics of the locations and times include the populations subject to the occurrences of the phenomenon at the locations and times.
The expectation generation model generates expected counts of occurrences at the locations and times using a Poisson model.
The occurrence modeling module determines the occurrences as equal to the occurrences in the input data. The occurrence modeling module determines the occurrences at the locations and times based on their characteristics and a domain dependent model. The occurrences are determined from the population using a Poisson model.
The search module considers candidate solutions represented as sets of points and utilizes the convex container module to determine solutions having the desired shape from the candidate solutions. The candidate solutions are initialized based on the input data. Each initial candidate solution is singleton point.
The search module determines candidate solutions from solutions considered using an iterative process. Candidate solutions are created from solutions considered based on the chosen convex container shape.
The convex container module may determine a solution in various ways. For example, the convex container module determines a solution with minimum volume, given the selected convex container shape, that includes all the points in a given candidate solution. The convex container module may determine a solution with maximum volume, given the selected convex container shape, that excludes all the points not in the given candidate solution. According to another example, the convex container module may determine a solution that maximizes a measure representing the equality between the set of points in the given candidate solution and the set of points included in the solution, given the selected convex container shape.
The solution evaluation module determines the strength metric based on all the points included in the solution and the expected occurrences determined by the expectation generation module and the occurrences determined by the occurrence modeling module.
The strength metric is based on the likelihood ratio using the spatial scan statistic.
BRIEF DESCRIPTION OF THE DRAWINGSPreferred embodiments of the present invention will be described below in more detail, with references to the accompanying drawings:
The detection of three-dimensional clusters in space and time is used for determining localized occurrences of a phenomenon of interest. Data comprising space and time information is analyzed to determine where and when the phenomenon of interest appears. A system and/or method analyze the input data to determine a phenomenon of interest and use a user selected three dimensional shape to determine properties of the phenomenon.
It is to be understood that the present invention may be implemented in various forms of hardware, software, firmware, special purpose processors, or a combination thereof. In one embodiment, the present invention may be implemented in software as an application program tangibly embodied on a program storage device. The application program may be uploaded to, and executed by, a machine comprising any suitable architecture.
Referring to
The computer platform 101 also includes an operating system and microinstruction code. The various processes and functions described herein may either be part of the microinstruction code or part of the application program (or a combination thereof), which is executed via the operating system. In addition, various other peripheral devices may be connected to the computer platform such as an additional data storage device and a printing device.
It is to be further understood that, because some of the constituent system components and method steps depicted in the accompanying figures may be implemented in software, the actual connections between the system components (or the process steps) may differ depending upon the manner in which the present invention is programmed. Given the teachings of the present disclosure provided herein, one of ordinary skill in the related art will be able to contemplate these and similar implementations or configurations of the present invention.
Referring to
Referring to
Referring to
Referring to
A solution of the convex container module 207 may be generated in any of a plurality of methods according to an embodiment of the present invention. For example, the convex container module generates a solution with minimum volume that includes all the points in the given set. According to another example, the convex container module generates a solution with maximum volume that excludes all the points not in the given set. According to yet another example, the convex container module generates a solution that is closest to the given set of points using a measure of equality between the given set of points and the set of points included in the solution. A measure of equality between two sets is the number of items that are only in one of the sets and minimizing this number would make the two sets closer to each other.
A cache module may be added to the cluster detection system for efficiency purposes. The cache module stores the solutions generated by the convex container module 207 for previously encountered sets of points. If a set of points is encountered more than once, the solution for it may be gotten from the cache module instead of invoking the convex container module again.
Convex container shapes may take any of a plurality of shapes. For example, a truncated pyramid with a square cross-section, where the square cross-section at any time in an interval represents the spatial extent of the cluster at the time. An example of a three-dimensional square pyramid cluster is shown in
Such a square pyramid may be specified by eight parameters as follows. Referring to
Accordingly, a solution of the convex container module 207 may be generated from a given set of points by solving a quadratic programming problem in which the volume as specified above using the parameters G and H of the square pyramid is minimized. Each point in the given set leads to four linear constraints in this quadratic programming formulation. These four constraints specify that the point is contained in the cross-section of the square pyramid at the specific time corresponding to the point. The cross-section of the square pyramid may be determined from the six parameters, A,B,C,D,G and H, using linear interpolation. The quadratic programming problem may be solved using any of a plurality of methods. For example, a quadratic programming problem with linear constraints may be solved exactly using any quadratic programming library package. According to another example, the quadratic programming problem may be solved approximately by considering a set of square pyramids that contain all the points in the given set and choosing the one with minimum volume. The square pyramid shape is one example of the convex container shapes that may be selected by the user for the convex container module 207.
Another example of a convex container shape is a truncated pyramid with a regular polygon for its cross-section. The generation of a solution by the convex container module 207 from a given set of points for this truncated pyramid container shape is an extension of the determination described above for the square pyramid. The volume of this pyramid is a similar function of the sides of the regular polygon at the minimum and maximum times of the pyramid interval. Each point in the given set leads to one linear constraint for each side of the polygon. The quadratic programming problem may be solved as described above for the square pyramid case. The truncated pyramid with a regular polygon is another example of the convex container shapes that may be selected by the user.
Another convex container shape that may be selected is a truncated cone with a circular spatial cross-section for each time in an interval. An example of this truncated cone is shown in
One having ordinary skill in the art would recognize, in light of the present disclosure, that other convex containers may be used for clustering.
Referring to
A heuristic model may be used for determining sets of points likely to contain a strongest solution fitting a convex container shape. Therefore, the search module may consider a subset of all possible sets of points while having a measure of confidence that a strongest solution fitting a convex container shape will be determined.
The search module 206 may select candidate solutions using other methods, for example, by systematically considering all candidate solutions based on a repetitive process such as a grid. This does not imply that all solutions will be explored for the chosen convex container shape. This approach may be effective for some simple shapes.
Referring to
An implementation according to an embodiment of the present invention was applied to data on cancer occurrences in 32 counties over a 19 year period. occurrence.txt
The file occurrence.txt contains a portion of the input occurrence data. Each line of this file specifies the county, number of occurrences of cancer, the year of occurrence and values for the other characteristics like age group and gender of the cancer patients.
The files location.txt and population.txt contain a portion of the characteristics of the locations and times. The file location.txt contains the Cartesian coordinates defining the location of each county being analyzed. Each line of the file population.txt contains a county name, year, and population for each set of values of the other characteristics (e.g., age group and gender). The cluster detected with the square pyramid as chosen convex container shape is shown in
Referring to
Having described embodiments for system for detecting generalized space-time clusters, 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 of the invention disclosed which are within the scope and spirit of the invention as defined by the appended claims. Having thus described 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 system for detecting clusters in space and time using input data on occurrences of a phenomenon and characteristics at a plurality of locations and times comprising:
- an expectation generation module determining expected occurrences of a phenomena at a plurality of locations and a plurality of times;
- an occurrence modeling module determining actual occurrences of the phenomena at a plurality of locations and a plurality of times;
- a search module searching the expected occurrences and the actual occurrences for a plurality of candidate solutions, wherein each solution is represented as a set of points in the three-dimensional space, and wherein each point corresponds to a location at a time;
- a convex container module determining at least one solution corresponding to a selected convex container shape from the plurality of candidate solutions; and
- a solution evaluation module determining a strength metric for each solution determined by the convex container module, the search module selecting a solution having a desirable strength, wherein the solution having the desirable strength indicates a dominant cluster in the input data.
2. The system of claim 1, wherein the search module selects a strongest solution as determined by the solution evaluation module.
3. The system of claim 1, further comprising a cache module to save the solutions having the desired shape determined by the convex container module for previously examined sets of points.
4. The system of claim 1, wherein the input data on occurrences of a phenomenon comprise counts and times of the occurrences of the phenomenon at the locations in a time period.
5. The system of claim 1, wherein the input data on characteristics of the locations and times comprise of the populations subject to the occurrences of the phenomenon at the locations and times.
6. The system of claim 1, wherein the expectation generation model generates expected counts of occurrences at the locations and times using a Poisson model.
7. The system of claim 1, wherein the occurrence modeling module determines the occurrences as equal to the occurrences in the input data.
8. The system of claim 1, wherein the occurrence modeling module determines the occurrences at the locations and times based on their characteristics and a domain dependent model.
9. The system of claim 8, wherein the occurrences are determined from the population using a Poisson model.
10. The system of claim 1, wherein the search module considers candidate solutions represented as sets of points and utilizes the convex container module to determine solutions having the desired shape from the candidate solutions.
11. The system of claim 10, wherein the candidate solutions are initialized based on the input data.
12. The system of claim 11, wherein each initial candidate solution is singleton point.
13. The system of claim 10, wherein the search module determines candidate solutions from solutions considered using an iterative process.
14. The system of claim 13, wherein candidate solutions are created from solutions considered based on the chosen convex container shape.
15. The system of claim 1, wherein the convex container module determines a solution with minimum volume, given the selected convex container shape, that includes all the points in a given candidate solution.
16. The system of claim 1, wherein the convex container module determines a solution with maximum volume, given the selected convex container shape, that excludes all the points not in the given candidate solution.
17. The system of claim 1, wherein the convex container module determines a solution that maximizes a measure representing the equality between the set of points in the given candidate solution and the set of points included in the solution, given the selected convex container shape.
18. The system of claim 1, wherein the solution evaluation module determines the strength metric based on all the points included in the solution and the expected occurrences determined by the expectation generation module and the occurrences determined by the occurrence modeling module.
19. The system of claim 1, wherein the strength metric is based on the likelihood ratio using the spatial scan statistic.
20. A method for detecting clusters comprising:
- receiving input data on occurrences of a phenomenon at locations and times and data on characteristics of the locations and times;
- determining actual occurrences of the phenomenon at the three-dimensional space-time points according to the input data;
- determining expected occurrences in the absence of any clustering of the phenomenon at the points according to the characteristics of the occurrences using a domain dependent model for the phenomenon;
- selecting a convex container shape for determining a cluster in the input data; and
- determining a solution represented as a set of points that conforms to the selected convex container shape for a cluster with a desirable strength.
21. The method of claim 20, further comprising caching solutions conforming to the selected convex container shape.
22. The method of claim 20, wherein determining expected occurrences further comprises generating expected counts of occurrences at the locations and times using a model.
23. The method of claim 20, further comprising determining a strength of the cluster based on points included in the cluster, and the expected occurrences and the actual occurrences.
24. A program storage device is provided readable by machine, tangibly embodying a program of instructions automatically executable by the machine to perform method steps for determining a clusters, the method steps comprising:
- receiving input data on occurrences of a phenomenon at locations and times and data on characteristics of the locations and times;
- determining actual occurrences of the phenomenon at the three-dimensional space-time points according to the input data;
- determining expected occurrences in the absence of any clustering of the phenomenon at the points according to the characteristics of the occurrences using a domain dependent model for the phenomenon;
- selecting a convex container shape for determining a cluster in the input data; and
- determining a solution represented as a set of points that conforms to the selected convex container shape for a cluster with a desirable strength.
25. The method of claim 24, further comprising caching solutions conforming to the selected convex container shape.
26. The method of claim 24, wherein determining expected occurrences further comprises generating expected counts of occurrences at the locations and times using a model.
27. The method of claim 24, further comprising determining a strength of the cluster based on points included in the cluster, and the expected occurrences and the actual occurrences.
Type: Application
Filed: Feb 12, 2004
Publication Date: Aug 18, 2005
Patent Grant number: 7343272
Applicant: International Business Machines Corporation (Armonk, NY)
Inventor: Vijay Iyengar (Cortlandt Manor, NY)
Application Number: 10/777,548