1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
|
# Turing Change Point Dataset
[](https://github.com/alan-turing-institute/TCPD/actions?query=workflow%3A%22Validate+TCPD%22)
[](https://zenodo.org/badge/latestdoi/224688676)
Welcome to the host repository of the Turing Change Point Dataset, a set of
time series specifically collected for the evaluation of change point
detection algorithms on real-world data. This dataset was introduced in [this
paper](https://arxiv.org/abs/2003.06222). For the repository containing the
code used for the experiments, see
[TCPDBench](https://github.com/alan-turing-institute/TCPDBench).
**Useful links:**
- [Turing Change Point Dataset](https://github.com/alan-turing-institute/TCPD)
on GitHub.
- [Turing Change Point Detection
Benchmark](https://github.com/alan-turing-institute/TCPDBench)
- [An Evaluation of Change Point Detection Algorithms](https://arxiv.org/abs/2003.06222) by
[Gertjan van den Burg](https://gertjan.dev) and [Chris
Williams](https://homepages.inf.ed.ac.uk/ckiw/).
- [Annotation Tool](https://github.com/alan-turing-institute/annotatechange)
## Introduction
Change point detection focuses on accurately detecting moments of abrupt
change in the behavior of a time series. While many methods for change point
detection exists, past research has paid little attention to the evaluation of
existing algorithms on real-world data. This work introduces a benchmark study
and a dataset ([TCPD](https://github.com/alan-turing-institute/TCPD)) that are
explicitly designed for the evaluation of change point detection algorithms.
We hope that our work becomes a proving ground for the evaluation and
development of change point detection algorithms that work well in practice.
This repository contains the code needed to obtain the time series in the
dataset. For the benchmark study, see
[TCPDBench](https://github.com/alan-turing-institute/TCPDBench). Note that
work based on the dataset should cite [our
paper](https://arxiv.org/abs/2003.06222):
```bib
@article{vandenburg2020evaluation,
title={An Evaluation of Change Point Detection Algorithms},
author={{Van den Burg}, G. J. J. and Williams, C. K. I.},
journal={arXiv preprint arXiv:2003.06222},
year={2020}
}
```
The annotations are stored in the [annotations.json](annotations.json) file,
which is the same as that used in the experiments (see
[here](https://github.com/alan-turing-institute/TCPDBench/blob/master/analysis/annotations/annotations.json)).
Annotations are organised in a JSON object by dataset name and annotator id,
and use 0-based indexing. See the
[TCPDBench](https://github.com/alan-turing-institute/TCPDBench) repository for
more information on extending the benchmark with your own methods or datasets.
## Getting Started
Many of the time series in the dataset are included in this repository.
However, due to licensing restrictions, some series can not be redistributed
and need to be downloaded locally. We've added a Python script and a Makefile
to make this process as easy as possible. There is also a Dockerfile to
facilitate reproducibility.
### Using Docker
To build the dataset using Docker, first build the docker image:
```
$ docker build -t tcpd https://github.com/alan-turing-institute/TCPD.git
```
then build the dataset:
```
$ docker run -i -t -v /path/to/where/you/want/the/dataset:/TCPD/export tcpd
```
### Using the command line
To obtain the dataset, please run the following steps:
1. Clone the GitHub repository and change to the new directory:
```
$ git clone https://github.com/alan-turing-institute/TCPD
$ cd TCPD
```
2. Make sure you have Python (v3.2 or newer) installed, as well as
[virtualenv](https://virtualenv.pypa.io/en/latest/):
```
$ pip install virtualenv
```
3. Next, use either of these steps:
- To obtain the dataset using Make, simply run:
```
$ make
```
This command will download all remaining datasets and verify that they
match the expected checksums.
- If you don't have Make, you can obtain the dataset by manually executing
the following commands:
```
$ virtualenv ./venv
$ source ./venv/bin/activate
$ pip install -r requirements.txt
$ python build_tcpd.py -v collect
```
If you wish to verify the downloaded datasets you can run:
```
$ python ./utils/check_checksums.py -v -c ./checksums.json -d ./datasets
```
4. It may be convenient to export all dataset files to a single directory.
This can be done using Make as follows:
```
$ make export
```
All datasets are stored in individual directories inside the ``datasets``
directory and each has its own README file with additional metadata and
sources. The data format used is [JSON](https://json.org/) and each file
follows the [JSON Schema](https://json-schema.org/) provided in
``schema.json``.
## Using the data
For your convenience, example code to load a dataset from the JSON format to a
data frame is provided in the ``examples`` directory in the following
languages:
- [Python](examples/python/)
- [R](examples/R/)
Implementations of various change point detection algorithms that use these
datasets are available in
[TCPDBench](https://github.com/alan-turing-institute/TCPDBench). A script to
plot the datasets and detection results from
[TCPDBench](https://github.com/alan-turing-institute/TCPDBench) is also
provided in [utils/plot_dataset.py](tree/master/utils/plot_dataset.py).
The annotations are included in the
[annotations.json](tree/master/annotations.json) file. They are in the format:
```
{
"<dataset>": {
"annotator_id": [
<change point index>
<change point index>
...
],
...
},
...
}
```
where the ``annotator_id`` is a unique ID for the annotator and the change
point indices are
[0-based](https://en.wikipedia.org/wiki/Zero-based_numbering). Please also see
the documentation in
[TCPDBench](https://github.com/alan-turing-institute/TCPDBench) for more
information about using the dataset and benchmark in your own work.
## License
The code in this repository is licensed under the MIT license. See the
[LICENSE file](LICENSE) for more details. Individual data files are often
distributed under different terms, see the relevant README files for more
details. Work that uses this dataset should cite [our
paper](https://arxiv.org/abs/2003.06222).
## Notes
If you find any problems or have a suggestion for improvement of this
repository, please let us know as it will help us make this resource better
for everyone. You can open an issue on
[GitHub](https://github.com/alan-turing-institute/TCPD) or send an email to
``gvandenburg at turing dot ac dot uk``.
|