flwr-nightly 1.21.0.dev20250829__tar.gz → 1.21.0.dev20250831__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.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/PKG-INFO +1 -1
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/new.py +11 -0
- flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/__init__.pytorch_msg_api.py.tpl +1 -0
- flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/client.pytorch_msg_api.py.tpl +80 -0
- flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/server.pytorch_msg_api.py.tpl +49 -0
- flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/task.pytorch_msg_api.py.tpl +98 -0
- flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/pyproject.pytorch_msg_api.toml.tpl +53 -0
- flwr_nightly-1.21.0.dev20250831/py/flwr/serverapp/__init__.py +21 -0
- {flwr_nightly-1.21.0.dev20250829/py/flwr/serverapp → flwr_nightly-1.21.0.dev20250831/py/flwr/serverapp/strategy}/__init__.py +2 -1
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/pyproject.toml +1 -1
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/README.md +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/app/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/app/error.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/app/metadata.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/auth_plugin/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/auth_plugin/oidc_cli_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/build.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/cli_user_auth_interceptor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/config_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/constant.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/example.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/install.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/log.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/login/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/login/login.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/ls.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/run/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/run/run.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/stop.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/client.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/client_app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/clientapp/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/clientapp/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/dpfedavg_numpy_client.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/grpc_adapter_client/connection.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/grpc_rere_client/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/grpc_rere_client/connection.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/message_handler/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/centraldp_mods.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/comms_mods.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/localdp_mod.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/numpy_client.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/rest_client/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/rest_client/connection.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/run_info_store.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/typing.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/clientapp/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/address.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/args.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/auth_plugin/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/auth_plugin/auth_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/config.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/constant.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/context.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/date.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/differential_privacy.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/differential_privacy_constants.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/dp.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/event_log_plugin/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/event_log_plugin/event_log_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/exit/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/exit/exit.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/exit/exit_code.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/exit_handlers.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/heartbeat.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/inflatable.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/inflatable_protobuf_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/inflatable_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/logger.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/message.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/object_ref.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/parameter.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/pyproject.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/array.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/arraychunk.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/arrayrecord.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/configrecord.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/conversion_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/metricrecord.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/recorddict.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/record/typeddict.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/recorddict_compat.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/retry_invoker.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/quantization.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/serde.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/serde_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/telemetry.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/typing.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/common/version.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/client/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/client/app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/client/grpc_client/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/client/grpc_client/connection.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/common/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/server/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/server/app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/compat/simulation/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/appio_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/appio_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/appio_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/appio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/clientappio_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/clientappio_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/control_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/control_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/control_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/control_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/error_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/error_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/error_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/error_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fab_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fab_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fab_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fleet_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fleet_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fleet_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/grpcadapter_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/heartbeat_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/heartbeat_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/heartbeat_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/heartbeat_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/log_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/log_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/log_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/log_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/message_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/message_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/message_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/message_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/node_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/node_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/node_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/node_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/recorddict_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/recorddict_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/recorddict_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/recorddict_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/run_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/run_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/run_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/run_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/serverappio_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/serverappio_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/simulationio_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/simulationio_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/transport_pb2.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/transport_pb2.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/transport_pb2_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/py.typed +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/client_manager.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/client_proxy.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/compat/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/compat/app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/compat/app_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/compat/grid_client_proxy.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/compat/legacy_context.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/criterion.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/fleet_event_log_interceptor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/grid/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/grid/grid.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/grid/grpc_grid.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/grid/inmemory_grid.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/history.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/run_serverapp.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/server.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/server_app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/server_config.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/serverapp/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/serverapp/app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/serverapp_components.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/aggregate.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/bulyan.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedadagrad.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedadam.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedavg.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedavg_android.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedavgm.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedmedian.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedopt.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedprox.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/fedyogi.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/krum.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/qfedavg.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/strategy/strategy.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/linkstate/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/linkstate/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/serverappio/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/serverappio/serverappio_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/serverappio/serverappio_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/simulation/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/superlink/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/typing.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/utils/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/utils/tensorboard.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/utils/validator.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/workflow/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/workflow/constant.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/workflow/default_workflows.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
- {flwr_nightly-1.21.0.dev20250829/py/flwr/serverapp → flwr_nightly-1.21.0.dev20250831/py/flwr/serverapp/strategy}/fedavg.py +0 -0
- {flwr_nightly-1.21.0.dev20250829/py/flwr/serverapp → flwr_nightly-1.21.0.dev20250831/py/flwr/serverapp/strategy}/result.py +0 -0
- {flwr_nightly-1.21.0.dev20250829/py/flwr/serverapp → flwr_nightly-1.21.0.dev20250831/py/flwr/serverapp/strategy}/strategy.py +0 -0
- {flwr_nightly-1.21.0.dev20250829/py/flwr/serverapp → flwr_nightly-1.21.0.dev20250831/py/flwr/serverapp/strategy}/strategy_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829/py/flwr/serverapp → flwr_nightly-1.21.0.dev20250831/py/flwr/serverapp/strategy}/strategy_utils_tests.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/legacy_app.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/ray_transport/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/ray_transport/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/run_simulation.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/simulation/simulationio_connection.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/app_utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/cli/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/cli/flower_superexec.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/corestate/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/corestate/corestate.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/ffs/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/ffs/disk_ffs.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/ffs/ffs.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/ffs/ffs_factory.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/grpc_health/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/grpc_health/simple_health_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/license_plugin/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/license_plugin/license_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/object_store/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/object_store/in_memory_object_store.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/object_store/object_store.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/object_store/object_store_factory.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/object_store/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/plugin/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/plugin/base_exec_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/plugin/clientapp_exec_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/plugin/exec_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/plugin/serverapp_exec_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/plugin/simulation_exec_plugin.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/superexec/run_superexec.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supercore/utils.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/servicer/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/servicer/control/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/servicer/control/control_event_log_interceptor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/servicer/control/control_grpc.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/servicer/control/control_license_interceptor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/servicer/control/control_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/superlink/servicer/control/control_user_auth_interceptor.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/cli/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/cli/flower_supernode.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/cli/flwr_clientapp.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/nodestate/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/nodestate/in_memory_nodestate.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/nodestate/nodestate.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/nodestate/nodestate_factory.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/runtime/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/runtime/run_clientapp.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/servicer/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/servicer/clientappio/__init__.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/supernode/servicer/clientappio/clientappio_servicer.py +0 -0
- {flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/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.21.0.
|
3
|
+
Version: 1.21.0.dev20250831
|
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
|
@@ -35,6 +35,7 @@ class MlFramework(str, Enum):
|
|
35
35
|
"""Available frameworks."""
|
36
36
|
|
37
37
|
PYTORCH = "PyTorch"
|
38
|
+
PYTORCH_MSG_API = "PyTorch (Message API)"
|
38
39
|
TENSORFLOW = "TensorFlow"
|
39
40
|
SKLEARN = "sklearn"
|
40
41
|
HUGGINGFACE = "HuggingFace"
|
@@ -154,6 +155,9 @@ def new(
|
|
154
155
|
if framework_str == MlFramework.BASELINE:
|
155
156
|
framework_str = "baseline"
|
156
157
|
|
158
|
+
if framework_str == MlFramework.PYTORCH_MSG_API:
|
159
|
+
framework_str = "pytorch_msg_api"
|
160
|
+
|
157
161
|
print(
|
158
162
|
typer.style(
|
159
163
|
f"\n🔨 Creating Flower App {app_name}...",
|
@@ -243,12 +247,19 @@ def new(
|
|
243
247
|
MlFramework.TENSORFLOW.value,
|
244
248
|
MlFramework.SKLEARN.value,
|
245
249
|
MlFramework.NUMPY.value,
|
250
|
+
"pytorch_msg_api",
|
246
251
|
]
|
247
252
|
if framework_str in frameworks_with_tasks:
|
248
253
|
files[f"{import_name}/task.py"] = {
|
249
254
|
"template": f"app/code/task.{template_name}.py.tpl"
|
250
255
|
}
|
251
256
|
|
257
|
+
if framework_str == "pytorch_msg_api":
|
258
|
+
# Use custom __init__ that better captures name of framework
|
259
|
+
files[f"{import_name}/__init__.py"] = {
|
260
|
+
"template": f"app/code/__init__.{framework_str}.py.tpl"
|
261
|
+
}
|
262
|
+
|
252
263
|
if framework_str == "baseline":
|
253
264
|
# Include additional files for baseline template
|
254
265
|
for file_name in ["model", "dataset", "strategy", "utils", "__init__"]:
|
flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/__init__.pytorch_msg_api.py.tpl
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
"""$project_name: A Flower / PyTorch app."""
|
flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/client.pytorch_msg_api.py.tpl
ADDED
@@ -0,0 +1,80 @@
|
|
1
|
+
"""$project_name: A Flower / $framework_str app."""
|
2
|
+
|
3
|
+
import torch
|
4
|
+
from flwr.client import ClientApp
|
5
|
+
from flwr.common import ArrayRecord, Context, Message, MetricRecord, RecordDict
|
6
|
+
|
7
|
+
from $import_name.task import Net, load_data
|
8
|
+
from $import_name.task import test as test_fn
|
9
|
+
from $import_name.task import train as train_fn
|
10
|
+
|
11
|
+
# Flower ClientApp
|
12
|
+
app = ClientApp()
|
13
|
+
|
14
|
+
|
15
|
+
@app.train()
|
16
|
+
def train(msg: Message, context: Context):
|
17
|
+
"""Train the model on local data."""
|
18
|
+
|
19
|
+
# Load the model and initialize it with the received weights
|
20
|
+
model = Net()
|
21
|
+
model.load_state_dict(msg.content["arrays"].to_torch_state_dict())
|
22
|
+
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
|
23
|
+
model.to(device)
|
24
|
+
|
25
|
+
# Load the data
|
26
|
+
partition_id = context.node_config["partition-id"]
|
27
|
+
num_partitions = context.node_config["num-partitions"]
|
28
|
+
trainloader, _ = load_data(partition_id, num_partitions)
|
29
|
+
|
30
|
+
# Call the training function
|
31
|
+
train_loss = train_fn(
|
32
|
+
model,
|
33
|
+
trainloader,
|
34
|
+
context.run_config["local-epochs"],
|
35
|
+
msg.content["config"]["lr"],
|
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
|
+
model.to(device)
|
59
|
+
|
60
|
+
# Load the data
|
61
|
+
partition_id = context.node_config["partition-id"]
|
62
|
+
num_partitions = context.node_config["num-partitions"]
|
63
|
+
_, valloader = load_data(partition_id, num_partitions)
|
64
|
+
|
65
|
+
# Call the evaluation function
|
66
|
+
eval_loss, eval_acc = test_fn(
|
67
|
+
model,
|
68
|
+
valloader,
|
69
|
+
device,
|
70
|
+
)
|
71
|
+
|
72
|
+
# Construct and return reply Message
|
73
|
+
metrics = {
|
74
|
+
"eval_loss": eval_loss,
|
75
|
+
"eval_acc": eval_acc,
|
76
|
+
"num-examples": len(valloader.dataset),
|
77
|
+
}
|
78
|
+
metric_record = MetricRecord(metrics)
|
79
|
+
content = RecordDict({"metrics": metric_record})
|
80
|
+
return Message(content=content, reply_to=msg)
|
flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/server.pytorch_msg_api.py.tpl
ADDED
@@ -0,0 +1,49 @@
|
|
1
|
+
"""$project_name: A Flower / $framework_str app."""
|
2
|
+
|
3
|
+
from pprint import pprint
|
4
|
+
|
5
|
+
import torch
|
6
|
+
from flwr.common import ArrayRecord, ConfigRecord, Context
|
7
|
+
from flwr.server import Grid, ServerApp
|
8
|
+
from flwr.serverapp.strategy import FedAvg
|
9
|
+
|
10
|
+
from $import_name.task import Net
|
11
|
+
|
12
|
+
# Create ServerApp
|
13
|
+
app = ServerApp()
|
14
|
+
|
15
|
+
|
16
|
+
@app.main()
|
17
|
+
def main(grid: Grid, context: Context) -> None:
|
18
|
+
"""Main entry point for the ServerApp."""
|
19
|
+
|
20
|
+
# Read run config
|
21
|
+
fraction_train: float = context.run_config["fraction-train"]
|
22
|
+
num_rounds: int = context.run_config["num-server-rounds"]
|
23
|
+
lr: float = context.run_config["lr"]
|
24
|
+
|
25
|
+
# Load global model
|
26
|
+
global_model = Net()
|
27
|
+
arrays = ArrayRecord(global_model.state_dict())
|
28
|
+
|
29
|
+
# Initialize FedAvg strategy
|
30
|
+
strategy = FedAvg(fraction_train=fraction_train)
|
31
|
+
|
32
|
+
# Start strategy, run FedAvg for `num_rounds`
|
33
|
+
result = strategy.start(
|
34
|
+
grid=grid,
|
35
|
+
initial_arrays=arrays,
|
36
|
+
train_config=ConfigRecord({"lr": lr}),
|
37
|
+
num_rounds=num_rounds,
|
38
|
+
)
|
39
|
+
|
40
|
+
# Log resulting metrics
|
41
|
+
print("\nDistributed train metrics:")
|
42
|
+
pprint(result.train_metrics_clientapp)
|
43
|
+
print("\nDistributed evaluate metrics:")
|
44
|
+
pprint(result.evaluate_metrics_clientapp)
|
45
|
+
|
46
|
+
# Save final model to disk
|
47
|
+
print("\nSaving final model to disk...")
|
48
|
+
state_dict = result.arrays.to_torch_state_dict()
|
49
|
+
torch.save(state_dict, "final_model.pt")
|
flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/code/task.pytorch_msg_api.py.tpl
ADDED
@@ -0,0 +1,98 @@
|
|
1
|
+
"""$project_name: A Flower / $framework_str app."""
|
2
|
+
|
3
|
+
import torch
|
4
|
+
import torch.nn as nn
|
5
|
+
import torch.nn.functional as F
|
6
|
+
from flwr_datasets import FederatedDataset
|
7
|
+
from flwr_datasets.partitioner import IidPartitioner
|
8
|
+
from torch.utils.data import DataLoader
|
9
|
+
from torchvision.transforms import Compose, Normalize, ToTensor
|
10
|
+
|
11
|
+
|
12
|
+
class Net(nn.Module):
|
13
|
+
"""Model (simple CNN adapted from 'PyTorch: A 60 Minute Blitz')"""
|
14
|
+
|
15
|
+
def __init__(self):
|
16
|
+
super(Net, self).__init__()
|
17
|
+
self.conv1 = nn.Conv2d(3, 6, 5)
|
18
|
+
self.pool = nn.MaxPool2d(2, 2)
|
19
|
+
self.conv2 = nn.Conv2d(6, 16, 5)
|
20
|
+
self.fc1 = nn.Linear(16 * 5 * 5, 120)
|
21
|
+
self.fc2 = nn.Linear(120, 84)
|
22
|
+
self.fc3 = nn.Linear(84, 10)
|
23
|
+
|
24
|
+
def forward(self, x):
|
25
|
+
x = self.pool(F.relu(self.conv1(x)))
|
26
|
+
x = self.pool(F.relu(self.conv2(x)))
|
27
|
+
x = x.view(-1, 16 * 5 * 5)
|
28
|
+
x = F.relu(self.fc1(x))
|
29
|
+
x = F.relu(self.fc2(x))
|
30
|
+
return self.fc3(x)
|
31
|
+
|
32
|
+
|
33
|
+
fds = None # Cache FederatedDataset
|
34
|
+
|
35
|
+
pytorch_transforms = Compose([ToTensor(), Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))])
|
36
|
+
|
37
|
+
|
38
|
+
def apply_transforms(batch):
|
39
|
+
"""Apply transforms to the partition from FederatedDataset."""
|
40
|
+
batch["img"] = [pytorch_transforms(img) for img in batch["img"]]
|
41
|
+
return batch
|
42
|
+
|
43
|
+
|
44
|
+
def load_data(partition_id: int, num_partitions: int):
|
45
|
+
"""Load partition CIFAR10 data."""
|
46
|
+
# Only initialize `FederatedDataset` once
|
47
|
+
global fds
|
48
|
+
if fds is None:
|
49
|
+
partitioner = IidPartitioner(num_partitions=num_partitions)
|
50
|
+
fds = FederatedDataset(
|
51
|
+
dataset="uoft-cs/cifar10",
|
52
|
+
partitioners={"train": partitioner},
|
53
|
+
)
|
54
|
+
partition = fds.load_partition(partition_id)
|
55
|
+
# Divide data on each node: 80% train, 20% test
|
56
|
+
partition_train_test = partition.train_test_split(test_size=0.2, seed=42)
|
57
|
+
# Construct dataloaders
|
58
|
+
partition_train_test = partition_train_test.with_transform(apply_transforms)
|
59
|
+
trainloader = DataLoader(partition_train_test["train"], batch_size=32, shuffle=True)
|
60
|
+
testloader = DataLoader(partition_train_test["test"], batch_size=32)
|
61
|
+
return trainloader, testloader
|
62
|
+
|
63
|
+
|
64
|
+
def train(net, trainloader, epochs, lr, device):
|
65
|
+
"""Train the model on the training set."""
|
66
|
+
net.to(device) # move model to GPU if available
|
67
|
+
criterion = torch.nn.CrossEntropyLoss().to(device)
|
68
|
+
optimizer = torch.optim.Adam(net.parameters(), lr=lr)
|
69
|
+
net.train()
|
70
|
+
running_loss = 0.0
|
71
|
+
for _ in range(epochs):
|
72
|
+
for batch in trainloader:
|
73
|
+
images = batch["img"].to(device)
|
74
|
+
labels = batch["label"].to(device)
|
75
|
+
optimizer.zero_grad()
|
76
|
+
loss = criterion(net(images), labels)
|
77
|
+
loss.backward()
|
78
|
+
optimizer.step()
|
79
|
+
running_loss += loss.item()
|
80
|
+
avg_trainloss = running_loss / len(trainloader)
|
81
|
+
return avg_trainloss
|
82
|
+
|
83
|
+
|
84
|
+
def test(net, testloader, device):
|
85
|
+
"""Validate the model on the test set."""
|
86
|
+
net.to(device)
|
87
|
+
criterion = torch.nn.CrossEntropyLoss()
|
88
|
+
correct, loss = 0, 0.0
|
89
|
+
with torch.no_grad():
|
90
|
+
for batch in testloader:
|
91
|
+
images = batch["img"].to(device)
|
92
|
+
labels = batch["label"].to(device)
|
93
|
+
outputs = net(images)
|
94
|
+
loss += criterion(outputs, labels).item()
|
95
|
+
correct += (torch.max(outputs.data, 1)[1] == labels).sum().item()
|
96
|
+
accuracy = correct / len(testloader.dataset)
|
97
|
+
loss = loss / len(testloader)
|
98
|
+
return loss, accuracy
|
flwr_nightly-1.21.0.dev20250831/py/flwr/cli/new/templates/app/pyproject.pytorch_msg_api.toml.tpl
ADDED
@@ -0,0 +1,53 @@
|
|
1
|
+
# =====================================================================
|
2
|
+
# For a full TOML configuration guide, check the Flower docs:
|
3
|
+
# https://flower.ai/docs/framework/how-to-configure-pyproject-toml.html
|
4
|
+
# =====================================================================
|
5
|
+
|
6
|
+
[build-system]
|
7
|
+
requires = ["hatchling"]
|
8
|
+
build-backend = "hatchling.build"
|
9
|
+
|
10
|
+
[project]
|
11
|
+
name = "$package_name"
|
12
|
+
version = "1.0.0"
|
13
|
+
description = ""
|
14
|
+
license = "Apache-2.0"
|
15
|
+
# Dependencies for your Flower App
|
16
|
+
dependencies = [
|
17
|
+
"flwr[simulation]>=1.21.0",
|
18
|
+
"flwr-datasets[vision]>=0.5.0",
|
19
|
+
"torch==2.7.1",
|
20
|
+
"torchvision==0.22.1",
|
21
|
+
]
|
22
|
+
|
23
|
+
[tool.hatch.build.targets.wheel]
|
24
|
+
packages = ["."]
|
25
|
+
|
26
|
+
[tool.flwr.app]
|
27
|
+
publisher = "$username"
|
28
|
+
|
29
|
+
# Point to your ServerApp and ClientApp objects
|
30
|
+
[tool.flwr.app.components]
|
31
|
+
serverapp = "$import_name.server_app:app"
|
32
|
+
clientapp = "$import_name.client_app:app"
|
33
|
+
|
34
|
+
# Custom config values accessible via `context.run_config`
|
35
|
+
[tool.flwr.app.config]
|
36
|
+
num-server-rounds = 3
|
37
|
+
fraction-train = 0.5
|
38
|
+
local-epochs = 1
|
39
|
+
lr = 0.01
|
40
|
+
|
41
|
+
# Default federation to use when running the app
|
42
|
+
[tool.flwr.federations]
|
43
|
+
default = "local-simulation"
|
44
|
+
|
45
|
+
# Local simulation federation with 10 virtual SuperNodes
|
46
|
+
[tool.flwr.federations.local-simulation]
|
47
|
+
options.num-supernodes = 10
|
48
|
+
|
49
|
+
# Remote federation example for use with SuperLink
|
50
|
+
[tool.flwr.federations.remote-federation]
|
51
|
+
address = "<SUPERLINK-ADDRESS>:<PORT>"
|
52
|
+
insecure = true # Remove this line to enable TLS
|
53
|
+
# root-certificates = "<PATH/TO/ca.crt>" # For TLS setup
|
@@ -0,0 +1,21 @@
|
|
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
|
+
"""Public Flower ServerApp APIs."""
|
16
|
+
|
17
|
+
from . import strategy
|
18
|
+
|
19
|
+
__all__ = [
|
20
|
+
"strategy",
|
21
|
+
]
|
@@ -12,7 +12,8 @@
|
|
12
12
|
# See the License for the specific language governing permissions and
|
13
13
|
# limitations under the License.
|
14
14
|
# ==============================================================================
|
15
|
-
"""
|
15
|
+
"""ServerApp strategies."""
|
16
|
+
|
16
17
|
|
17
18
|
from .fedavg import FedAvg
|
18
19
|
from .result import Result
|
@@ -4,7 +4,7 @@ build-backend = "poetry.core.masonry.api"
|
|
4
4
|
|
5
5
|
[tool.poetry]
|
6
6
|
name = "flwr-nightly"
|
7
|
-
version = "1.21.0.
|
7
|
+
version = "1.21.0.dev20250831"
|
8
8
|
description = "Flower: A Friendly Federated AI Framework"
|
9
9
|
license = "Apache-2.0"
|
10
10
|
authors = ["The Flower Authors <hello@flower.ai>"]
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/config_utils.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/login/__init__.py
RENAMED
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/login/login.py
RENAMED
File without changes
|
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/new/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/cli/run/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/__init__.py
RENAMED
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/client.py
RENAMED
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/client_app.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/__init__.py
RENAMED
File without changes
|
File without changes
|
{flwr_nightly-1.21.0.dev20250829 → flwr_nightly-1.21.0.dev20250831}/py/flwr/client/mod/comms_mods.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|