-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathbase_model.py
More file actions
53 lines (43 loc) · 1.39 KB
/
base_model.py
File metadata and controls
53 lines (43 loc) · 1.39 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
import numpy as np
class BaseModel:
def __init__(self, alpha, features_train, target_variables_train) -> None:
self._alpha: float = alpha
self._features_train_no_intercept: np.array[np.array] = np.array(features_train)
self.target_variables_train = np.array(target_variables_train)
self.initial_vector_of_parameters: np.array = np.zeros(self.number_of_parameters)
@property
def alpha(self):
"""
learning rate
"""
return self._alpha
@property
def features_train_no_intercept(self):
"""
matrix of data
"""
return self._features_train_no_intercept
@property
def features_shape(self):
return np.shape(self.features_train_no_intercept)
@property
def features_train(self):
"""
2d np.array with x_0 = 1 for every row
"""
return np.c_[np.ones(self.features_shape[0]), self.features_train_no_intercept]
@property
def number_of_outputs(self):
return len(self.target_variables_train)
@property
def number_of_inputs(self):
"""
number of examples
"""
return len(self.features_train)
@property
def number_of_parameters(self):
return len(self.features_train[0])
@property
def hypothesis_vector(self):
return np.ones(self.number_of_parameters)