flwr-nightly 1.10.0.dev20240709__tar.gz → 1.10.0.dev20240710__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 (274) hide show
  1. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/PKG-INFO +1 -1
  2. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/pyproject.toml +1 -1
  3. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/new.py +3 -1
  4. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/supernode/app.py +19 -6
  5. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/vce/vce_api.py +43 -13
  6. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/LICENSE +0 -0
  7. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/README.md +0 -0
  8. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/__init__.py +0 -0
  9. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/__init__.py +0 -0
  10. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/app.py +0 -0
  11. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/build.py +0 -0
  12. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/config_utils.py +0 -0
  13. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/example.py +0 -0
  14. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/install.py +0 -0
  15. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/__init__.py +0 -0
  16. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/__init__.py +0 -0
  17. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  18. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  19. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  20. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/__init__.py +0 -0
  21. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  22. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  23. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/client.hf.py.tpl +0 -0
  24. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  25. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +0 -0
  26. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  27. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +0 -0
  28. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +0 -0
  29. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +0 -0
  30. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  31. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/app.py.tpl +0 -0
  32. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/client.py.tpl +0 -0
  33. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/config.yaml.tpl +0 -0
  34. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  35. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  36. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/server.py.tpl +0 -0
  37. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/flwr_tune/static_config.yaml.tpl +0 -0
  38. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/server.hf.py.tpl +0 -0
  39. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  40. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  41. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  42. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  43. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  44. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  45. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/task.hf.py.tpl +0 -0
  46. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  47. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  48. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  49. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  50. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  51. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.hf.toml.tpl +0 -0
  52. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +0 -0
  53. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +0 -0
  54. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  55. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +0 -0
  56. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  57. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +0 -0
  58. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/run/__init__.py +0 -0
  59. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/run/run.py +0 -0
  60. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/cli/utils.py +0 -0
  61. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/__init__.py +0 -0
  62. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/app.py +0 -0
  63. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/client.py +0 -0
  64. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/client_app.py +0 -0
  65. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  66. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  67. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  68. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_client/__init__.py +0 -0
  69. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_client/connection.py +0 -0
  70. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  71. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  72. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_rere_client/connection.py +0 -0
  73. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  74. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/heartbeat.py +0 -0
  75. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/message_handler/__init__.py +0 -0
  76. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/message_handler/message_handler.py +0 -0
  77. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/message_handler/task_handler.py +0 -0
  78. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/__init__.py +0 -0
  79. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/centraldp_mods.py +0 -0
  80. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/comms_mods.py +0 -0
  81. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/localdp_mod.py +0 -0
  82. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  83. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  84. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  85. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/mod/utils.py +0 -0
  86. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/node_state.py +0 -0
  87. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/node_state_tests.py +0 -0
  88. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/numpy_client.py +0 -0
  89. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/rest_client/__init__.py +0 -0
  90. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/rest_client/connection.py +0 -0
  91. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/supernode/__init__.py +0 -0
  92. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/client/typing.py +0 -0
  93. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/__init__.py +0 -0
  94. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/address.py +0 -0
  95. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/config.py +0 -0
  96. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/constant.py +0 -0
  97. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/context.py +0 -0
  98. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/date.py +0 -0
  99. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/differential_privacy.py +0 -0
  100. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/differential_privacy_constants.py +0 -0
  101. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/dp.py +0 -0
  102. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/exit_handlers.py +0 -0
  103. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/grpc.py +0 -0
  104. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/logger.py +0 -0
  105. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/message.py +0 -0
  106. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/object_ref.py +0 -0
  107. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/parameter.py +0 -0
  108. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/pyproject.py +0 -0
  109. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/record/__init__.py +0 -0
  110. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/record/configsrecord.py +0 -0
  111. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/record/conversion_utils.py +0 -0
  112. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/record/metricsrecord.py +0 -0
  113. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/record/parametersrecord.py +0 -0
  114. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/record/recordset.py +0 -0
  115. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/record/typeddict.py +0 -0
  116. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/recordset_compat.py +0 -0
  117. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/retry_invoker.py +0 -0
  118. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/__init__.py +0 -0
  119. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  120. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  121. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  122. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  123. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/quantization.py +0 -0
  124. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  125. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  126. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/serde.py +0 -0
  127. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/telemetry.py +0 -0
  128. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/typing.py +0 -0
  129. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/common/version.py +0 -0
  130. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/__init__.py +0 -0
  131. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/common_pb2.py +0 -0
  132. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/common_pb2.pyi +0 -0
  133. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/common_pb2_grpc.py +0 -0
  134. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/common_pb2_grpc.pyi +0 -0
  135. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/driver_pb2.py +0 -0
  136. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/driver_pb2.pyi +0 -0
  137. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/driver_pb2_grpc.py +0 -0
  138. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/driver_pb2_grpc.pyi +0 -0
  139. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/error_pb2.py +0 -0
  140. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/error_pb2.pyi +0 -0
  141. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/error_pb2_grpc.py +0 -0
  142. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  143. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/exec_pb2.py +0 -0
  144. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/exec_pb2.pyi +0 -0
  145. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/exec_pb2_grpc.py +0 -0
  146. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/exec_pb2_grpc.pyi +0 -0
  147. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fab_pb2.py +0 -0
  148. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fab_pb2.pyi +0 -0
  149. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fab_pb2_grpc.py +0 -0
  150. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  151. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fleet_pb2.py +0 -0
  152. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fleet_pb2.pyi +0 -0
  153. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  154. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  155. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/grpcadapter_pb2.py +0 -0
  156. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  157. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  158. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  159. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/node_pb2.py +0 -0
  160. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/node_pb2.pyi +0 -0
  161. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/node_pb2_grpc.py +0 -0
  162. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  163. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/recordset_pb2.py +0 -0
  164. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/recordset_pb2.pyi +0 -0
  165. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/recordset_pb2_grpc.py +0 -0
  166. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/recordset_pb2_grpc.pyi +0 -0
  167. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/run_pb2.py +0 -0
  168. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/run_pb2.pyi +0 -0
  169. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/run_pb2_grpc.py +0 -0
  170. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  171. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/task_pb2.py +0 -0
  172. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/task_pb2.pyi +0 -0
  173. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/task_pb2_grpc.py +0 -0
  174. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/task_pb2_grpc.pyi +0 -0
  175. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/transport_pb2.py +0 -0
  176. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/transport_pb2.pyi +0 -0
  177. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/transport_pb2_grpc.py +0 -0
  178. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  179. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/py.typed +0 -0
  180. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/__init__.py +0 -0
  181. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/app.py +0 -0
  182. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/client_manager.py +0 -0
  183. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/client_proxy.py +0 -0
  184. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/compat/__init__.py +0 -0
  185. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/compat/app.py +0 -0
  186. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/compat/app_utils.py +0 -0
  187. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/compat/driver_client_proxy.py +0 -0
  188. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/compat/legacy_context.py +0 -0
  189. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/criterion.py +0 -0
  190. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/driver/__init__.py +0 -0
  191. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/driver/driver.py +0 -0
  192. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/driver/grpc_driver.py +0 -0
  193. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/driver/inmemory_driver.py +0 -0
  194. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/history.py +0 -0
  195. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/run_serverapp.py +0 -0
  196. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/server.py +0 -0
  197. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/server_app.py +0 -0
  198. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/server_config.py +0 -0
  199. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/__init__.py +0 -0
  200. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/aggregate.py +0 -0
  201. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/bulyan.py +0 -0
  202. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  203. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  204. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  205. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  206. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  207. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedadagrad.py +0 -0
  208. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedadam.py +0 -0
  209. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedavg.py +0 -0
  210. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedavg_android.py +0 -0
  211. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedavgm.py +0 -0
  212. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedmedian.py +0 -0
  213. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedopt.py +0 -0
  214. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedprox.py +0 -0
  215. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  216. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  217. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  218. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  219. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/fedyogi.py +0 -0
  220. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/krum.py +0 -0
  221. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/qfedavg.py +0 -0
  222. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/strategy/strategy.py +0 -0
  223. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/__init__.py +0 -0
  224. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/driver/__init__.py +0 -0
  225. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/driver/driver_grpc.py +0 -0
  226. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/driver/driver_servicer.py +0 -0
  227. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/__init__.py +0 -0
  228. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  229. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  230. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  231. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  232. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  233. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  234. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  235. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  236. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  237. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  238. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  239. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  240. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  241. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  242. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  243. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  244. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  245. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  246. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/state/__init__.py +0 -0
  247. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/state/in_memory_state.py +0 -0
  248. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/state/sqlite_state.py +0 -0
  249. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/state/state.py +0 -0
  250. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/state/state_factory.py +0 -0
  251. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/superlink/state/utils.py +0 -0
  252. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/typing.py +0 -0
  253. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/utils/__init__.py +0 -0
  254. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/utils/tensorboard.py +0 -0
  255. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/utils/validator.py +0 -0
  256. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/workflow/__init__.py +0 -0
  257. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/workflow/constant.py +0 -0
  258. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/workflow/default_workflows.py +0 -0
  259. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  260. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  261. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  262. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/simulation/__init__.py +0 -0
  263. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/simulation/app.py +0 -0
  264. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/simulation/ray_transport/__init__.py +0 -0
  265. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  266. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  267. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/simulation/ray_transport/utils.py +0 -0
  268. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/simulation/run_simulation.py +0 -0
  269. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/superexec/__init__.py +0 -0
  270. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/superexec/app.py +0 -0
  271. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/superexec/deployment.py +0 -0
  272. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/superexec/exec_grpc.py +0 -0
  273. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/superexec/exec_servicer.py +0 -0
  274. {flwr_nightly-1.10.0.dev20240709 → flwr_nightly-1.10.0.dev20240710}/src/py/flwr/superexec/executor.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: flwr-nightly
3
- Version: 1.10.0.dev20240709
3
+ Version: 1.10.0.dev20240710
4
4
  Summary: Flower: A Friendly Federated Learning Framework
5
5
  Home-page: https://flower.ai
6
6
  License: Apache-2.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.10.0.dev20240709"
7
+ version = "1.10.0.dev20240710"
8
8
  description = "Flower: A Friendly Federated Learning Framework"
9
9
  license = "Apache-2.0"
10
10
  authors = ["The Flower Authors <hello@flower.ai>"]
@@ -264,9 +264,11 @@ def new(
264
264
  bold=True,
265
265
  )
266
266
  )
267
+
268
+ _add = " huggingface-cli login\n" if framework_str == "flowertune" else ""
267
269
  print(
268
270
  typer.style(
269
- f" cd {package_name}\n" + " pip install -e .\n flwr run\n",
271
+ f" cd {package_name}\n" + " pip install -e .\n" + _add + " flwr run\n",
270
272
  fg=typer.colors.BRIGHT_CYAN,
271
273
  bold=True,
272
274
  )
@@ -178,7 +178,7 @@ def _get_load_client_app_fn(
178
178
  else:
179
179
  flwr_dir = Path(args.flwr_dir).absolute()
180
180
 
181
- sys.path.insert(0, str(flwr_dir.absolute()))
181
+ inserted_path = None
182
182
 
183
183
  default_app_ref: str = getattr(args, "client-app")
184
184
 
@@ -188,6 +188,11 @@ def _get_load_client_app_fn(
188
188
  "Flower SuperNode will load and validate ClientApp `%s`",
189
189
  getattr(args, "client-app"),
190
190
  )
191
+ # Insert sys.path
192
+ dir_path = Path(args.dir).absolute()
193
+ sys.path.insert(0, str(dir_path))
194
+ inserted_path = str(dir_path)
195
+
191
196
  valid, error_msg = validate(default_app_ref)
192
197
  if not valid and error_msg:
193
198
  raise LoadClientAppError(error_msg) from None
@@ -196,7 +201,7 @@ def _get_load_client_app_fn(
196
201
  # If multi-app feature is disabled
197
202
  if not multi_app:
198
203
  # Get sys path to be inserted
199
- sys_path = Path(args.dir).absolute()
204
+ dir_path = Path(args.dir).absolute()
200
205
 
201
206
  # Set app reference
202
207
  client_app_ref = default_app_ref
@@ -209,7 +214,7 @@ def _get_load_client_app_fn(
209
214
 
210
215
  log(WARN, "FAB ID is not provided; the default ClientApp will be loaded.")
211
216
  # Get sys path to be inserted
212
- sys_path = Path(args.dir).absolute()
217
+ dir_path = Path(args.dir).absolute()
213
218
 
214
219
  # Set app reference
215
220
  client_app_ref = default_app_ref
@@ -222,13 +227,21 @@ def _get_load_client_app_fn(
222
227
  raise LoadClientAppError("Failed to load ClientApp") from e
223
228
 
224
229
  # Get sys path to be inserted
225
- sys_path = Path(project_dir).absolute()
230
+ dir_path = Path(project_dir).absolute()
226
231
 
227
232
  # Set app reference
228
233
  client_app_ref = config["flower"]["components"]["clientapp"]
229
234
 
230
235
  # Set sys.path
231
- sys.path.insert(0, str(sys_path))
236
+ nonlocal inserted_path
237
+ if inserted_path != str(dir_path):
238
+ # Remove the previously inserted path
239
+ if inserted_path is not None:
240
+ sys.path.remove(inserted_path)
241
+ # Insert the new path
242
+ sys.path.insert(0, str(dir_path))
243
+
244
+ inserted_path = str(dir_path)
232
245
 
233
246
  # Load ClientApp
234
247
  log(
@@ -236,7 +249,7 @@ def _get_load_client_app_fn(
236
249
  "Loading ClientApp `%s`",
237
250
  client_app_ref,
238
251
  )
239
- client_app = load_app(client_app_ref, LoadClientAppError, sys_path)
252
+ client_app = load_app(client_app_ref, LoadClientAppError, dir_path)
240
253
 
241
254
  if not isinstance(client_app, ClientApp):
242
255
  raise LoadClientAppError(
@@ -30,7 +30,7 @@ from flwr.common.logger import log
30
30
  from flwr.common.message import Error
31
31
  from flwr.common.object_ref import load_app
32
32
  from flwr.common.serde import message_from_taskins, message_to_taskres
33
- from flwr.proto.task_pb2 import TaskIns # pylint: disable=E0611
33
+ from flwr.proto.task_pb2 import TaskIns, TaskRes # pylint: disable=E0611
34
34
  from flwr.server.superlink.state import StateFactory
35
35
 
36
36
  from .backend import Backend, error_messages_backends, supported_backends
@@ -54,17 +54,16 @@ def _register_nodes(
54
54
  # pylint: disable=too-many-arguments,too-many-locals
55
55
  async def worker(
56
56
  app_fn: Callable[[], ClientApp],
57
- queue: "asyncio.Queue[TaskIns]",
57
+ taskins_queue: "asyncio.Queue[TaskIns]",
58
+ taskres_queue: "asyncio.Queue[TaskRes]",
58
59
  node_states: Dict[int, NodeState],
59
- state_factory: StateFactory,
60
60
  backend: Backend,
61
61
  ) -> None:
62
62
  """Get TaskIns from queue and pass it to an actor in the pool to execute it."""
63
- state = state_factory.state()
64
63
  while True:
65
64
  out_mssg = None
66
65
  try:
67
- task_ins: TaskIns = await queue.get()
66
+ task_ins: TaskIns = await taskins_queue.get()
68
67
  node_id = task_ins.task.consumer.node_id
69
68
 
70
69
  # Register and retrieve runstate
@@ -111,7 +110,7 @@ async def worker(
111
110
  task_res = message_to_taskres(out_mssg)
112
111
  # Store TaskRes in state
113
112
  task_res.task.pushed_at = time.time()
114
- state.store_task_res(task_res)
113
+ await taskres_queue.put(task_res)
115
114
 
116
115
 
117
116
  async def add_taskins_to_queue(
@@ -162,6 +161,21 @@ async def add_taskins_to_queue(
162
161
  log(DEBUG, "Async producer: Stopped pulling from StateFactory.")
163
162
 
164
163
 
164
+ async def put_taskres_into_state(
165
+ queue: "asyncio.Queue[TaskRes]",
166
+ state_factory: StateFactory,
167
+ f_stop: asyncio.Event,
168
+ ) -> None:
169
+ """Remove TaskRes from queue and add into State."""
170
+ state = state_factory.state()
171
+ while not f_stop.is_set():
172
+ if queue.qsize():
173
+ task_res = await queue.get()
174
+ state.store_task_res(task_res)
175
+ else:
176
+ await asyncio.sleep(0.1)
177
+
178
+
165
179
  async def run(
166
180
  app_fn: Callable[[], ClientApp],
167
181
  backend_fn: Callable[[], Backend],
@@ -171,7 +185,8 @@ async def run(
171
185
  f_stop: asyncio.Event,
172
186
  ) -> None:
173
187
  """Run the VCE async."""
174
- queue: "asyncio.Queue[TaskIns]" = asyncio.Queue(128)
188
+ taskins_queue: "asyncio.Queue[TaskIns]" = asyncio.Queue(128)
189
+ taskres_queue: "asyncio.Queue[TaskRes]" = asyncio.Queue(128)
175
190
 
176
191
  try:
177
192
 
@@ -184,22 +199,37 @@ async def run(
184
199
  # Add workers (they submit Messages to Backend)
185
200
  worker_tasks = [
186
201
  asyncio.create_task(
187
- worker(app_fn, queue, node_states, state_factory, backend)
202
+ worker(
203
+ app_fn,
204
+ taskins_queue,
205
+ taskres_queue,
206
+ node_states,
207
+ backend,
208
+ )
188
209
  )
189
210
  for _ in range(backend.num_workers)
190
211
  ]
191
212
  # Create producer (adds TaskIns into Queue)
192
- producer = asyncio.create_task(
213
+ taskins_producer = asyncio.create_task(
193
214
  add_taskins_to_queue(
194
- queue, state_factory, nodes_mapping, backend, worker_tasks, f_stop
215
+ taskins_queue,
216
+ state_factory,
217
+ nodes_mapping,
218
+ backend,
219
+ worker_tasks,
220
+ f_stop,
195
221
  )
196
222
  )
197
223
 
198
- # Wait for producer to finish
199
- # The producer runs forever until f_stop is set or until
224
+ taskres_consumer = asyncio.create_task(
225
+ put_taskres_into_state(taskres_queue, state_factory, f_stop)
226
+ )
227
+
228
+ # Wait for asyncio taks pulling/pushing TaskIns/TaskRes.
229
+ # These run forever until f_stop is set or until
200
230
  # all worker (consumer) coroutines are completed. Workers
201
231
  # also run forever and only end if an exception is raised.
202
- await asyncio.gather(producer)
232
+ await asyncio.gather(*(taskins_producer, taskres_consumer))
203
233
 
204
234
  except Exception as ex:
205
235