2023-04-03 12:19:10 +00:00
|
|
|
from abc import ABC, abstractmethod
|
|
|
|
from typing import Optional, Tuple
|
|
|
|
|
|
|
|
import pandas as pd
|
|
|
|
import torch
|
|
|
|
|
|
|
|
|
|
|
|
class PyTorchDataConvertor(ABC):
|
2023-04-03 14:06:39 +00:00
|
|
|
"""
|
|
|
|
This class is responsible for converting `*_features` & `*_labels` pandas dataframes
|
|
|
|
to pytorch tensors.
|
|
|
|
"""
|
2023-04-03 12:19:10 +00:00
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def convert_x(self, df: pd.DataFrame, device: Optional[str] = None) -> Tuple[torch.Tensor, ...]:
|
|
|
|
"""
|
|
|
|
:param df: "*_features" dataframe.
|
2023-04-03 13:36:38 +00:00
|
|
|
:param device: The device to use for training (e.g. 'cpu', 'cuda').
|
2023-04-03 12:19:10 +00:00
|
|
|
:returns: tuple of tensors.
|
|
|
|
"""
|
|
|
|
|
|
|
|
@abstractmethod
|
|
|
|
def convert_y(self, df: pd.DataFrame, device: Optional[str] = None) -> Tuple[torch.Tensor, ...]:
|
|
|
|
"""
|
|
|
|
:param df: "*_labels" dataframe.
|
2023-04-03 13:36:38 +00:00
|
|
|
:param device: The device to use for training (e.g. 'cpu', 'cuda').
|
2023-04-03 12:19:10 +00:00
|
|
|
:returns: tuple of tensors.
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
class DefaultPyTorchDataConvertor(PyTorchDataConvertor):
|
2023-04-03 14:06:39 +00:00
|
|
|
"""
|
|
|
|
A default conversion that keeps features dataframe shapes.
|
|
|
|
"""
|
2023-04-03 12:19:10 +00:00
|
|
|
|
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
target_tensor_type: Optional[torch.dtype] = None,
|
|
|
|
squeeze_target_tensor: bool = False
|
|
|
|
):
|
2023-04-03 13:39:49 +00:00
|
|
|
"""
|
|
|
|
:param target_tensor_type: type of target tensor, for classification use
|
|
|
|
torch.long, for regressor use torch.float or torch.double.
|
|
|
|
:param squeeze_target_tensor: controls the target shape, used for loss functions
|
|
|
|
that requires 0D or 1D.
|
|
|
|
"""
|
2023-04-03 12:19:10 +00:00
|
|
|
self._target_tensor_type = target_tensor_type
|
|
|
|
self._squeeze_target_tensor = squeeze_target_tensor
|
|
|
|
|
|
|
|
def convert_x(self, df: pd.DataFrame, device: Optional[str] = None) -> Tuple[torch.Tensor, ...]:
|
|
|
|
x = torch.from_numpy(df.values).float()
|
|
|
|
if device:
|
|
|
|
x = x.to(device)
|
|
|
|
|
|
|
|
return x,
|
|
|
|
|
|
|
|
def convert_y(self, df: pd.DataFrame, device: Optional[str] = None) -> Tuple[torch.Tensor, ...]:
|
|
|
|
y = torch.from_numpy(df.values)
|
|
|
|
|
|
|
|
if self._target_tensor_type:
|
|
|
|
y = y.to(self._target_tensor_type)
|
|
|
|
|
|
|
|
if self._squeeze_target_tensor:
|
|
|
|
y = y.squeeze()
|
|
|
|
|
|
|
|
if device:
|
|
|
|
y = y.to(device)
|
|
|
|
|
|
|
|
return y,
|