code-loader 1.0.64.dev1__tar.gz → 1.0.64.dev2__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/PKG-INFO +1 -1
  2. code_loader-1.0.64.dev2/code_loader/default_metrics.py +81 -0
  3. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/inner_leap_binder/leapbinder.py +6 -0
  4. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/pyproject.toml +1 -1
  5. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/LICENSE +0 -0
  6. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/README.md +0 -0
  7. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/__init__.py +0 -0
  8. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/code_inegration_processes_manager.py +0 -0
  9. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/contract/__init__.py +0 -0
  10. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/contract/datasetclasses.py +0 -0
  11. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/contract/enums.py +0 -0
  12. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/contract/exceptions.py +0 -0
  13. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/contract/responsedataclasses.py +0 -0
  14. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/contract/visualizer_classes.py +0 -0
  15. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/__init__.py +0 -0
  16. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/api.py +0 -0
  17. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/cli_config_utils.py +0 -0
  18. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/client.py +0 -0
  19. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/epoch.py +0 -0
  20. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/experiment.py +0 -0
  21. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/experiment_context.py +0 -0
  22. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/types.py +0 -0
  23. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/utils.py +0 -0
  24. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/experiment_api/workingspace_config_utils.py +0 -0
  25. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/inner_leap_binder/__init__.py +0 -0
  26. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/inner_leap_binder/leapbinder_decorators.py +0 -0
  27. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/leaploader.py +0 -0
  28. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/leaploaderbase.py +0 -0
  29. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/utils.py +0 -0
  30. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/visualizers/__init__.py +0 -0
  31. {code_loader-1.0.64.dev1 → code_loader-1.0.64.dev2}/code_loader/visualizers/default_visualizers.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: code-loader
3
- Version: 1.0.64.dev1
3
+ Version: 1.0.64.dev2
4
4
  Summary:
5
5
  Home-page: https://github.com/tensorleap/code-loader
6
6
  License: MIT
@@ -0,0 +1,81 @@
1
+ from enum import Enum
2
+ from typing import List, Tuple
3
+ import numpy as np
4
+
5
+ from code_loader.contract.datasetclasses import ConfusionMatrixElement # type: ignore
6
+ from code_loader.contract.enums import ConfusionMatrixValue, MetricDirection # type: ignore
7
+
8
+
9
+ class Metric(Enum):
10
+ MeanSquaredError = 'MeanSquaredError'
11
+ MeanSquaredLogarithmicError = 'MeanSquaredLogarithmicError'
12
+ MeanAbsoluteError = 'MeanAbsoluteError'
13
+ MeanAbsolutePercentageError = 'MeanAbsolutePercentageError'
14
+ Accuracy = 'Accuracy'
15
+ ConfusionMatrixClassification = 'ConfusionMatrixClassification'
16
+
17
+
18
+ def accuracy_reduced(ground_truth: np.array, prediction: np.array) -> np.array:
19
+ ground_truth, prediction = flatten_non_batch_dims(ground_truth, prediction)
20
+ return np.mean((np.round(prediction).astype(np.bool_) == ground_truth.astype(np.bool_)), axis=1)
21
+
22
+
23
+ def mean_squared_error_dimension_reduced(ground_truth: np.array, prediction: np.array) -> np.array:
24
+ ground_truth, prediction = flatten_non_batch_dims(ground_truth, prediction)
25
+ return ((ground_truth - prediction) ** 2).mean(axis=1).astype(np.float32)
26
+
27
+
28
+ def mean_absolute_error_dimension_reduced(ground_truth: np.array, prediction: np.array) -> np.array:
29
+ ground_truth, prediction = flatten_non_batch_dims(ground_truth, prediction)
30
+ return np.abs(ground_truth - prediction).mean(axis=1).astype(np.float32)
31
+
32
+
33
+ def mean_absolute_percentage_error_dimension_reduced(ground_truth: np.array, prediction: np.array) -> np.array:
34
+ ground_truth, prediction = flatten_non_batch_dims(ground_truth, prediction)
35
+ return (np.abs(ground_truth - prediction) / np.abs(ground_truth)).mean(axis=1).astype(np.float32)
36
+
37
+
38
+ def mean_squared_logarithmic_error_dimension_reduced(ground_truth: np.array, prediction: np.array) -> np.array:
39
+ ground_truth, prediction = flatten_non_batch_dims(ground_truth, prediction)
40
+ return np.mean((np.log(1 + ground_truth) - np.log(1 + prediction)) ** 2, axis=1).astype(np.float32)
41
+
42
+
43
+ def flatten_non_batch_dims(ground_truth: np.array, prediction: np.array) -> Tuple[np.array, np.array]:
44
+ batch_size = ground_truth.shape[0]
45
+ ground_truth = np.reshape(ground_truth, (batch_size, -1))
46
+ prediction = np.reshape(prediction, (batch_size, -1))
47
+ return ground_truth, prediction
48
+
49
+
50
+ def confusion_matrix_classification_metric(ground_truth, prediction) -> List[List[ConfusionMatrixElement]]:
51
+ num_labels = prediction.shape[-1]
52
+ labels = [str(i) for i in range(num_labels)]
53
+ if len(labels) == 1:
54
+ labels = ['0', '1']
55
+ ground_truth = np.concatenate([1 - ground_truth, ground_truth], axis=1)
56
+ prediction = np.concatenate([1 - prediction, prediction], axis=1)
57
+
58
+ ret = []
59
+ for batch_i in range(ground_truth.shape[0]):
60
+ one_hot_vec = list(ground_truth[batch_i])
61
+ pred_vec = list(prediction[batch_i])
62
+ confusion_matrix_elements = []
63
+ for i, label in enumerate(labels):
64
+ expected_outcome = ConfusionMatrixValue.Positive if int(
65
+ one_hot_vec[i]) == 1 else ConfusionMatrixValue.Negative
66
+ cm_element = ConfusionMatrixElement(label, expected_outcome, float(pred_vec[i]))
67
+ confusion_matrix_elements.append(cm_element)
68
+ ret.append(confusion_matrix_elements)
69
+ return ret
70
+
71
+
72
+ metrics_names_to_functions_and_direction = {
73
+ Metric.MeanSquaredError.name: (mean_squared_error_dimension_reduced, MetricDirection.Downward),
74
+ Metric.MeanSquaredLogarithmicError.name: (
75
+ mean_squared_logarithmic_error_dimension_reduced, MetricDirection.Downward),
76
+ Metric.MeanAbsoluteError.name: (mean_absolute_error_dimension_reduced, MetricDirection.Downward),
77
+ Metric.MeanAbsolutePercentageError.name: (
78
+ mean_absolute_percentage_error_dimension_reduced, MetricDirection.Downward),
79
+ Metric.Accuracy.name: (accuracy_reduced, MetricDirection.Upward),
80
+ Metric.ConfusionMatrixClassification.name: (confusion_matrix_classification_metric, None),
81
+ }
@@ -14,6 +14,7 @@ from code_loader.contract.datasetclasses import SectionCallableInterface, InputH
14
14
  from code_loader.contract.enums import LeapDataType, DataStateEnum, DataStateType, MetricDirection
15
15
  from code_loader.contract.responsedataclasses import DatasetTestResultPayload
16
16
  from code_loader.contract.visualizer_classes import map_leap_data_type_to_visualizer_class
17
+ from code_loader.default_metrics import metrics_names_to_functions_and_direction
17
18
  from code_loader.utils import to_numpy_return_wrapper, get_shape
18
19
  from code_loader.visualizers.default_visualizers import DefaultVisualizer, \
19
20
  default_graph_visualizer, \
@@ -37,6 +38,7 @@ class LeapBinder:
37
38
  self._visualizer_names: List[str] = list()
38
39
  self._encoder_names: List[str] = list()
39
40
  self._extend_with_default_visualizers()
41
+ self._extend_with_default_metrics()
40
42
 
41
43
  self.batch_size_to_validate: Optional[int] = None
42
44
 
@@ -56,6 +58,10 @@ class LeapBinder:
56
58
  self.set_visualizer(function=default_text_mask_visualizer, name=DefaultVisualizer.TextMask.value,
57
59
  visualizer_type=LeapDataType.TextMask)
58
60
 
61
+ def _extend_with_default_metrics(self) -> None:
62
+ for metric_name, (func, direction) in metrics_names_to_functions_and_direction.items():
63
+ self.add_custom_metric(func, metric_name, direction)
64
+
59
65
  def set_visualizer(self, function: VisualizerCallableInterface,
60
66
  name: str,
61
67
  visualizer_type: LeapDataType,
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "code-loader"
3
- version = "1.0.64.dev1"
3
+ version = "1.0.64.dev2"
4
4
  description = ""
5
5
  authors = ["dorhar <doron.harnoy@tensorleap.ai>"]
6
6
  license = "MIT"