flwr-nightly 1.21.0.dev20250828__tar.gz → 1.21.0.dev20250830__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (395) hide show
  1. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/PKG-INFO +1 -1
  2. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/__init__.py +4 -1
  3. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/new.py +11 -0
  4. flwr_nightly-1.21.0.dev20250830/py/flwr/cli/new/templates/app/code/__init__.pytorch_msg_api.py.tpl +1 -0
  5. flwr_nightly-1.21.0.dev20250830/py/flwr/cli/new/templates/app/code/client.pytorch_msg_api.py.tpl +80 -0
  6. flwr_nightly-1.21.0.dev20250830/py/flwr/cli/new/templates/app/code/server.pytorch_msg_api.py.tpl +49 -0
  7. flwr_nightly-1.21.0.dev20250830/py/flwr/cli/new/templates/app/code/task.pytorch_msg_api.py.tpl +98 -0
  8. flwr_nightly-1.21.0.dev20250830/py/flwr/cli/new/templates/app/pyproject.pytorch_msg_api.toml.tpl +53 -0
  9. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/serverapp/fedavg.py +21 -18
  10. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/serverapp/strategy_utils.py +0 -1
  11. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/pyproject.toml +1 -1
  12. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/README.md +0 -0
  13. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/app/__init__.py +0 -0
  14. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/app/error.py +0 -0
  15. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/app/metadata.py +0 -0
  16. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/__init__.py +0 -0
  17. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/app.py +0 -0
  18. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/auth_plugin/__init__.py +0 -0
  19. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/auth_plugin/oidc_cli_plugin.py +0 -0
  20. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/build.py +0 -0
  21. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/cli_user_auth_interceptor.py +0 -0
  22. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/config_utils.py +0 -0
  23. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/constant.py +0 -0
  24. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/example.py +0 -0
  25. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/install.py +0 -0
  26. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/log.py +0 -0
  27. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/login/__init__.py +0 -0
  28. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/login/login.py +0 -0
  29. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/ls.py +0 -0
  30. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/__init__.py +0 -0
  31. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/__init__.py +0 -0
  32. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  33. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
  34. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
  35. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  36. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  37. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/__init__.py +0 -0
  38. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
  39. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  40. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  41. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
  42. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
  43. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  44. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
  45. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  46. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
  47. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
  48. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
  49. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
  50. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  51. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
  52. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  53. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  54. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
  55. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
  56. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
  57. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
  58. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
  59. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  60. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  61. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  62. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  63. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  64. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  65. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
  66. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
  67. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  68. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  69. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
  70. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  71. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
  72. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  73. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
  74. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
  75. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  76. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
  77. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
  78. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
  79. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  80. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
  81. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  82. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
  83. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/run/__init__.py +0 -0
  84. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/run/run.py +0 -0
  85. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/stop.py +0 -0
  86. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/cli/utils.py +0 -0
  87. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/__init__.py +0 -0
  88. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/client.py +0 -0
  89. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/client_app.py +0 -0
  90. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/clientapp/__init__.py +0 -0
  91. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/clientapp/utils.py +0 -0
  92. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  93. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  94. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  95. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  96. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  97. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/grpc_rere_client/connection.py +0 -0
  98. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  99. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/message_handler/__init__.py +0 -0
  100. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/message_handler/message_handler.py +0 -0
  101. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/__init__.py +0 -0
  102. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/centraldp_mods.py +0 -0
  103. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/comms_mods.py +0 -0
  104. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/localdp_mod.py +0 -0
  105. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  106. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  107. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  108. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/mod/utils.py +0 -0
  109. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/numpy_client.py +0 -0
  110. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/rest_client/__init__.py +0 -0
  111. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/rest_client/connection.py +0 -0
  112. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/run_info_store.py +0 -0
  113. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/client/typing.py +0 -0
  114. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/clientapp/__init__.py +0 -0
  115. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/__init__.py +0 -0
  116. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/address.py +0 -0
  117. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/args.py +0 -0
  118. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/auth_plugin/__init__.py +0 -0
  119. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/auth_plugin/auth_plugin.py +0 -0
  120. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/config.py +0 -0
  121. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/constant.py +0 -0
  122. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/context.py +0 -0
  123. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/date.py +0 -0
  124. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/differential_privacy.py +0 -0
  125. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/differential_privacy_constants.py +0 -0
  126. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/dp.py +0 -0
  127. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/event_log_plugin/__init__.py +0 -0
  128. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/event_log_plugin/event_log_plugin.py +0 -0
  129. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/exit/__init__.py +0 -0
  130. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/exit/exit.py +0 -0
  131. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/exit/exit_code.py +0 -0
  132. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/exit_handlers.py +0 -0
  133. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/grpc.py +0 -0
  134. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/heartbeat.py +0 -0
  135. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/inflatable.py +0 -0
  136. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/inflatable_protobuf_utils.py +0 -0
  137. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/inflatable_utils.py +0 -0
  138. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/logger.py +0 -0
  139. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/message.py +0 -0
  140. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/object_ref.py +0 -0
  141. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/parameter.py +0 -0
  142. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/pyproject.py +0 -0
  143. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/__init__.py +0 -0
  144. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/array.py +0 -0
  145. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/arraychunk.py +0 -0
  146. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/arrayrecord.py +0 -0
  147. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/configrecord.py +0 -0
  148. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/conversion_utils.py +0 -0
  149. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/metricrecord.py +0 -0
  150. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/recorddict.py +0 -0
  151. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/record/typeddict.py +0 -0
  152. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/recorddict_compat.py +0 -0
  153. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/retry_invoker.py +0 -0
  154. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/__init__.py +0 -0
  155. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  156. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  157. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  158. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  159. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/quantization.py +0 -0
  160. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  161. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  162. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/serde.py +0 -0
  163. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/serde_utils.py +0 -0
  164. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/telemetry.py +0 -0
  165. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/typing.py +0 -0
  166. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/common/version.py +0 -0
  167. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/__init__.py +0 -0
  168. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/client/__init__.py +0 -0
  169. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/client/app.py +0 -0
  170. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/client/grpc_client/__init__.py +0 -0
  171. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/client/grpc_client/connection.py +0 -0
  172. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/common/__init__.py +0 -0
  173. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/server/__init__.py +0 -0
  174. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/server/app.py +0 -0
  175. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/compat/simulation/__init__.py +0 -0
  176. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/__init__.py +0 -0
  177. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/appio_pb2.py +0 -0
  178. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/appio_pb2.pyi +0 -0
  179. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/appio_pb2_grpc.py +0 -0
  180. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/appio_pb2_grpc.pyi +0 -0
  181. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/clientappio_pb2.py +0 -0
  182. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/clientappio_pb2.pyi +0 -0
  183. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
  184. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
  185. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/control_pb2.py +0 -0
  186. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/control_pb2.pyi +0 -0
  187. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/control_pb2_grpc.py +0 -0
  188. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/control_pb2_grpc.pyi +0 -0
  189. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/error_pb2.py +0 -0
  190. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/error_pb2.pyi +0 -0
  191. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/error_pb2_grpc.py +0 -0
  192. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  193. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fab_pb2.py +0 -0
  194. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fab_pb2.pyi +0 -0
  195. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fab_pb2_grpc.py +0 -0
  196. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  197. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fleet_pb2.py +0 -0
  198. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fleet_pb2.pyi +0 -0
  199. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  200. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  201. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/grpcadapter_pb2.py +0 -0
  202. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  203. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  204. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  205. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/heartbeat_pb2.py +0 -0
  206. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/heartbeat_pb2.pyi +0 -0
  207. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/heartbeat_pb2_grpc.py +0 -0
  208. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/heartbeat_pb2_grpc.pyi +0 -0
  209. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/log_pb2.py +0 -0
  210. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/log_pb2.pyi +0 -0
  211. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/log_pb2_grpc.py +0 -0
  212. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/log_pb2_grpc.pyi +0 -0
  213. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/message_pb2.py +0 -0
  214. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/message_pb2.pyi +0 -0
  215. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/message_pb2_grpc.py +0 -0
  216. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/message_pb2_grpc.pyi +0 -0
  217. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/node_pb2.py +0 -0
  218. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/node_pb2.pyi +0 -0
  219. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/node_pb2_grpc.py +0 -0
  220. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  221. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/recorddict_pb2.py +0 -0
  222. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/recorddict_pb2.pyi +0 -0
  223. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/recorddict_pb2_grpc.py +0 -0
  224. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/recorddict_pb2_grpc.pyi +0 -0
  225. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/run_pb2.py +0 -0
  226. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/run_pb2.pyi +0 -0
  227. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/run_pb2_grpc.py +0 -0
  228. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  229. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/serverappio_pb2.py +0 -0
  230. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/serverappio_pb2.pyi +0 -0
  231. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
  232. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
  233. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/simulationio_pb2.py +0 -0
  234. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/simulationio_pb2.pyi +0 -0
  235. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
  236. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
  237. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/transport_pb2.py +0 -0
  238. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/transport_pb2.pyi +0 -0
  239. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/transport_pb2_grpc.py +0 -0
  240. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  241. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/py.typed +0 -0
  242. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/__init__.py +0 -0
  243. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/app.py +0 -0
  244. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/client_manager.py +0 -0
  245. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/client_proxy.py +0 -0
  246. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/compat/__init__.py +0 -0
  247. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/compat/app.py +0 -0
  248. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/compat/app_utils.py +0 -0
  249. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/compat/grid_client_proxy.py +0 -0
  250. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/compat/legacy_context.py +0 -0
  251. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/criterion.py +0 -0
  252. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/fleet_event_log_interceptor.py +0 -0
  253. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/grid/__init__.py +0 -0
  254. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/grid/grid.py +0 -0
  255. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/grid/grpc_grid.py +0 -0
  256. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/grid/inmemory_grid.py +0 -0
  257. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/history.py +0 -0
  258. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/run_serverapp.py +0 -0
  259. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/server.py +0 -0
  260. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/server_app.py +0 -0
  261. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/server_config.py +0 -0
  262. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/serverapp/__init__.py +0 -0
  263. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/serverapp/app.py +0 -0
  264. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/serverapp_components.py +0 -0
  265. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/__init__.py +0 -0
  266. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/aggregate.py +0 -0
  267. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/bulyan.py +0 -0
  268. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  269. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  270. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  271. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  272. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  273. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedadagrad.py +0 -0
  274. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedadam.py +0 -0
  275. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedavg.py +0 -0
  276. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedavg_android.py +0 -0
  277. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedavgm.py +0 -0
  278. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedmedian.py +0 -0
  279. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedopt.py +0 -0
  280. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedprox.py +0 -0
  281. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  282. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  283. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  284. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  285. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/fedyogi.py +0 -0
  286. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/krum.py +0 -0
  287. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/qfedavg.py +0 -0
  288. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/strategy/strategy.py +0 -0
  289. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/__init__.py +0 -0
  290. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/__init__.py +0 -0
  291. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  292. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  293. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  294. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  295. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  296. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  297. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  298. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  299. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  300. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  301. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  302. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  303. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  304. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  305. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  306. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  307. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  308. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  309. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  310. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/linkstate/__init__.py +0 -0
  311. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
  312. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
  313. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
  314. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
  315. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/linkstate/utils.py +0 -0
  316. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/serverappio/__init__.py +0 -0
  317. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/serverappio/serverappio_grpc.py +0 -0
  318. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/serverappio/serverappio_servicer.py +0 -0
  319. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/simulation/__init__.py +0 -0
  320. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
  321. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
  322. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/superlink/utils.py +0 -0
  323. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/typing.py +0 -0
  324. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/utils/__init__.py +0 -0
  325. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/utils/tensorboard.py +0 -0
  326. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/utils/validator.py +0 -0
  327. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/workflow/__init__.py +0 -0
  328. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/workflow/constant.py +0 -0
  329. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/workflow/default_workflows.py +0 -0
  330. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  331. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  332. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  333. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/serverapp/__init__.py +0 -0
  334. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/serverapp/result.py +0 -0
  335. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/serverapp/strategy.py +0 -0
  336. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/serverapp/strategy_utils_tests.py +0 -0
  337. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/__init__.py +0 -0
  338. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/app.py +0 -0
  339. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/legacy_app.py +0 -0
  340. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/ray_transport/__init__.py +0 -0
  341. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  342. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  343. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/ray_transport/utils.py +0 -0
  344. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/run_simulation.py +0 -0
  345. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/simulation/simulationio_connection.py +0 -0
  346. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/__init__.py +0 -0
  347. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/app_utils.py +0 -0
  348. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/cli/__init__.py +0 -0
  349. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/cli/flower_superexec.py +0 -0
  350. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/corestate/__init__.py +0 -0
  351. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/corestate/corestate.py +0 -0
  352. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/ffs/__init__.py +0 -0
  353. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/ffs/disk_ffs.py +0 -0
  354. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/ffs/ffs.py +0 -0
  355. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/ffs/ffs_factory.py +0 -0
  356. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/grpc_health/__init__.py +0 -0
  357. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/grpc_health/simple_health_servicer.py +0 -0
  358. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/license_plugin/__init__.py +0 -0
  359. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/license_plugin/license_plugin.py +0 -0
  360. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/object_store/__init__.py +0 -0
  361. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/object_store/in_memory_object_store.py +0 -0
  362. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/object_store/object_store.py +0 -0
  363. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/object_store/object_store_factory.py +0 -0
  364. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/object_store/utils.py +0 -0
  365. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/__init__.py +0 -0
  366. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/plugin/__init__.py +0 -0
  367. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/plugin/base_exec_plugin.py +0 -0
  368. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/plugin/clientapp_exec_plugin.py +0 -0
  369. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/plugin/exec_plugin.py +0 -0
  370. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/plugin/serverapp_exec_plugin.py +0 -0
  371. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/plugin/simulation_exec_plugin.py +0 -0
  372. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/superexec/run_superexec.py +0 -0
  373. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supercore/utils.py +0 -0
  374. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/__init__.py +0 -0
  375. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/servicer/__init__.py +0 -0
  376. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/servicer/control/__init__.py +0 -0
  377. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/servicer/control/control_event_log_interceptor.py +0 -0
  378. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/servicer/control/control_grpc.py +0 -0
  379. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/servicer/control/control_license_interceptor.py +0 -0
  380. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/servicer/control/control_servicer.py +0 -0
  381. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/superlink/servicer/control/control_user_auth_interceptor.py +0 -0
  382. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/__init__.py +0 -0
  383. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/cli/__init__.py +0 -0
  384. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/cli/flower_supernode.py +0 -0
  385. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/cli/flwr_clientapp.py +0 -0
  386. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/nodestate/__init__.py +0 -0
  387. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/nodestate/in_memory_nodestate.py +0 -0
  388. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/nodestate/nodestate.py +0 -0
  389. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/nodestate/nodestate_factory.py +0 -0
  390. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/runtime/__init__.py +0 -0
  391. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/runtime/run_clientapp.py +0 -0
  392. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/servicer/__init__.py +0 -0
  393. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/servicer/clientappio/__init__.py +0 -0
  394. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/py/flwr/supernode/servicer/clientappio/clientappio_servicer.py +0 -0
  395. {flwr_nightly-1.21.0.dev20250828 → flwr_nightly-1.21.0.dev20250830}/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.dev20250828
3
+ Version: 1.21.0.dev20250830
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
@@ -17,12 +17,15 @@
17
17
 
18
18
  from flwr.common.version import package_version as _package_version
19
19
 
20
- from . import client, common, server, simulation
20
+ from . import app, client, clientapp, common, server, serverapp, simulation
21
21
 
22
22
  __all__ = [
23
+ "app",
23
24
  "client",
25
+ "clientapp",
24
26
  "common",
25
27
  "server",
28
+ "serverapp",
26
29
  "simulation",
27
30
  ]
28
31
 
@@ -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__"]:
@@ -0,0 +1 @@
1
+ """$project_name: A Flower / PyTorch app."""
@@ -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)
@@ -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 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")
@@ -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
@@ -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
@@ -197,7 +197,7 @@ class FedAvg(Strategy):
197
197
  log(
198
198
  INFO,
199
199
  "aggregate_train: Received %s results and %s failures",
200
- len(replies_with_content) - num_errors,
200
+ len(replies_with_content),
201
201
  num_errors,
202
202
  )
203
203
 
@@ -208,17 +208,19 @@ class FedAvg(Strategy):
208
208
  check_arrayrecord=True,
209
209
  )
210
210
 
211
- # Aggregate ArrayRecords
212
- arrays = aggregate_arrayrecords(
213
- replies_with_content,
214
- self.weighted_by_key,
215
- )
211
+ arrays, metrics = None, None
212
+ if replies_with_content:
213
+ # Aggregate ArrayRecords
214
+ arrays = aggregate_arrayrecords(
215
+ replies_with_content,
216
+ self.weighted_by_key,
217
+ )
216
218
 
217
- # Aggregate MetricRecords
218
- metrics = self.train_metrics_aggr_fn(
219
- replies_with_content,
220
- self.weighted_by_key,
221
- )
219
+ # Aggregate MetricRecords
220
+ metrics = self.train_metrics_aggr_fn(
221
+ replies_with_content,
222
+ self.weighted_by_key,
223
+ )
222
224
  return arrays, metrics
223
225
 
224
226
  def configure_evaluate(
@@ -273,7 +275,7 @@ class FedAvg(Strategy):
273
275
  log(
274
276
  INFO,
275
277
  "aggregate_evaluate: Received %s results and %s failures",
276
- len(replies_with_content) - num_errors,
278
+ len(replies_with_content),
277
279
  num_errors,
278
280
  )
279
281
 
@@ -283,10 +285,11 @@ class FedAvg(Strategy):
283
285
  weighted_by_key=self.weighted_by_key,
284
286
  check_arrayrecord=False,
285
287
  )
286
-
287
- # Aggregate MetricRecords
288
- metrics = self.evaluate_metrics_aggr_fn(
289
- replies_with_content,
290
- self.weighted_by_key,
291
- )
288
+ metrics = None
289
+ if replies_with_content:
290
+ # Aggregate MetricRecords
291
+ metrics = self.evaluate_metrics_aggr_fn(
292
+ replies_with_content,
293
+ self.weighted_by_key,
294
+ )
292
295
  return metrics
@@ -33,7 +33,6 @@ from flwr.common import (
33
33
  from flwr.server import Grid
34
34
 
35
35
 
36
- # Define a new exception
37
36
  class InconsistentMessageReplies(Exception):
38
37
  """Exception triggered when replies are inconsistent and therefore aggregation must
39
38
  be skipped."""
@@ -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.dev20250828"
7
+ version = "1.21.0.dev20250830"
8
8
  description = "Flower: A Friendly Federated AI Framework"
9
9
  license = "Apache-2.0"
10
10
  authors = ["The Flower Authors <hello@flower.ai>"]