wandb 0.16.5__py3-none-any.whl → 0.17.0__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (194) hide show
  1. package_readme.md +95 -0
  2. wandb/__init__.py +2 -3
  3. wandb/agents/pyagent.py +0 -1
  4. wandb/analytics/sentry.py +2 -1
  5. wandb/apis/importers/internals/internal.py +0 -1
  6. wandb/apis/importers/internals/protocols.py +30 -56
  7. wandb/apis/importers/mlflow.py +13 -26
  8. wandb/apis/importers/wandb.py +8 -14
  9. wandb/apis/internal.py +0 -3
  10. wandb/apis/public/api.py +55 -3
  11. wandb/apis/public/artifacts.py +1 -0
  12. wandb/apis/public/files.py +1 -0
  13. wandb/apis/public/history.py +1 -0
  14. wandb/apis/public/jobs.py +17 -4
  15. wandb/apis/public/projects.py +1 -0
  16. wandb/apis/public/reports.py +1 -0
  17. wandb/apis/public/runs.py +15 -17
  18. wandb/apis/public/sweeps.py +1 -0
  19. wandb/apis/public/teams.py +1 -0
  20. wandb/apis/public/users.py +1 -0
  21. wandb/apis/reports/v1/_blocks.py +3 -7
  22. wandb/apis/reports/v2/gql.py +1 -0
  23. wandb/apis/reports/v2/interface.py +3 -4
  24. wandb/apis/reports/v2/internal.py +5 -8
  25. wandb/cli/cli.py +95 -22
  26. wandb/data_types.py +9 -6
  27. wandb/docker/__init__.py +1 -1
  28. wandb/env.py +38 -8
  29. wandb/errors/__init__.py +5 -0
  30. wandb/errors/term.py +10 -2
  31. wandb/filesync/step_checksum.py +1 -4
  32. wandb/filesync/step_prepare.py +4 -24
  33. wandb/filesync/step_upload.py +4 -106
  34. wandb/filesync/upload_job.py +0 -76
  35. wandb/integration/catboost/catboost.py +1 -1
  36. wandb/integration/fastai/__init__.py +1 -0
  37. wandb/integration/huggingface/resolver.py +2 -2
  38. wandb/integration/keras/__init__.py +1 -0
  39. wandb/integration/keras/callbacks/metrics_logger.py +1 -1
  40. wandb/integration/keras/keras.py +7 -7
  41. wandb/integration/langchain/wandb_tracer.py +1 -0
  42. wandb/integration/lightning/fabric/logger.py +1 -3
  43. wandb/integration/metaflow/metaflow.py +41 -6
  44. wandb/integration/openai/fine_tuning.py +77 -40
  45. wandb/integration/prodigy/prodigy.py +1 -1
  46. wandb/old/summary.py +1 -1
  47. wandb/plot/confusion_matrix.py +1 -1
  48. wandb/plot/pr_curve.py +2 -1
  49. wandb/plot/roc_curve.py +2 -1
  50. wandb/{plots → plot}/utils.py +13 -25
  51. wandb/proto/v3/wandb_internal_pb2.py +364 -332
  52. wandb/proto/v3/wandb_settings_pb2.py +2 -2
  53. wandb/proto/v3/wandb_telemetry_pb2.py +10 -10
  54. wandb/proto/v4/wandb_internal_pb2.py +322 -316
  55. wandb/proto/v4/wandb_settings_pb2.py +2 -2
  56. wandb/proto/v4/wandb_telemetry_pb2.py +10 -10
  57. wandb/proto/wandb_deprecated.py +7 -1
  58. wandb/proto/wandb_internal_codegen.py +3 -29
  59. wandb/sdk/artifacts/artifact.py +51 -20
  60. wandb/sdk/artifacts/artifact_download_logger.py +1 -0
  61. wandb/sdk/artifacts/artifact_file_cache.py +18 -4
  62. wandb/sdk/artifacts/artifact_instance_cache.py +1 -0
  63. wandb/sdk/artifacts/artifact_manifest.py +1 -0
  64. wandb/sdk/artifacts/artifact_manifest_entry.py +7 -3
  65. wandb/sdk/artifacts/artifact_manifests/artifact_manifest_v1.py +1 -0
  66. wandb/sdk/artifacts/artifact_saver.py +18 -27
  67. wandb/sdk/artifacts/artifact_state.py +1 -0
  68. wandb/sdk/artifacts/artifact_ttl.py +1 -0
  69. wandb/sdk/artifacts/exceptions.py +1 -0
  70. wandb/sdk/artifacts/storage_handlers/azure_handler.py +1 -0
  71. wandb/sdk/artifacts/storage_handlers/gcs_handler.py +13 -18
  72. wandb/sdk/artifacts/storage_handlers/http_handler.py +1 -0
  73. wandb/sdk/artifacts/storage_handlers/local_file_handler.py +1 -0
  74. wandb/sdk/artifacts/storage_handlers/multi_handler.py +1 -0
  75. wandb/sdk/artifacts/storage_handlers/s3_handler.py +5 -3
  76. wandb/sdk/artifacts/storage_handlers/tracking_handler.py +1 -0
  77. wandb/sdk/artifacts/storage_handlers/wb_artifact_handler.py +1 -0
  78. wandb/sdk/artifacts/storage_handlers/wb_local_artifact_handler.py +1 -0
  79. wandb/sdk/artifacts/storage_policies/wandb_storage_policy.py +3 -42
  80. wandb/sdk/artifacts/storage_policy.py +2 -12
  81. wandb/sdk/data_types/_dtypes.py +8 -8
  82. wandb/sdk/data_types/base_types/media.py +3 -6
  83. wandb/sdk/data_types/helper_types/bounding_boxes_2d.py +3 -1
  84. wandb/sdk/data_types/image.py +1 -1
  85. wandb/sdk/data_types/video.py +1 -1
  86. wandb/sdk/integration_utils/auto_logging.py +5 -6
  87. wandb/sdk/integration_utils/data_logging.py +10 -6
  88. wandb/sdk/interface/interface.py +86 -38
  89. wandb/sdk/interface/interface_shared.py +7 -13
  90. wandb/sdk/internal/datastore.py +1 -1
  91. wandb/sdk/internal/file_pusher.py +2 -5
  92. wandb/sdk/internal/file_stream.py +5 -18
  93. wandb/sdk/internal/handler.py +18 -2
  94. wandb/sdk/internal/internal.py +0 -1
  95. wandb/sdk/internal/internal_api.py +1 -129
  96. wandb/sdk/internal/internal_util.py +0 -1
  97. wandb/sdk/internal/job_builder.py +159 -45
  98. wandb/sdk/internal/profiler.py +1 -0
  99. wandb/sdk/internal/progress.py +0 -28
  100. wandb/sdk/internal/run.py +1 -0
  101. wandb/sdk/internal/sender.py +1 -2
  102. wandb/sdk/internal/system/assets/gpu_amd.py +44 -44
  103. wandb/sdk/internal/system/assets/gpu_apple.py +56 -11
  104. wandb/sdk/internal/system/assets/interfaces.py +6 -8
  105. wandb/sdk/internal/system/assets/open_metrics.py +2 -2
  106. wandb/sdk/internal/system/assets/trainium.py +1 -3
  107. wandb/sdk/launch/__init__.py +9 -1
  108. wandb/sdk/launch/_launch.py +9 -24
  109. wandb/sdk/launch/_launch_add.py +1 -3
  110. wandb/sdk/launch/_project_spec.py +188 -241
  111. wandb/sdk/launch/agent/agent.py +115 -48
  112. wandb/sdk/launch/agent/config.py +80 -14
  113. wandb/sdk/launch/builder/abstract.py +69 -1
  114. wandb/sdk/launch/builder/build.py +156 -555
  115. wandb/sdk/launch/builder/context_manager.py +235 -0
  116. wandb/sdk/launch/builder/docker_builder.py +8 -23
  117. wandb/sdk/launch/builder/kaniko_builder.py +161 -159
  118. wandb/sdk/launch/builder/noop.py +1 -0
  119. wandb/sdk/launch/builder/templates/dockerfile.py +92 -0
  120. wandb/sdk/launch/create_job.py +68 -63
  121. wandb/sdk/launch/environment/abstract.py +1 -0
  122. wandb/sdk/launch/environment/gcp_environment.py +1 -0
  123. wandb/sdk/launch/environment/local_environment.py +1 -0
  124. wandb/sdk/launch/inputs/files.py +148 -0
  125. wandb/sdk/launch/inputs/internal.py +217 -0
  126. wandb/sdk/launch/inputs/manage.py +95 -0
  127. wandb/sdk/launch/loader.py +1 -0
  128. wandb/sdk/launch/registry/abstract.py +1 -0
  129. wandb/sdk/launch/registry/azure_container_registry.py +1 -0
  130. wandb/sdk/launch/registry/elastic_container_registry.py +1 -0
  131. wandb/sdk/launch/registry/google_artifact_registry.py +2 -1
  132. wandb/sdk/launch/registry/local_registry.py +1 -0
  133. wandb/sdk/launch/runner/abstract.py +1 -0
  134. wandb/sdk/launch/runner/kubernetes_monitor.py +4 -1
  135. wandb/sdk/launch/runner/kubernetes_runner.py +9 -10
  136. wandb/sdk/launch/runner/local_container.py +2 -3
  137. wandb/sdk/launch/runner/local_process.py +8 -29
  138. wandb/sdk/launch/runner/sagemaker_runner.py +21 -20
  139. wandb/sdk/launch/runner/vertex_runner.py +8 -7
  140. wandb/sdk/launch/sweeps/scheduler.py +7 -4
  141. wandb/sdk/launch/sweeps/scheduler_sweep.py +2 -1
  142. wandb/sdk/launch/sweeps/utils.py +3 -3
  143. wandb/sdk/launch/utils.py +33 -140
  144. wandb/sdk/lib/_settings_toposort_generated.py +1 -5
  145. wandb/sdk/lib/fsm.py +8 -12
  146. wandb/sdk/lib/gitlib.py +4 -4
  147. wandb/sdk/lib/import_hooks.py +1 -1
  148. wandb/sdk/lib/lazyloader.py +0 -1
  149. wandb/sdk/lib/proto_util.py +23 -2
  150. wandb/sdk/lib/redirect.py +19 -14
  151. wandb/sdk/lib/retry.py +3 -2
  152. wandb/sdk/lib/run_moment.py +7 -1
  153. wandb/sdk/lib/tracelog.py +1 -1
  154. wandb/sdk/service/service.py +19 -16
  155. wandb/sdk/verify/verify.py +2 -1
  156. wandb/sdk/wandb_init.py +16 -63
  157. wandb/sdk/wandb_manager.py +2 -2
  158. wandb/sdk/wandb_require.py +5 -0
  159. wandb/sdk/wandb_run.py +164 -90
  160. wandb/sdk/wandb_settings.py +2 -48
  161. wandb/sdk/wandb_setup.py +1 -1
  162. wandb/sklearn/__init__.py +1 -0
  163. wandb/sklearn/plot/__init__.py +1 -0
  164. wandb/sklearn/plot/classifier.py +11 -12
  165. wandb/sklearn/plot/clusterer.py +2 -1
  166. wandb/sklearn/plot/regressor.py +1 -0
  167. wandb/sklearn/plot/shared.py +1 -0
  168. wandb/sklearn/utils.py +1 -0
  169. wandb/testing/relay.py +4 -4
  170. wandb/trigger.py +1 -0
  171. wandb/util.py +67 -54
  172. wandb/wandb_controller.py +2 -3
  173. wandb/wandb_torch.py +1 -2
  174. {wandb-0.16.5.dist-info → wandb-0.17.0.dist-info}/METADATA +67 -70
  175. {wandb-0.16.5.dist-info → wandb-0.17.0.dist-info}/RECORD +178 -188
  176. {wandb-0.16.5.dist-info → wandb-0.17.0.dist-info}/WHEEL +1 -2
  177. wandb/bin/apple_gpu_stats +0 -0
  178. wandb/catboost/__init__.py +0 -9
  179. wandb/fastai/__init__.py +0 -9
  180. wandb/keras/__init__.py +0 -18
  181. wandb/lightgbm/__init__.py +0 -9
  182. wandb/plots/__init__.py +0 -6
  183. wandb/plots/explain_text.py +0 -36
  184. wandb/plots/heatmap.py +0 -81
  185. wandb/plots/named_entity.py +0 -43
  186. wandb/plots/part_of_speech.py +0 -50
  187. wandb/plots/plot_definitions.py +0 -768
  188. wandb/plots/precision_recall.py +0 -121
  189. wandb/plots/roc.py +0 -103
  190. wandb/sacred/__init__.py +0 -3
  191. wandb/xgboost/__init__.py +0 -9
  192. wandb-0.16.5.dist-info/top_level.txt +0 -1
  193. {wandb-0.16.5.dist-info → wandb-0.17.0.dist-info}/entry_points.txt +0 -0
  194. {wandb-0.16.5.dist-info → wandb-0.17.0.dist-info/licenses}/LICENSE +0 -0
@@ -1,121 +0,0 @@
1
- import wandb
2
- from wandb import util
3
- from wandb.plots.utils import (
4
- deprecation_notice,
5
- encode_labels,
6
- test_missing,
7
- test_types,
8
- )
9
-
10
- chart_limit = wandb.Table.MAX_ROWS
11
-
12
-
13
- def precision_recall(
14
- y_true=None, y_probas=None, labels=None, plot_micro=True, classes_to_plot=None
15
- ):
16
- """
17
- Computes the tradeoff between precision and recall for different thresholds.
18
- A high area under the curve represents both high recall and high precision,
19
- where high precision relates to a low false positive rate, and high recall
20
- relates to a low false negative rate. High scores for both show that the
21
- classifier is returning accurate results (high precision), as well as
22
- returning a majority of all positive results (high recall).
23
- PR curve is useful when the classes are very imbalanced.
24
-
25
- Arguments:
26
- y_true (arr): Test set labels.
27
- y_probas (arr): Test set predicted probabilities.
28
- labels (list): Named labels for target varible (y). Makes plots easier to
29
- read by replacing target values with corresponding index.
30
- For example labels= ['dog', 'cat', 'owl'] all 0s are
31
- replaced by 'dog', 1s by 'cat'.
32
-
33
- Returns:
34
- Nothing. To see plots, go to your W&B run page then expand the 'media' tab
35
- under 'auto visualizations'.
36
-
37
- Example:
38
- wandb.log({'pr': wandb.plots.precision_recall(y_true, y_probas, labels)})
39
- """
40
- deprecation_notice()
41
-
42
- np = util.get_module(
43
- "numpy",
44
- required="roc requires the numpy library, install with `pip install numpy`",
45
- )
46
- preprocessing = util.get_module(
47
- "sklearn.preprocessing",
48
- "roc requires the scikit preprocessing submodule, install with `pip install scikit-learn`",
49
- )
50
- metrics = util.get_module(
51
- "sklearn.metrics",
52
- "roc requires the scikit metrics submodule, install with `pip install scikit-learn`",
53
- )
54
-
55
- y_true = np.array(y_true)
56
- y_probas = np.array(y_probas)
57
-
58
- if test_missing(y_true=y_true, y_probas=y_probas) and test_types(
59
- y_true=y_true, y_probas=y_probas
60
- ):
61
- classes = np.unique(y_true)
62
- probas = y_probas
63
-
64
- if classes_to_plot is None:
65
- classes_to_plot = classes
66
-
67
- binarized_y_true = preprocessing.label_binarize(y_true, classes=classes)
68
- if len(classes) == 2:
69
- binarized_y_true = np.hstack((1 - binarized_y_true, binarized_y_true))
70
-
71
- pr_curves = {}
72
- indices_to_plot = np.in1d(classes, classes_to_plot)
73
- for i, to_plot in enumerate(indices_to_plot):
74
- if to_plot:
75
- average_precision = metrics.average_precision_score(
76
- binarized_y_true[:, i], probas[:, i]
77
- )
78
- precision, recall, _ = metrics.precision_recall_curve(
79
- y_true, probas[:, i], pos_label=classes[i]
80
- )
81
-
82
- samples = 20
83
- sample_precision = []
84
- sample_recall = []
85
- for k in range(samples):
86
- sample_precision.append(
87
- precision[int(len(precision) * k / samples)]
88
- )
89
- sample_recall.append(recall[int(len(recall) * k / samples)])
90
-
91
- pr_curves[classes[i]] = (sample_precision, sample_recall)
92
-
93
- def pr_table(pr_curves):
94
- data = []
95
- count = 0
96
- for i, class_name in enumerate(pr_curves.keys()):
97
- precision, recall = pr_curves[class_name]
98
- for p, r in zip(precision, recall):
99
- # if class_names are ints and labels are set
100
- if labels is not None and (
101
- isinstance(class_name, int)
102
- or isinstance(class_name, np.integer)
103
- ):
104
- class_name = labels[class_name]
105
- # if class_names are ints and labels are not set
106
- # or, if class_names have something other than ints
107
- # (string, float, date) - user class_names
108
- data.append([class_name, round(p, 3), round(r, 3)])
109
- count += 1
110
- if count >= chart_limit:
111
- wandb.termwarn(
112
- "wandb uses only the first %d datapoints to create the plots."
113
- % wandb.Table.MAX_ROWS
114
- )
115
- break
116
- return wandb.visualize(
117
- "wandb/pr_curve/v1",
118
- wandb.Table(columns=["class", "precision", "recall"], data=data),
119
- )
120
-
121
- return pr_table(pr_curves)
wandb/plots/roc.py DELETED
@@ -1,103 +0,0 @@
1
- import wandb
2
- from wandb import util
3
- from wandb.plots.utils import (
4
- deprecation_notice,
5
- encode_labels,
6
- test_missing,
7
- test_types,
8
- )
9
-
10
- chart_limit = wandb.Table.MAX_ROWS
11
-
12
-
13
- def roc(
14
- y_true=None,
15
- y_probas=None,
16
- labels=None,
17
- plot_micro=True,
18
- plot_macro=True,
19
- classes_to_plot=None,
20
- ):
21
- """
22
- Calculates receiver operating characteristic scores and visualizes them as the
23
- ROC curve.
24
-
25
- Arguments:
26
- y_true (arr): Test set labels.
27
- y_probas (arr): Test set predicted probabilities.
28
- labels (list): Named labels for target varible (y). Makes plots easier to
29
- read by replacing target values with corresponding index.
30
- For example labels= ['dog', 'cat', 'owl'] all 0s are
31
- replaced by 'dog', 1s by 'cat'.
32
-
33
- Returns:
34
- Nothing. To see plots, go to your W&B run page then expand the 'media' tab
35
- under 'auto visualizations'.
36
-
37
- Example:
38
- wandb.log({'roc': wandb.plots.ROC(y_true, y_probas, labels)})
39
- """
40
- deprecation_notice()
41
-
42
- np = util.get_module(
43
- "numpy",
44
- required="roc requires the numpy library, install with `pip install numpy`",
45
- )
46
- sklearn = util.get_module(
47
- "sklearn",
48
- required="roc requires the scikit library, install with `pip install scikit-learn`",
49
- )
50
- from sklearn.metrics import auc, roc_curve
51
-
52
- if test_missing(y_true=y_true, y_probas=y_probas) and test_types(
53
- y_true=y_true, y_probas=y_probas
54
- ):
55
- y_true = np.array(y_true)
56
- y_probas = np.array(y_probas)
57
- classes = np.unique(y_true)
58
- probas = y_probas
59
-
60
- if classes_to_plot is None:
61
- classes_to_plot = classes
62
-
63
- fpr_dict = dict()
64
- tpr_dict = dict()
65
-
66
- indices_to_plot = np.in1d(classes, classes_to_plot)
67
-
68
- def roc_table(fpr_dict, tpr_dict, classes, indices_to_plot):
69
- data = []
70
- count = 0
71
-
72
- for i, to_plot in enumerate(indices_to_plot):
73
- fpr_dict[i], tpr_dict[i], _ = roc_curve(
74
- y_true, probas[:, i], pos_label=classes[i]
75
- )
76
- if to_plot:
77
- roc_auc = auc(fpr_dict[i], tpr_dict[i])
78
- for j in range(len(fpr_dict[i])):
79
- if labels is not None and (
80
- isinstance(classes[i], int)
81
- or isinstance(classes[0], np.integer)
82
- ):
83
- class_dict = labels[classes[i]]
84
- else:
85
- class_dict = classes[i]
86
- fpr = [
87
- class_dict,
88
- round(fpr_dict[i][j], 3),
89
- round(tpr_dict[i][j], 3),
90
- ]
91
- data.append(fpr)
92
- count += 1
93
- if count >= chart_limit:
94
- wandb.termwarn(
95
- "wandb uses only the first %d datapoints to create the plots."
96
- % wandb.Table.MAX_ROWS
97
- )
98
- break
99
- return wandb.visualize(
100
- "wandb/roc/v1", wandb.Table(columns=["class", "fpr", "tpr"], data=data)
101
- )
102
-
103
- return roc_table(fpr_dict, tpr_dict, classes, indices_to_plot)
wandb/sacred/__init__.py DELETED
@@ -1,3 +0,0 @@
1
- from wandb.integration.sacred import WandbObserver
2
-
3
- __all__ = ["WandbObserver"]
wandb/xgboost/__init__.py DELETED
@@ -1,9 +0,0 @@
1
- """Compatibility xgboost module.
2
-
3
- In the future use:
4
- from wandb.integration.xgboost import wandb_callback
5
- """
6
-
7
- from wandb.integration.xgboost import WandbCallback, wandb_callback
8
-
9
- __all__ = ["wandb_callback", "WandbCallback"]
@@ -1 +0,0 @@
1
- wandb