1
0
Fork 0
This repository has been archived on 2024-06-28. You can view files and clone it, but cannot push or open issues or pull requests.
collision-analysis-and-inte.../CustomScaler.py

37 lines
1.2 KiB
Python
Raw Permalink Normal View History

2021-03-29 15:02:46 +02:00
from typing import List, Iterator, Optional
2019-05-02 14:12:06 +02:00
import numpy as np
class CustomScaler:
2019-07-29 14:18:15 +02:00
"""
This is basically a simpler implementation of `sklearn.preprocessing.StandardScaler` that
allows transforming both parameter sets and the initial data.
"""
2019-05-02 14:12:06 +02:00
def __init__(self):
2021-03-29 15:02:46 +02:00
self.means: Optional[np.ndarray] = None
self.stds: Optional[np.ndarray] = None
2019-05-02 14:12:06 +02:00
def fit(self, data: np.ndarray) -> None:
self.means = np.mean(data, 0)
self.stds = np.std(data, 0)
2019-07-06 15:50:16 +02:00
# print(self.means)
# print(self.stds)
2019-05-02 14:12:06 +02:00
def _check_fitted(self):
if (self.means is None) or (self.stds is None):
raise Exception("you need to first fit data")
def transform_data(self, data: np.ndarray) -> np.ndarray:
self._check_fitted()
return (data - self.means) / self.stds
# return data
2021-03-08 15:39:47 +01:00
def transform_parameters(self, parameters: List) -> Iterator[float]:
2019-05-02 14:12:06 +02:00
self._check_fitted()
if len(parameters) != len(self.means):
raise ValueError("incorrect number of parameters")
for index, parameter in enumerate(parameters):
yield (parameter - self.means[index]) / self.stds[index]