2021-10-28 16:21:23 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- encoding: utf-8 -*-
|
|
|
|
|
|
|
|
from abc import ABC, abstractmethod
|
2023-04-05 15:24:43 +00:00
|
|
|
from typing import Callable, Iterable
|
2021-10-28 16:21:23 +00:00
|
|
|
|
|
|
|
import torch
|
|
|
|
|
Develop/experiments (#59)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
* Split conv2d, class token, positional embedding in 2d, Fix random number in ddp
Fix convergence in cifar10, Imagenet1000
* Integrate 1d tensor parallel in Colossal-AI (#39)
* fixed 1D and 2D convergence (#38)
* optimized 2D operations
* fixed 1D ViT convergence problem
* Feature/ddp (#49)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* support torch ddp
* fix loss accumulation
* add log for ddp
* change seed
* modify timing hook
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* Feature/pipeline (#40)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* optimize communication of pipeline parallel
* fix grad clip for pipeline
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* optimized 3d layer to fix slow computation ; tested imagenet performance with 3d; reworked lr_scheduler config definition; fixed launch args; fixed some printing issues; simplified apis of 3d layers (#51)
* Update 2.5d layer code to get a similar accuracy on imagenet-1k dataset
* update api for better usability (#58)
update api for better usability
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
Co-authored-by: puck_WCR <46049915+WANG-CR@users.noreply.github.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
Co-authored-by: アマデウス <kurisusnowdeng@users.noreply.github.com>
Co-authored-by: BoxiangW <45734921+BoxiangW@users.noreply.github.com>
2021-12-09 07:08:29 +00:00
|
|
|
from colossalai.logging import get_dist_logger
|
2021-10-28 16:21:23 +00:00
|
|
|
from colossalai.utils import get_current_device
|
|
|
|
|
2022-01-21 02:44:30 +00:00
|
|
|
|
2021-10-28 16:21:23 +00:00
|
|
|
class BaseSchedule(ABC):
|
|
|
|
"""A basic helper class to control the process of training or evaluation.
|
2021-11-18 11:45:06 +00:00
|
|
|
It mainly composes of forward_backward_step for gradient backward and
|
|
|
|
optimizer_step for parameters update.
|
2022-03-25 05:02:39 +00:00
|
|
|
For the convenience to enable FP16, we aggregate all codes that contain the
|
2021-11-18 11:45:06 +00:00
|
|
|
control of FP16 in class schedule.
|
2022-03-25 05:02:39 +00:00
|
|
|
|
|
|
|
Args:
|
2022-06-15 02:41:28 +00:00
|
|
|
data_process_func (Callable, optional): The preprocessing function which receives a batch of data and arranges them into data and label.
|
2021-10-28 16:21:23 +00:00
|
|
|
"""
|
2021-11-18 11:45:06 +00:00
|
|
|
|
2022-06-15 02:41:28 +00:00
|
|
|
def __init__(self, data_process_func: Callable = None):
|
Develop/experiments (#59)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
* Split conv2d, class token, positional embedding in 2d, Fix random number in ddp
Fix convergence in cifar10, Imagenet1000
* Integrate 1d tensor parallel in Colossal-AI (#39)
* fixed 1D and 2D convergence (#38)
* optimized 2D operations
* fixed 1D ViT convergence problem
* Feature/ddp (#49)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* support torch ddp
* fix loss accumulation
* add log for ddp
* change seed
* modify timing hook
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* Feature/pipeline (#40)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* optimize communication of pipeline parallel
* fix grad clip for pipeline
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* optimized 3d layer to fix slow computation ; tested imagenet performance with 3d; reworked lr_scheduler config definition; fixed launch args; fixed some printing issues; simplified apis of 3d layers (#51)
* Update 2.5d layer code to get a similar accuracy on imagenet-1k dataset
* update api for better usability (#58)
update api for better usability
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
Co-authored-by: puck_WCR <46049915+WANG-CR@users.noreply.github.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
Co-authored-by: アマデウス <kurisusnowdeng@users.noreply.github.com>
Co-authored-by: BoxiangW <45734921+BoxiangW@users.noreply.github.com>
2021-12-09 07:08:29 +00:00
|
|
|
self.logger = get_dist_logger()
|
2022-06-15 02:41:28 +00:00
|
|
|
self.data_process_func = data_process_func
|
2021-10-28 16:21:23 +00:00
|
|
|
|
2021-11-18 11:45:06 +00:00
|
|
|
@staticmethod
|
|
|
|
def _move_tensor(element):
|
|
|
|
if torch.is_tensor(element):
|
|
|
|
if not element.is_cuda:
|
|
|
|
return element.to(get_current_device()).detach()
|
|
|
|
return element
|
2021-10-28 16:21:23 +00:00
|
|
|
|
2021-11-18 11:45:06 +00:00
|
|
|
def _move_to_device(self, data):
|
2022-06-15 02:41:28 +00:00
|
|
|
if isinstance(data, torch.Tensor):
|
|
|
|
data = data.to(get_current_device())
|
|
|
|
elif isinstance(data, (list, tuple)):
|
2022-06-21 14:46:30 +00:00
|
|
|
data_to_return = []
|
|
|
|
for element in data:
|
|
|
|
if isinstance(element, dict):
|
|
|
|
data_to_return.append({k: self._move_tensor(v) for k, v in element.items()})
|
|
|
|
else:
|
|
|
|
data_to_return.append(self._move_tensor(element))
|
|
|
|
data = data_to_return
|
2022-06-15 02:41:28 +00:00
|
|
|
elif isinstance(data, dict):
|
2021-12-30 07:56:46 +00:00
|
|
|
data = {k: self._move_tensor(v) for k, v in data.items()}
|
|
|
|
else:
|
2022-06-15 02:41:28 +00:00
|
|
|
raise TypeError(
|
2023-09-19 06:20:26 +00:00
|
|
|
f"Expected batch data to be of type torch.Tensor, list, tuple, or dict, but got {type(data)}"
|
|
|
|
)
|
2021-11-18 11:45:06 +00:00
|
|
|
return data
|
2021-10-28 16:21:23 +00:00
|
|
|
|
2022-06-15 02:41:28 +00:00
|
|
|
def _get_batch_size(self, data):
|
|
|
|
if isinstance(data, torch.Tensor):
|
|
|
|
return data.size(0)
|
|
|
|
elif isinstance(data, (list, tuple)):
|
2022-06-16 03:19:48 +00:00
|
|
|
if isinstance(data[0], dict):
|
|
|
|
return data[0][list(data[0].keys())[0]].size(0)
|
2022-06-15 02:41:28 +00:00
|
|
|
return data[0].size(0)
|
|
|
|
elif isinstance(data, dict):
|
2022-06-16 03:19:48 +00:00
|
|
|
return data[list(data.keys())[0]].size(0)
|
Develop/experiments (#59)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
* Split conv2d, class token, positional embedding in 2d, Fix random number in ddp
Fix convergence in cifar10, Imagenet1000
* Integrate 1d tensor parallel in Colossal-AI (#39)
* fixed 1D and 2D convergence (#38)
* optimized 2D operations
* fixed 1D ViT convergence problem
* Feature/ddp (#49)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* support torch ddp
* fix loss accumulation
* add log for ddp
* change seed
* modify timing hook
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* Feature/pipeline (#40)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* optimize communication of pipeline parallel
* fix grad clip for pipeline
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* optimized 3d layer to fix slow computation ; tested imagenet performance with 3d; reworked lr_scheduler config definition; fixed launch args; fixed some printing issues; simplified apis of 3d layers (#51)
* Update 2.5d layer code to get a similar accuracy on imagenet-1k dataset
* update api for better usability (#58)
update api for better usability
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
Co-authored-by: puck_WCR <46049915+WANG-CR@users.noreply.github.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
Co-authored-by: アマデウス <kurisusnowdeng@users.noreply.github.com>
Co-authored-by: BoxiangW <45734921+BoxiangW@users.noreply.github.com>
2021-12-09 07:08:29 +00:00
|
|
|
|
2021-12-30 07:56:46 +00:00
|
|
|
def load_batch(self, data_iter, to_gpu=True):
|
2021-11-18 11:45:06 +00:00
|
|
|
"""Loads a batch from data iterator. It returns the data and labels which are
|
2021-10-28 16:21:23 +00:00
|
|
|
already in the same GPU as where the model's.
|
|
|
|
|
2022-03-25 05:02:39 +00:00
|
|
|
Args:
|
|
|
|
data_iter (Iterable): Data iterator from which get a batch of data, obtained by calling iter(dataloader).
|
|
|
|
to_gpu (bool, optional): Whether the data should be moved to GPU
|
2022-01-21 02:44:30 +00:00
|
|
|
|
2022-03-25 05:02:39 +00:00
|
|
|
Returns:
|
|
|
|
Tuple (:class:`Tensor`, :class:`torch.Tensor`): A tuple of (data, label).
|
2021-10-28 16:21:23 +00:00
|
|
|
"""
|
2021-11-18 11:45:06 +00:00
|
|
|
if data_iter is None:
|
2023-09-19 06:20:26 +00:00
|
|
|
raise RuntimeError("Dataloader is not defined.")
|
Develop/experiments (#59)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
* Split conv2d, class token, positional embedding in 2d, Fix random number in ddp
Fix convergence in cifar10, Imagenet1000
* Integrate 1d tensor parallel in Colossal-AI (#39)
* fixed 1D and 2D convergence (#38)
* optimized 2D operations
* fixed 1D ViT convergence problem
* Feature/ddp (#49)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* support torch ddp
* fix loss accumulation
* add log for ddp
* change seed
* modify timing hook
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* Feature/pipeline (#40)
* remove redundancy func in setup (#19) (#20)
* use env to control the language of doc (#24) (#25)
* Support TP-compatible Torch AMP and Update trainer API (#27)
* Add gradient accumulation, fix lr scheduler
* fix FP16 optimizer and adapted torch amp with tensor parallel (#18)
* fixed bugs in compatibility between torch amp and tensor parallel and performed some minor fixes
* fixed trainer
* Revert "fixed trainer"
This reverts commit 2e0b0b76990e8d4e337add483d878c0f61cf5097.
* improved consistency between trainer, engine and schedule (#23)
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
* add an example of ViT-B/16 and remove w_norm clipping in LAMB (#29)
* add explanation for ViT example (#35) (#36)
* optimize communication of pipeline parallel
* fix grad clip for pipeline
Co-authored-by: Frank Lee <somerlee.9@gmail.com>
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
* optimized 3d layer to fix slow computation ; tested imagenet performance with 3d; reworked lr_scheduler config definition; fixed launch args; fixed some printing issues; simplified apis of 3d layers (#51)
* Update 2.5d layer code to get a similar accuracy on imagenet-1k dataset
* update api for better usability (#58)
update api for better usability
Co-authored-by: 1SAA <c2h214748@gmail.com>
Co-authored-by: ver217 <lhx0217@gmail.com>
Co-authored-by: puck_WCR <46049915+WANG-CR@users.noreply.github.com>
Co-authored-by: binmakeswell <binmakeswell@gmail.com>
Co-authored-by: アマデウス <kurisusnowdeng@users.noreply.github.com>
Co-authored-by: BoxiangW <45734921+BoxiangW@users.noreply.github.com>
2021-12-09 07:08:29 +00:00
|
|
|
batch_data = next(data_iter)
|
2021-10-28 16:21:23 +00:00
|
|
|
|
2021-12-30 07:56:46 +00:00
|
|
|
if to_gpu:
|
2022-06-15 02:41:28 +00:00
|
|
|
batch_data = self._move_to_device(batch_data)
|
|
|
|
self.batch_size = self._get_batch_size(batch_data)
|
|
|
|
return batch_data
|
2021-12-30 07:56:46 +00:00
|
|
|
|
2022-04-03 12:46:45 +00:00
|
|
|
def pre_processing(self, engine):
|
2023-09-19 06:20:26 +00:00
|
|
|
"""To perform actions before running the schedule."""
|
2021-10-28 16:21:23 +00:00
|
|
|
|
2021-11-18 11:45:06 +00:00
|
|
|
@abstractmethod
|
2023-09-19 06:20:26 +00:00
|
|
|
def forward_backward_step(
|
|
|
|
self,
|
|
|
|
engine,
|
|
|
|
data_iter: Iterable,
|
|
|
|
forward_only: bool,
|
|
|
|
return_loss: bool = True,
|
|
|
|
return_output_label: bool = True,
|
|
|
|
):
|
2021-11-18 11:45:06 +00:00
|
|
|
"""The process function over a batch of dataset for training or evaluation.
|
2021-10-28 16:21:23 +00:00
|
|
|
|
2022-03-25 05:02:39 +00:00
|
|
|
Args:
|
2023-09-04 03:33:40 +00:00
|
|
|
engine (colossalai.legacy.engine.Engine): Colossalai engine for training and inference.
|
2022-03-25 05:02:39 +00:00
|
|
|
data_iter (Iterable): Data iterator from which get a batch of data, obtained by calling iter(dataloader).
|
|
|
|
forward_only (bool): If True, the process won't include backward.
|
|
|
|
return_loss (bool, optional): If False, the loss won't be returned.
|
|
|
|
return_output_label (bool, optional): If False, the output and label won't be returned.
|
2021-10-28 16:21:23 +00:00
|
|
|
"""
|
2021-12-30 07:56:46 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def _call_engine(engine, inputs):
|
|
|
|
if isinstance(inputs, torch.Tensor):
|
|
|
|
return engine(inputs)
|
2022-06-15 02:41:28 +00:00
|
|
|
elif isinstance(inputs, (list, tuple)):
|
|
|
|
return engine(*inputs)
|
|
|
|
elif isinstance(inputs, dict):
|
2021-12-30 07:56:46 +00:00
|
|
|
return engine(**inputs)
|
2022-06-15 02:41:28 +00:00
|
|
|
else:
|
|
|
|
TypeError(
|
2023-09-19 06:20:26 +00:00
|
|
|
f"Expected engine inputs to be of type torch.Tensor, list, tuple, or dict, but got {type(inputs)}"
|
|
|
|
)
|
2021-12-30 07:56:46 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def _call_engine_criterion(engine, outputs, labels):
|
2023-09-19 06:20:26 +00:00
|
|
|
assert isinstance(
|
|
|
|
outputs, (torch.Tensor, list, tuple, dict)
|
|
|
|
), f"Expect output of model is (torch.Tensor, list, tuple), got {type(outputs)}"
|
2021-12-30 07:56:46 +00:00
|
|
|
if isinstance(outputs, torch.Tensor):
|
2022-01-21 02:44:30 +00:00
|
|
|
outputs = (outputs,)
|
2021-12-30 07:56:46 +00:00
|
|
|
if isinstance(labels, torch.Tensor):
|
2022-06-15 02:41:28 +00:00
|
|
|
labels = (labels,)
|
|
|
|
|
|
|
|
if isinstance(outputs, (tuple, list)) and isinstance(labels, (tuple, list)):
|
|
|
|
return engine.criterion(*outputs, *labels)
|
|
|
|
elif isinstance(outputs, (tuple, list)) and isinstance(labels, dict):
|
2021-12-30 07:56:46 +00:00
|
|
|
return engine.criterion(*outputs, **labels)
|
2022-06-15 02:41:28 +00:00
|
|
|
elif isinstance(outputs, dict) and isinstance(labels, dict):
|
|
|
|
return engine.criterion(**outputs, **labels)
|
|
|
|
elif isinstance(outputs, dict) and isinstance(labels, (list, tuple)):
|
|
|
|
raise ValueError(f"Expected labels to be a dict when the model outputs are dict, but got {type(labels)}")
|
|
|
|
else:
|
2023-09-19 06:20:26 +00:00
|
|
|
raise TypeError(
|
|
|
|
f"Expected model outputs and labels to be of type torch.Tensor ' \
|
2022-06-15 02:41:28 +00:00
|
|
|
'(which is auto-converted to tuple), list, tuple, or dict, ' \
|
2023-09-19 06:20:26 +00:00
|
|
|
'but got {type(outputs)} (model outputs) and {type(labels)} (labels)"
|
|
|
|
)
|