2020-03-03 01:49:14 +00:00
|
|
|
import pickle
|
|
|
|
|
2020-03-25 11:46:27 +00:00
|
|
|
import tests.base.utils as tutils
|
2020-03-03 01:49:14 +00:00
|
|
|
from pytorch_lightning import Trainer
|
2020-03-25 11:46:27 +00:00
|
|
|
from tests.base import LightningTestModel
|
2020-03-03 01:49:14 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_testtube_logger(tmpdir):
|
|
|
|
"""Verify that basic functionality of test tube logger works."""
|
|
|
|
tutils.reset_seed()
|
2020-03-25 11:46:27 +00:00
|
|
|
hparams = tutils.get_default_hparams()
|
2020-03-03 01:49:14 +00:00
|
|
|
model = LightningTestModel(hparams)
|
|
|
|
|
2020-03-25 11:46:27 +00:00
|
|
|
logger = tutils.get_default_testtube_logger(tmpdir, False)
|
2020-03-03 01:49:14 +00:00
|
|
|
|
|
|
|
assert logger.name == 'lightning_logs'
|
|
|
|
|
|
|
|
trainer_options = dict(
|
|
|
|
default_save_path=tmpdir,
|
|
|
|
max_epochs=1,
|
|
|
|
train_percent_check=0.05,
|
|
|
|
logger=logger
|
|
|
|
)
|
|
|
|
|
|
|
|
trainer = Trainer(**trainer_options)
|
|
|
|
result = trainer.fit(model)
|
|
|
|
|
|
|
|
assert result == 1, 'Training failed'
|
|
|
|
|
|
|
|
|
|
|
|
def test_testtube_pickle(tmpdir):
|
|
|
|
"""Verify that pickling a trainer containing a test tube logger works."""
|
|
|
|
tutils.reset_seed()
|
|
|
|
|
2020-03-25 11:46:27 +00:00
|
|
|
hparams = tutils.get_default_hparams()
|
2020-03-03 01:49:14 +00:00
|
|
|
|
2020-03-25 11:46:27 +00:00
|
|
|
logger = tutils.get_default_testtube_logger(tmpdir, False)
|
2020-03-03 01:49:14 +00:00
|
|
|
logger.log_hyperparams(hparams)
|
|
|
|
logger.save()
|
|
|
|
|
|
|
|
trainer_options = dict(
|
|
|
|
default_save_path=tmpdir,
|
|
|
|
max_epochs=1,
|
|
|
|
train_percent_check=0.05,
|
|
|
|
logger=logger
|
|
|
|
)
|
|
|
|
|
|
|
|
trainer = Trainer(**trainer_options)
|
|
|
|
pkl_bytes = pickle.dumps(trainer)
|
|
|
|
trainer2 = pickle.loads(pkl_bytes)
|
|
|
|
trainer2.logger.log_metrics({'acc': 1.0})
|