2020-02-25 18:06:24 +00:00
|
|
|
import csv
|
2020-03-12 16:41:37 +00:00
|
|
|
import os
|
2020-02-25 18:06:24 +00:00
|
|
|
from argparse import Namespace
|
2020-03-12 16:47:23 +00:00
|
|
|
from typing import Union, Dict, Any
|
2020-02-25 18:06:24 +00:00
|
|
|
|
2020-03-17 22:44:00 +00:00
|
|
|
from pytorch_lightning import _logger as log
|
|
|
|
|
2020-02-25 18:06:24 +00:00
|
|
|
|
2019-03-31 01:45:16 +00:00
|
|
|
class ModelIO(object):
|
|
|
|
|
2020-03-12 16:47:23 +00:00
|
|
|
def on_load_checkpoint(self, checkpoint: Dict[str, Any]) -> None:
|
2019-03-31 01:45:16 +00:00
|
|
|
"""
|
|
|
|
Do something with the checkpoint
|
2019-07-27 01:37:06 +00:00
|
|
|
Gives model a chance to load something before state_dict is restored
|
2019-03-31 01:45:16 +00:00
|
|
|
:param checkpoint:
|
|
|
|
:return:
|
|
|
|
"""
|
|
|
|
|
2020-03-12 16:47:23 +00:00
|
|
|
def on_save_checkpoint(self, checkpoint: Dict[str, Any]) -> None:
|
2019-03-31 01:45:16 +00:00
|
|
|
"""
|
2019-07-27 02:04:27 +00:00
|
|
|
Give the model a chance to add something to the checkpoint.
|
|
|
|
state_dict is already there
|
2019-03-31 01:45:16 +00:00
|
|
|
"""
|
|
|
|
|
2019-07-02 13:36:33 +00:00
|
|
|
# -------------------------
|
|
|
|
# OPTIONAL HOOKS
|
|
|
|
# -------------------------
|
2020-03-12 16:47:23 +00:00
|
|
|
def on_hpc_save(self, checkpoint: Dict[str, Any]) -> None:
|
2019-07-02 13:35:15 +00:00
|
|
|
"""
|
|
|
|
Hook to do whatever you need right before Slurm manager saves the model
|
|
|
|
"""
|
|
|
|
|
2020-03-12 16:47:23 +00:00
|
|
|
def on_hpc_load(self, checkpoint: Dict[str, Any]) -> None:
|
2019-07-02 13:35:15 +00:00
|
|
|
"""
|
|
|
|
Hook to do whatever you need right before Slurm manager loads the model
|
|
|
|
"""
|
2020-02-25 18:06:24 +00:00
|
|
|
|
|
|
|
|
2020-03-12 16:47:23 +00:00
|
|
|
def load_hparams_from_tags_csv(tags_csv: str) -> Namespace:
|
2020-02-25 18:06:24 +00:00
|
|
|
if not os.path.isfile(tags_csv):
|
|
|
|
log.warning(f'Missing Tags: {tags_csv}.')
|
|
|
|
return Namespace()
|
|
|
|
|
|
|
|
with open(tags_csv) as f:
|
|
|
|
csv_reader = csv.reader(f, delimiter=',')
|
2020-03-04 14:33:39 +00:00
|
|
|
tags = {row[0]: convert(row[1]) for row in list(csv_reader)[1:]}
|
2020-02-25 18:06:24 +00:00
|
|
|
ns = Namespace(**tags)
|
|
|
|
return ns
|
|
|
|
|
|
|
|
|
2020-03-12 16:47:23 +00:00
|
|
|
def convert(val: str) -> Union[int, float, bool, str]:
|
2020-02-25 18:06:24 +00:00
|
|
|
constructors = [int, float, str]
|
|
|
|
|
|
|
|
if isinstance(val, str):
|
|
|
|
if val.lower() == 'true':
|
|
|
|
return True
|
|
|
|
if val.lower() == 'false':
|
|
|
|
return False
|
|
|
|
|
|
|
|
for c in constructors:
|
|
|
|
try:
|
|
|
|
return c(val)
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
return val
|