Download presentation
Presentation is loading. Please wait.
1
Bayesian Network Anomaly Pattern Detection for Disease Outbreaks Weng-Keen Wong (Carnegie Mellon University) Andrew Moore (Carnegie Mellon University) Gregory Cooper (University of Pittsburgh) Michael Wagner (University of Pittsburgh)
2
Motivation Primary Key DateTimeHospitalICD9ProdromeGenderAgeHome Location Work Location Many more… 1006/1/039:121781FeverM20sNE?… 1016/1/0310:451787DiarrheaF40sNE … 1026/1/0311:031786RespiratoryF60sNEN… 1036/1/0311:072787DiarrheaM60sE?… 1046/1/0312:151717RespiratoryM60sENE… 1056/1/0313:013780ViralF50s?NW… 1066/1/0313:053487RespiratoryF40sSW … 1076/1/0313:572786UnmappedM50sSESW… 1086/1/0314:221780ViralM40s??… : : : : : : : : : : : Suppose we have real-time access to Emergency Department data from hospitals around a city (with patient confidentiality preserved)
3
The Problem From this data, can we detect if a disease outbreak is happening?
4
The Problem From this data, can we detect if a disease outbreak is happening? We’re talking about a non- specific disease detection
5
The Problem From this data, can we detect if a disease outbreak is happening? How early can we detect it?
6
The Problem From this data, can we detect if a disease outbreak is happening? How early can we detect it? The question we’re really asking: What’s strange about recent events?
7
Traditional Approaches What about using traditional anomaly detection? Typically assume data is generated by a model Finds individual data points that have low probability with respect to this model These outliers have rare attributes or combinations of attributes Need to identify anomalous patterns not isolated data points
8
Traditional Approaches –Time series algorithms –Regression techniques –Statistical Quality Control methods Need to know apriori which attributes to form daily aggregates for! What about monitoring aggregate daily counts of certain attributes? We’ve now turned multivariate data into univariate data Lots of algorithms have been developed for monitoring univariate data:
9
Traditional Approaches What if we don’t know what attributes to monitor? What if we want to exploit the spatial, temporal and/or demographic characteristics of the epidemic to detect the outbreak as early as possible?
10
Traditional Approaches We need to build a univariate detector to monitor each interesting combination of attributes: Diarrhea cases among children Respiratory syndrome cases among females Viral syndrome cases involving senior citizens from eastern part of city Number of children from downtown hospital Number of cases involving people working in southern part of the city Number of cases involving teenage girls living in the western part of the city Botulinic syndrome cases And so on…
11
Traditional Approaches We need to build a univariate detector to monitor each interesting combination of attributes: Diarrhea cases among children Respiratory syndrome cases among females Viral syndrome cases involving senior citizens from eastern part of city Number of children from downtown hospital Number of cases involving people working in southern part of the city Number of cases involving teenage girls living in the western part of the city Botulinic syndrome cases And so on… You’ll need hundreds of univariate detectors! We would like to identify the groups with the strangest behavior in recent events.
12
One Possible Approach Primary Key DateTimeGenderAgeHospitalMany more… 1008/24/039:12M20s1… 1018/24/0310:45F40s1… ::::::: 22438/17/0311:07M60s2… 22448/17/0312:15M60s1… ::::::: 125678/24/0213:05F40s3… 125688/24/0213:57M50s2… : : : : : : : Today’s Records Yesterday’s Records Last Year’s Records
13
One Possible Approach Primary Key DateTimeGenderAgeHospitalMany more… 1008/24/039:12M20s1… 1018/24/0310:45F40s1… ::::::: 22438/17/0311:07M60s2… 22448/17/0312:15M60s1… ::::::: 125678/24/0213:05F40s3… 125688/24/0213:57M50s2… : : : : : : : Today’s Records Yesterday’s Records Last Year’s Records Idea: Can use association rules to find patterns in today’s records that weren’t there in past data
14
One Possible Approach Primary Key DateTimeGenderAge… 1008/24/039:12MChild… 1018/24/0310:45MSenior… : : : : : : Primary Key DateTimeGenderAge… 21648/17/0313:05FSenior… 21658/17/0313:57FSenior… : : : : : : Recent records ( from today ) Baseline records ( from 7 days ago ) Primary Key DateTime…Source 1008/24/039:12…Recent 1018/24/0310:45…Recent : :::: 21648/17/0313:05…Baseline 21658/17/0313:57…Baseline ::: : : Find which rules predict unusually high proportions in recent records when compared to the baseline eg. 52/200 records from “recent” have Gender = Male AND Age = Senior 90/180 records from “baseline” have Gender = Male AND Age = Senior
15
Which rules do we report? Search over all rules with at most 2 components For each rule, form a 2x2 contingency table eg. Perform Fisher’s Exact Test to get a p-value for each rule (call this the score) Report the rule with the lowest score Count Recent Count Baseline Home Location = NW4845 Home Location NW 86220
16
Problems with the Approach 1.Multiple Hypothesis Testing 2. A Changing Baseline
17
Problem #1: Multiple Hypothesis Testing Can’t interpret the rule scores as p-values Suppose we reject null hypothesis when score < , where = 0.05 For a single hypothesis test, the probability of making a false discovery = Suppose we do 1000 tests, one for each possible rule Probability(false discovery) could be as bad as: 1 – ( 1 – 0.05) 1000 >> 0.05
18
Randomization Test Take the recent cases and the baseline cases. Shuffle the date field to produce a randomized dataset called DB Rand Find the rule with the best score on DB Rand. Aug 16, 2003C2 Aug 17, 2003C3 Aug 17, 2003C4 Aug 17, 2003C5 Aug 17, 2003C6 Aug 17, 2003C7 Aug 21, 2003C8 Aug 21, 2003C9 Aug 22, 2003C10 Aug 22, 2003C11 Aug 23, 2003C12 Aug 23, 2003C13 Aug 24, 2003C14 Aug 24, 2003C15 Aug 16, 2003C2 Aug 17, 2003C3 Aug 24, 2003C4 Aug 17, 2003C5 Aug 24, 2003C6 Aug 17, 2003C7 Aug 21, 2003C8 Aug 21, 2003C9 Aug 22, 2003C10 Aug 22, 2003C11 Aug 23, 2003C12 Aug 23, 2003C13 Aug 17, 2003C14 Aug 17, 2003C15
19
Randomization Test Repeat the procedure on the previous slide for 1000 iterations. Determine how many scores from the 1000 iterations are better than the original score. If the original score were here, it would place in the top 1% of the 1000 scores from the randomization test. We would be impressed and an alert should be raised. Corrected p-value of the rule is: # better scores / # iterations
20
Problem #2: A Changing Baseline From: Goldenberg, A., Shmueli, G., Caruana, R. A., and Fienberg, S. E. (2002). Early statistical detection of anthrax outbreaks by tracking over-the-counter medication sales. Proceedings of the National Academy of Sciences (pp. 5237-5249)
21
Problem #2: A Changing Baseline Baseline is affected by temporal trends in health care data: –Seasonal effects in temperature and weather –Day of Week effects –Holidays –Etc. Choosing the wrong baseline distribution can affect the detection time and false positives rate
22
Generating the Baseline… “Taking into account that today is a public holiday…” “Taking into account that this is Spring…” “Taking into account recent heatwave…” “Taking into account recent flu levels…” “Taking into account that there’s a known natural Food- borne outbreak in progress…”
23
Generating the Baseline… “Taking into account that today is a public holiday…” “Taking into account that this is Spring…” “Taking into account recent heatwave…” “Taking into account recent flu levels…” “Taking into account that there’s a known natural Food- borne outbreak in progress…” Use a Bayes net to model the joint probability distribution of the attributes
24
Obtaining Baseline Data Baseline All Historical Data Today’s Environment 1.Learn Bayesian Network using Optimal Reinsertion [Moore and Wong 2003] 2. Generate baseline given today’s environment
25
Environmental Attributes Divide the data into two types of attributes: Environmental attributes: attributes that cause trends in the data eg. day of week, season, weather, flu levels Response attributes: all other non- environmental attributes
26
Environmental Attributes When learning the Bayesian network structure, do not allow environmental attributes to have parents. Why? We are not interested in predicting their distributions Instead, we use them to predict the distributions of the response attributes Side Benefit: We can speed up the structure search by avoiding DAGs that assign parents to the environmental attributes SeasonDay of WeekWeatherFlu Level
27
Generate Baseline Given Today’s Environment SeasonDay of WeekWeatherFlu Level TodayWinterMondaySnowHigh Season = Winter Day of Week = Monday Weather = Snow Flu Level = High Suppose we know the following for today: We fill in these values for the environmental attributes in the learned Bayesian network Baseline We sample 10000 records from the Bayesian network and make this data set the baseline
28
Generate Baseline Given Today’s Environment SeasonDay of WeekWeatherFlu Level TodayWinterMondaySnowHigh Season = Winter Day of Week = Monday Flu Level = High Suppose we know the following for today: We fill in these values for the environmental attributes in the learned Bayesian network Baseline We sample 10000 records from the Bayesian network and make this data set the baseline Sampling is easy because environmental attributes are at the top of the Bayes Net Weather = Snow
29
Generate Baseline Given Today’s Environment SeasonDay of WeekWeatherFlu Level TodayWinterMondaySnowHigh Season = Winter Day of Week = Monday Flu Level = High Suppose we know the following for today: We fill in these values for the environmental attributes in the learned Bayesian network Baseline We sample 10000 records from the Bayesian network and make this data set the baseline An alternate possible technique is to use inference Weather = Snow
30
What’s Strange About Recent Events (WSARE) 3.0 2.Search for rule with best score 3.Determine p-value of best scoring rule All Data 4.If p-value is less than threshold, signal alert Recent Data Baseline 1.Obtain Recent and Baseline datasets
31
Simulator
32
Simulation 100 different data sets Each data set consisted of a two year period Anthrax release occurred at a random point during the second year Algorithms allowed to train on data from the current day back to the first day in the simulation Any alerts before actual anthrax release are considered a false positive Detection time calculated as first alert after anthrax release. If no alerts raised, cap detection time at 14 days
33
Other Algorithms used in Simulation Signal Time Mean Upper Safe Range 1. Standard algorithm 2. WSARE 2.0 Create baseline using historical data from 7, 14, 21 and 28 days ago 3. WSARE 2.5 Use all past data but condition on environmental attributes
34
Results on Simulation
36
Results on Actual ED Data from 2001 1. Sat 2001-02-13: SCORE = -0.00000004 PVALUE = 0.00000000 14.80% ( 74/500) of today's cases have Viral Syndrome = True and Encephalitic Prodome = False 7.42% (742/10000) of baseline have Viral Syndrome = True and Encephalitic Syndrome = False 2. Sat 2001-03-13: SCORE = -0.00000464 PVALUE = 0.00000000 12.42% ( 58/467) of today's cases have Respiratory Syndrome = True 6.53% (653/10000) of baseline have Respiratory Syndrome = True 3. Wed 2001-06-30: SCORE = -0.00000013 PVALUE = 0.00000000 1.44% ( 9/625) of today's cases have 100 <= Age < 110 0.08% ( 8/10000) of baseline have 100 <= Age < 110 4. Sun 2001-08-08: SCORE = -0.00000007 PVALUE = 0.00000000 83.80% (481/574) of today's cases have Unknown Syndrome = False 74.29% (7430/10001) of baseline have Unknown Syndrome = False 5. Thu 2001-12-02: SCORE = -0.00000087 PVALUE = 0.00000000 14.71% ( 70/476) of today's cases have Viral Syndrome = True and Encephalitic Syndrome = False 7.89% (789/9999) of baseline have Viral Syndrome = True and Encephalitic Syndrome = False 6. Thu 2001-12-09: SCORE = -0.00000000 PVALUE = 0.00000000 8.58% ( 38/443) of today's cases have Hospital ID = 1 and Viral Syndrome = True 2.40% (240/10000) of baseline have Hospital ID = 1 and Viral Syndrome = True
37
Related Work Deviations between models induced by two datasets [Ganti, Gehrke and Ramakrishnan] Emerging Patterns [Dong and Li] Mining Surprising Patterns using Temporal Description Length [Chakrabarti, Sarawagi and Dom] Contrast sets [Bay and Pazzani] Association Rules and Data Mining in Hospital Infection Control and Public Health Surveillance [Brossette et. al.] Spatial Scan Statistic [Kulldorff]
38
Conclusion One approach to biosurveillance: one algorithm monitoring millions of signals derived from multivariate data instead of Hundreds of univariate detectors WSARE is best used as a general purpose safety net in combination with other detectors Careful evaluation of statistical significance Modeling historical data with Bayesian Networks to allow conditioning on unique features of today Software: http://www.autonlab.org/
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.