2020-08-13 22:56:51 +00:00
|
|
|
.. _test-set:
|
|
|
|
|
2020-02-11 04:55:22 +00:00
|
|
|
Test set
|
2020-05-05 02:16:54 +00:00
|
|
|
========
|
2020-05-31 04:48:05 +00:00
|
|
|
Lightning forces the user to run the test set separately to make sure it isn't evaluated by mistake.
|
2020-02-11 04:55:22 +00:00
|
|
|
|
2020-06-19 06:38:10 +00:00
|
|
|
----------
|
2020-02-11 04:55:22 +00:00
|
|
|
|
|
|
|
Test after fit
|
2020-05-05 02:16:54 +00:00
|
|
|
--------------
|
2020-06-15 12:02:37 +00:00
|
|
|
To run the test set after training completes, use this method.
|
2020-02-11 04:55:22 +00:00
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
# run full training
|
|
|
|
trainer.fit(model)
|
|
|
|
|
2020-06-15 12:02:37 +00:00
|
|
|
# (1) load the best checkpoint automatically (lightning tracks this for you)
|
2020-02-11 04:55:22 +00:00
|
|
|
trainer.test()
|
|
|
|
|
2020-06-15 12:02:37 +00:00
|
|
|
# (2) don't load a checkpoint, instead use the model with the latest weights
|
|
|
|
trainer.test(ckpt_path=None)
|
|
|
|
|
|
|
|
# (3) test using a specific checkpoint
|
|
|
|
trainer.test(ckpt_path='/path/to/my_checkpoint.ckpt')
|
|
|
|
|
|
|
|
# (4) test with an explicit model (will use this model and not load a checkpoint)
|
|
|
|
trainer.test(model)
|
|
|
|
|
2020-06-19 06:38:10 +00:00
|
|
|
----------
|
2020-06-15 12:02:37 +00:00
|
|
|
|
|
|
|
Test multiple models
|
|
|
|
--------------------
|
|
|
|
You can run the test set on multiple models using the same trainer instance.
|
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
model1 = LitModel()
|
|
|
|
model2 = GANModel()
|
|
|
|
|
|
|
|
trainer = Trainer()
|
|
|
|
trainer.test(model1)
|
|
|
|
trainer.test(model2)
|
|
|
|
|
2020-06-19 06:38:10 +00:00
|
|
|
----------
|
2020-05-31 04:48:05 +00:00
|
|
|
|
2020-02-11 04:55:22 +00:00
|
|
|
Test pre-trained model
|
2020-02-11 12:41:15 +00:00
|
|
|
----------------------
|
2020-05-05 02:16:54 +00:00
|
|
|
To run the test set on a pre-trained model, use this method.
|
2020-02-11 04:55:22 +00:00
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
2020-05-13 13:05:15 +00:00
|
|
|
model = MyLightningModule.load_from_checkpoint(
|
|
|
|
checkpoint_path='/path/to/pytorch_checkpoint.ckpt',
|
|
|
|
hparams_file='/path/to/test_tube/experiment/version/hparams.yaml',
|
2020-02-11 04:55:22 +00:00
|
|
|
map_location=None
|
|
|
|
)
|
|
|
|
|
|
|
|
# init trainer with whatever options
|
|
|
|
trainer = Trainer(...)
|
|
|
|
|
|
|
|
# test (pass in the model)
|
|
|
|
trainer.test(model)
|
|
|
|
|
|
|
|
In this case, the options you pass to trainer will be used when
|
2020-05-31 04:48:05 +00:00
|
|
|
running the test set (ie: 16-bit, dp, ddp, etc...)
|
|
|
|
|
2020-06-19 06:38:10 +00:00
|
|
|
----------
|
2020-05-31 04:48:05 +00:00
|
|
|
|
|
|
|
Test with additional data loaders
|
|
|
|
---------------------------------
|
|
|
|
You can still run inference on a test set even if the `test_dataloader` method hasn't been
|
|
|
|
defined within your :class:`~pytorch_lightning.core.LightningModule` instance. This would be the case when your test data
|
|
|
|
is not available at the time your model was declared.
|
|
|
|
|
|
|
|
.. code-block:: python
|
|
|
|
|
|
|
|
# setup your data loader
|
|
|
|
test = DataLoader(...)
|
|
|
|
|
|
|
|
# test (pass in the loader)
|
|
|
|
trainer.test(test_dataloaders=test)
|
|
|
|
|
|
|
|
You can either pass in a single dataloader or a list of them. This optional named
|
|
|
|
parameter can be used in conjunction with any of the above use cases.
|