flwr-nightly 1.22.0.dev20250916__tar.gz → 1.22.0.dev20250917__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.
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/PKG-INFO +1 -1
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/app.py +2 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/new.py +2 -2
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +1 -1
- flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +75 -0
- flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +92 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +1 -23
- flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +73 -0
- flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +78 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -14
- flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +43 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +3 -3
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +1 -1
- flwr_nightly-1.22.0.dev20250917/py/flwr/cli/pull.py +100 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/utils.py +17 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/constant.py +2 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2.py +7 -3
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2.pyi +24 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2_grpc.py +34 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2_grpc.pyi +13 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/app.py +13 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/__init__.py +2 -0
- flwr_nightly-1.22.0.dev20250917/py/flwr/serverapp/strategy/fedprox.py +174 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/app.py +1 -1
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/run_simulation.py +25 -30
- flwr_nightly-1.22.0.dev20250917/py/flwr/superlink/artifact_provider/__init__.py +22 -0
- flwr_nightly-1.22.0.dev20250917/py/flwr/superlink/artifact_provider/artifact_provider.py +37 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_grpc.py +3 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_servicer.py +59 -2
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/pyproject.toml +1 -1
- flwr_nightly-1.22.0.dev20250916/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -58
- flwr_nightly-1.22.0.dev20250916/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -126
- flwr_nightly-1.22.0.dev20250916/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -94
- flwr_nightly-1.22.0.dev20250916/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -83
- flwr_nightly-1.22.0.dev20250916/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -45
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/README.md +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/error.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/exception.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/metadata.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/auth_plugin/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/auth_plugin/oidc_cli_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/build.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/cli_user_auth_interceptor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/config_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/constant.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/example.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/install.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/log.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/login/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/login/login.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/ls.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.pytorch_legacy_api.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.pytorch_legacy_api.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/run/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/run/run.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/stop.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/client.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/client_app.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/clientapp/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/clientapp/utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/dpfedavg_numpy_client.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_adapter_client/connection.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/connection.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/message_handler/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/centraldp_mods.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/comms_mods.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/localdp_mod.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/numpy_client.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/rest_client/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/rest_client/connection.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/run_info_store.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/typing.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/clientapp/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/clientapp/mod/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/clientapp/mod/centraldp_mods.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/address.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/args.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/auth_plugin/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/auth_plugin/auth_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/config.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/context.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/date.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/differential_privacy.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/differential_privacy_constants.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/dp.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/event_log_plugin/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/event_log_plugin/event_log_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/exit.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/exit_code.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/exit_handler.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/signal_handler.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/heartbeat.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/inflatable.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/inflatable_protobuf_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/inflatable_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/logger.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/message.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/object_ref.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/parameter.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/pyproject.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/array.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/arraychunk.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/arrayrecord.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/configrecord.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/conversion_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/metricrecord.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/recorddict.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/typeddict.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/recorddict_compat.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/retry_invoker.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/quantization.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/serde.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/serde_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/telemetry.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/typing.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/version.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/app.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/grpc_client/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/grpc_client/connection.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/common/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/server/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/server/app.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/simulation/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/py.typed +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/client_manager.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/client_proxy.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/app.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/app_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/grid_client_proxy.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/legacy_context.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/criterion.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/fleet_event_log_interceptor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/grid.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/grpc_grid.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/inmemory_grid.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/history.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/run_serverapp.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/server.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/server_app.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/server_config.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/serverapp/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/serverapp/app.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/serverapp_components.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/aggregate.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/bulyan.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedadagrad.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedadam.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedavg.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedavg_android.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedavgm.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedmedian.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedopt.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedprox.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedyogi.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/krum.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/qfedavg.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/strategy.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/serverappio/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/serverappio/serverappio_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/serverappio/serverappio_servicer.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/simulation/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/typing.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/utils/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/utils/tensorboard.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/utils/validator.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/constant.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/default_workflows.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/dp_fixed_clipping.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/exception.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/dp_fixed_clipping.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedadagrad.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedadam.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedavg.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedavgm.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedmedian.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedopt.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedtrimmedavg.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedxgb_bagging.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedyogi.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/result.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/strategy.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/strategy_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/strategy_utils_tests.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/legacy_app.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/simulationio_connection.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/app_utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/cli/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/cli/flower_superexec.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/corestate/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/corestate/corestate.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/disk_ffs.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/ffs.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/ffs_factory.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/grpc_health/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/grpc_health/health_server.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/grpc_health/simple_health_servicer.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/license_plugin/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/license_plugin/license_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/in_memory_object_store.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/object_store.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/object_store_factory.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/base_exec_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/clientapp_exec_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/exec_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/serverapp_exec_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/simulation_exec_plugin.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/run_superexec.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/utils.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_event_log_interceptor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_license_interceptor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_user_auth_interceptor.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/cli/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/cli/flower_supernode.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/cli/flwr_clientapp.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/in_memory_nodestate.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/nodestate.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/nodestate_factory.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/runtime/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/runtime/run_clientapp.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/servicer/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/servicer/clientappio/__init__.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/servicer/clientappio/clientappio_servicer.py +0 -0
- {flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/start_client_internal.py +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.3
|
2
2
|
Name: flwr-nightly
|
3
|
-
Version: 1.22.0.
|
3
|
+
Version: 1.22.0.dev20250917
|
4
4
|
Summary: Flower: A Friendly Federated AI Framework
|
5
5
|
License: Apache-2.0
|
6
6
|
Keywords: Artificial Intelligence,Federated AI,Federated Analytics,Federated Evaluation,Federated Learning,Flower,Machine Learning
|
@@ -25,6 +25,7 @@ from .log import log
|
|
25
25
|
from .login import login
|
26
26
|
from .ls import ls
|
27
27
|
from .new import new
|
28
|
+
from .pull import pull
|
28
29
|
from .run import run
|
29
30
|
from .stop import stop
|
30
31
|
|
@@ -46,6 +47,7 @@ app.command()(log)
|
|
46
47
|
app.command()(ls)
|
47
48
|
app.command()(stop)
|
48
49
|
app.command()(login)
|
50
|
+
app.command()(pull)
|
49
51
|
|
50
52
|
typer_click_object = get_command(app)
|
51
53
|
|
@@ -201,7 +201,7 @@ def new(
|
|
201
201
|
}
|
202
202
|
|
203
203
|
# Challenge specific context
|
204
|
-
|
204
|
+
fraction_train = "0.2" if llm_challenge_str == "code" else "0.1"
|
205
205
|
if llm_challenge_str == "generalnlp":
|
206
206
|
challenge_name = "General NLP"
|
207
207
|
num_clients = "20"
|
@@ -220,7 +220,7 @@ def new(
|
|
220
220
|
dataset_name = "flwrlabs/code-alpaca-20k"
|
221
221
|
|
222
222
|
context["llm_challenge_str"] = llm_challenge_str
|
223
|
-
context["
|
223
|
+
context["fraction_train"] = fraction_train
|
224
224
|
context["challenge_name"] = challenge_name
|
225
225
|
context["num_clients"] = num_clients
|
226
226
|
context["dataset_name"] = dataset_name
|
@@ -26,7 +26,7 @@ pip install -e .
|
|
26
26
|
## Experimental setup
|
27
27
|
|
28
28
|
The dataset is divided into $num_clients partitions in an IID fashion, a partition is assigned to each ClientApp.
|
29
|
-
We randomly sample a fraction ($
|
29
|
+
We randomly sample a fraction ($fraction_train) of the total nodes to participate in each round, for a total of `200` rounds.
|
30
30
|
All settings are defined in `pyproject.toml`.
|
31
31
|
|
32
32
|
> [!IMPORTANT]
|
@@ -0,0 +1,75 @@
|
|
1
|
+
"""$project_name: A Flower Baseline."""
|
2
|
+
|
3
|
+
import torch
|
4
|
+
from flwr.app import ArrayRecord, Context, Message, MetricRecord, RecordDict
|
5
|
+
from flwr.clientapp import ClientApp
|
6
|
+
|
7
|
+
from $import_name.dataset import load_data
|
8
|
+
from $import_name.model import Net
|
9
|
+
from $import_name.model import test as test_fn
|
10
|
+
from $import_name.model import train as train_fn
|
11
|
+
|
12
|
+
# Flower ClientApp
|
13
|
+
app = ClientApp()
|
14
|
+
|
15
|
+
|
16
|
+
@app.train()
|
17
|
+
def train(msg: Message, context: Context):
|
18
|
+
"""Train the model on local data."""
|
19
|
+
|
20
|
+
# Load the model and initialize it with the received weights
|
21
|
+
model = Net()
|
22
|
+
model.load_state_dict(msg.content["arrays"].to_torch_state_dict())
|
23
|
+
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
|
24
|
+
|
25
|
+
# Load the data
|
26
|
+
partition_id = int(context.node_config["partition-id"])
|
27
|
+
num_partitions = int(context.node_config["num-partitions"])
|
28
|
+
trainloader, _ = load_data(partition_id, num_partitions)
|
29
|
+
local_epochs = context.run_config["local-epochs"]
|
30
|
+
|
31
|
+
# Call the training function
|
32
|
+
train_loss = train_fn(
|
33
|
+
model,
|
34
|
+
trainloader,
|
35
|
+
local_epochs,
|
36
|
+
device,
|
37
|
+
)
|
38
|
+
|
39
|
+
# Construct and return reply Message
|
40
|
+
model_record = ArrayRecord(model.state_dict())
|
41
|
+
metrics = {
|
42
|
+
"train_loss": train_loss,
|
43
|
+
"num-examples": len(trainloader.dataset),
|
44
|
+
}
|
45
|
+
metric_record = MetricRecord(metrics)
|
46
|
+
content = RecordDict({"arrays": model_record, "metrics": metric_record})
|
47
|
+
return Message(content=content, reply_to=msg)
|
48
|
+
|
49
|
+
|
50
|
+
@app.evaluate()
|
51
|
+
def evaluate(msg: Message, context: Context):
|
52
|
+
"""Evaluate the model on local data."""
|
53
|
+
|
54
|
+
# Load the model and initialize it with the received weights
|
55
|
+
model = Net()
|
56
|
+
model.load_state_dict(msg.content["arrays"].to_torch_state_dict())
|
57
|
+
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
|
58
|
+
|
59
|
+
# Load the data
|
60
|
+
partition_id = int(context.node_config["partition-id"])
|
61
|
+
num_partitions = int(context.node_config["num-partitions"])
|
62
|
+
_, valloader = load_data(partition_id, num_partitions)
|
63
|
+
|
64
|
+
# Call the evaluation function
|
65
|
+
eval_loss, eval_acc = test_fn(model, valloader, device)
|
66
|
+
|
67
|
+
# Construct and return reply Message
|
68
|
+
metrics = {
|
69
|
+
"eval_loss": eval_loss,
|
70
|
+
"eval_acc": eval_acc,
|
71
|
+
"num-examples": len(valloader.dataset),
|
72
|
+
}
|
73
|
+
metric_record = MetricRecord(metrics)
|
74
|
+
content = RecordDict({"metrics": metric_record})
|
75
|
+
return Message(content=content, reply_to=msg)
|
flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl
ADDED
@@ -0,0 +1,92 @@
|
|
1
|
+
"""$project_name: A Flower / FlowerTune app."""
|
2
|
+
|
3
|
+
import os
|
4
|
+
import warnings
|
5
|
+
|
6
|
+
from flwr.app import ArrayRecord, Context, Message, MetricRecord, RecordDict
|
7
|
+
from flwr.clientapp import ClientApp
|
8
|
+
from flwr.common.config import unflatten_dict
|
9
|
+
from omegaconf import DictConfig
|
10
|
+
from peft import get_peft_model_state_dict, set_peft_model_state_dict
|
11
|
+
from transformers import TrainingArguments
|
12
|
+
from trl import SFTTrainer
|
13
|
+
|
14
|
+
from $import_name.dataset import (
|
15
|
+
get_tokenizer_and_data_collator_and_propt_formatting,
|
16
|
+
load_data,
|
17
|
+
replace_keys,
|
18
|
+
)
|
19
|
+
from $import_name.models import cosine_annealing, get_model
|
20
|
+
|
21
|
+
# Avoid warnings
|
22
|
+
os.environ["TOKENIZERS_PARALLELISM"] = "true"
|
23
|
+
os.environ["RAY_DISABLE_DOCKER_CPU_WARNING"] = "1"
|
24
|
+
warnings.filterwarnings("ignore", category=UserWarning)
|
25
|
+
|
26
|
+
|
27
|
+
# Avoid warnings
|
28
|
+
os.environ["TOKENIZERS_PARALLELISM"] = "true"
|
29
|
+
os.environ["RAY_DISABLE_DOCKER_CPU_WARNING"] = "1"
|
30
|
+
warnings.filterwarnings("ignore", category=UserWarning)
|
31
|
+
|
32
|
+
|
33
|
+
# Flower ClientApp
|
34
|
+
app = ClientApp()
|
35
|
+
|
36
|
+
|
37
|
+
@app.train()
|
38
|
+
def train(msg: Message, context: Context):
|
39
|
+
"""Train the model on local data."""
|
40
|
+
# Parse config
|
41
|
+
partition_id = context.node_config["partition-id"]
|
42
|
+
num_partitions = context.node_config["num-partitions"]
|
43
|
+
num_rounds = context.run_config["num-server-rounds"]
|
44
|
+
cfg = DictConfig(replace_keys(unflatten_dict(context.run_config)))
|
45
|
+
training_arguments = TrainingArguments(**cfg.train.training_arguments)
|
46
|
+
|
47
|
+
# Let's get the client partition
|
48
|
+
trainset = load_data(partition_id, num_partitions, cfg.static.dataset.name)
|
49
|
+
(
|
50
|
+
tokenizer,
|
51
|
+
data_collator,
|
52
|
+
formatting_prompts_func,
|
53
|
+
) = get_tokenizer_and_data_collator_and_propt_formatting(cfg.model.name)
|
54
|
+
|
55
|
+
# Load the model and initialize it with the received weights
|
56
|
+
model = get_model(cfg.model)
|
57
|
+
set_peft_model_state_dict(model, msg.content["arrays"].to_torch_state_dict())
|
58
|
+
|
59
|
+
# Set learning rate for current round
|
60
|
+
new_lr = cosine_annealing(
|
61
|
+
msg.content["config"]["server-round"],
|
62
|
+
num_rounds,
|
63
|
+
cfg.train.learning_rate_max,
|
64
|
+
cfg.train.learning_rate_min,
|
65
|
+
)
|
66
|
+
|
67
|
+
training_arguments.learning_rate = new_lr
|
68
|
+
training_arguments.output_dir = msg.content["config"]["save_path"]
|
69
|
+
|
70
|
+
# Construct trainer
|
71
|
+
trainer = SFTTrainer(
|
72
|
+
model=model,
|
73
|
+
tokenizer=tokenizer,
|
74
|
+
args=training_arguments,
|
75
|
+
max_seq_length=cfg.train.seq_length,
|
76
|
+
train_dataset=trainset,
|
77
|
+
formatting_func=formatting_prompts_func,
|
78
|
+
data_collator=data_collator,
|
79
|
+
)
|
80
|
+
|
81
|
+
# Do local training
|
82
|
+
results = trainer.train()
|
83
|
+
|
84
|
+
# Construct and return reply Message
|
85
|
+
model_record = ArrayRecord(get_peft_model_state_dict(model))
|
86
|
+
metrics = {
|
87
|
+
"train_loss": results.training_loss,
|
88
|
+
"num-examples": len(trainset),
|
89
|
+
}
|
90
|
+
metric_record = MetricRecord(metrics)
|
91
|
+
content = RecordDict({"arrays": model_record, "metrics": metric_record})
|
92
|
+
return Message(content=content, reply_to=msg)
|
@@ -4,18 +4,10 @@ import math
|
|
4
4
|
|
5
5
|
import torch
|
6
6
|
from omegaconf import DictConfig
|
7
|
-
from
|
8
|
-
from peft import (
|
9
|
-
LoraConfig,
|
10
|
-
get_peft_model,
|
11
|
-
get_peft_model_state_dict,
|
12
|
-
set_peft_model_state_dict,
|
13
|
-
)
|
7
|
+
from peft import LoraConfig, get_peft_model
|
14
8
|
from peft.utils import prepare_model_for_kbit_training
|
15
9
|
from transformers import AutoModelForCausalLM, BitsAndBytesConfig
|
16
10
|
|
17
|
-
from flwr.common.typing import NDArrays
|
18
|
-
|
19
11
|
|
20
12
|
def cosine_annealing(
|
21
13
|
current_round: int,
|
@@ -62,17 +54,3 @@ def get_model(model_cfg: DictConfig):
|
|
62
54
|
model.config.use_cache = False
|
63
55
|
|
64
56
|
return get_peft_model(model, peft_config)
|
65
|
-
|
66
|
-
|
67
|
-
def set_parameters(model, parameters: NDArrays) -> None:
|
68
|
-
"""Change the parameters of the model using the given ones."""
|
69
|
-
peft_state_dict_keys = get_peft_model_state_dict(model).keys()
|
70
|
-
params_dict = zip(peft_state_dict_keys, parameters)
|
71
|
-
state_dict = OrderedDict({k: torch.Tensor(v) for k, v in params_dict})
|
72
|
-
set_peft_model_state_dict(model, state_dict)
|
73
|
-
|
74
|
-
|
75
|
-
def get_parameters(model) -> NDArrays:
|
76
|
-
"""Return the parameters of the current net."""
|
77
|
-
state_dict = get_peft_model_state_dict(model)
|
78
|
-
return [val.cpu().numpy() for _, val in state_dict.items()]
|
flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl
ADDED
@@ -0,0 +1,73 @@
|
|
1
|
+
"""$project_name: A Flower / FlowerTune app."""
|
2
|
+
|
3
|
+
import os
|
4
|
+
from datetime import datetime
|
5
|
+
|
6
|
+
from flwr.app import ArrayRecord, ConfigRecord, Context, MetricRecord
|
7
|
+
from flwr.common.config import unflatten_dict
|
8
|
+
from flwr.serverapp import Grid, ServerApp
|
9
|
+
from omegaconf import DictConfig
|
10
|
+
from peft import get_peft_model_state_dict, set_peft_model_state_dict
|
11
|
+
|
12
|
+
from $import_name.dataset import replace_keys
|
13
|
+
from $import_name.models import get_model
|
14
|
+
from $import_name.strategy import FlowerTuneLlm
|
15
|
+
|
16
|
+
# Create ServerApp
|
17
|
+
app = ServerApp()
|
18
|
+
|
19
|
+
|
20
|
+
@app.main()
|
21
|
+
def main(grid: Grid, context: Context) -> None:
|
22
|
+
"""Main entry point for the ServerApp."""
|
23
|
+
# Create output directory given current timestamp
|
24
|
+
current_time = datetime.now()
|
25
|
+
folder_name = current_time.strftime("%Y-%m-%d_%H-%M-%S")
|
26
|
+
save_path = os.path.join(os.getcwd(), f"results/{folder_name}")
|
27
|
+
os.makedirs(save_path, exist_ok=True)
|
28
|
+
|
29
|
+
# Read from config
|
30
|
+
num_rounds = context.run_config["num-server-rounds"]
|
31
|
+
cfg = DictConfig(replace_keys(unflatten_dict(context.run_config)))
|
32
|
+
|
33
|
+
# Get initial model weights
|
34
|
+
init_model = get_model(cfg.model)
|
35
|
+
arrays = ArrayRecord(get_peft_model_state_dict(init_model))
|
36
|
+
|
37
|
+
# Define strategy
|
38
|
+
strategy = FlowerTuneLlm(
|
39
|
+
fraction_train=cfg.strategy.fraction_train,
|
40
|
+
fraction_evaluate=cfg.strategy.fraction_evaluate,
|
41
|
+
)
|
42
|
+
|
43
|
+
# Start strategy, run FedAvg for `num_rounds`
|
44
|
+
strategy.start(
|
45
|
+
grid=grid,
|
46
|
+
initial_arrays=arrays,
|
47
|
+
train_config=ConfigRecord({"save_path": save_path}),
|
48
|
+
num_rounds=num_rounds,
|
49
|
+
evaluate_fn=get_evaluate_fn(
|
50
|
+
cfg.model, cfg.train.save_every_round, num_rounds, save_path
|
51
|
+
),
|
52
|
+
)
|
53
|
+
|
54
|
+
|
55
|
+
# Get function that will be executed by the strategy
|
56
|
+
# Here we use it to save global model checkpoints
|
57
|
+
def get_evaluate_fn(model_cfg, save_every_round, total_round, save_path):
|
58
|
+
"""Return an evaluation function for saving global model."""
|
59
|
+
|
60
|
+
def evaluate(server_round: int, arrays: ArrayRecord) -> MetricRecord:
|
61
|
+
# Save model
|
62
|
+
if server_round != 0 and (
|
63
|
+
server_round == total_round or server_round % save_every_round == 0
|
64
|
+
):
|
65
|
+
# Init model
|
66
|
+
model = get_model(model_cfg)
|
67
|
+
set_peft_model_state_dict(model, arrays.to_torch_state_dict())
|
68
|
+
|
69
|
+
model.save_pretrained(f"{save_path}/peft_{server_round}")
|
70
|
+
|
71
|
+
return MetricRecord()
|
72
|
+
|
73
|
+
return evaluate
|
@@ -0,0 +1,78 @@
|
|
1
|
+
"""$project_name: A Flower / FlowerTune app."""
|
2
|
+
|
3
|
+
from collections.abc import Iterable
|
4
|
+
from logging import INFO, WARN
|
5
|
+
from typing import Optional
|
6
|
+
|
7
|
+
from flwr.app import ArrayRecord, ConfigRecord, Message, MetricRecord
|
8
|
+
from flwr.common import log
|
9
|
+
from flwr.serverapp import Grid
|
10
|
+
from flwr.serverapp.strategy import FedAvg
|
11
|
+
|
12
|
+
|
13
|
+
class FlowerTuneLlm(FedAvg):
|
14
|
+
"""Customised FedAvg strategy implementation.
|
15
|
+
|
16
|
+
This class behaves just like FedAvg but also tracks the communication
|
17
|
+
costs associated with `train` over FL rounds.
|
18
|
+
"""
|
19
|
+
def __init__(self, **kwargs):
|
20
|
+
super().__init__(**kwargs)
|
21
|
+
self.comm_tracker = CommunicationTracker()
|
22
|
+
|
23
|
+
def configure_train(
|
24
|
+
self, server_round: int, arrays: ArrayRecord, config: ConfigRecord, grid: Grid
|
25
|
+
) -> Iterable[Message]:
|
26
|
+
"""Configure the next round of training."""
|
27
|
+
messages = super().configure_train(server_round, arrays, config, grid)
|
28
|
+
|
29
|
+
# Track communication costs
|
30
|
+
self.comm_tracker.track(messages)
|
31
|
+
|
32
|
+
return messages
|
33
|
+
|
34
|
+
def aggregate_train(
|
35
|
+
self,
|
36
|
+
server_round: int,
|
37
|
+
replies: Iterable[Message],
|
38
|
+
) -> tuple[Optional[ArrayRecord], Optional[MetricRecord]]:
|
39
|
+
"""Aggregate ArrayRecords and MetricRecords in the received Messages."""
|
40
|
+
# Track communication costs
|
41
|
+
self.comm_tracker.track(replies)
|
42
|
+
|
43
|
+
arrays, metrics = super().aggregate_train(server_round, replies)
|
44
|
+
|
45
|
+
return arrays, metrics
|
46
|
+
|
47
|
+
|
48
|
+
class CommunicationTracker:
|
49
|
+
"""Communication costs tracker over FL rounds."""
|
50
|
+
def __init__(self):
|
51
|
+
self.curr_comm_cost = 0.0
|
52
|
+
|
53
|
+
def track(self, messages: Iterable[Message]):
|
54
|
+
comm_cost = (
|
55
|
+
sum(
|
56
|
+
record.count_bytes()
|
57
|
+
for msg in messages
|
58
|
+
if msg.has_content()
|
59
|
+
for record in msg.content.array_records.values()
|
60
|
+
)
|
61
|
+
/ 1024**2
|
62
|
+
)
|
63
|
+
|
64
|
+
self.curr_comm_cost += comm_cost
|
65
|
+
log(
|
66
|
+
INFO,
|
67
|
+
"Communication budget: used %.2f MB (+%.2f MB this round) / 200,000 MB",
|
68
|
+
self.curr_comm_cost,
|
69
|
+
comm_cost,
|
70
|
+
)
|
71
|
+
|
72
|
+
if self.curr_comm_cost > 2e5:
|
73
|
+
log(
|
74
|
+
WARN,
|
75
|
+
"The accumulated communication cost has exceeded 200,000 MB. "
|
76
|
+
"Please consider reducing it if you plan to participate "
|
77
|
+
"FlowerTune LLM Leaderboard.",
|
78
|
+
)
|
@@ -1,7 +1,5 @@
|
|
1
1
|
"""$project_name: A Flower Baseline."""
|
2
2
|
|
3
|
-
from collections import OrderedDict
|
4
|
-
|
5
3
|
import torch
|
6
4
|
import torch.nn.functional as F
|
7
5
|
from torch import nn
|
@@ -66,15 +64,3 @@ def test(net, testloader, device):
|
|
66
64
|
accuracy = correct / len(testloader.dataset)
|
67
65
|
loss = loss / len(testloader)
|
68
66
|
return loss, accuracy
|
69
|
-
|
70
|
-
|
71
|
-
def get_weights(net):
|
72
|
-
"""Extract model parameters as numpy arrays from state_dict."""
|
73
|
-
return [val.cpu().numpy() for _, val in net.state_dict().items()]
|
74
|
-
|
75
|
-
|
76
|
-
def set_weights(net, parameters):
|
77
|
-
"""Apply parameters to an existing model."""
|
78
|
-
params_dict = zip(net.state_dict().keys(), parameters)
|
79
|
-
state_dict = OrderedDict({k: torch.from_numpy(v) for k, v in params_dict})
|
80
|
-
net.load_state_dict(state_dict, strict=True)
|
@@ -0,0 +1,43 @@
|
|
1
|
+
"""$project_name: A Flower Baseline."""
|
2
|
+
|
3
|
+
import torch
|
4
|
+
from flwr.app import ArrayRecord, Context
|
5
|
+
from flwr.serverapp import Grid, ServerApp
|
6
|
+
from flwr.serverapp.strategy import FedAvg
|
7
|
+
|
8
|
+
from $import_name.model import Net
|
9
|
+
|
10
|
+
# Create ServerApp
|
11
|
+
app = ServerApp()
|
12
|
+
|
13
|
+
|
14
|
+
@app.main()
|
15
|
+
def main(grid: Grid, context: Context) -> None:
|
16
|
+
"""Main entry point for the ServerApp."""
|
17
|
+
|
18
|
+
# Read from config
|
19
|
+
num_rounds = context.run_config["num-server-rounds"]
|
20
|
+
fraction_train = context.run_config["fraction-train"]
|
21
|
+
|
22
|
+
# Load global model
|
23
|
+
global_model = Net()
|
24
|
+
arrays = ArrayRecord(global_model.state_dict())
|
25
|
+
|
26
|
+
# Initialize FedAvg strategy
|
27
|
+
strategy = FedAvg(
|
28
|
+
fraction_train=fraction_train,
|
29
|
+
fraction_evaluate=1.0,
|
30
|
+
min_available_nodes=2,
|
31
|
+
)
|
32
|
+
|
33
|
+
# Start strategy, run FedAvg for `num_rounds`
|
34
|
+
result = strategy.start(
|
35
|
+
grid=grid,
|
36
|
+
initial_arrays=arrays,
|
37
|
+
num_rounds=num_rounds,
|
38
|
+
)
|
39
|
+
|
40
|
+
# Save final model to disk
|
41
|
+
print("\nSaving final model to disk...")
|
42
|
+
state_dict = result.arrays.to_torch_state_dict()
|
43
|
+
torch.save(state_dict, "final_model.pt")
|
@@ -16,8 +16,8 @@ license = "Apache-2.0"
|
|
16
16
|
dependencies = [
|
17
17
|
"flwr[simulation]>=1.22.0",
|
18
18
|
"flwr-datasets[vision]>=0.5.0",
|
19
|
-
"torch==2.
|
20
|
-
"torchvision==0.
|
19
|
+
"torch==2.8.0",
|
20
|
+
"torchvision==0.23.0",
|
21
21
|
]
|
22
22
|
|
23
23
|
[tool.hatch.metadata]
|
@@ -132,7 +132,7 @@ clientapp = "$import_name.client_app:app"
|
|
132
132
|
# Custom config values accessible via `context.run_config`
|
133
133
|
[tool.flwr.app.config]
|
134
134
|
num-server-rounds = 3
|
135
|
-
fraction-
|
135
|
+
fraction-train = 0.5
|
136
136
|
local-epochs = 1
|
137
137
|
|
138
138
|
# Default federation to use when running the app
|
@@ -61,7 +61,7 @@ train.training-arguments.save-steps = 1000
|
|
61
61
|
train.training-arguments.save-total-limit = 10
|
62
62
|
train.training-arguments.gradient-checkpointing = true
|
63
63
|
train.training-arguments.lr-scheduler-type = "constant"
|
64
|
-
strategy.fraction-
|
64
|
+
strategy.fraction-train = $fraction_train
|
65
65
|
strategy.fraction-evaluate = 0.0
|
66
66
|
num-server-rounds = 200
|
67
67
|
|
@@ -0,0 +1,100 @@
|
|
1
|
+
# Copyright 2025 Flower Labs GmbH. All Rights Reserved.
|
2
|
+
#
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
+
# you may not use this file except in compliance with the License.
|
5
|
+
# You may obtain a copy of the License at
|
6
|
+
#
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
+
#
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
+
# See the License for the specific language governing permissions and
|
13
|
+
# limitations under the License.
|
14
|
+
# ==============================================================================
|
15
|
+
"""Flower command line interface `pull` command."""
|
16
|
+
|
17
|
+
|
18
|
+
from pathlib import Path
|
19
|
+
from typing import Annotated, Optional
|
20
|
+
|
21
|
+
import typer
|
22
|
+
|
23
|
+
from flwr.cli.config_utils import (
|
24
|
+
exit_if_no_address,
|
25
|
+
load_and_validate,
|
26
|
+
process_loaded_project_config,
|
27
|
+
validate_federation_in_project_config,
|
28
|
+
)
|
29
|
+
from flwr.cli.constant import FEDERATION_CONFIG_HELP_MESSAGE
|
30
|
+
from flwr.common.constant import FAB_CONFIG_FILE
|
31
|
+
from flwr.proto.control_pb2 import ( # pylint: disable=E0611
|
32
|
+
PullArtifactsRequest,
|
33
|
+
PullArtifactsResponse,
|
34
|
+
)
|
35
|
+
from flwr.proto.control_pb2_grpc import ControlStub
|
36
|
+
|
37
|
+
from .utils import flwr_cli_grpc_exc_handler, init_channel, try_obtain_cli_auth_plugin
|
38
|
+
|
39
|
+
|
40
|
+
def pull( # pylint: disable=R0914
|
41
|
+
run_id: Annotated[
|
42
|
+
int,
|
43
|
+
typer.Option(
|
44
|
+
"--run-id",
|
45
|
+
help="Run ID to pull artifacts from.",
|
46
|
+
),
|
47
|
+
],
|
48
|
+
app: Annotated[
|
49
|
+
Path,
|
50
|
+
typer.Argument(help="Path of the Flower App to run."),
|
51
|
+
] = Path("."),
|
52
|
+
federation: Annotated[
|
53
|
+
Optional[str],
|
54
|
+
typer.Argument(help="Name of the federation."),
|
55
|
+
] = None,
|
56
|
+
federation_config_overrides: Annotated[
|
57
|
+
Optional[list[str]],
|
58
|
+
typer.Option(
|
59
|
+
"--federation-config",
|
60
|
+
help=FEDERATION_CONFIG_HELP_MESSAGE,
|
61
|
+
),
|
62
|
+
] = None,
|
63
|
+
) -> None:
|
64
|
+
"""Pull artifacts from a Flower run."""
|
65
|
+
typer.secho("Loading project configuration... ", fg=typer.colors.BLUE)
|
66
|
+
|
67
|
+
pyproject_path = app / FAB_CONFIG_FILE if app else None
|
68
|
+
config, errors, warnings = load_and_validate(path=pyproject_path)
|
69
|
+
config = process_loaded_project_config(config, errors, warnings)
|
70
|
+
federation, federation_config = validate_federation_in_project_config(
|
71
|
+
federation, config, federation_config_overrides
|
72
|
+
)
|
73
|
+
exit_if_no_address(federation_config, "pull")
|
74
|
+
channel = None
|
75
|
+
try:
|
76
|
+
|
77
|
+
auth_plugin = try_obtain_cli_auth_plugin(app, federation, federation_config)
|
78
|
+
channel = init_channel(app, federation_config, auth_plugin)
|
79
|
+
stub = ControlStub(channel)
|
80
|
+
with flwr_cli_grpc_exc_handler():
|
81
|
+
res: PullArtifactsResponse = stub.PullArtifacts(
|
82
|
+
PullArtifactsRequest(run_id=run_id)
|
83
|
+
)
|
84
|
+
|
85
|
+
if not res.url:
|
86
|
+
typer.secho(
|
87
|
+
f"❌ A download URL for artifacts from run {run_id} couldn't be "
|
88
|
+
"obtained.",
|
89
|
+
fg=typer.colors.RED,
|
90
|
+
bold=True,
|
91
|
+
)
|
92
|
+
raise typer.Exit(code=1)
|
93
|
+
|
94
|
+
typer.secho(
|
95
|
+
f"✅ Artifacts for run {run_id} can be downloaded from: {res.url}",
|
96
|
+
fg=typer.colors.GREEN,
|
97
|
+
)
|
98
|
+
finally:
|
99
|
+
if channel:
|
100
|
+
channel.close()
|
@@ -32,7 +32,9 @@ from flwr.common.constant import (
|
|
32
32
|
AUTH_TYPE_JSON_KEY,
|
33
33
|
CREDENTIALS_DIR,
|
34
34
|
FLWR_DIR,
|
35
|
+
NO_ARTIFACT_PROVIDER_MESSAGE,
|
35
36
|
NO_USER_AUTH_MESSAGE,
|
37
|
+
PULL_UNFINISHED_RUN_MESSAGE,
|
36
38
|
RUN_ID_NOT_FOUND_MESSAGE,
|
37
39
|
)
|
38
40
|
from flwr.common.grpc import (
|
@@ -319,6 +321,12 @@ def flwr_cli_grpc_exc_handler() -> Iterator[None]:
|
|
319
321
|
fg=typer.colors.RED,
|
320
322
|
bold=True,
|
321
323
|
)
|
324
|
+
elif e.details() == NO_ARTIFACT_PROVIDER_MESSAGE: # pylint: disable=E1101
|
325
|
+
typer.secho(
|
326
|
+
"❌ The SuperLink does not support `flwr pull` command.",
|
327
|
+
fg=typer.colors.RED,
|
328
|
+
bold=True,
|
329
|
+
)
|
322
330
|
else:
|
323
331
|
typer.secho(
|
324
332
|
"❌ The SuperLink cannot process this request. Please verify that "
|
@@ -356,4 +364,13 @@ def flwr_cli_grpc_exc_handler() -> Iterator[None]:
|
|
356
364
|
bold=True,
|
357
365
|
)
|
358
366
|
raise typer.Exit(code=1) from None
|
367
|
+
if e.code() == grpc.StatusCode.FAILED_PRECONDITION:
|
368
|
+
if e.details() == PULL_UNFINISHED_RUN_MESSAGE: # pylint: disable=E1101
|
369
|
+
typer.secho(
|
370
|
+
"❌ Run is not finished yet. Artifacts can only be pulled after "
|
371
|
+
"the run is finished. You can check the run status with `flwr ls`.",
|
372
|
+
fg=typer.colors.RED,
|
373
|
+
bold=True,
|
374
|
+
)
|
375
|
+
raise typer.Exit(code=1) from None
|
359
376
|
raise
|
{flwr_nightly-1.22.0.dev20250916 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/constant.py
RENAMED
@@ -155,6 +155,8 @@ PULL_BACKOFF_CAP = 10 # Maximum backoff time for pulling objects
|
|
155
155
|
# ControlServicer constants
|
156
156
|
RUN_ID_NOT_FOUND_MESSAGE = "Run ID not found"
|
157
157
|
NO_USER_AUTH_MESSAGE = "ControlServicer initialized without user authentication"
|
158
|
+
NO_ARTIFACT_PROVIDER_MESSAGE = "ControlServicer initialized without artifact provider"
|
159
|
+
PULL_UNFINISHED_RUN_MESSAGE = "Cannot pull artifacts for an unfinished run"
|
158
160
|
|
159
161
|
|
160
162
|
class MessageType:
|