flwr-nightly 1.22.0.dev20250915__tar.gz → 1.22.0.dev20250917__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (421) hide show
  1. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/PKG-INFO +6 -16
  2. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/README.md +5 -15
  3. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/app.py +2 -0
  4. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/new.py +2 -2
  5. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +1 -1
  6. flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +75 -0
  7. flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +92 -0
  8. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +1 -23
  9. flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +73 -0
  10. flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +78 -0
  11. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -14
  12. flwr_nightly-1.22.0.dev20250917/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +43 -0
  13. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +3 -3
  14. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +1 -1
  15. flwr_nightly-1.22.0.dev20250917/py/flwr/cli/pull.py +100 -0
  16. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/utils.py +17 -0
  17. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/constant.py +2 -0
  18. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2.py +7 -3
  19. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2.pyi +24 -0
  20. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2_grpc.py +34 -0
  21. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/control_pb2_grpc.pyi +13 -0
  22. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/app.py +13 -0
  23. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/__init__.py +8 -0
  24. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedavg.py +23 -2
  25. flwr_nightly-1.22.0.dev20250917/py/flwr/serverapp/strategy/fedavgm.py +198 -0
  26. flwr_nightly-1.22.0.dev20250917/py/flwr/serverapp/strategy/fedmedian.py +71 -0
  27. flwr_nightly-1.22.0.dev20250917/py/flwr/serverapp/strategy/fedprox.py +174 -0
  28. flwr_nightly-1.22.0.dev20250917/py/flwr/serverapp/strategy/fedtrimmedavg.py +176 -0
  29. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/strategy_utils_tests.py +20 -1
  30. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/app.py +1 -1
  31. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/run_simulation.py +25 -30
  32. flwr_nightly-1.22.0.dev20250917/py/flwr/superlink/artifact_provider/__init__.py +22 -0
  33. flwr_nightly-1.22.0.dev20250917/py/flwr/superlink/artifact_provider/artifact_provider.py +37 -0
  34. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_grpc.py +3 -0
  35. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_servicer.py +59 -2
  36. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/pyproject.toml +1 -1
  37. flwr_nightly-1.22.0.dev20250915/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -58
  38. flwr_nightly-1.22.0.dev20250915/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -126
  39. flwr_nightly-1.22.0.dev20250915/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -94
  40. flwr_nightly-1.22.0.dev20250915/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -83
  41. flwr_nightly-1.22.0.dev20250915/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -45
  42. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/__init__.py +0 -0
  43. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/__init__.py +0 -0
  44. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/error.py +0 -0
  45. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/exception.py +0 -0
  46. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/app/metadata.py +0 -0
  47. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/__init__.py +0 -0
  48. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/auth_plugin/__init__.py +0 -0
  49. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/auth_plugin/oidc_cli_plugin.py +0 -0
  50. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/build.py +0 -0
  51. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/cli_user_auth_interceptor.py +0 -0
  52. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/config_utils.py +0 -0
  53. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/constant.py +0 -0
  54. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/example.py +0 -0
  55. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/install.py +0 -0
  56. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/log.py +0 -0
  57. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/login/__init__.py +0 -0
  58. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/login/login.py +0 -0
  59. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/ls.py +0 -0
  60. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/__init__.py +0 -0
  61. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/__init__.py +0 -0
  62. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  63. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
  64. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
  65. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  66. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/__init__.py +0 -0
  67. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
  68. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  69. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  70. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/__init__.pytorch_legacy_api.py.tpl +0 -0
  71. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
  72. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  73. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
  74. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  75. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
  76. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.pytorch_legacy_api.py.tpl +0 -0
  77. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
  78. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
  79. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
  80. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  81. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  82. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
  83. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  84. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  85. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  86. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  87. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.pytorch_legacy_api.py.tpl +0 -0
  88. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  89. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  90. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
  91. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
  92. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  93. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  94. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
  95. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  96. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.pytorch_legacy_api.py.tpl +0 -0
  97. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
  98. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  99. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
  100. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
  101. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
  102. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
  103. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  104. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
  105. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.pytorch_legacy_api.toml.tpl +0 -0
  106. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  107. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
  108. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/run/__init__.py +0 -0
  109. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/run/run.py +0 -0
  110. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/cli/stop.py +0 -0
  111. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/__init__.py +0 -0
  112. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/client.py +0 -0
  113. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/client_app.py +0 -0
  114. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/clientapp/__init__.py +0 -0
  115. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/clientapp/utils.py +0 -0
  116. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  117. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  118. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  119. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  120. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  121. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/connection.py +0 -0
  122. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  123. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/message_handler/__init__.py +0 -0
  124. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/message_handler/message_handler.py +0 -0
  125. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/__init__.py +0 -0
  126. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/centraldp_mods.py +0 -0
  127. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/comms_mods.py +0 -0
  128. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/localdp_mod.py +0 -0
  129. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  130. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  131. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  132. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/mod/utils.py +0 -0
  133. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/numpy_client.py +0 -0
  134. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/rest_client/__init__.py +0 -0
  135. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/rest_client/connection.py +0 -0
  136. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/run_info_store.py +0 -0
  137. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/client/typing.py +0 -0
  138. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/clientapp/__init__.py +0 -0
  139. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/clientapp/mod/__init__.py +0 -0
  140. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/clientapp/mod/centraldp_mods.py +0 -0
  141. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/__init__.py +0 -0
  142. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/address.py +0 -0
  143. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/args.py +0 -0
  144. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/auth_plugin/__init__.py +0 -0
  145. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/auth_plugin/auth_plugin.py +0 -0
  146. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/config.py +0 -0
  147. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/context.py +0 -0
  148. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/date.py +0 -0
  149. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/differential_privacy.py +0 -0
  150. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/differential_privacy_constants.py +0 -0
  151. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/dp.py +0 -0
  152. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/event_log_plugin/__init__.py +0 -0
  153. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/event_log_plugin/event_log_plugin.py +0 -0
  154. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/__init__.py +0 -0
  155. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/exit.py +0 -0
  156. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/exit_code.py +0 -0
  157. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/exit_handler.py +0 -0
  158. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/exit/signal_handler.py +0 -0
  159. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/grpc.py +0 -0
  160. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/heartbeat.py +0 -0
  161. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/inflatable.py +0 -0
  162. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/inflatable_protobuf_utils.py +0 -0
  163. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/inflatable_utils.py +0 -0
  164. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/logger.py +0 -0
  165. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/message.py +0 -0
  166. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/object_ref.py +0 -0
  167. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/parameter.py +0 -0
  168. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/pyproject.py +0 -0
  169. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/__init__.py +0 -0
  170. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/array.py +0 -0
  171. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/arraychunk.py +0 -0
  172. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/arrayrecord.py +0 -0
  173. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/configrecord.py +0 -0
  174. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/conversion_utils.py +0 -0
  175. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/metricrecord.py +0 -0
  176. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/recorddict.py +0 -0
  177. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/record/typeddict.py +0 -0
  178. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/recorddict_compat.py +0 -0
  179. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/retry_invoker.py +0 -0
  180. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/__init__.py +0 -0
  181. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  182. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  183. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  184. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  185. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/quantization.py +0 -0
  186. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  187. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  188. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/serde.py +0 -0
  189. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/serde_utils.py +0 -0
  190. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/telemetry.py +0 -0
  191. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/typing.py +0 -0
  192. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/common/version.py +0 -0
  193. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/__init__.py +0 -0
  194. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/__init__.py +0 -0
  195. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/app.py +0 -0
  196. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/grpc_client/__init__.py +0 -0
  197. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/client/grpc_client/connection.py +0 -0
  198. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/common/__init__.py +0 -0
  199. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/server/__init__.py +0 -0
  200. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/server/app.py +0 -0
  201. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/compat/simulation/__init__.py +0 -0
  202. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/__init__.py +0 -0
  203. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2.py +0 -0
  204. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2.pyi +0 -0
  205. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2_grpc.py +0 -0
  206. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/appio_pb2_grpc.pyi +0 -0
  207. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2.py +0 -0
  208. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2.pyi +0 -0
  209. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
  210. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
  211. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2.py +0 -0
  212. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2.pyi +0 -0
  213. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2_grpc.py +0 -0
  214. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  215. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2.py +0 -0
  216. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2.pyi +0 -0
  217. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2_grpc.py +0 -0
  218. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  219. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2.py +0 -0
  220. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2.pyi +0 -0
  221. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  222. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  223. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2.py +0 -0
  224. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  225. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  226. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  227. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2.py +0 -0
  228. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2.pyi +0 -0
  229. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2_grpc.py +0 -0
  230. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/heartbeat_pb2_grpc.pyi +0 -0
  231. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2.py +0 -0
  232. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2.pyi +0 -0
  233. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2_grpc.py +0 -0
  234. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/log_pb2_grpc.pyi +0 -0
  235. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2.py +0 -0
  236. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2.pyi +0 -0
  237. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2_grpc.py +0 -0
  238. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/message_pb2_grpc.pyi +0 -0
  239. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2.py +0 -0
  240. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2.pyi +0 -0
  241. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2_grpc.py +0 -0
  242. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  243. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2.py +0 -0
  244. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2.pyi +0 -0
  245. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2_grpc.py +0 -0
  246. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/recorddict_pb2_grpc.pyi +0 -0
  247. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2.py +0 -0
  248. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2.pyi +0 -0
  249. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2_grpc.py +0 -0
  250. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  251. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2.py +0 -0
  252. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2.pyi +0 -0
  253. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
  254. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
  255. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2.py +0 -0
  256. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2.pyi +0 -0
  257. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2_grpc.py +0 -0
  258. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/simulationio_pb2_grpc.pyi +0 -0
  259. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2.py +0 -0
  260. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2.pyi +0 -0
  261. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2_grpc.py +0 -0
  262. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  263. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/py.typed +0 -0
  264. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/__init__.py +0 -0
  265. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/client_manager.py +0 -0
  266. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/client_proxy.py +0 -0
  267. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/__init__.py +0 -0
  268. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/app.py +0 -0
  269. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/app_utils.py +0 -0
  270. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/grid_client_proxy.py +0 -0
  271. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/compat/legacy_context.py +0 -0
  272. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/criterion.py +0 -0
  273. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/fleet_event_log_interceptor.py +0 -0
  274. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/__init__.py +0 -0
  275. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/grid.py +0 -0
  276. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/grpc_grid.py +0 -0
  277. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/grid/inmemory_grid.py +0 -0
  278. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/history.py +0 -0
  279. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/run_serverapp.py +0 -0
  280. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/server.py +0 -0
  281. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/server_app.py +0 -0
  282. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/server_config.py +0 -0
  283. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/serverapp/__init__.py +0 -0
  284. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/serverapp/app.py +0 -0
  285. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/serverapp_components.py +0 -0
  286. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/__init__.py +0 -0
  287. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/aggregate.py +0 -0
  288. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/bulyan.py +0 -0
  289. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  290. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  291. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  292. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  293. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  294. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedadagrad.py +0 -0
  295. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedadam.py +0 -0
  296. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedavg.py +0 -0
  297. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedavg_android.py +0 -0
  298. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedavgm.py +0 -0
  299. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedmedian.py +0 -0
  300. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedopt.py +0 -0
  301. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedprox.py +0 -0
  302. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  303. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  304. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  305. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  306. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/fedyogi.py +0 -0
  307. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/krum.py +0 -0
  308. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/qfedavg.py +0 -0
  309. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/strategy/strategy.py +0 -0
  310. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/__init__.py +0 -0
  311. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/__init__.py +0 -0
  312. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  313. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  314. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  315. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  316. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  317. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  318. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  319. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  320. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  321. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  322. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  323. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  324. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  325. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  326. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  327. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  328. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  329. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  330. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  331. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/__init__.py +0 -0
  332. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
  333. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
  334. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
  335. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
  336. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/linkstate/utils.py +0 -0
  337. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/serverappio/__init__.py +0 -0
  338. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/serverappio/serverappio_grpc.py +0 -0
  339. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/serverappio/serverappio_servicer.py +0 -0
  340. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/simulation/__init__.py +0 -0
  341. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
  342. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/simulation/simulationio_servicer.py +0 -0
  343. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/superlink/utils.py +0 -0
  344. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/typing.py +0 -0
  345. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/utils/__init__.py +0 -0
  346. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/utils/tensorboard.py +0 -0
  347. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/utils/validator.py +0 -0
  348. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/__init__.py +0 -0
  349. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/constant.py +0 -0
  350. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/default_workflows.py +0 -0
  351. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  352. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  353. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  354. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/__init__.py +0 -0
  355. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/dp_fixed_clipping.py +0 -0
  356. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/exception.py +0 -0
  357. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/dp_fixed_clipping.py +0 -0
  358. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedadagrad.py +0 -0
  359. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedadam.py +0 -0
  360. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedopt.py +0 -0
  361. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedxgb_bagging.py +0 -0
  362. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/fedyogi.py +0 -0
  363. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/result.py +0 -0
  364. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/strategy.py +0 -0
  365. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/serverapp/strategy/strategy_utils.py +0 -0
  366. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/__init__.py +0 -0
  367. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/legacy_app.py +0 -0
  368. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/__init__.py +0 -0
  369. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  370. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  371. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/ray_transport/utils.py +0 -0
  372. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/simulation/simulationio_connection.py +0 -0
  373. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/__init__.py +0 -0
  374. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/app_utils.py +0 -0
  375. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/cli/__init__.py +0 -0
  376. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/cli/flower_superexec.py +0 -0
  377. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/corestate/__init__.py +0 -0
  378. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/corestate/corestate.py +0 -0
  379. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/__init__.py +0 -0
  380. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/disk_ffs.py +0 -0
  381. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/ffs.py +0 -0
  382. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/ffs/ffs_factory.py +0 -0
  383. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/grpc_health/__init__.py +0 -0
  384. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/grpc_health/health_server.py +0 -0
  385. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/grpc_health/simple_health_servicer.py +0 -0
  386. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/license_plugin/__init__.py +0 -0
  387. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/license_plugin/license_plugin.py +0 -0
  388. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/__init__.py +0 -0
  389. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/in_memory_object_store.py +0 -0
  390. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/object_store.py +0 -0
  391. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/object_store_factory.py +0 -0
  392. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/object_store/utils.py +0 -0
  393. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/__init__.py +0 -0
  394. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/__init__.py +0 -0
  395. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/base_exec_plugin.py +0 -0
  396. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/clientapp_exec_plugin.py +0 -0
  397. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/exec_plugin.py +0 -0
  398. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/serverapp_exec_plugin.py +0 -0
  399. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/plugin/simulation_exec_plugin.py +0 -0
  400. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/superexec/run_superexec.py +0 -0
  401. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supercore/utils.py +0 -0
  402. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/__init__.py +0 -0
  403. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/__init__.py +0 -0
  404. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/__init__.py +0 -0
  405. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_event_log_interceptor.py +0 -0
  406. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_license_interceptor.py +0 -0
  407. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/superlink/servicer/control/control_user_auth_interceptor.py +0 -0
  408. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/__init__.py +0 -0
  409. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/cli/__init__.py +0 -0
  410. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/cli/flower_supernode.py +0 -0
  411. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/cli/flwr_clientapp.py +0 -0
  412. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/__init__.py +0 -0
  413. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/in_memory_nodestate.py +0 -0
  414. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/nodestate.py +0 -0
  415. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/nodestate/nodestate_factory.py +0 -0
  416. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/runtime/__init__.py +0 -0
  417. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/runtime/run_clientapp.py +0 -0
  418. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/servicer/__init__.py +0 -0
  419. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/servicer/clientappio/__init__.py +0 -0
  420. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/servicer/clientappio/clientappio_servicer.py +0 -0
  421. {flwr_nightly-1.22.0.dev20250915 → flwr_nightly-1.22.0.dev20250917}/py/flwr/supernode/start_client_internal.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: flwr-nightly
3
- Version: 1.22.0.dev20250915
3
+ Version: 1.22.0.dev20250917
4
4
  Summary: Flower: A Friendly Federated AI Framework
5
5
  License: Apache-2.0
6
6
  Keywords: Artificial Intelligence,Federated AI,Federated Analytics,Federated Evaluation,Federated Learning,Flower,Machine Learning
@@ -102,25 +102,15 @@ Meet the Flower community on [flower.ai](https://flower.ai)!
102
102
 
103
103
  Flower's goal is to make federated learning accessible to everyone. This series of tutorials introduces the fundamentals of federated learning and how to implement them in Flower.
104
104
 
105
- 0. **What is Federated Learning?**
105
+ 0. **[What is Federated Learning?](https://flower.ai/docs/framework/main/en/tutorial-series-what-is-federated-learning.html)**
106
106
 
107
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-what-is-federated-learning.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-what-is-federated-learning.ipynb))
107
+ 1. **[An Introduction to Federated Learning](https://flower.ai/docs/framework/main/en/tutorial-series-get-started-with-flower-pytorch.html)**
108
108
 
109
- 1. **An Introduction to Federated Learning**
109
+ 2. **[Using Strategies in Federated Learning](https://flower.ai/docs/framework/main/en/tutorial-series-use-a-federated-learning-strategy-pytorch.html)**
110
110
 
111
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-get-started-with-flower-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-get-started-with-flower-pytorch.ipynb))
111
+ 3. **[Customize a Flower Strategy](https://flower.ai/docs/framework/main/en/tutorial-series-build-a-strategy-from-scratch-pytorch.html)**
112
112
 
113
- 2. **Using Strategies in Federated Learning**
114
-
115
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-use-a-federated-learning-strategy-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-use-a-federated-learning-strategy-pytorch.ipynb))
116
-
117
- 3. **Building Strategies for Federated Learning**
118
-
119
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-build-a-strategy-from-scratch-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-build-a-strategy-from-scratch-pytorch.ipynb))
120
-
121
- 4. **Custom Clients for Federated Learning**
122
-
123
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-customize-the-client-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-customize-the-client-pytorch.ipynb))
113
+ 4. **[Communicate Custom Messages](https://flower.ai/docs/framework/main/en/tutorial-series-customize-the-client-pytorch.html)**
124
114
 
125
115
  Stay tuned, more tutorials are coming soon. Topics include **Privacy and Security in Federated Learning**, and **Scaling Federated Learning**.
126
116
 
@@ -46,25 +46,15 @@ Meet the Flower community on [flower.ai](https://flower.ai)!
46
46
 
47
47
  Flower's goal is to make federated learning accessible to everyone. This series of tutorials introduces the fundamentals of federated learning and how to implement them in Flower.
48
48
 
49
- 0. **What is Federated Learning?**
49
+ 0. **[What is Federated Learning?](https://flower.ai/docs/framework/main/en/tutorial-series-what-is-federated-learning.html)**
50
50
 
51
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-what-is-federated-learning.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-what-is-federated-learning.ipynb))
51
+ 1. **[An Introduction to Federated Learning](https://flower.ai/docs/framework/main/en/tutorial-series-get-started-with-flower-pytorch.html)**
52
52
 
53
- 1. **An Introduction to Federated Learning**
53
+ 2. **[Using Strategies in Federated Learning](https://flower.ai/docs/framework/main/en/tutorial-series-use-a-federated-learning-strategy-pytorch.html)**
54
54
 
55
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-get-started-with-flower-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-get-started-with-flower-pytorch.ipynb))
55
+ 3. **[Customize a Flower Strategy](https://flower.ai/docs/framework/main/en/tutorial-series-build-a-strategy-from-scratch-pytorch.html)**
56
56
 
57
- 2. **Using Strategies in Federated Learning**
58
-
59
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-use-a-federated-learning-strategy-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-use-a-federated-learning-strategy-pytorch.ipynb))
60
-
61
- 3. **Building Strategies for Federated Learning**
62
-
63
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-build-a-strategy-from-scratch-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-build-a-strategy-from-scratch-pytorch.ipynb))
64
-
65
- 4. **Custom Clients for Federated Learning**
66
-
67
- [![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/adap/flower/blob/main/framework/docs/source/tutorial-series-customize-the-client-pytorch.ipynb) (or open the [Jupyter Notebook](https://github.com/adap/flower/blob/main/framework/docs/source/tutorial-series-customize-the-client-pytorch.ipynb))
57
+ 4. **[Communicate Custom Messages](https://flower.ai/docs/framework/main/en/tutorial-series-customize-the-client-pytorch.html)**
68
58
 
69
59
  Stay tuned, more tutorials are coming soon. Topics include **Privacy and Security in Federated Learning**, and **Scaling Federated Learning**.
70
60
 
@@ -25,6 +25,7 @@ from .log import log
25
25
  from .login import login
26
26
  from .ls import ls
27
27
  from .new import new
28
+ from .pull import pull
28
29
  from .run import run
29
30
  from .stop import stop
30
31
 
@@ -46,6 +47,7 @@ app.command()(log)
46
47
  app.command()(ls)
47
48
  app.command()(stop)
48
49
  app.command()(login)
50
+ app.command()(pull)
49
51
 
50
52
  typer_click_object = get_command(app)
51
53
 
@@ -201,7 +201,7 @@ def new(
201
201
  }
202
202
 
203
203
  # Challenge specific context
204
- fraction_fit = "0.2" if llm_challenge_str == "code" else "0.1"
204
+ fraction_train = "0.2" if llm_challenge_str == "code" else "0.1"
205
205
  if llm_challenge_str == "generalnlp":
206
206
  challenge_name = "General NLP"
207
207
  num_clients = "20"
@@ -220,7 +220,7 @@ def new(
220
220
  dataset_name = "flwrlabs/code-alpaca-20k"
221
221
 
222
222
  context["llm_challenge_str"] = llm_challenge_str
223
- context["fraction_fit"] = fraction_fit
223
+ context["fraction_train"] = fraction_train
224
224
  context["challenge_name"] = challenge_name
225
225
  context["num_clients"] = num_clients
226
226
  context["dataset_name"] = dataset_name
@@ -26,7 +26,7 @@ pip install -e .
26
26
  ## Experimental setup
27
27
 
28
28
  The dataset is divided into $num_clients partitions in an IID fashion, a partition is assigned to each ClientApp.
29
- We randomly sample a fraction ($fraction_fit) of the total nodes to participate in each round, for a total of `200` rounds.
29
+ We randomly sample a fraction ($fraction_train) of the total nodes to participate in each round, for a total of `200` rounds.
30
30
  All settings are defined in `pyproject.toml`.
31
31
 
32
32
  > [!IMPORTANT]
@@ -0,0 +1,75 @@
1
+ """$project_name: A Flower Baseline."""
2
+
3
+ import torch
4
+ from flwr.app import ArrayRecord, Context, Message, MetricRecord, RecordDict
5
+ from flwr.clientapp import ClientApp
6
+
7
+ from $import_name.dataset import load_data
8
+ from $import_name.model import Net
9
+ from $import_name.model import test as test_fn
10
+ from $import_name.model import train as train_fn
11
+
12
+ # Flower ClientApp
13
+ app = ClientApp()
14
+
15
+
16
+ @app.train()
17
+ def train(msg: Message, context: Context):
18
+ """Train the model on local data."""
19
+
20
+ # Load the model and initialize it with the received weights
21
+ model = Net()
22
+ model.load_state_dict(msg.content["arrays"].to_torch_state_dict())
23
+ device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
24
+
25
+ # Load the data
26
+ partition_id = int(context.node_config["partition-id"])
27
+ num_partitions = int(context.node_config["num-partitions"])
28
+ trainloader, _ = load_data(partition_id, num_partitions)
29
+ local_epochs = context.run_config["local-epochs"]
30
+
31
+ # Call the training function
32
+ train_loss = train_fn(
33
+ model,
34
+ trainloader,
35
+ local_epochs,
36
+ device,
37
+ )
38
+
39
+ # Construct and return reply Message
40
+ model_record = ArrayRecord(model.state_dict())
41
+ metrics = {
42
+ "train_loss": train_loss,
43
+ "num-examples": len(trainloader.dataset),
44
+ }
45
+ metric_record = MetricRecord(metrics)
46
+ content = RecordDict({"arrays": model_record, "metrics": metric_record})
47
+ return Message(content=content, reply_to=msg)
48
+
49
+
50
+ @app.evaluate()
51
+ def evaluate(msg: Message, context: Context):
52
+ """Evaluate the model on local data."""
53
+
54
+ # Load the model and initialize it with the received weights
55
+ model = Net()
56
+ model.load_state_dict(msg.content["arrays"].to_torch_state_dict())
57
+ device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
58
+
59
+ # Load the data
60
+ partition_id = int(context.node_config["partition-id"])
61
+ num_partitions = int(context.node_config["num-partitions"])
62
+ _, valloader = load_data(partition_id, num_partitions)
63
+
64
+ # Call the evaluation function
65
+ eval_loss, eval_acc = test_fn(model, valloader, device)
66
+
67
+ # Construct and return reply Message
68
+ metrics = {
69
+ "eval_loss": eval_loss,
70
+ "eval_acc": eval_acc,
71
+ "num-examples": len(valloader.dataset),
72
+ }
73
+ metric_record = MetricRecord(metrics)
74
+ content = RecordDict({"metrics": metric_record})
75
+ return Message(content=content, reply_to=msg)
@@ -0,0 +1,92 @@
1
+ """$project_name: A Flower / FlowerTune app."""
2
+
3
+ import os
4
+ import warnings
5
+
6
+ from flwr.app import ArrayRecord, Context, Message, MetricRecord, RecordDict
7
+ from flwr.clientapp import ClientApp
8
+ from flwr.common.config import unflatten_dict
9
+ from omegaconf import DictConfig
10
+ from peft import get_peft_model_state_dict, set_peft_model_state_dict
11
+ from transformers import TrainingArguments
12
+ from trl import SFTTrainer
13
+
14
+ from $import_name.dataset import (
15
+ get_tokenizer_and_data_collator_and_propt_formatting,
16
+ load_data,
17
+ replace_keys,
18
+ )
19
+ from $import_name.models import cosine_annealing, get_model
20
+
21
+ # Avoid warnings
22
+ os.environ["TOKENIZERS_PARALLELISM"] = "true"
23
+ os.environ["RAY_DISABLE_DOCKER_CPU_WARNING"] = "1"
24
+ warnings.filterwarnings("ignore", category=UserWarning)
25
+
26
+
27
+ # Avoid warnings
28
+ os.environ["TOKENIZERS_PARALLELISM"] = "true"
29
+ os.environ["RAY_DISABLE_DOCKER_CPU_WARNING"] = "1"
30
+ warnings.filterwarnings("ignore", category=UserWarning)
31
+
32
+
33
+ # Flower ClientApp
34
+ app = ClientApp()
35
+
36
+
37
+ @app.train()
38
+ def train(msg: Message, context: Context):
39
+ """Train the model on local data."""
40
+ # Parse config
41
+ partition_id = context.node_config["partition-id"]
42
+ num_partitions = context.node_config["num-partitions"]
43
+ num_rounds = context.run_config["num-server-rounds"]
44
+ cfg = DictConfig(replace_keys(unflatten_dict(context.run_config)))
45
+ training_arguments = TrainingArguments(**cfg.train.training_arguments)
46
+
47
+ # Let's get the client partition
48
+ trainset = load_data(partition_id, num_partitions, cfg.static.dataset.name)
49
+ (
50
+ tokenizer,
51
+ data_collator,
52
+ formatting_prompts_func,
53
+ ) = get_tokenizer_and_data_collator_and_propt_formatting(cfg.model.name)
54
+
55
+ # Load the model and initialize it with the received weights
56
+ model = get_model(cfg.model)
57
+ set_peft_model_state_dict(model, msg.content["arrays"].to_torch_state_dict())
58
+
59
+ # Set learning rate for current round
60
+ new_lr = cosine_annealing(
61
+ msg.content["config"]["server-round"],
62
+ num_rounds,
63
+ cfg.train.learning_rate_max,
64
+ cfg.train.learning_rate_min,
65
+ )
66
+
67
+ training_arguments.learning_rate = new_lr
68
+ training_arguments.output_dir = msg.content["config"]["save_path"]
69
+
70
+ # Construct trainer
71
+ trainer = SFTTrainer(
72
+ model=model,
73
+ tokenizer=tokenizer,
74
+ args=training_arguments,
75
+ max_seq_length=cfg.train.seq_length,
76
+ train_dataset=trainset,
77
+ formatting_func=formatting_prompts_func,
78
+ data_collator=data_collator,
79
+ )
80
+
81
+ # Do local training
82
+ results = trainer.train()
83
+
84
+ # Construct and return reply Message
85
+ model_record = ArrayRecord(get_peft_model_state_dict(model))
86
+ metrics = {
87
+ "train_loss": results.training_loss,
88
+ "num-examples": len(trainset),
89
+ }
90
+ metric_record = MetricRecord(metrics)
91
+ content = RecordDict({"arrays": model_record, "metrics": metric_record})
92
+ return Message(content=content, reply_to=msg)
@@ -4,18 +4,10 @@ import math
4
4
 
5
5
  import torch
6
6
  from omegaconf import DictConfig
7
- from collections import OrderedDict
8
- from peft import (
9
- LoraConfig,
10
- get_peft_model,
11
- get_peft_model_state_dict,
12
- set_peft_model_state_dict,
13
- )
7
+ from peft import LoraConfig, get_peft_model
14
8
  from peft.utils import prepare_model_for_kbit_training
15
9
  from transformers import AutoModelForCausalLM, BitsAndBytesConfig
16
10
 
17
- from flwr.common.typing import NDArrays
18
-
19
11
 
20
12
  def cosine_annealing(
21
13
  current_round: int,
@@ -62,17 +54,3 @@ def get_model(model_cfg: DictConfig):
62
54
  model.config.use_cache = False
63
55
 
64
56
  return get_peft_model(model, peft_config)
65
-
66
-
67
- def set_parameters(model, parameters: NDArrays) -> None:
68
- """Change the parameters of the model using the given ones."""
69
- peft_state_dict_keys = get_peft_model_state_dict(model).keys()
70
- params_dict = zip(peft_state_dict_keys, parameters)
71
- state_dict = OrderedDict({k: torch.Tensor(v) for k, v in params_dict})
72
- set_peft_model_state_dict(model, state_dict)
73
-
74
-
75
- def get_parameters(model) -> NDArrays:
76
- """Return the parameters of the current net."""
77
- state_dict = get_peft_model_state_dict(model)
78
- return [val.cpu().numpy() for _, val in state_dict.items()]
@@ -0,0 +1,73 @@
1
+ """$project_name: A Flower / FlowerTune app."""
2
+
3
+ import os
4
+ from datetime import datetime
5
+
6
+ from flwr.app import ArrayRecord, ConfigRecord, Context, MetricRecord
7
+ from flwr.common.config import unflatten_dict
8
+ from flwr.serverapp import Grid, ServerApp
9
+ from omegaconf import DictConfig
10
+ from peft import get_peft_model_state_dict, set_peft_model_state_dict
11
+
12
+ from $import_name.dataset import replace_keys
13
+ from $import_name.models import get_model
14
+ from $import_name.strategy import FlowerTuneLlm
15
+
16
+ # Create ServerApp
17
+ app = ServerApp()
18
+
19
+
20
+ @app.main()
21
+ def main(grid: Grid, context: Context) -> None:
22
+ """Main entry point for the ServerApp."""
23
+ # Create output directory given current timestamp
24
+ current_time = datetime.now()
25
+ folder_name = current_time.strftime("%Y-%m-%d_%H-%M-%S")
26
+ save_path = os.path.join(os.getcwd(), f"results/{folder_name}")
27
+ os.makedirs(save_path, exist_ok=True)
28
+
29
+ # Read from config
30
+ num_rounds = context.run_config["num-server-rounds"]
31
+ cfg = DictConfig(replace_keys(unflatten_dict(context.run_config)))
32
+
33
+ # Get initial model weights
34
+ init_model = get_model(cfg.model)
35
+ arrays = ArrayRecord(get_peft_model_state_dict(init_model))
36
+
37
+ # Define strategy
38
+ strategy = FlowerTuneLlm(
39
+ fraction_train=cfg.strategy.fraction_train,
40
+ fraction_evaluate=cfg.strategy.fraction_evaluate,
41
+ )
42
+
43
+ # Start strategy, run FedAvg for `num_rounds`
44
+ strategy.start(
45
+ grid=grid,
46
+ initial_arrays=arrays,
47
+ train_config=ConfigRecord({"save_path": save_path}),
48
+ num_rounds=num_rounds,
49
+ evaluate_fn=get_evaluate_fn(
50
+ cfg.model, cfg.train.save_every_round, num_rounds, save_path
51
+ ),
52
+ )
53
+
54
+
55
+ # Get function that will be executed by the strategy
56
+ # Here we use it to save global model checkpoints
57
+ def get_evaluate_fn(model_cfg, save_every_round, total_round, save_path):
58
+ """Return an evaluation function for saving global model."""
59
+
60
+ def evaluate(server_round: int, arrays: ArrayRecord) -> MetricRecord:
61
+ # Save model
62
+ if server_round != 0 and (
63
+ server_round == total_round or server_round % save_every_round == 0
64
+ ):
65
+ # Init model
66
+ model = get_model(model_cfg)
67
+ set_peft_model_state_dict(model, arrays.to_torch_state_dict())
68
+
69
+ model.save_pretrained(f"{save_path}/peft_{server_round}")
70
+
71
+ return MetricRecord()
72
+
73
+ return evaluate
@@ -0,0 +1,78 @@
1
+ """$project_name: A Flower / FlowerTune app."""
2
+
3
+ from collections.abc import Iterable
4
+ from logging import INFO, WARN
5
+ from typing import Optional
6
+
7
+ from flwr.app import ArrayRecord, ConfigRecord, Message, MetricRecord
8
+ from flwr.common import log
9
+ from flwr.serverapp import Grid
10
+ from flwr.serverapp.strategy import FedAvg
11
+
12
+
13
+ class FlowerTuneLlm(FedAvg):
14
+ """Customised FedAvg strategy implementation.
15
+
16
+ This class behaves just like FedAvg but also tracks the communication
17
+ costs associated with `train` over FL rounds.
18
+ """
19
+ def __init__(self, **kwargs):
20
+ super().__init__(**kwargs)
21
+ self.comm_tracker = CommunicationTracker()
22
+
23
+ def configure_train(
24
+ self, server_round: int, arrays: ArrayRecord, config: ConfigRecord, grid: Grid
25
+ ) -> Iterable[Message]:
26
+ """Configure the next round of training."""
27
+ messages = super().configure_train(server_round, arrays, config, grid)
28
+
29
+ # Track communication costs
30
+ self.comm_tracker.track(messages)
31
+
32
+ return messages
33
+
34
+ def aggregate_train(
35
+ self,
36
+ server_round: int,
37
+ replies: Iterable[Message],
38
+ ) -> tuple[Optional[ArrayRecord], Optional[MetricRecord]]:
39
+ """Aggregate ArrayRecords and MetricRecords in the received Messages."""
40
+ # Track communication costs
41
+ self.comm_tracker.track(replies)
42
+
43
+ arrays, metrics = super().aggregate_train(server_round, replies)
44
+
45
+ return arrays, metrics
46
+
47
+
48
+ class CommunicationTracker:
49
+ """Communication costs tracker over FL rounds."""
50
+ def __init__(self):
51
+ self.curr_comm_cost = 0.0
52
+
53
+ def track(self, messages: Iterable[Message]):
54
+ comm_cost = (
55
+ sum(
56
+ record.count_bytes()
57
+ for msg in messages
58
+ if msg.has_content()
59
+ for record in msg.content.array_records.values()
60
+ )
61
+ / 1024**2
62
+ )
63
+
64
+ self.curr_comm_cost += comm_cost
65
+ log(
66
+ INFO,
67
+ "Communication budget: used %.2f MB (+%.2f MB this round) / 200,000 MB",
68
+ self.curr_comm_cost,
69
+ comm_cost,
70
+ )
71
+
72
+ if self.curr_comm_cost > 2e5:
73
+ log(
74
+ WARN,
75
+ "The accumulated communication cost has exceeded 200,000 MB. "
76
+ "Please consider reducing it if you plan to participate "
77
+ "FlowerTune LLM Leaderboard.",
78
+ )
@@ -1,7 +1,5 @@
1
1
  """$project_name: A Flower Baseline."""
2
2
 
3
- from collections import OrderedDict
4
-
5
3
  import torch
6
4
  import torch.nn.functional as F
7
5
  from torch import nn
@@ -66,15 +64,3 @@ def test(net, testloader, device):
66
64
  accuracy = correct / len(testloader.dataset)
67
65
  loss = loss / len(testloader)
68
66
  return loss, accuracy
69
-
70
-
71
- def get_weights(net):
72
- """Extract model parameters as numpy arrays from state_dict."""
73
- return [val.cpu().numpy() for _, val in net.state_dict().items()]
74
-
75
-
76
- def set_weights(net, parameters):
77
- """Apply parameters to an existing model."""
78
- params_dict = zip(net.state_dict().keys(), parameters)
79
- state_dict = OrderedDict({k: torch.from_numpy(v) for k, v in params_dict})
80
- net.load_state_dict(state_dict, strict=True)
@@ -0,0 +1,43 @@
1
+ """$project_name: A Flower Baseline."""
2
+
3
+ import torch
4
+ from flwr.app import ArrayRecord, Context
5
+ from flwr.serverapp import Grid, ServerApp
6
+ from flwr.serverapp.strategy import FedAvg
7
+
8
+ from $import_name.model import Net
9
+
10
+ # Create ServerApp
11
+ app = ServerApp()
12
+
13
+
14
+ @app.main()
15
+ def main(grid: Grid, context: Context) -> None:
16
+ """Main entry point for the ServerApp."""
17
+
18
+ # Read from config
19
+ num_rounds = context.run_config["num-server-rounds"]
20
+ fraction_train = context.run_config["fraction-train"]
21
+
22
+ # Load global model
23
+ global_model = Net()
24
+ arrays = ArrayRecord(global_model.state_dict())
25
+
26
+ # Initialize FedAvg strategy
27
+ strategy = FedAvg(
28
+ fraction_train=fraction_train,
29
+ fraction_evaluate=1.0,
30
+ min_available_nodes=2,
31
+ )
32
+
33
+ # Start strategy, run FedAvg for `num_rounds`
34
+ result = strategy.start(
35
+ grid=grid,
36
+ initial_arrays=arrays,
37
+ num_rounds=num_rounds,
38
+ )
39
+
40
+ # Save final model to disk
41
+ print("\nSaving final model to disk...")
42
+ state_dict = result.arrays.to_torch_state_dict()
43
+ torch.save(state_dict, "final_model.pt")
@@ -16,8 +16,8 @@ license = "Apache-2.0"
16
16
  dependencies = [
17
17
  "flwr[simulation]>=1.22.0",
18
18
  "flwr-datasets[vision]>=0.5.0",
19
- "torch==2.7.1",
20
- "torchvision==0.22.1",
19
+ "torch==2.8.0",
20
+ "torchvision==0.23.0",
21
21
  ]
22
22
 
23
23
  [tool.hatch.metadata]
@@ -132,7 +132,7 @@ clientapp = "$import_name.client_app:app"
132
132
  # Custom config values accessible via `context.run_config`
133
133
  [tool.flwr.app.config]
134
134
  num-server-rounds = 3
135
- fraction-fit = 0.5
135
+ fraction-train = 0.5
136
136
  local-epochs = 1
137
137
 
138
138
  # Default federation to use when running the app
@@ -61,7 +61,7 @@ train.training-arguments.save-steps = 1000
61
61
  train.training-arguments.save-total-limit = 10
62
62
  train.training-arguments.gradient-checkpointing = true
63
63
  train.training-arguments.lr-scheduler-type = "constant"
64
- strategy.fraction-fit = $fraction_fit
64
+ strategy.fraction-train = $fraction_train
65
65
  strategy.fraction-evaluate = 0.0
66
66
  num-server-rounds = 200
67
67