Creates a dataset of sliding windows over a timeseries provided as array.
tf.keras.preprocessing.timeseries_dataset_from_array( data, targets, sequence_length, sequence_stride=1, sampling_rate=1, batch_size=128, shuffle=False, seed=None, start_index=None, end_index=None )
This function takes in a sequence of data-points gathered at equal intervals, along with time series parameters such as length of the sequences/windows, spacing between two sequence/windows, etc., to produce batches of timeseries inputs and targets.
| ||Numpy array or eager tensor containing consecutive data points (timesteps). Axis 0 is expected to be the time dimension.|
| || Targets corresponding to timesteps in |
| ||Length of the output sequences (in number of timesteps).|
| || Period between successive output sequences. For stride |
| || Period between successive individual timesteps within sequences. For rate |
| ||Number of timeseries samples in each batch (except maybe the last one).|
| ||Whether to shuffle output samples, or instead draw them in chronological order.|
| ||Optional int; random seed for shuffling.|
| || Optional int; data points earlier (exclusive) than |
| || Optional int; data points later (exclusive) than |
| A tf.data.Dataset instance. If |
[0, 1, ... 99]. With
sequence_length=10, sampling_rate=2, sequence_stride=3,
shuffle=False, the dataset will yield batches of sequences composed of the following indices:
First sequence: [0 2 4 6 8 10 12 14 16 18] Second sequence: [3 5 7 9 11 13 15 17 19 21] Third sequence: [6 8 10 12 14 16 18 20 22 24] ... Last sequence: [78 80 82 84 86 88 90 92 94 96]
In this case the last 3 data points are discarded since no full sequence can be generated to include them (the next sequence would have started at index 81, and thus its last step would have gone over 99).
Example 2: temporal regression. Consider an array
data of scalar values, of shape
(steps,). To generate a dataset that uses the past 10 timesteps to predict the next timestep, you would use:
input_data = data[:-10] targets = data[10:] dataset = tf.keras.preprocessing.timeseries_dataset_from_array( input_data, targets, sequence_length=10) for batch in dataset: inputs, targets = batch assert np.array_equal(inputs, data[:10]) # First sequence: steps [0-9] assert np.array_equal(targets, data) # Corresponding target: step 10 break
© 2020 The TensorFlow Authors. All rights reserved.
Licensed under the Creative Commons Attribution License 3.0.
Code samples licensed under the Apache 2.0 License.