flwr-nightly 1.13.0.dev20241107__tar.gz → 1.13.0.dev20241108__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.

Potentially problematic release.


This version of flwr-nightly might be problematic. Click here for more details.

Files changed (325) hide show
  1. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/PKG-INFO +3 -3
  2. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/pyproject.toml +3 -3
  3. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/object_ref.py +38 -14
  4. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/typing.py +1 -1
  5. flwr_nightly-1.13.0.dev20241108/src/py/flwr/proto/run_pb2.py +64 -0
  6. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/run_pb2.pyi +26 -0
  7. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/simulationio_pb2.py +2 -2
  8. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/simulationio_pb2_grpc.py +34 -0
  9. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/simulationio_pb2_grpc.pyi +13 -0
  10. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/aggregate.py +4 -4
  11. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/simulation/simulationio_servicer.py +22 -1
  12. flwr_nightly-1.13.0.dev20241107/src/py/flwr/proto/run_pb2.py +0 -59
  13. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/LICENSE +0 -0
  14. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/README.md +0 -0
  15. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/__init__.py +0 -0
  16. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/__init__.py +0 -0
  17. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/app.py +0 -0
  18. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/build.py +0 -0
  19. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/config_utils.py +0 -0
  20. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/example.py +0 -0
  21. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/install.py +0 -0
  22. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/log.py +0 -0
  23. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/__init__.py +0 -0
  24. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/new.py +0 -0
  25. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/__init__.py +0 -0
  26. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  27. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/LICENSE.tpl +0 -0
  28. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/README.baseline.md.tpl +0 -0
  29. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  30. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  31. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/__init__.py +0 -0
  32. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/__init__.baseline.py.tpl +0 -0
  33. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  34. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  35. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.baseline.py.tpl +0 -0
  36. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.huggingface.py.tpl +0 -0
  37. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  38. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
  39. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  40. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
  41. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
  42. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
  43. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/dataset.baseline.py.tpl +0 -0
  44. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  45. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/flwr_tune/client_app.py.tpl +0 -0
  46. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  47. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  48. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/flwr_tune/server_app.py.tpl +0 -0
  49. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/flwr_tune/strategy.py.tpl +0 -0
  50. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/model.baseline.py.tpl +0 -0
  51. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.baseline.py.tpl +0 -0
  52. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.huggingface.py.tpl +0 -0
  53. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  54. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  55. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  56. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  57. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  58. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  59. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/strategy.baseline.py.tpl +0 -0
  60. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/task.huggingface.py.tpl +0 -0
  61. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  62. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  63. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/task.numpy.py.tpl +0 -0
  64. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  65. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/task.sklearn.py.tpl +0 -0
  66. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  67. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/code/utils.baseline.py.tpl +0 -0
  68. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.baseline.toml.tpl +0 -0
  69. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  70. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.huggingface.toml.tpl +0 -0
  71. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
  72. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
  73. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  74. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
  75. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  76. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
  77. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/run/__init__.py +0 -0
  78. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/run/run.py +0 -0
  79. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/cli/utils.py +0 -0
  80. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/__init__.py +0 -0
  81. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/app.py +0 -0
  82. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/client.py +0 -0
  83. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/client_app.py +0 -0
  84. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/clientapp/__init__.py +0 -0
  85. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/clientapp/app.py +0 -0
  86. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/clientapp/clientappio_servicer.py +0 -0
  87. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/clientapp/utils.py +0 -0
  88. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  89. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  90. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  91. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_client/__init__.py +0 -0
  92. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_client/connection.py +0 -0
  93. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  94. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  95. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_rere_client/connection.py +0 -0
  96. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  97. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/heartbeat.py +0 -0
  98. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/message_handler/__init__.py +0 -0
  99. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/message_handler/message_handler.py +0 -0
  100. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/message_handler/task_handler.py +0 -0
  101. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/__init__.py +0 -0
  102. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/centraldp_mods.py +0 -0
  103. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/comms_mods.py +0 -0
  104. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/localdp_mod.py +0 -0
  105. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  106. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  107. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  108. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/mod/utils.py +0 -0
  109. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/nodestate/__init__.py +0 -0
  110. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/nodestate/in_memory_nodestate.py +0 -0
  111. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/nodestate/nodestate.py +0 -0
  112. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/nodestate/nodestate_factory.py +0 -0
  113. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/numpy_client.py +0 -0
  114. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/rest_client/__init__.py +0 -0
  115. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/rest_client/connection.py +0 -0
  116. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/run_info_store.py +0 -0
  117. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/supernode/__init__.py +0 -0
  118. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/supernode/app.py +0 -0
  119. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/client/typing.py +0 -0
  120. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/__init__.py +0 -0
  121. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/address.py +0 -0
  122. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/config.py +0 -0
  123. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/constant.py +0 -0
  124. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/context.py +0 -0
  125. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/date.py +0 -0
  126. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/differential_privacy.py +0 -0
  127. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/differential_privacy_constants.py +0 -0
  128. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/dp.py +0 -0
  129. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/exit_handlers.py +0 -0
  130. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/grpc.py +0 -0
  131. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/logger.py +0 -0
  132. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/message.py +0 -0
  133. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/parameter.py +0 -0
  134. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/pyproject.py +0 -0
  135. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/record/__init__.py +0 -0
  136. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/record/configsrecord.py +0 -0
  137. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/record/conversion_utils.py +0 -0
  138. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/record/metricsrecord.py +0 -0
  139. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/record/parametersrecord.py +0 -0
  140. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/record/recordset.py +0 -0
  141. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/record/typeddict.py +0 -0
  142. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/recordset_compat.py +0 -0
  143. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/retry_invoker.py +0 -0
  144. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/__init__.py +0 -0
  145. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  146. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  147. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  148. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  149. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/quantization.py +0 -0
  150. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  151. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  152. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/serde.py +0 -0
  153. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/telemetry.py +0 -0
  154. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/common/version.py +0 -0
  155. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/__init__.py +0 -0
  156. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/clientappio_pb2.py +0 -0
  157. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/clientappio_pb2.pyi +0 -0
  158. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/clientappio_pb2_grpc.py +0 -0
  159. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/clientappio_pb2_grpc.pyi +0 -0
  160. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/common_pb2.py +0 -0
  161. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/common_pb2.pyi +0 -0
  162. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/common_pb2_grpc.py +0 -0
  163. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/common_pb2_grpc.pyi +0 -0
  164. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/control_pb2.py +0 -0
  165. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/control_pb2.pyi +0 -0
  166. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/control_pb2_grpc.py +0 -0
  167. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/control_pb2_grpc.pyi +0 -0
  168. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/error_pb2.py +0 -0
  169. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/error_pb2.pyi +0 -0
  170. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/error_pb2_grpc.py +0 -0
  171. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  172. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/exec_pb2.py +0 -0
  173. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/exec_pb2.pyi +0 -0
  174. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/exec_pb2_grpc.py +0 -0
  175. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/exec_pb2_grpc.pyi +0 -0
  176. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fab_pb2.py +0 -0
  177. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fab_pb2.pyi +0 -0
  178. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fab_pb2_grpc.py +0 -0
  179. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  180. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fleet_pb2.py +0 -0
  181. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fleet_pb2.pyi +0 -0
  182. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  183. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  184. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/grpcadapter_pb2.py +0 -0
  185. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  186. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  187. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  188. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/log_pb2.py +0 -0
  189. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/log_pb2.pyi +0 -0
  190. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/log_pb2_grpc.py +0 -0
  191. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/log_pb2_grpc.pyi +0 -0
  192. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/message_pb2.py +0 -0
  193. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/message_pb2.pyi +0 -0
  194. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/message_pb2_grpc.py +0 -0
  195. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/message_pb2_grpc.pyi +0 -0
  196. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/node_pb2.py +0 -0
  197. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/node_pb2.pyi +0 -0
  198. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/node_pb2_grpc.py +0 -0
  199. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  200. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/recordset_pb2.py +0 -0
  201. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/recordset_pb2.pyi +0 -0
  202. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/recordset_pb2_grpc.py +0 -0
  203. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/recordset_pb2_grpc.pyi +0 -0
  204. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/run_pb2_grpc.py +0 -0
  205. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  206. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/serverappio_pb2.py +0 -0
  207. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/serverappio_pb2.pyi +0 -0
  208. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/serverappio_pb2_grpc.py +0 -0
  209. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/serverappio_pb2_grpc.pyi +0 -0
  210. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/simulationio_pb2.pyi +0 -0
  211. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/task_pb2.py +0 -0
  212. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/task_pb2.pyi +0 -0
  213. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/task_pb2_grpc.py +0 -0
  214. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/task_pb2_grpc.pyi +0 -0
  215. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/transport_pb2.py +0 -0
  216. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/transport_pb2.pyi +0 -0
  217. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/transport_pb2_grpc.py +0 -0
  218. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  219. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/py.typed +0 -0
  220. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/__init__.py +0 -0
  221. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/app.py +0 -0
  222. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/client_manager.py +0 -0
  223. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/client_proxy.py +0 -0
  224. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/compat/__init__.py +0 -0
  225. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/compat/app.py +0 -0
  226. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/compat/app_utils.py +0 -0
  227. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/compat/driver_client_proxy.py +0 -0
  228. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/compat/legacy_context.py +0 -0
  229. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/criterion.py +0 -0
  230. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/driver/__init__.py +0 -0
  231. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/driver/driver.py +0 -0
  232. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/driver/grpc_driver.py +0 -0
  233. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/driver/inmemory_driver.py +0 -0
  234. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/history.py +0 -0
  235. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/run_serverapp.py +0 -0
  236. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/server.py +0 -0
  237. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/server_app.py +0 -0
  238. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/server_config.py +0 -0
  239. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/serverapp/__init__.py +0 -0
  240. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/serverapp/app.py +0 -0
  241. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/serverapp_components.py +0 -0
  242. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/__init__.py +0 -0
  243. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/bulyan.py +0 -0
  244. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  245. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  246. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  247. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  248. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  249. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedadagrad.py +0 -0
  250. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedadam.py +0 -0
  251. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedavg.py +0 -0
  252. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedavg_android.py +0 -0
  253. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedavgm.py +0 -0
  254. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedmedian.py +0 -0
  255. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedopt.py +0 -0
  256. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedprox.py +0 -0
  257. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  258. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  259. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  260. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  261. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/fedyogi.py +0 -0
  262. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/krum.py +0 -0
  263. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/qfedavg.py +0 -0
  264. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/strategy/strategy.py +0 -0
  265. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/__init__.py +0 -0
  266. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/driver/__init__.py +0 -0
  267. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/driver/serverappio_grpc.py +0 -0
  268. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/driver/serverappio_servicer.py +0 -0
  269. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/ffs/__init__.py +0 -0
  270. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/ffs/disk_ffs.py +0 -0
  271. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/ffs/ffs.py +0 -0
  272. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/ffs/ffs_factory.py +0 -0
  273. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/__init__.py +0 -0
  274. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  275. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  276. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  277. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  278. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  279. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  280. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  281. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  282. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  283. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  284. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  285. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  286. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  287. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  288. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  289. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  290. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  291. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  292. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  293. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/linkstate/__init__.py +0 -0
  294. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/linkstate/in_memory_linkstate.py +0 -0
  295. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/linkstate/linkstate.py +0 -0
  296. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/linkstate/linkstate_factory.py +0 -0
  297. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/linkstate/sqlite_linkstate.py +0 -0
  298. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/linkstate/utils.py +0 -0
  299. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/simulation/__init__.py +0 -0
  300. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/superlink/simulation/simulationio_grpc.py +0 -0
  301. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/typing.py +0 -0
  302. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/utils/__init__.py +0 -0
  303. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/utils/tensorboard.py +0 -0
  304. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/utils/validator.py +0 -0
  305. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/workflow/__init__.py +0 -0
  306. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/workflow/constant.py +0 -0
  307. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/workflow/default_workflows.py +0 -0
  308. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  309. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  310. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  311. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/__init__.py +0 -0
  312. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/app.py +0 -0
  313. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/ray_transport/__init__.py +0 -0
  314. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  315. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  316. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/ray_transport/utils.py +0 -0
  317. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/run_simulation.py +0 -0
  318. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/simulation/simulationio_connection.py +0 -0
  319. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/superexec/__init__.py +0 -0
  320. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/superexec/app.py +0 -0
  321. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/superexec/deployment.py +0 -0
  322. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/superexec/exec_grpc.py +0 -0
  323. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/superexec/exec_servicer.py +0 -0
  324. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/superexec/executor.py +0 -0
  325. {flwr_nightly-1.13.0.dev20241107 → flwr_nightly-1.13.0.dev20241108}/src/py/flwr/superexec/simulation.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: flwr-nightly
3
- Version: 1.13.0.dev20241107
3
+ Version: 1.13.0.dev20241108
4
4
  Summary: Flower: A Friendly Federated Learning Framework
5
5
  Home-page: https://flower.ai
6
6
  License: Apache-2.0
@@ -32,9 +32,9 @@ Classifier: Typing :: Typed
32
32
  Provides-Extra: rest
33
33
  Provides-Extra: simulation
34
34
  Requires-Dist: cryptography (>=42.0.4,<43.0.0)
35
- Requires-Dist: grpcio (>=1.60.0,<2.0.0,!=1.64.2,!=1.65.1,!=1.65.2,!=1.65.4,!=1.65.5,!=1.66.0,!=1.66.1)
35
+ Requires-Dist: grpcio (>=1.60.0,<2.0.0,!=1.64.2,<=1.64.3)
36
36
  Requires-Dist: iterators (>=0.0.2,<0.0.3)
37
- Requires-Dist: numpy (>=1.21.0,<2.0.0)
37
+ Requires-Dist: numpy (>=1.26.0,<3.0.0)
38
38
  Requires-Dist: pathspec (>=0.12.1,<0.13.0)
39
39
  Requires-Dist: protobuf (>=4.25.2,<5.0.0)
40
40
  Requires-Dist: pycryptodome (>=3.18.0,<4.0.0)
@@ -4,7 +4,7 @@ build-backend = "poetry.core.masonry.api"
4
4
 
5
5
  [tool.poetry]
6
6
  name = "flwr-nightly"
7
- version = "1.13.0.dev20241107"
7
+ version = "1.13.0.dev20241108"
8
8
  description = "Flower: A Friendly Federated Learning Framework"
9
9
  license = "Apache-2.0"
10
10
  authors = ["The Flower Authors <hello@flower.ai>"]
@@ -64,8 +64,8 @@ flower-client-app = "flwr.client.supernode:run_client_app" # Deprecated
64
64
  [tool.poetry.dependencies]
65
65
  python = "^3.9"
66
66
  # Mandatory dependencies
67
- numpy = "^1.21.0"
68
- grpcio = "^1.60.0,!=1.64.2,!=1.65.1,!=1.65.2,!=1.65.4,!=1.65.5,!=1.66.0,!=1.66.1"
67
+ numpy = ">=1.26.0,<3.0.0"
68
+ grpcio = "^1.60.0,!=1.64.2,<=1.64.3"
69
69
  protobuf = "^4.25.2"
70
70
  cryptography = "^42.0.4"
71
71
  pycryptodome = "^3.18.0"
@@ -153,21 +153,36 @@ def load_app( # pylint: disable= too-many-branches
153
153
  module_str, _, attributes_str = module_attribute_str.partition(":")
154
154
 
155
155
  try:
156
- if _current_sys_path:
157
- # Hack: `tabnet` does not work with reloading
158
- if "tabnet" in sys.modules:
159
- log(
160
- WARN,
161
- "Cannot reload module `%s` from disk due to compatibility issues "
162
- "with the `tabnet` library. The module will be loaded from the "
163
- "cache instead. If you experience issues, consider restarting "
164
- "the application.",
165
- module_str,
166
- )
167
- else:
168
- _unload_modules(Path(_current_sys_path))
156
+ # Initialize project path
157
+ if project_dir is None:
158
+ project_dir = Path.cwd()
159
+ project_dir = Path(project_dir).absolute()
160
+
161
+ # Unload modules if the project directory has changed
162
+ if _current_sys_path and _current_sys_path != str(project_dir):
163
+ _unload_modules(Path(_current_sys_path))
164
+
165
+ # Set the system path
169
166
  _set_sys_path(project_dir)
170
- module = importlib.import_module(module_str)
167
+
168
+ # Import the module
169
+ if module_str not in sys.modules:
170
+ module = importlib.import_module(module_str)
171
+ # Hack: `tabnet` does not work with `importlib.reload`
172
+ elif "tabnet" in sys.modules:
173
+ log(
174
+ WARN,
175
+ "Cannot reload module `%s` from disk due to compatibility issues "
176
+ "with the `tabnet` library. The module will be loaded from the "
177
+ "cache instead. If you experience issues, consider restarting "
178
+ "the application.",
179
+ module_str,
180
+ )
181
+ module = sys.modules[module_str]
182
+ else:
183
+ module = sys.modules[module_str]
184
+ _reload_modules(project_dir)
185
+
171
186
  except ModuleNotFoundError as err:
172
187
  raise error_type(
173
188
  f"Unable to load module {module_str}{OBJECT_REF_HELP_STR}",
@@ -196,6 +211,15 @@ def _unload_modules(project_dir: Path) -> None:
196
211
  del sys.modules[name]
197
212
 
198
213
 
214
+ def _reload_modules(project_dir: Path) -> None:
215
+ """Reload modules from the project directory."""
216
+ dir_str = str(project_dir.absolute())
217
+ for m in list(sys.modules.values()):
218
+ path: Optional[str] = getattr(m, "__file__", None)
219
+ if path is not None and path.startswith(dir_str):
220
+ importlib.reload(m)
221
+
222
+
199
223
  def _set_sys_path(directory: Optional[Union[str, Path]]) -> None:
200
224
  """Set the system path."""
201
225
  if directory is None:
@@ -24,7 +24,7 @@ import numpy.typing as npt
24
24
 
25
25
  NDArray = npt.NDArray[Any]
26
26
  NDArrayInt = npt.NDArray[np.int_]
27
- NDArrayFloat = npt.NDArray[np.float_]
27
+ NDArrayFloat = npt.NDArray[np.float64]
28
28
  NDArrays = list[NDArray]
29
29
 
30
30
  # The following union type contains Python types corresponding to ProtoBuf types that
@@ -0,0 +1,64 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
3
+ # source: flwr/proto/run.proto
4
+ # Protobuf Python Version: 4.25.0
5
+ """Generated protocol buffer code."""
6
+ from google.protobuf import descriptor as _descriptor
7
+ from google.protobuf import descriptor_pool as _descriptor_pool
8
+ from google.protobuf import symbol_database as _symbol_database
9
+ from google.protobuf.internal import builder as _builder
10
+ # @@protoc_insertion_point(imports)
11
+
12
+ _sym_db = _symbol_database.Default()
13
+
14
+
15
+ from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
16
+ from flwr.proto import node_pb2 as flwr_dot_proto_dot_node__pb2
17
+ from flwr.proto import recordset_pb2 as flwr_dot_proto_dot_recordset__pb2
18
+ from flwr.proto import transport_pb2 as flwr_dot_proto_dot_transport__pb2
19
+
20
+
21
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x14\x66lwr/proto/run.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x15\x66lwr/proto/node.proto\x1a\x1a\x66lwr/proto/recordset.proto\x1a\x1a\x66lwr/proto/transport.proto\"\xd5\x01\n\x03Run\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x0e\n\x06\x66\x61\x62_id\x18\x02 \x01(\t\x12\x13\n\x0b\x66\x61\x62_version\x18\x03 \x01(\t\x12<\n\x0foverride_config\x18\x04 \x03(\x0b\x32#.flwr.proto.Run.OverrideConfigEntry\x12\x10\n\x08\x66\x61\x62_hash\x18\x05 \x01(\t\x1aI\n\x13OverrideConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"@\n\tRunStatus\x12\x0e\n\x06status\x18\x01 \x01(\t\x12\x12\n\nsub_status\x18\x02 \x01(\t\x12\x0f\n\x07\x64\x65tails\x18\x03 \x01(\t\"\xeb\x01\n\x10\x43reateRunRequest\x12\x0e\n\x06\x66\x61\x62_id\x18\x01 \x01(\t\x12\x13\n\x0b\x66\x61\x62_version\x18\x02 \x01(\t\x12I\n\x0foverride_config\x18\x03 \x03(\x0b\x32\x30.flwr.proto.CreateRunRequest.OverrideConfigEntry\x12\x1c\n\x03\x66\x61\x62\x18\x04 \x01(\x0b\x32\x0f.flwr.proto.Fab\x1aI\n\x13OverrideConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"#\n\x11\x43reateRunResponse\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"?\n\rGetRunRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x0e\n\x06run_id\x18\x02 \x01(\x04\".\n\x0eGetRunResponse\x12\x1c\n\x03run\x18\x01 \x01(\x0b\x32\x0f.flwr.proto.Run\"S\n\x16UpdateRunStatusRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12)\n\nrun_status\x18\x02 \x01(\x0b\x32\x15.flwr.proto.RunStatus\"\x19\n\x17UpdateRunStatusResponse\"F\n\x13GetRunStatusRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x0f\n\x07run_ids\x18\x02 \x03(\x04\"\xb1\x01\n\x14GetRunStatusResponse\x12L\n\x0frun_status_dict\x18\x01 \x03(\x0b\x32\x33.flwr.proto.GetRunStatusResponse.RunStatusDictEntry\x1aK\n\x12RunStatusDictEntry\x12\x0b\n\x03key\x18\x01 \x01(\x04\x12$\n\x05value\x18\x02 \x01(\x0b\x32\x15.flwr.proto.RunStatus:\x02\x38\x01\"-\n\x1bGetFederationOptionsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"U\n\x1cGetFederationOptionsResponse\x12\x35\n\x12\x66\x65\x64\x65ration_options\x18\x01 \x01(\x0b\x32\x19.flwr.proto.ConfigsRecordb\x06proto3')
22
+
23
+ _globals = globals()
24
+ _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
25
+ _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'flwr.proto.run_pb2', _globals)
26
+ if _descriptor._USE_C_DESCRIPTORS == False:
27
+ DESCRIPTOR._options = None
28
+ _globals['_RUN_OVERRIDECONFIGENTRY']._options = None
29
+ _globals['_RUN_OVERRIDECONFIGENTRY']._serialized_options = b'8\001'
30
+ _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._options = None
31
+ _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._serialized_options = b'8\001'
32
+ _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._options = None
33
+ _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._serialized_options = b'8\001'
34
+ _globals['_RUN']._serialized_start=138
35
+ _globals['_RUN']._serialized_end=351
36
+ _globals['_RUN_OVERRIDECONFIGENTRY']._serialized_start=278
37
+ _globals['_RUN_OVERRIDECONFIGENTRY']._serialized_end=351
38
+ _globals['_RUNSTATUS']._serialized_start=353
39
+ _globals['_RUNSTATUS']._serialized_end=417
40
+ _globals['_CREATERUNREQUEST']._serialized_start=420
41
+ _globals['_CREATERUNREQUEST']._serialized_end=655
42
+ _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._serialized_start=278
43
+ _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._serialized_end=351
44
+ _globals['_CREATERUNRESPONSE']._serialized_start=657
45
+ _globals['_CREATERUNRESPONSE']._serialized_end=692
46
+ _globals['_GETRUNREQUEST']._serialized_start=694
47
+ _globals['_GETRUNREQUEST']._serialized_end=757
48
+ _globals['_GETRUNRESPONSE']._serialized_start=759
49
+ _globals['_GETRUNRESPONSE']._serialized_end=805
50
+ _globals['_UPDATERUNSTATUSREQUEST']._serialized_start=807
51
+ _globals['_UPDATERUNSTATUSREQUEST']._serialized_end=890
52
+ _globals['_UPDATERUNSTATUSRESPONSE']._serialized_start=892
53
+ _globals['_UPDATERUNSTATUSRESPONSE']._serialized_end=917
54
+ _globals['_GETRUNSTATUSREQUEST']._serialized_start=919
55
+ _globals['_GETRUNSTATUSREQUEST']._serialized_end=989
56
+ _globals['_GETRUNSTATUSRESPONSE']._serialized_start=992
57
+ _globals['_GETRUNSTATUSRESPONSE']._serialized_end=1169
58
+ _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._serialized_start=1094
59
+ _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._serialized_end=1169
60
+ _globals['_GETFEDERATIONOPTIONSREQUEST']._serialized_start=1171
61
+ _globals['_GETFEDERATIONOPTIONSREQUEST']._serialized_end=1216
62
+ _globals['_GETFEDERATIONOPTIONSRESPONSE']._serialized_start=1218
63
+ _globals['_GETFEDERATIONOPTIONSRESPONSE']._serialized_end=1303
64
+ # @@protoc_insertion_point(module_scope)
@@ -5,6 +5,7 @@ isort:skip_file
5
5
  import builtins
6
6
  import flwr.proto.fab_pb2
7
7
  import flwr.proto.node_pb2
8
+ import flwr.proto.recordset_pb2
8
9
  import flwr.proto.transport_pb2
9
10
  import google.protobuf.descriptor
10
11
  import google.protobuf.internal.containers
@@ -223,3 +224,28 @@ class GetRunStatusResponse(google.protobuf.message.Message):
223
224
  ) -> None: ...
224
225
  def ClearField(self, field_name: typing_extensions.Literal["run_status_dict",b"run_status_dict"]) -> None: ...
225
226
  global___GetRunStatusResponse = GetRunStatusResponse
227
+
228
+ class GetFederationOptionsRequest(google.protobuf.message.Message):
229
+ """Get Federation Options associated with run"""
230
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
231
+ RUN_ID_FIELD_NUMBER: builtins.int
232
+ run_id: builtins.int
233
+ def __init__(self,
234
+ *,
235
+ run_id: builtins.int = ...,
236
+ ) -> None: ...
237
+ def ClearField(self, field_name: typing_extensions.Literal["run_id",b"run_id"]) -> None: ...
238
+ global___GetFederationOptionsRequest = GetFederationOptionsRequest
239
+
240
+ class GetFederationOptionsResponse(google.protobuf.message.Message):
241
+ DESCRIPTOR: google.protobuf.descriptor.Descriptor
242
+ FEDERATION_OPTIONS_FIELD_NUMBER: builtins.int
243
+ @property
244
+ def federation_options(self) -> flwr.proto.recordset_pb2.ConfigsRecord: ...
245
+ def __init__(self,
246
+ *,
247
+ federation_options: typing.Optional[flwr.proto.recordset_pb2.ConfigsRecord] = ...,
248
+ ) -> None: ...
249
+ def HasField(self, field_name: typing_extensions.Literal["federation_options",b"federation_options"]) -> builtins.bool: ...
250
+ def ClearField(self, field_name: typing_extensions.Literal["federation_options",b"federation_options"]) -> None: ...
251
+ global___GetFederationOptionsResponse = GetFederationOptionsResponse
@@ -18,7 +18,7 @@ from flwr.proto import run_pb2 as flwr_dot_proto_dot_run__pb2
18
18
  from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
19
19
 
20
20
 
21
- DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1d\x66lwr/proto/simulationio.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/log.proto\x1a\x18\x66lwr/proto/message.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x14\x66lwr/proto/fab.proto\"\x1d\n\x1bPullSimulationInputsRequest\"\x80\x01\n\x1cPullSimulationInputsResponse\x12$\n\x07\x63ontext\x18\x01 \x01(\x0b\x32\x13.flwr.proto.Context\x12\x1c\n\x03run\x18\x02 \x01(\x0b\x32\x0f.flwr.proto.Run\x12\x1c\n\x03\x66\x61\x62\x18\x03 \x01(\x0b\x32\x0f.flwr.proto.Fab\"T\n\x1cPushSimulationOutputsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12$\n\x07\x63ontext\x18\x02 \x01(\x0b\x32\x13.flwr.proto.Context\"\x1f\n\x1dPushSimulationOutputsResponse2\x92\x03\n\x0cSimulationIo\x12k\n\x14PullSimulationInputs\x12\'.flwr.proto.PullSimulationInputsRequest\x1a(.flwr.proto.PullSimulationInputsResponse\"\x00\x12n\n\x15PushSimulationOutputs\x12(.flwr.proto.PushSimulationOutputsRequest\x1a).flwr.proto.PushSimulationOutputsResponse\"\x00\x12\\\n\x0fUpdateRunStatus\x12\".flwr.proto.UpdateRunStatusRequest\x1a#.flwr.proto.UpdateRunStatusResponse\"\x00\x12G\n\x08PushLogs\x12\x1b.flwr.proto.PushLogsRequest\x1a\x1c.flwr.proto.PushLogsResponse\"\x00\x62\x06proto3')
21
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x1d\x66lwr/proto/simulationio.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/log.proto\x1a\x18\x66lwr/proto/message.proto\x1a\x14\x66lwr/proto/run.proto\x1a\x14\x66lwr/proto/fab.proto\"\x1d\n\x1bPullSimulationInputsRequest\"\x80\x01\n\x1cPullSimulationInputsResponse\x12$\n\x07\x63ontext\x18\x01 \x01(\x0b\x32\x13.flwr.proto.Context\x12\x1c\n\x03run\x18\x02 \x01(\x0b\x32\x0f.flwr.proto.Run\x12\x1c\n\x03\x66\x61\x62\x18\x03 \x01(\x0b\x32\x0f.flwr.proto.Fab\"T\n\x1cPushSimulationOutputsRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12$\n\x07\x63ontext\x18\x02 \x01(\x0b\x32\x13.flwr.proto.Context\"\x1f\n\x1dPushSimulationOutputsResponse2\xff\x03\n\x0cSimulationIo\x12k\n\x14PullSimulationInputs\x12\'.flwr.proto.PullSimulationInputsRequest\x1a(.flwr.proto.PullSimulationInputsResponse\"\x00\x12n\n\x15PushSimulationOutputs\x12(.flwr.proto.PushSimulationOutputsRequest\x1a).flwr.proto.PushSimulationOutputsResponse\"\x00\x12\\\n\x0fUpdateRunStatus\x12\".flwr.proto.UpdateRunStatusRequest\x1a#.flwr.proto.UpdateRunStatusResponse\"\x00\x12G\n\x08PushLogs\x12\x1b.flwr.proto.PushLogsRequest\x1a\x1c.flwr.proto.PushLogsResponse\"\x00\x12k\n\x14GetFederationOptions\x12\'.flwr.proto.GetFederationOptionsRequest\x1a(.flwr.proto.GetFederationOptionsResponse\"\x00\x62\x06proto3')
22
22
 
23
23
  _globals = globals()
24
24
  _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
@@ -34,5 +34,5 @@ if _descriptor._USE_C_DESCRIPTORS == False:
34
34
  _globals['_PUSHSIMULATIONOUTPUTSRESPONSE']._serialized_start=385
35
35
  _globals['_PUSHSIMULATIONOUTPUTSRESPONSE']._serialized_end=416
36
36
  _globals['_SIMULATIONIO']._serialized_start=419
37
- _globals['_SIMULATIONIO']._serialized_end=821
37
+ _globals['_SIMULATIONIO']._serialized_end=930
38
38
  # @@protoc_insertion_point(module_scope)
@@ -36,6 +36,11 @@ class SimulationIoStub(object):
36
36
  request_serializer=flwr_dot_proto_dot_log__pb2.PushLogsRequest.SerializeToString,
37
37
  response_deserializer=flwr_dot_proto_dot_log__pb2.PushLogsResponse.FromString,
38
38
  )
39
+ self.GetFederationOptions = channel.unary_unary(
40
+ '/flwr.proto.SimulationIo/GetFederationOptions',
41
+ request_serializer=flwr_dot_proto_dot_run__pb2.GetFederationOptionsRequest.SerializeToString,
42
+ response_deserializer=flwr_dot_proto_dot_run__pb2.GetFederationOptionsResponse.FromString,
43
+ )
39
44
 
40
45
 
41
46
  class SimulationIoServicer(object):
@@ -69,6 +74,13 @@ class SimulationIoServicer(object):
69
74
  context.set_details('Method not implemented!')
70
75
  raise NotImplementedError('Method not implemented!')
71
76
 
77
+ def GetFederationOptions(self, request, context):
78
+ """Get Federation Options
79
+ """
80
+ context.set_code(grpc.StatusCode.UNIMPLEMENTED)
81
+ context.set_details('Method not implemented!')
82
+ raise NotImplementedError('Method not implemented!')
83
+
72
84
 
73
85
  def add_SimulationIoServicer_to_server(servicer, server):
74
86
  rpc_method_handlers = {
@@ -92,6 +104,11 @@ def add_SimulationIoServicer_to_server(servicer, server):
92
104
  request_deserializer=flwr_dot_proto_dot_log__pb2.PushLogsRequest.FromString,
93
105
  response_serializer=flwr_dot_proto_dot_log__pb2.PushLogsResponse.SerializeToString,
94
106
  ),
107
+ 'GetFederationOptions': grpc.unary_unary_rpc_method_handler(
108
+ servicer.GetFederationOptions,
109
+ request_deserializer=flwr_dot_proto_dot_run__pb2.GetFederationOptionsRequest.FromString,
110
+ response_serializer=flwr_dot_proto_dot_run__pb2.GetFederationOptionsResponse.SerializeToString,
111
+ ),
95
112
  }
96
113
  generic_handler = grpc.method_handlers_generic_handler(
97
114
  'flwr.proto.SimulationIo', rpc_method_handlers)
@@ -169,3 +186,20 @@ class SimulationIo(object):
169
186
  flwr_dot_proto_dot_log__pb2.PushLogsResponse.FromString,
170
187
  options, channel_credentials,
171
188
  insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
189
+
190
+ @staticmethod
191
+ def GetFederationOptions(request,
192
+ target,
193
+ options=(),
194
+ channel_credentials=None,
195
+ call_credentials=None,
196
+ insecure=False,
197
+ compression=None,
198
+ wait_for_ready=None,
199
+ timeout=None,
200
+ metadata=None):
201
+ return grpc.experimental.unary_unary(request, target, '/flwr.proto.SimulationIo/GetFederationOptions',
202
+ flwr_dot_proto_dot_run__pb2.GetFederationOptionsRequest.SerializeToString,
203
+ flwr_dot_proto_dot_run__pb2.GetFederationOptionsResponse.FromString,
204
+ options, channel_credentials,
205
+ insecure, call_credentials, compression, wait_for_ready, timeout, metadata)
@@ -30,6 +30,11 @@ class SimulationIoStub:
30
30
  flwr.proto.log_pb2.PushLogsResponse]
31
31
  """Push ServerApp logs"""
32
32
 
33
+ GetFederationOptions: grpc.UnaryUnaryMultiCallable[
34
+ flwr.proto.run_pb2.GetFederationOptionsRequest,
35
+ flwr.proto.run_pb2.GetFederationOptionsResponse]
36
+ """Get Federation Options"""
37
+
33
38
 
34
39
  class SimulationIoServicer(metaclass=abc.ABCMeta):
35
40
  @abc.abstractmethod
@@ -64,5 +69,13 @@ class SimulationIoServicer(metaclass=abc.ABCMeta):
64
69
  """Push ServerApp logs"""
65
70
  pass
66
71
 
72
+ @abc.abstractmethod
73
+ def GetFederationOptions(self,
74
+ request: flwr.proto.run_pb2.GetFederationOptionsRequest,
75
+ context: grpc.ServicerContext,
76
+ ) -> flwr.proto.run_pb2.GetFederationOptionsResponse:
77
+ """Get Federation Options"""
78
+ pass
79
+
67
80
 
68
81
  def add_SimulationIoServicer_to_server(servicer: SimulationIoServicer, server: grpc.Server) -> None: ...
@@ -48,12 +48,12 @@ def aggregate_inplace(results: list[tuple[ClientProxy, FitRes]]) -> NDArrays:
48
48
  num_examples_total = sum(fit_res.num_examples for (_, fit_res) in results)
49
49
 
50
50
  # Compute scaling factors for each result
51
- scaling_factors = [
52
- fit_res.num_examples / num_examples_total for _, fit_res in results
53
- ]
51
+ scaling_factors = np.asarray(
52
+ [fit_res.num_examples / num_examples_total for _, fit_res in results]
53
+ )
54
54
 
55
55
  def _try_inplace(
56
- x: NDArray, y: Union[NDArray, float], np_binary_op: np.ufunc
56
+ x: NDArray, y: Union[NDArray, np.float64], np_binary_op: np.ufunc
57
57
  ) -> NDArray:
58
58
  return ( # type: ignore[no-any-return]
59
59
  np_binary_op(x, y, out=x)
@@ -23,6 +23,7 @@ from grpc import ServicerContext
23
23
  from flwr.common.constant import Status
24
24
  from flwr.common.logger import log
25
25
  from flwr.common.serde import (
26
+ configs_record_to_proto,
26
27
  context_from_proto,
27
28
  context_to_proto,
28
29
  fab_to_proto,
@@ -36,6 +37,8 @@ from flwr.proto.log_pb2 import ( # pylint: disable=E0611
36
37
  PushLogsResponse,
37
38
  )
38
39
  from flwr.proto.run_pb2 import ( # pylint: disable=E0611
40
+ GetFederationOptionsRequest,
41
+ GetFederationOptionsResponse,
39
42
  UpdateRunStatusRequest,
40
43
  UpdateRunStatusResponse,
41
44
  )
@@ -123,10 +126,28 @@ class SimulationIoServicer(simulationio_pb2_grpc.SimulationIoServicer):
123
126
  self, request: PushLogsRequest, context: grpc.ServicerContext
124
127
  ) -> PushLogsResponse:
125
128
  """Push logs."""
126
- log(DEBUG, "ServerAppIoServicer.PushLogs")
129
+ log(DEBUG, "SimultionIoServicer.PushLogs")
127
130
  state = self.state_factory.state()
128
131
 
129
132
  # Add logs to LinkState
130
133
  merged_logs = "".join(request.logs)
131
134
  state.add_serverapp_log(request.run_id, merged_logs)
132
135
  return PushLogsResponse()
136
+
137
+ def GetFederationOptions(
138
+ self, request: GetFederationOptionsRequest, context: ServicerContext
139
+ ) -> GetFederationOptionsResponse:
140
+ """Get Federation Options associated with a run."""
141
+ log(DEBUG, "SimultionIoServicer.GetFederationOptions")
142
+ state = self.state_factory.state()
143
+
144
+ federation_options = state.get_federation_options(request.run_id)
145
+ if federation_options is None:
146
+ context.abort(
147
+ grpc.StatusCode.FAILED_PRECONDITION,
148
+ "Expected federation options to be set, but none available.",
149
+ )
150
+ return GetFederationOptionsResponse()
151
+ return GetFederationOptionsResponse(
152
+ federation_options=configs_record_to_proto(federation_options)
153
+ )
@@ -1,59 +0,0 @@
1
- # -*- coding: utf-8 -*-
2
- # Generated by the protocol buffer compiler. DO NOT EDIT!
3
- # source: flwr/proto/run.proto
4
- # Protobuf Python Version: 4.25.0
5
- """Generated protocol buffer code."""
6
- from google.protobuf import descriptor as _descriptor
7
- from google.protobuf import descriptor_pool as _descriptor_pool
8
- from google.protobuf import symbol_database as _symbol_database
9
- from google.protobuf.internal import builder as _builder
10
- # @@protoc_insertion_point(imports)
11
-
12
- _sym_db = _symbol_database.Default()
13
-
14
-
15
- from flwr.proto import fab_pb2 as flwr_dot_proto_dot_fab__pb2
16
- from flwr.proto import node_pb2 as flwr_dot_proto_dot_node__pb2
17
- from flwr.proto import transport_pb2 as flwr_dot_proto_dot_transport__pb2
18
-
19
-
20
- DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x14\x66lwr/proto/run.proto\x12\nflwr.proto\x1a\x14\x66lwr/proto/fab.proto\x1a\x15\x66lwr/proto/node.proto\x1a\x1a\x66lwr/proto/transport.proto\"\xd5\x01\n\x03Run\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12\x0e\n\x06\x66\x61\x62_id\x18\x02 \x01(\t\x12\x13\n\x0b\x66\x61\x62_version\x18\x03 \x01(\t\x12<\n\x0foverride_config\x18\x04 \x03(\x0b\x32#.flwr.proto.Run.OverrideConfigEntry\x12\x10\n\x08\x66\x61\x62_hash\x18\x05 \x01(\t\x1aI\n\x13OverrideConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"@\n\tRunStatus\x12\x0e\n\x06status\x18\x01 \x01(\t\x12\x12\n\nsub_status\x18\x02 \x01(\t\x12\x0f\n\x07\x64\x65tails\x18\x03 \x01(\t\"\xeb\x01\n\x10\x43reateRunRequest\x12\x0e\n\x06\x66\x61\x62_id\x18\x01 \x01(\t\x12\x13\n\x0b\x66\x61\x62_version\x18\x02 \x01(\t\x12I\n\x0foverride_config\x18\x03 \x03(\x0b\x32\x30.flwr.proto.CreateRunRequest.OverrideConfigEntry\x12\x1c\n\x03\x66\x61\x62\x18\x04 \x01(\x0b\x32\x0f.flwr.proto.Fab\x1aI\n\x13OverrideConfigEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.flwr.proto.Scalar:\x02\x38\x01\"#\n\x11\x43reateRunResponse\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\"?\n\rGetRunRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x0e\n\x06run_id\x18\x02 \x01(\x04\".\n\x0eGetRunResponse\x12\x1c\n\x03run\x18\x01 \x01(\x0b\x32\x0f.flwr.proto.Run\"S\n\x16UpdateRunStatusRequest\x12\x0e\n\x06run_id\x18\x01 \x01(\x04\x12)\n\nrun_status\x18\x02 \x01(\x0b\x32\x15.flwr.proto.RunStatus\"\x19\n\x17UpdateRunStatusResponse\"F\n\x13GetRunStatusRequest\x12\x1e\n\x04node\x18\x01 \x01(\x0b\x32\x10.flwr.proto.Node\x12\x0f\n\x07run_ids\x18\x02 \x03(\x04\"\xb1\x01\n\x14GetRunStatusResponse\x12L\n\x0frun_status_dict\x18\x01 \x03(\x0b\x32\x33.flwr.proto.GetRunStatusResponse.RunStatusDictEntry\x1aK\n\x12RunStatusDictEntry\x12\x0b\n\x03key\x18\x01 \x01(\x04\x12$\n\x05value\x18\x02 \x01(\x0b\x32\x15.flwr.proto.RunStatus:\x02\x38\x01\x62\x06proto3')
21
-
22
- _globals = globals()
23
- _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
24
- _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'flwr.proto.run_pb2', _globals)
25
- if _descriptor._USE_C_DESCRIPTORS == False:
26
- DESCRIPTOR._options = None
27
- _globals['_RUN_OVERRIDECONFIGENTRY']._options = None
28
- _globals['_RUN_OVERRIDECONFIGENTRY']._serialized_options = b'8\001'
29
- _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._options = None
30
- _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._serialized_options = b'8\001'
31
- _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._options = None
32
- _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._serialized_options = b'8\001'
33
- _globals['_RUN']._serialized_start=110
34
- _globals['_RUN']._serialized_end=323
35
- _globals['_RUN_OVERRIDECONFIGENTRY']._serialized_start=250
36
- _globals['_RUN_OVERRIDECONFIGENTRY']._serialized_end=323
37
- _globals['_RUNSTATUS']._serialized_start=325
38
- _globals['_RUNSTATUS']._serialized_end=389
39
- _globals['_CREATERUNREQUEST']._serialized_start=392
40
- _globals['_CREATERUNREQUEST']._serialized_end=627
41
- _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._serialized_start=250
42
- _globals['_CREATERUNREQUEST_OVERRIDECONFIGENTRY']._serialized_end=323
43
- _globals['_CREATERUNRESPONSE']._serialized_start=629
44
- _globals['_CREATERUNRESPONSE']._serialized_end=664
45
- _globals['_GETRUNREQUEST']._serialized_start=666
46
- _globals['_GETRUNREQUEST']._serialized_end=729
47
- _globals['_GETRUNRESPONSE']._serialized_start=731
48
- _globals['_GETRUNRESPONSE']._serialized_end=777
49
- _globals['_UPDATERUNSTATUSREQUEST']._serialized_start=779
50
- _globals['_UPDATERUNSTATUSREQUEST']._serialized_end=862
51
- _globals['_UPDATERUNSTATUSRESPONSE']._serialized_start=864
52
- _globals['_UPDATERUNSTATUSRESPONSE']._serialized_end=889
53
- _globals['_GETRUNSTATUSREQUEST']._serialized_start=891
54
- _globals['_GETRUNSTATUSREQUEST']._serialized_end=961
55
- _globals['_GETRUNSTATUSRESPONSE']._serialized_start=964
56
- _globals['_GETRUNSTATUSRESPONSE']._serialized_end=1141
57
- _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._serialized_start=1066
58
- _globals['_GETRUNSTATUSRESPONSE_RUNSTATUSDICTENTRY']._serialized_end=1141
59
- # @@protoc_insertion_point(module_scope)