wandb 0.16.6__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.
- package_readme.md +95 -0
- wandb/__init__.py +2 -3
- wandb/agents/pyagent.py +0 -1
- wandb/analytics/sentry.py +2 -1
- wandb/apis/importers/internals/internal.py +0 -1
- wandb/apis/importers/internals/protocols.py +30 -56
- wandb/apis/importers/mlflow.py +13 -26
- wandb/apis/importers/wandb.py +8 -14
- wandb/apis/internal.py +0 -3
- wandb/apis/public/api.py +55 -3
- wandb/apis/public/artifacts.py +1 -0
- wandb/apis/public/files.py +1 -0
- wandb/apis/public/history.py +1 -0
- wandb/apis/public/jobs.py +17 -4
- wandb/apis/public/projects.py +1 -0
- wandb/apis/public/reports.py +1 -0
- wandb/apis/public/runs.py +15 -17
- wandb/apis/public/sweeps.py +1 -0
- wandb/apis/public/teams.py +1 -0
- wandb/apis/public/users.py +1 -0
- wandb/apis/reports/v1/_blocks.py +3 -7
- wandb/apis/reports/v2/gql.py +1 -0
- wandb/apis/reports/v2/interface.py +3 -4
- wandb/apis/reports/v2/internal.py +5 -8
- wandb/cli/cli.py +92 -22
- wandb/data_types.py +9 -6
- wandb/docker/__init__.py +1 -1
- wandb/env.py +38 -8
- wandb/errors/__init__.py +5 -0
- wandb/errors/term.py +10 -2
- wandb/filesync/step_checksum.py +1 -4
- wandb/filesync/step_prepare.py +4 -24
- wandb/filesync/step_upload.py +4 -106
- wandb/filesync/upload_job.py +0 -76
- wandb/integration/catboost/catboost.py +1 -1
- wandb/integration/fastai/__init__.py +1 -0
- wandb/integration/huggingface/resolver.py +2 -2
- wandb/integration/keras/__init__.py +1 -0
- wandb/integration/keras/callbacks/metrics_logger.py +1 -1
- wandb/integration/keras/keras.py +7 -7
- wandb/integration/langchain/wandb_tracer.py +1 -0
- wandb/integration/lightning/fabric/logger.py +1 -3
- wandb/integration/metaflow/metaflow.py +41 -6
- wandb/integration/openai/fine_tuning.py +3 -3
- wandb/integration/prodigy/prodigy.py +1 -1
- wandb/old/summary.py +1 -1
- wandb/plot/confusion_matrix.py +1 -1
- wandb/plot/pr_curve.py +2 -1
- wandb/plot/roc_curve.py +2 -1
- wandb/{plots → plot}/utils.py +13 -25
- wandb/proto/v3/wandb_internal_pb2.py +364 -332
- wandb/proto/v3/wandb_settings_pb2.py +2 -2
- wandb/proto/v3/wandb_telemetry_pb2.py +10 -10
- wandb/proto/v4/wandb_internal_pb2.py +322 -316
- wandb/proto/v4/wandb_settings_pb2.py +2 -2
- wandb/proto/v4/wandb_telemetry_pb2.py +10 -10
- wandb/proto/wandb_deprecated.py +7 -1
- wandb/proto/wandb_internal_codegen.py +3 -29
- wandb/sdk/artifacts/artifact.py +26 -11
- wandb/sdk/artifacts/artifact_download_logger.py +1 -0
- wandb/sdk/artifacts/artifact_file_cache.py +18 -4
- wandb/sdk/artifacts/artifact_instance_cache.py +1 -0
- wandb/sdk/artifacts/artifact_manifest.py +1 -0
- wandb/sdk/artifacts/artifact_manifest_entry.py +7 -3
- wandb/sdk/artifacts/artifact_manifests/artifact_manifest_v1.py +1 -0
- wandb/sdk/artifacts/artifact_saver.py +2 -8
- wandb/sdk/artifacts/artifact_state.py +1 -0
- wandb/sdk/artifacts/artifact_ttl.py +1 -0
- wandb/sdk/artifacts/exceptions.py +1 -0
- wandb/sdk/artifacts/storage_handlers/azure_handler.py +1 -0
- wandb/sdk/artifacts/storage_handlers/gcs_handler.py +13 -18
- wandb/sdk/artifacts/storage_handlers/http_handler.py +1 -0
- wandb/sdk/artifacts/storage_handlers/local_file_handler.py +1 -0
- wandb/sdk/artifacts/storage_handlers/multi_handler.py +1 -0
- wandb/sdk/artifacts/storage_handlers/s3_handler.py +5 -3
- wandb/sdk/artifacts/storage_handlers/tracking_handler.py +1 -0
- wandb/sdk/artifacts/storage_handlers/wb_artifact_handler.py +1 -0
- wandb/sdk/artifacts/storage_handlers/wb_local_artifact_handler.py +1 -0
- wandb/sdk/artifacts/storage_policies/wandb_storage_policy.py +3 -42
- wandb/sdk/artifacts/storage_policy.py +2 -12
- wandb/sdk/data_types/_dtypes.py +8 -8
- wandb/sdk/data_types/base_types/media.py +3 -6
- wandb/sdk/data_types/helper_types/bounding_boxes_2d.py +3 -1
- wandb/sdk/data_types/image.py +1 -1
- wandb/sdk/data_types/video.py +1 -1
- wandb/sdk/integration_utils/auto_logging.py +5 -6
- wandb/sdk/integration_utils/data_logging.py +10 -6
- wandb/sdk/interface/interface.py +68 -32
- wandb/sdk/interface/interface_shared.py +7 -13
- wandb/sdk/internal/datastore.py +1 -1
- wandb/sdk/internal/file_pusher.py +2 -5
- wandb/sdk/internal/file_stream.py +5 -18
- wandb/sdk/internal/handler.py +18 -2
- wandb/sdk/internal/internal.py +0 -1
- wandb/sdk/internal/internal_api.py +1 -129
- wandb/sdk/internal/internal_util.py +0 -1
- wandb/sdk/internal/job_builder.py +159 -45
- wandb/sdk/internal/profiler.py +1 -0
- wandb/sdk/internal/progress.py +0 -28
- wandb/sdk/internal/run.py +1 -0
- wandb/sdk/internal/sender.py +1 -2
- wandb/sdk/internal/system/assets/gpu_amd.py +44 -44
- wandb/sdk/internal/system/assets/gpu_apple.py +56 -11
- wandb/sdk/internal/system/assets/interfaces.py +6 -8
- wandb/sdk/internal/system/assets/open_metrics.py +2 -2
- wandb/sdk/internal/system/assets/trainium.py +1 -3
- wandb/sdk/launch/__init__.py +9 -1
- wandb/sdk/launch/_launch.py +4 -24
- wandb/sdk/launch/_launch_add.py +1 -3
- wandb/sdk/launch/_project_spec.py +186 -224
- wandb/sdk/launch/agent/agent.py +37 -13
- wandb/sdk/launch/agent/config.py +72 -14
- wandb/sdk/launch/builder/abstract.py +69 -1
- wandb/sdk/launch/builder/build.py +156 -555
- wandb/sdk/launch/builder/context_manager.py +235 -0
- wandb/sdk/launch/builder/docker_builder.py +8 -23
- wandb/sdk/launch/builder/kaniko_builder.py +12 -25
- wandb/sdk/launch/builder/noop.py +1 -0
- wandb/sdk/launch/builder/templates/dockerfile.py +92 -0
- wandb/sdk/launch/create_job.py +47 -37
- wandb/sdk/launch/environment/abstract.py +1 -0
- wandb/sdk/launch/environment/gcp_environment.py +1 -0
- wandb/sdk/launch/environment/local_environment.py +1 -0
- wandb/sdk/launch/inputs/files.py +148 -0
- wandb/sdk/launch/inputs/internal.py +217 -0
- wandb/sdk/launch/inputs/manage.py +95 -0
- wandb/sdk/launch/loader.py +1 -0
- wandb/sdk/launch/registry/abstract.py +1 -0
- wandb/sdk/launch/registry/azure_container_registry.py +1 -0
- wandb/sdk/launch/registry/elastic_container_registry.py +1 -0
- wandb/sdk/launch/registry/google_artifact_registry.py +2 -1
- wandb/sdk/launch/registry/local_registry.py +1 -0
- wandb/sdk/launch/runner/abstract.py +1 -0
- wandb/sdk/launch/runner/kubernetes_monitor.py +1 -0
- wandb/sdk/launch/runner/kubernetes_runner.py +9 -10
- wandb/sdk/launch/runner/local_container.py +2 -3
- wandb/sdk/launch/runner/local_process.py +8 -29
- wandb/sdk/launch/runner/sagemaker_runner.py +21 -20
- wandb/sdk/launch/runner/vertex_runner.py +8 -7
- wandb/sdk/launch/sweeps/scheduler.py +4 -3
- wandb/sdk/launch/sweeps/scheduler_sweep.py +2 -1
- wandb/sdk/launch/sweeps/utils.py +3 -3
- wandb/sdk/launch/utils.py +15 -140
- wandb/sdk/lib/_settings_toposort_generated.py +0 -5
- wandb/sdk/lib/fsm.py +8 -12
- wandb/sdk/lib/gitlib.py +4 -4
- wandb/sdk/lib/import_hooks.py +1 -1
- wandb/sdk/lib/lazyloader.py +0 -1
- wandb/sdk/lib/proto_util.py +23 -2
- wandb/sdk/lib/redirect.py +19 -14
- wandb/sdk/lib/retry.py +3 -2
- wandb/sdk/lib/tracelog.py +1 -1
- wandb/sdk/service/service.py +19 -16
- wandb/sdk/verify/verify.py +2 -1
- wandb/sdk/wandb_init.py +14 -55
- wandb/sdk/wandb_manager.py +2 -2
- wandb/sdk/wandb_require.py +5 -0
- wandb/sdk/wandb_run.py +114 -56
- wandb/sdk/wandb_settings.py +0 -48
- wandb/sdk/wandb_setup.py +1 -1
- wandb/sklearn/__init__.py +1 -0
- wandb/sklearn/plot/__init__.py +1 -0
- wandb/sklearn/plot/classifier.py +11 -12
- wandb/sklearn/plot/clusterer.py +2 -1
- wandb/sklearn/plot/regressor.py +1 -0
- wandb/sklearn/plot/shared.py +1 -0
- wandb/sklearn/utils.py +1 -0
- wandb/testing/relay.py +4 -4
- wandb/trigger.py +1 -0
- wandb/util.py +67 -54
- wandb/wandb_controller.py +2 -3
- wandb/wandb_torch.py +1 -2
- {wandb-0.16.6.dist-info → wandb-0.17.0.dist-info}/METADATA +67 -70
- {wandb-0.16.6.dist-info → wandb-0.17.0.dist-info}/RECORD +177 -187
- {wandb-0.16.6.dist-info → wandb-0.17.0.dist-info}/WHEEL +1 -2
- wandb/bin/apple_gpu_stats +0 -0
- wandb/catboost/__init__.py +0 -9
- wandb/fastai/__init__.py +0 -9
- wandb/keras/__init__.py +0 -18
- wandb/lightgbm/__init__.py +0 -9
- wandb/plots/__init__.py +0 -6
- wandb/plots/explain_text.py +0 -36
- wandb/plots/heatmap.py +0 -81
- wandb/plots/named_entity.py +0 -43
- wandb/plots/part_of_speech.py +0 -50
- wandb/plots/plot_definitions.py +0 -768
- wandb/plots/precision_recall.py +0 -121
- wandb/plots/roc.py +0 -103
- wandb/sacred/__init__.py +0 -3
- wandb/xgboost/__init__.py +0 -9
- wandb-0.16.6.dist-info/top_level.txt +0 -1
- {wandb-0.16.6.dist-info → wandb-0.17.0.dist-info}/entry_points.txt +0 -0
- {wandb-0.16.6.dist-info → wandb-0.17.0.dist-info/licenses}/LICENSE +0 -0
wandb/sdk/wandb_settings.py
CHANGED
@@ -298,7 +298,6 @@ class SettingsData:
|
|
298
298
|
|
299
299
|
_args: Sequence[str]
|
300
300
|
_aws_lambda: bool
|
301
|
-
_async_upload_concurrency_limit: int
|
302
301
|
_cli_only_mode: bool # Avoid running any code specific for runs
|
303
302
|
_code_path_local: str
|
304
303
|
_colab: bool
|
@@ -313,7 +312,6 @@ class SettingsData:
|
|
313
312
|
_disable_update_check: bool # Disable version check
|
314
313
|
_disable_viewer: bool # Prevent early viewer query
|
315
314
|
_disable_machine_info: bool # Disable automatic machine info collection
|
316
|
-
_except_exit: bool
|
317
315
|
_executable: str
|
318
316
|
_extra_http_headers: Mapping[str, str]
|
319
317
|
# file stream retry client configuration
|
@@ -425,7 +423,6 @@ class SettingsData:
|
|
425
423
|
# magic: Union[str, bool, dict] # never used in code, deprecated
|
426
424
|
mode: str
|
427
425
|
notebook_name: str
|
428
|
-
problem: str
|
429
426
|
program: str
|
430
427
|
program_abspath: str
|
431
428
|
program_relpath: str
|
@@ -621,10 +618,6 @@ class Settings(SettingsData):
|
|
621
618
|
Note that key names must be the same as the class attribute names.
|
622
619
|
"""
|
623
620
|
props: Dict[str, Dict[str, Any]] = dict(
|
624
|
-
_async_upload_concurrency_limit={
|
625
|
-
"preprocessor": int,
|
626
|
-
"validator": self._validate__async_upload_concurrency_limit,
|
627
|
-
},
|
628
621
|
_aws_lambda={
|
629
622
|
"hook": lambda _: is_aws_lambda(),
|
630
623
|
"auto_hook": True,
|
@@ -862,7 +855,6 @@ class Settings(SettingsData):
|
|
862
855
|
},
|
863
856
|
login_timeout={"preprocessor": lambda x: float(x)},
|
864
857
|
mode={"value": "online", "validator": self._validate_mode},
|
865
|
-
problem={"value": "fatal", "validator": self._validate_problem},
|
866
858
|
program={
|
867
859
|
"hook": lambda x: self._get_program(x),
|
868
860
|
},
|
@@ -1025,13 +1017,6 @@ class Settings(SettingsData):
|
|
1025
1017
|
raise UsageError(f"Settings field `console`: {value!r} not in {choices}")
|
1026
1018
|
return True
|
1027
1019
|
|
1028
|
-
@staticmethod
|
1029
|
-
def _validate_problem(value: str) -> bool:
|
1030
|
-
choices: Set[str] = {"fatal", "warn", "silent"}
|
1031
|
-
if value not in choices:
|
1032
|
-
raise UsageError(f"Settings field `problem`: {value!r} not in {choices}")
|
1033
|
-
return True
|
1034
|
-
|
1035
1020
|
@staticmethod
|
1036
1021
|
def _validate_anonymous(value: str) -> bool:
|
1037
1022
|
choices: Set[str] = {"allow", "must", "never", "false", "true"}
|
@@ -1179,35 +1164,6 @@ class Settings(SettingsData):
|
|
1179
1164
|
raise UsageError("_stats_samples_to_average must be between 1 and 30")
|
1180
1165
|
return True
|
1181
1166
|
|
1182
|
-
@staticmethod
|
1183
|
-
def _validate__async_upload_concurrency_limit(value: int) -> bool:
|
1184
|
-
if value <= 0:
|
1185
|
-
raise UsageError("_async_upload_concurrency_limit must be positive")
|
1186
|
-
|
1187
|
-
try:
|
1188
|
-
import resource # not always available on Windows
|
1189
|
-
|
1190
|
-
file_limit = resource.getrlimit(resource.RLIMIT_NOFILE)[0]
|
1191
|
-
except Exception:
|
1192
|
-
# Couldn't get the open-file-limit for some reason,
|
1193
|
-
# probably very platform-specific. Not a problem,
|
1194
|
-
# we just won't use it to cap the concurrency.
|
1195
|
-
pass
|
1196
|
-
else:
|
1197
|
-
if value > file_limit:
|
1198
|
-
wandb.termwarn(
|
1199
|
-
(
|
1200
|
-
"_async_upload_concurrency_limit setting of"
|
1201
|
-
f" {value} exceeds this process's limit"
|
1202
|
-
f" on open files ({file_limit}); may cause file-upload failures."
|
1203
|
-
" Try decreasing _async_upload_concurrency_limit,"
|
1204
|
-
" or increasing your file limit with `ulimit -n`."
|
1205
|
-
),
|
1206
|
-
repeat=False,
|
1207
|
-
)
|
1208
|
-
|
1209
|
-
return True
|
1210
|
-
|
1211
1167
|
@staticmethod
|
1212
1168
|
def _validate_job_source(value: str) -> bool:
|
1213
1169
|
valid_sources = ["repo", "artifact", "image"]
|
@@ -1675,7 +1631,6 @@ class Settings(SettingsData):
|
|
1675
1631
|
"WANDB_TRACELOG": "_tracelog",
|
1676
1632
|
"WANDB_DISABLE_SERVICE": "_disable_service",
|
1677
1633
|
"WANDB_SERVICE_TRANSPORT": "_service_transport",
|
1678
|
-
"WANDB_REQUIRE_CORE": "_require_core",
|
1679
1634
|
"WANDB_DIR": "root_dir",
|
1680
1635
|
"WANDB_NAME": "run_name",
|
1681
1636
|
"WANDB_NOTES": "run_notes",
|
@@ -1784,9 +1739,6 @@ class Settings(SettingsData):
|
|
1784
1739
|
settings["_args"] = sys.argv[1:]
|
1785
1740
|
settings["_os"] = platform.platform(aliased=True)
|
1786
1741
|
settings["_python"] = platform.python_version()
|
1787
|
-
# hack to make sure we don't hang on windows
|
1788
|
-
if self._windows and self._except_exit is None:
|
1789
|
-
settings["_except_exit"] = True # type: ignore
|
1790
1742
|
|
1791
1743
|
if _logger is not None:
|
1792
1744
|
_logger.info(
|
wandb/sdk/wandb_setup.py
CHANGED
wandb/sklearn/__init__.py
CHANGED
wandb/sklearn/plot/__init__.py
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
"""Create and logs charts introspecting models built with scikit-learn to W&B."""
|
2
|
+
|
2
3
|
from .classifier import calibration_curve as plot_calibration_curve
|
3
4
|
from .classifier import class_proportions as plot_class_proportions
|
4
5
|
from .classifier import classifier as plot_classifier
|
wandb/sklearn/plot/classifier.py
CHANGED
@@ -1,11 +1,12 @@
|
|
1
1
|
"""Define plots for classification models built with scikit-learn."""
|
2
|
+
|
2
3
|
from warnings import simplefilter
|
3
4
|
|
4
5
|
import numpy as np
|
5
6
|
from sklearn import naive_bayes
|
6
7
|
|
7
8
|
import wandb
|
8
|
-
import wandb.
|
9
|
+
import wandb.plot
|
9
10
|
from wandb.sklearn import calculate, utils
|
10
11
|
|
11
12
|
from . import shared
|
@@ -32,9 +33,9 @@ def classifier(
|
|
32
33
|
|
33
34
|
The following plots are generated:
|
34
35
|
feature importances, confusion matrix, summary metrics,
|
35
|
-
class
|
36
|
+
class proportions, calibration curve, roc curve, precision-recall curve.
|
36
37
|
|
37
|
-
Should only be called with a fitted
|
38
|
+
Should only be called with a fitted classifier (otherwise an error is thrown).
|
38
39
|
|
39
40
|
Arguments:
|
40
41
|
model: (classifier) Takes in a fitted classifier.
|
@@ -44,7 +45,7 @@ def classifier(
|
|
44
45
|
y_test: (arr) Test set labels.
|
45
46
|
y_pred: (arr) Test set predictions by the model passed.
|
46
47
|
y_probas: (arr) Test set predicted probabilities by the model passed.
|
47
|
-
labels: (list) Named labels for target
|
48
|
+
labels: (list) Named labels for target variable (y). Makes plots easier to
|
48
49
|
read by replacing target values with corresponding index.
|
49
50
|
For example if `labels=['dog', 'cat', 'owl']` all 0s are
|
50
51
|
replaced by dog, 1s by cat.
|
@@ -133,9 +134,7 @@ def roc(
|
|
133
134
|
wandb.sklearn.plot_roc(y_true, y_probas, labels)
|
134
135
|
```
|
135
136
|
"""
|
136
|
-
roc_chart = wandb.
|
137
|
-
y_true, y_probas, labels, plot_micro, plot_macro, classes_to_plot
|
138
|
-
)
|
137
|
+
roc_chart = wandb.plot.roc_curve(y_true, y_probas, labels, classes_to_plot)
|
139
138
|
wandb.log({"roc": roc_chart})
|
140
139
|
|
141
140
|
|
@@ -212,8 +211,8 @@ def precision_recall(
|
|
212
211
|
wandb.sklearn.plot_precision_recall(y_true, y_probas, labels)
|
213
212
|
```
|
214
213
|
"""
|
215
|
-
precision_recall_chart = wandb.
|
216
|
-
y_true, y_probas, labels,
|
214
|
+
precision_recall_chart = wandb.plot.pr_curve(
|
215
|
+
y_true, y_probas, labels, classes_to_plot
|
217
216
|
)
|
218
217
|
|
219
218
|
wandb.log({"precision_recall": precision_recall_chart})
|
@@ -224,7 +223,7 @@ def feature_importances(
|
|
224
223
|
):
|
225
224
|
"""Log a plot depicting the relative importance of each feature for a classifier's decisions.
|
226
225
|
|
227
|
-
Should only be called with a fitted
|
226
|
+
Should only be called with a fitted classifier (otherwise an error is thrown).
|
228
227
|
Only works with classifiers that have a feature_importances_ attribute, like trees.
|
229
228
|
|
230
229
|
Arguments:
|
@@ -251,7 +250,7 @@ def feature_importances(
|
|
251
250
|
|
252
251
|
|
253
252
|
def class_proportions(y_train=None, y_test=None, labels=None):
|
254
|
-
"""Plot the distribution of target
|
253
|
+
"""Plot the distribution of target classes in training and test sets.
|
255
254
|
|
256
255
|
Useful for detecting imbalanced classes.
|
257
256
|
|
@@ -295,7 +294,7 @@ def calibration_curve(clf=None, X=None, y=None, clf_name="Classifier"):
|
|
295
294
|
if so which calibration (sigmoid or isotonic) might help fix this.
|
296
295
|
For more details, see https://scikit-learn.org/stable/auto_examples/calibration/plot_calibration_curve.html.
|
297
296
|
|
298
|
-
Should only be called with a fitted
|
297
|
+
Should only be called with a fitted classifier (otherwise an error is thrown).
|
299
298
|
|
300
299
|
Please note this function fits variations of the model on the training set when called.
|
301
300
|
|
wandb/sklearn/plot/clusterer.py
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
"""Define plots for clustering models built with scikit-learn."""
|
2
|
+
|
2
3
|
from warnings import simplefilter
|
3
4
|
|
4
5
|
import pandas as pd
|
@@ -24,7 +25,7 @@ def clusterer(model, X_train, cluster_labels, labels=None, model_name="Clusterer
|
|
24
25
|
X_train: (arr) Training set features.
|
25
26
|
cluster_labels: (list) Names for cluster labels. Makes plots easier to read
|
26
27
|
by replacing cluster indexes with corresponding names.
|
27
|
-
labels: (list) Named labels for target
|
28
|
+
labels: (list) Named labels for target variable (y). Makes plots easier to
|
28
29
|
read by replacing target values with corresponding index.
|
29
30
|
For example if `labels=['dog', 'cat', 'owl']` all 0s are
|
30
31
|
replaced by dog, 1s by cat.
|
wandb/sklearn/plot/regressor.py
CHANGED
wandb/sklearn/plot/shared.py
CHANGED
wandb/sklearn/utils.py
CHANGED
wandb/testing/relay.py
CHANGED
@@ -586,11 +586,11 @@ class InjectedResponse:
|
|
586
586
|
|
587
587
|
|
588
588
|
class RelayControlProtocol(Protocol):
|
589
|
-
def process(self, request: "flask.Request") -> None:
|
590
|
-
... # pragma: no cover
|
589
|
+
def process(self, request: "flask.Request") -> None: ... # pragma: no cover
|
591
590
|
|
592
|
-
def control(
|
593
|
-
|
591
|
+
def control(
|
592
|
+
self, request: "flask.Request"
|
593
|
+
) -> Mapping[str, str]: ... # pragma: no cover
|
594
594
|
|
595
595
|
|
596
596
|
class RelayServer:
|
wandb/trigger.py
CHANGED
wandb/util.py
CHANGED
@@ -11,6 +11,7 @@ import logging
|
|
11
11
|
import math
|
12
12
|
import numbers
|
13
13
|
import os
|
14
|
+
import pathlib
|
14
15
|
import platform
|
15
16
|
import queue
|
16
17
|
import random
|
@@ -43,7 +44,6 @@ from typing import (
|
|
43
44
|
Mapping,
|
44
45
|
Optional,
|
45
46
|
Sequence,
|
46
|
-
Set,
|
47
47
|
TextIO,
|
48
48
|
Tuple,
|
49
49
|
TypeVar,
|
@@ -55,7 +55,13 @@ import yaml
|
|
55
55
|
|
56
56
|
import wandb
|
57
57
|
import wandb.env
|
58
|
-
from wandb.errors import
|
58
|
+
from wandb.errors import (
|
59
|
+
AuthenticationError,
|
60
|
+
CommError,
|
61
|
+
UsageError,
|
62
|
+
WandbCoreNotAvailableError,
|
63
|
+
term,
|
64
|
+
)
|
59
65
|
from wandb.sdk.internal.thread_local_settings import _thread_local_api_settings
|
60
66
|
from wandb.sdk.lib import filesystem, runid
|
61
67
|
from wandb.sdk.lib.json_util import dump, dumps
|
@@ -537,50 +543,41 @@ def _numpy_generic_convert(obj: Any) -> Any:
|
|
537
543
|
return obj
|
538
544
|
|
539
545
|
|
540
|
-
def
|
546
|
+
def _sanitize_numpy_keys(
|
541
547
|
d: Dict,
|
542
|
-
|
543
|
-
|
544
|
-
|
545
|
-
) -> Generator[Tuple[Tuple[Any, ...], Any], None, None]:
|
546
|
-
"""Recursively find all keys that satisfies a match function.
|
548
|
+
visited: Optional[Dict[int, Dict]] = None,
|
549
|
+
) -> Tuple[Dict, bool]:
|
550
|
+
"""Returns a dictionary where all NumPy keys are converted.
|
547
551
|
|
548
552
|
Args:
|
549
|
-
|
550
|
-
match_fn: The function to determine if the key is a match.
|
551
|
-
visited: Keep track of visited nodes so we dont recurse forever.
|
552
|
-
key_path: Keep track of all the keys to get to the current node.
|
553
|
+
d: The dictionary to sanitize.
|
553
554
|
|
554
|
-
|
555
|
-
|
555
|
+
Returns:
|
556
|
+
A sanitized dictionary, and a boolean indicating whether anything was
|
557
|
+
changed.
|
556
558
|
"""
|
559
|
+
out: Dict[Any, Any] = dict()
|
560
|
+
converted = False
|
561
|
+
|
562
|
+
# Work with recursive dictionaries: if a dictionary has already been
|
563
|
+
# converted, reuse its converted value to retain the recursive structure
|
564
|
+
# of the input.
|
557
565
|
if visited is None:
|
558
|
-
visited =
|
559
|
-
|
560
|
-
|
561
|
-
|
562
|
-
for key, value in d.items():
|
563
|
-
if match_fn(key):
|
564
|
-
yield key_path, key
|
565
|
-
if isinstance(value, dict):
|
566
|
-
yield from _find_all_matching_keys(
|
567
|
-
value,
|
568
|
-
match_fn,
|
569
|
-
visited=visited,
|
570
|
-
key_path=tuple(list(key_path) + [key]),
|
571
|
-
)
|
566
|
+
visited = {id(d): out}
|
567
|
+
elif id(d) in visited:
|
568
|
+
return visited[id(d)], False
|
569
|
+
visited[id(d)] = out
|
572
570
|
|
571
|
+
for key, value in d.items():
|
572
|
+
if isinstance(value, dict):
|
573
|
+
value, converted_value = _sanitize_numpy_keys(value, visited)
|
574
|
+
converted |= converted_value
|
575
|
+
if isinstance(key, np.generic):
|
576
|
+
key = _numpy_generic_convert(key)
|
577
|
+
converted = True
|
578
|
+
out[key] = value
|
573
579
|
|
574
|
-
|
575
|
-
np_keys = list(_find_all_matching_keys(d, lambda k: isinstance(k, np.generic)))
|
576
|
-
if not np_keys:
|
577
|
-
return d, False
|
578
|
-
for key_path, key in np_keys:
|
579
|
-
ptr = d
|
580
|
-
for k in key_path:
|
581
|
-
ptr = ptr[k]
|
582
|
-
ptr[_numpy_generic_convert(key)] = ptr.pop(key)
|
583
|
-
return d, True
|
580
|
+
return out, converted
|
584
581
|
|
585
582
|
|
586
583
|
def json_friendly( # noqa: C901
|
@@ -1842,15 +1839,6 @@ def sample_with_exponential_decay_weights(
|
|
1842
1839
|
return sampled_xs, sampled_ys, sampled_keys
|
1843
1840
|
|
1844
1841
|
|
1845
|
-
def get_core_path() -> str:
|
1846
|
-
core_path: str = os.environ.get("_WANDB_CORE_PATH", "")
|
1847
|
-
wandb_core = get_module("wandb_core")
|
1848
|
-
if not core_path and wandb_core:
|
1849
|
-
_check_wandb_core_version_compatibility(wandb_core.__version__)
|
1850
|
-
core_path = wandb_core.get_core_path()
|
1851
|
-
return core_path
|
1852
|
-
|
1853
|
-
|
1854
1842
|
@dataclasses.dataclass(frozen=True)
|
1855
1843
|
class InstalledDistribution:
|
1856
1844
|
"""An installed distribution.
|
@@ -1888,15 +1876,40 @@ def parse_version(version: str) -> "packaging.version.Version":
|
|
1888
1876
|
try:
|
1889
1877
|
from packaging.version import parse as parse_version # type: ignore
|
1890
1878
|
except ImportError:
|
1891
|
-
from pkg_resources import parse_version
|
1879
|
+
from pkg_resources import parse_version # type: ignore[assignment]
|
1892
1880
|
|
1893
1881
|
return parse_version(version)
|
1894
1882
|
|
1895
1883
|
|
1896
|
-
def
|
1897
|
-
"""
|
1898
|
-
|
1899
|
-
|
1900
|
-
|
1901
|
-
|
1884
|
+
def get_core_path() -> str:
|
1885
|
+
"""Returns the path to the wandb-core binary.
|
1886
|
+
|
1887
|
+
The path can be set explicitly via the _WANDB_CORE_PATH environment
|
1888
|
+
variable. Otherwise, the path to the binary in the current package
|
1889
|
+
is returned.
|
1890
|
+
|
1891
|
+
Returns:
|
1892
|
+
str: The path to the wandb-core package.
|
1893
|
+
|
1894
|
+
Raises:
|
1895
|
+
WandbCoreNotAvailableError: If wandb-core was not built for the current system.
|
1896
|
+
"""
|
1897
|
+
# NOTE: Environment variable _WANDB_CORE_PATH is a temporary development feature
|
1898
|
+
# to assist in running the core service from a live development directory.
|
1899
|
+
path_from_env: str = os.environ.get("_WANDB_CORE_PATH", "")
|
1900
|
+
if path_from_env:
|
1901
|
+
wandb.termwarn(
|
1902
|
+
f"Using wandb-core from path `_WANDB_CORE_PATH={path_from_env}`. "
|
1903
|
+
"This is a development feature and may not work as expected."
|
1902
1904
|
)
|
1905
|
+
return path_from_env
|
1906
|
+
|
1907
|
+
bin_path = pathlib.Path(__file__).parent / "bin" / "wandb-core"
|
1908
|
+
if not bin_path.exists():
|
1909
|
+
raise WandbCoreNotAvailableError(
|
1910
|
+
f"Looks like wandb-core is not compiled for your system ({platform.platform()}):"
|
1911
|
+
" Please contact support at support@wandb.com to request `wandb-core`"
|
1912
|
+
" support for your system."
|
1913
|
+
)
|
1914
|
+
|
1915
|
+
return str(bin_path)
|
wandb/wandb_controller.py
CHANGED
@@ -20,7 +20,7 @@ Example:
|
|
20
20
|
tuner = wandb.controller()
|
21
21
|
tuner.configure(sweep_config)
|
22
22
|
tuner.create()
|
23
|
-
# (3) create by constructing
|
23
|
+
# (3) create by constructing programmatic sweep configuration
|
24
24
|
tuner = wandb.controller()
|
25
25
|
tuner.configure_search('random')
|
26
26
|
tuner.configure_program('train-dummy.py')
|
@@ -47,7 +47,6 @@ Example:
|
|
47
47
|
tuner.stop_runs(runs)
|
48
48
|
"""
|
49
49
|
|
50
|
-
|
51
50
|
import json
|
52
51
|
import os
|
53
52
|
import random
|
@@ -128,7 +127,7 @@ class _WandbController:
|
|
128
127
|
"""
|
129
128
|
|
130
129
|
def __init__(self, sweep_id_or_config=None, entity=None, project=None):
|
131
|
-
# sweep id configured in
|
130
|
+
# sweep id configured in constructor
|
132
131
|
self._sweep_id: Optional[str] = None
|
133
132
|
|
134
133
|
# configured parameters
|