Generative Time-series Modeling with Fourier Flows
Project description
Fourier-flows 🌀
Code for the Generative Time-series Modeling with Fourier Flows paper.
Code author: Ahmed Alaa
Description
Generating synthetic time-series data is crucial in various application domains, such as medical prognosis, wherein research is hamstrung by the lack of access to data due to concerns over privacy.
Most of the recently proposed methods for generating synthetic time-series rely on implicit likelihood modeling using generative adversarial networks (GANs)—but such models can be difficult to train, and may jeopardize privacy by “memorizing” temporal patterns in training data.
In this paper, we propose an explicit likelihood model based on a novel class of normalizing flows that view time-series data in the frequency-domain rather than the time-domain. The proposed flow, dubbed a Fourier flow, uses a discrete Fourier transform (DFT) to convert variable-length time-series with arbitrary sampling periods into fixed-length spectral representations, then applies a (data-dependent) spectral filter to the frequency-transformed time-series. We show that, by virtue of the DFT analytic properties, the Jacobian determinants and inverse mapping for the Fourier flow can be computed efficiently in linearithmic time, without imposing explicit structural constraints as in existing flows such as NICE (Dinh et al. (2014)), RealNVP (Dinh et al. (2016)) and GLOW (Kingma & Dhariwal (2018)).
Installation
Install with pip
:
pip install fflows
Examples
Fit a Fourier flow
import numpy as np
from fflows import FourierFlow
T = 11
n_samples = 100
dims = 3
X = np.random.randn(n_samples, T, dims)
model_params = {
"hidden": 11,
"n_flows": 11,
}
train_params = {
"epochs": 10,
"batch_size": 500,
"learning_rate": 1e-3,
"display_step": 100,
}
model = FourierFlow(**model_params)
model.fit(X, **train_params)
Generate new data
samples = model.sample(10)
assert samples.shape == (10, T, dims)
Data
The public datasets used in the paper are available at:
Experiments
- For Experiment 1 (Section 5.1), run
ICLR 2021 - Experiment 1.ipynb
. - For Experiment 2 (Section 5.2), run
run_experiment_2.py
.
Citing
Please cite using:
@inproceedings{alaa2020generative,
title={Generative Time-series Modeling with Fourier Flows},
author={Alaa, Ahmed and Chan, Alex James and van der Schaar, Mihaela},
booktitle={International Conference on Learning Representations},
year={2021}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
File details
Details for the file fflows-0.0.3-py3-none-macosx_10_14_x86_64.whl
.
File metadata
- Download URL: fflows-0.0.3-py3-none-macosx_10_14_x86_64.whl
- Upload date:
- Size: 19.9 kB
- Tags: Python 3, macOS 10.14+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.7.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c6101a5b3ebf241cf3bb473420ac1669759e4ca84fabbb09fb576d16eb2b6928 |
|
MD5 | 03e586b1da51b2a5008c4925adf82746 |
|
BLAKE2b-256 | 5693eba05d84a28ed2f1885a37d528f6b4bef6e8aabae19d0a104a6439570a24 |
File details
Details for the file fflows-0.0.3-py3-none-any.whl
.
File metadata
- Download URL: fflows-0.0.3-py3-none-any.whl
- Upload date:
- Size: 20.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 18de7a7b98e3708ff2d5ae9f10fad625740230c4de6447906b7ca477667b78fb |
|
MD5 | a32bcafeef32848925fdc16972cedab8 |
|
BLAKE2b-256 | 3078b5d1e92ef17cbf0bf1fa97266f58a128b466d20ee1d6c444f652e92583d7 |