2020-05-05 02:16:54 +00:00
|
|
|
.. testsetup:: *
|
|
|
|
|
|
|
|
from torch.utils.data import IterableDataset
|
|
|
|
from pytorch_lightning.trainer.trainer import Trainer
|
2020-08-13 22:56:51 +00:00
|
|
|
|
|
|
|
.. _sequences:
|
2020-05-05 02:16:54 +00:00
|
|
|
|
2020-02-11 04:55:22 +00:00
|
|
|
Sequential Data
|
|
|
|
================
|
|
|
|
Lightning has built in support for dealing with sequential data.
|
|
|
|
|
2020-06-19 06:38:10 +00:00
|
|
|
----------
|
2020-02-11 04:55:22 +00:00
|
|
|
|
|
|
|
Packed sequences as inputs
|
2020-06-17 21:44:11 +00:00
|
|
|
--------------------------
|
2020-02-11 04:55:22 +00:00
|
|
|
When using PackedSequence, do 2 things:
|
|
|
|
|
2020-10-07 20:11:03 +00:00
|
|
|
1. Return either a padded tensor in dataset or a list of variable length tensors in the dataloader collate_fn (example shows the list implementation).
|
2020-02-11 04:55:22 +00:00
|
|
|
2. Pack the sequence in forward or training and validation steps depending on use case.
|
|
|
|
|
2020-05-05 02:16:54 +00:00
|
|
|
.. testcode::
|
2020-02-11 04:55:22 +00:00
|
|
|
|
2020-05-05 02:16:54 +00:00
|
|
|
# For use in dataloader
|
2020-02-11 04:55:22 +00:00
|
|
|
def collate_fn(batch):
|
|
|
|
x = [item[0] for item in batch]
|
|
|
|
y = [item[1] for item in batch]
|
|
|
|
return x, y
|
|
|
|
|
|
|
|
# In module
|
|
|
|
def training_step(self, batch, batch_nb):
|
|
|
|
x = rnn.pack_sequence(batch[0], enforce_sorted=False)
|
|
|
|
y = rnn.pack_sequence(batch[1], enforce_sorted=False)
|
|
|
|
|
2020-06-19 06:38:10 +00:00
|
|
|
----------
|
|
|
|
|
2020-02-11 04:55:22 +00:00
|
|
|
Truncated Backpropagation Through Time
|
2020-06-17 21:44:11 +00:00
|
|
|
--------------------------------------
|
2020-02-11 04:55:22 +00:00
|
|
|
There are times when multiple backwards passes are needed for each batch.
|
|
|
|
For example, it may save memory to use Truncated Backpropagation Through Time when training RNNs.
|
|
|
|
|
|
|
|
Lightning can handle TBTT automatically via this flag.
|
|
|
|
|
2020-05-05 02:16:54 +00:00
|
|
|
.. testcode::
|
2020-02-11 04:55:22 +00:00
|
|
|
|
|
|
|
# DEFAULT (single backwards pass per batch)
|
|
|
|
trainer = Trainer(truncated_bptt_steps=None)
|
|
|
|
|
|
|
|
# (split batch into sequences of size 2)
|
|
|
|
trainer = Trainer(truncated_bptt_steps=2)
|
|
|
|
|
|
|
|
.. note:: If you need to modify how the batch is split,
|
|
|
|
override :meth:`pytorch_lightning.core.LightningModule.tbptt_split_batch`.
|
|
|
|
|
2020-08-07 11:02:36 +00:00
|
|
|
.. note:: Using this feature requires updating your LightningModule's
|
|
|
|
:meth:`pytorch_lightning.core.LightningModule.training_step` to include a `hiddens` arg.
|
2020-03-29 19:29:09 +00:00
|
|
|
|
2020-06-19 06:38:10 +00:00
|
|
|
----------
|
|
|
|
|
2020-03-29 19:29:09 +00:00
|
|
|
Iterable Datasets
|
2020-06-17 21:44:11 +00:00
|
|
|
-----------------
|
2020-03-29 19:29:09 +00:00
|
|
|
Lightning supports using IterableDatasets as well as map-style Datasets. IterableDatasets provide a more natural
|
|
|
|
option when using sequential data.
|
|
|
|
|
2020-08-07 11:02:36 +00:00
|
|
|
.. note:: When using an IterableDataset you must set the ``val_check_interval`` to 1.0 (the default) or an int
|
|
|
|
(specifying the number of training batches to run before validation) when initializing the Trainer. This is
|
|
|
|
because the IterableDataset does not have a ``__len__`` and Lightning requires this to calculate the validation
|
|
|
|
interval when ``val_check_interval`` is less than one. Similarly, you can set ``limit_{mode}_batches`` to a float or
|
|
|
|
an int. If it is set to 0.0 or 0 it will set ``num_{mode}_batches`` to 0, if it is an int it will set ``num_{mode}_batches``
|
|
|
|
to ``limit_{mode}_batches``, if it is set to 1.0 it will run for the whole dataset, otherwise it will throw an exception.
|
|
|
|
Here mode can be train/val/test.
|
2020-03-29 19:29:09 +00:00
|
|
|
|
2020-05-05 02:16:54 +00:00
|
|
|
.. testcode::
|
2020-03-29 19:29:09 +00:00
|
|
|
|
|
|
|
# IterableDataset
|
|
|
|
class CustomDataset(IterableDataset):
|
|
|
|
|
|
|
|
def __init__(self, data):
|
|
|
|
self.data_source
|
|
|
|
|
|
|
|
def __iter__(self):
|
|
|
|
return iter(self.data_source)
|
|
|
|
|
|
|
|
# Setup DataLoader
|
|
|
|
def train_dataloader(self):
|
|
|
|
seq_data = ['A', 'long', 'time', 'ago', 'in', 'a', 'galaxy', 'far', 'far', 'away']
|
|
|
|
iterable_dataset = CustomDataset(seq_data)
|
|
|
|
|
|
|
|
dataloader = DataLoader(dataset=iterable_dataset, batch_size=5)
|
|
|
|
return dataloader
|
|
|
|
|
2020-05-05 02:16:54 +00:00
|
|
|
.. testcode::
|
|
|
|
|
2020-03-29 19:29:09 +00:00
|
|
|
# Set val_check_interval
|
2020-05-05 02:16:54 +00:00
|
|
|
trainer = Trainer(val_check_interval=100)
|
2020-08-07 11:02:36 +00:00
|
|
|
|
|
|
|
# Set limit_val_batches to 0.0 or 0
|
|
|
|
trainer = Trainer(limit_val_batches=0.0)
|
|
|
|
|
|
|
|
# Set limit_val_batches as an int
|
|
|
|
trainer = Trainer(limit_val_batches=100)
|