pythagoras 0.23.1__tar.gz → 0.23.3__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 (65) hide show
  1. {pythagoras-0.23.1 → pythagoras-0.23.3}/PKG-INFO +16 -7
  2. {pythagoras-0.23.1 → pythagoras-0.23.3}/README.md +14 -6
  3. {pythagoras-0.23.1 → pythagoras-0.23.3}/pyproject.toml +2 -1
  4. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/.DS_Store +0 -0
  5. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_010_basic_portals/__init__.py +0 -0
  6. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_010_basic_portals/basic_portal_core_classes.py +0 -0
  7. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_010_basic_portals/exceptions.py +0 -0
  8. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_010_basic_portals/long_infoname.py +0 -0
  9. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_010_basic_portals/not_picklable_class.py +0 -0
  10. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_010_basic_portals/portal_tester.py +0 -0
  11. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_010_basic_portals/post_init_metaclass.py +0 -0
  12. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_020_ordinary_code_portals/__init__.py +0 -0
  13. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_020_ordinary_code_portals/code_normalizer.py +0 -0
  14. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_020_ordinary_code_portals/function_processing.py +0 -0
  15. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_020_ordinary_code_portals/ordinary_decorator.py +0 -0
  16. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_020_ordinary_code_portals/ordinary_portal_core_classes.py +0 -0
  17. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_030_data_portals/__init__.py +0 -0
  18. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_030_data_portals/data_portal_core_classes.py +0 -0
  19. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_030_data_portals/ready_and_get.py +0 -0
  20. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_030_data_portals/storable_decorator.py +0 -0
  21. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/__init__.py +0 -0
  22. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/exception_processing_tracking.py +0 -0
  23. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/execution_environment_summary.py +0 -0
  24. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/kw_args.py +0 -0
  25. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/logging_decorator.py +0 -0
  26. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/logging_portal_core_classes.py +0 -0
  27. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/notebook_checker.py +0 -0
  28. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/output_capturer.py +0 -0
  29. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_040_logging_code_portals/uncaught_exceptions.py +0 -0
  30. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_050_safe_code_portals/__init__.py +0 -0
  31. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_050_safe_code_portals/safe_decorator.py +0 -0
  32. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_050_safe_code_portals/safe_portal_core_classes.py +0 -0
  33. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_060_autonomous_code_portals/__init__.py +0 -0
  34. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_060_autonomous_code_portals/autonomous_decorators.py +0 -0
  35. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_060_autonomous_code_portals/autonomous_portal_core_classes.py +0 -0
  36. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_060_autonomous_code_portals/names_usage_analyzer.py +0 -0
  37. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/__init__.py +0 -0
  38. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/basic_pre_validators.py +0 -0
  39. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/fn_arg_names_checker.py +0 -0
  40. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/list_flattener.py +0 -0
  41. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/package_manager.py +0 -0
  42. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/protected_decorators.py +0 -0
  43. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/protected_portal_core_classes.py +0 -0
  44. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/system_utils.py +0 -0
  45. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/validation_succesful_const.py +0 -0
  46. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_070_protected_code_portals/validator_fn_classes.py +0 -0
  47. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_080_pure_code_portals/__init__.py +0 -0
  48. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_080_pure_code_portals/pure_core_classes.py +0 -0
  49. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_080_pure_code_portals/pure_decorator.py +0 -0
  50. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_090_swarming_portals/__init__.py +0 -0
  51. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_090_swarming_portals/output_suppressor.py +0 -0
  52. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_090_swarming_portals/swarming_portals.py +0 -0
  53. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_100_top_level_API/__init__.py +0 -0
  54. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_100_top_level_API/default_local_portal.py +0 -0
  55. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_100_top_level_API/top_level_API.py +0 -0
  56. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_800_signatures_and_converters/__init__.py +0 -0
  57. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_800_signatures_and_converters/base_16_32_convertors.py +0 -0
  58. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_800_signatures_and_converters/current_date_gmt_str.py +0 -0
  59. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_800_signatures_and_converters/hash_signatures.py +0 -0
  60. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_800_signatures_and_converters/node_signatures.py +0 -0
  61. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_800_signatures_and_converters/random_signatures.py +0 -0
  62. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_900_project_stats_collector/__init__.py +0 -0
  63. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/_900_project_stats_collector/project_analyzer.py +0 -0
  64. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/__init__.py +0 -0
  65. {pythagoras-0.23.1 → pythagoras-0.23.3}/src/pythagoras/core/__init__.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: pythagoras
3
- Version: 0.23.1
3
+ Version: 0.23.3
4
4
  Summary: Planet-scale distributed computing in Python.
5
5
  Keywords: cloud,ML,AI,serverless,distributed,parallel,machine-learning,deep-learning,pythagoras
6
6
  Author: Volodymyr (Vlad) Pavlov
@@ -26,6 +26,7 @@ Requires-Dist: jsonpickle
26
26
  Requires-Dist: psutil
27
27
  Requires-Dist: autopep8
28
28
  Requires-Dist: deepdiff
29
+ Requires-Dist: numpy
29
30
  Requires-Dist: pytest
30
31
  Requires-Dist: boto3
31
32
  Requires-Dist: moto
@@ -53,24 +54,32 @@ Description-Content-Type: text/markdown
53
54
 
54
55
  Planet-scale distributed computing in Python.
55
56
 
56
- !!! RESEARCH PREVIEW !!!
57
+ **!!! RESEARCH PREVIEW !!!**
57
58
 
58
59
  ## What is it?
59
60
 
60
- `Pythagoras` is an easy-to-use framework for cost-efficient
61
+ `Pythagoras` is a super-scalable, low-maintenance framework for
61
62
  massive algorithm parallelization in Python. It simplifies and accelerates
62
63
  data science, machine learning, and AI workflows.
63
64
 
64
65
  Pythagoras offers:
65
66
 
66
67
  * seamless parallel execution of Python code, locally or
67
- in diverse distributed environments of virtually any scale;
68
+ in heterogeneous distributed environments of virtually any scale;
68
69
  * ubiquitous caching for intermediate program states,
69
70
  with intelligent data and code change tracking;
70
71
  * simple and budget-friendly orchestration backend.
71
72
 
73
+ Pythagoras excels at optimizing complex, long-running,
74
+ resource-demanding computations. It’s not the best choice for real-time,
75
+ latency-sensitive workflows.
76
+
72
77
  ## Usage
73
78
 
79
+ Pythagoras elevates two popular techniques — memoization and parallelization —
80
+ to a global scale and then fuses them, unlocking performance and scalability
81
+ that were previously out of reach.
82
+
74
83
  * `Introduction to Pythagoras` notebook:
75
84
  https://colab.research.google.com/drive/117rAtaWxjfSubzGx0shgqNjONY3E5jgd
76
85
 
@@ -94,6 +103,7 @@ pip install pythagoras
94
103
  ## Dependencies
95
104
 
96
105
  * [persidict](https://pypi.org/project/persidict)
106
+ * [parameterizable](https://pypi.org/project/parameterizable/)
97
107
  * [jsonpickle](https://jsonpickle.github.io)
98
108
  * [joblib](https://joblib.readthedocs.io)
99
109
  * [lz4](https://python-lz4.readthedocs.io)
@@ -108,10 +118,9 @@ pip install pythagoras
108
118
  * [jsonpickle](https://jsonpickle.github.io)
109
119
  * [scikit-learn](https://scikit-learn.org)
110
120
  * [autopep8](https://pypi.org/project/autopep8)
111
- * [pytorch](https://pytorch.org)
112
- * [tensorflow](https://www.tensorflow.org)
113
- * [keras](https://keras.io)
114
121
  * [deepdiff](https://zepworks.com/deepdiff/current/)
122
+ * [nvidia-ml-p](https://pypi.org/project/nvidia-ml-py/)
123
+ * [uv](https://docs.astral.sh/uv/)
115
124
 
116
125
  ## Key Contacts
117
126
 
@@ -2,24 +2,32 @@
2
2
 
3
3
  Planet-scale distributed computing in Python.
4
4
 
5
- !!! RESEARCH PREVIEW !!!
5
+ **!!! RESEARCH PREVIEW !!!**
6
6
 
7
7
  ## What is it?
8
8
 
9
- `Pythagoras` is an easy-to-use framework for cost-efficient
9
+ `Pythagoras` is a super-scalable, low-maintenance framework for
10
10
  massive algorithm parallelization in Python. It simplifies and accelerates
11
11
  data science, machine learning, and AI workflows.
12
12
 
13
13
  Pythagoras offers:
14
14
 
15
15
  * seamless parallel execution of Python code, locally or
16
- in diverse distributed environments of virtually any scale;
16
+ in heterogeneous distributed environments of virtually any scale;
17
17
  * ubiquitous caching for intermediate program states,
18
18
  with intelligent data and code change tracking;
19
19
  * simple and budget-friendly orchestration backend.
20
20
 
21
+ Pythagoras excels at optimizing complex, long-running,
22
+ resource-demanding computations. It’s not the best choice for real-time,
23
+ latency-sensitive workflows.
24
+
21
25
  ## Usage
22
26
 
27
+ Pythagoras elevates two popular techniques — memoization and parallelization —
28
+ to a global scale and then fuses them, unlocking performance and scalability
29
+ that were previously out of reach.
30
+
23
31
  * `Introduction to Pythagoras` notebook:
24
32
  https://colab.research.google.com/drive/117rAtaWxjfSubzGx0shgqNjONY3E5jgd
25
33
 
@@ -43,6 +51,7 @@ pip install pythagoras
43
51
  ## Dependencies
44
52
 
45
53
  * [persidict](https://pypi.org/project/persidict)
54
+ * [parameterizable](https://pypi.org/project/parameterizable/)
46
55
  * [jsonpickle](https://jsonpickle.github.io)
47
56
  * [joblib](https://joblib.readthedocs.io)
48
57
  * [lz4](https://python-lz4.readthedocs.io)
@@ -57,10 +66,9 @@ pip install pythagoras
57
66
  * [jsonpickle](https://jsonpickle.github.io)
58
67
  * [scikit-learn](https://scikit-learn.org)
59
68
  * [autopep8](https://pypi.org/project/autopep8)
60
- * [pytorch](https://pytorch.org)
61
- * [tensorflow](https://www.tensorflow.org)
62
- * [keras](https://keras.io)
63
69
  * [deepdiff](https://zepworks.com/deepdiff/current/)
70
+ * [nvidia-ml-p](https://pypi.org/project/nvidia-ml-py/)
71
+ * [uv](https://docs.astral.sh/uv/)
64
72
 
65
73
  ## Key Contacts
66
74
 
@@ -4,7 +4,7 @@ build-backend = "uv_build"
4
4
 
5
5
  [project]
6
6
  name = "pythagoras"
7
- version = "0.23.1"
7
+ version = "0.23.3"
8
8
  authors = [
9
9
  {name = "Volodymyr (Vlad) Pavlov", email = "vlpavlov@ieee.org"},
10
10
  ]
@@ -36,6 +36,7 @@ dependencies = [
36
36
  "psutil",
37
37
  "autopep8",
38
38
  "deepdiff",
39
+ "numpy",
39
40
  "pytest",
40
41
  "boto3",
41
42
  "moto",