Skip to content

Latest commit

 

History

History
19 lines (12 loc) · 2.41 KB

File metadata and controls

19 lines (12 loc) · 2.41 KB

Memetic Genetic Algorithms for Time Series Compression by Piecewise Linear Approximation

This repository contains the source code and measurements for the paper accepted at ICONIP 2020.

Abstract

Time series are sequences of data indexed by time. Such data are collected in various domains, often in massive amounts, such that storing them proves challenging. Thus, time series are commonly stored in a compressed format. An important compression approach is piecewise linear approximation (PLA), which only keeps a small set of time points and interpolates the remainder linearly. Picking a subset of time points such that the PLA minimizes the mean squared error to the original time series is a challenging task, naturally lending itself to heuristics.

We propose the piecewise linear approximation genetic algorithm (PLA-GA) for compressing time series by PLA. The PLA-GA is a memetic (μ+λ) GA that makes use of two distinct operators tailored to time series compression. First, we add special individuals to the initial population that are derived using established PLA heuristics. Second, we propose a novel local search operator that greedily improves a compressed time series. We compare the PLA-GA empirically with existing evolutionary approaches and with a deterministic PLA algorithm, known as Bellman's algorithm, that is optimal for the restricted setting of sampling. In both cases, the PLA-GA approximates the original time series better and quicker. Further, it drastically outperforms Bellman's algorithm with increasing instance size with respect to run time until finding a solution of equal or better quality -- we observe speed-up factors between 7 and 100 for instances of 90,000 to 100,000 data points.

Content

This repository contains

  • the appendix of the paper explaining the operators of the genetic algorithm.
  • the measurements discussed in the paper. They can be found in the results directory along with two jupyter notebooks for visualization.
  • the source code. Experiments are configured and started in src/experiment.jl and additional data sets can be added to src/datasets.jl.

Please reach out to [email protected] if you have any questions or need help in using the code.

Please note that the provided timeseries belong to The UCR Time Series Classification Archive and to the UCI Machine Learning Repository.