flwr-nightly 1.10.0.dev20240716__tar.gz → 1.10.0.dev20240719__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 (276) hide show
  1. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/PKG-INFO +1 -1
  2. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/pyproject.toml +1 -1
  3. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/install.py +16 -0
  4. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/new.py +4 -3
  5. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/client.hf.py.tpl +7 -3
  6. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +10 -8
  7. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +7 -1
  8. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +2 -1
  9. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +9 -2
  10. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/app.py.tpl +2 -2
  11. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/server.py.tpl +1 -1
  12. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.hf.toml.tpl +3 -2
  13. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +2 -2
  14. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +7 -2
  15. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +2 -2
  16. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +3 -2
  17. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +2 -2
  18. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +5 -2
  19. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/run/run.py +9 -7
  20. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/supernode/app.py +2 -2
  21. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/config.py +15 -13
  22. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/simulation/run_simulation.py +1 -1
  23. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/superexec/app.py +1 -1
  24. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/superexec/deployment.py +1 -9
  25. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/superexec/simulation.py +8 -18
  26. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/LICENSE +0 -0
  27. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/README.md +0 -0
  28. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/__init__.py +0 -0
  29. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/__init__.py +0 -0
  30. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/app.py +0 -0
  31. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/build.py +0 -0
  32. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/config_utils.py +0 -0
  33. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/example.py +0 -0
  34. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/__init__.py +0 -0
  35. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/__init__.py +0 -0
  36. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  37. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  38. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  39. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/__init__.py +0 -0
  40. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  41. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  42. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  43. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  44. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  45. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/client.py.tpl +0 -0
  46. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/config.yaml.tpl +0 -0
  47. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  48. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  49. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/flwr_tune/static_config.yaml.tpl +0 -0
  50. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/server.hf.py.tpl +0 -0
  51. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  52. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  53. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  54. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  55. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  56. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  57. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/task.hf.py.tpl +0 -0
  58. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  59. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  60. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  61. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  62. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  63. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/run/__init__.py +0 -0
  64. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/cli/utils.py +0 -0
  65. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/__init__.py +0 -0
  66. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/app.py +0 -0
  67. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/client.py +0 -0
  68. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/client_app.py +0 -0
  69. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  70. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  71. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  72. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_client/__init__.py +0 -0
  73. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_client/connection.py +0 -0
  74. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  75. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  76. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_rere_client/connection.py +0 -0
  77. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  78. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/heartbeat.py +0 -0
  79. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/message_handler/__init__.py +0 -0
  80. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/message_handler/message_handler.py +0 -0
  81. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/message_handler/task_handler.py +0 -0
  82. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/__init__.py +0 -0
  83. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/centraldp_mods.py +0 -0
  84. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/comms_mods.py +0 -0
  85. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/localdp_mod.py +0 -0
  86. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  87. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  88. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  89. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/mod/utils.py +0 -0
  90. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/node_state.py +0 -0
  91. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/node_state_tests.py +0 -0
  92. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/numpy_client.py +0 -0
  93. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/rest_client/__init__.py +0 -0
  94. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/rest_client/connection.py +0 -0
  95. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/supernode/__init__.py +0 -0
  96. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/client/typing.py +0 -0
  97. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/__init__.py +0 -0
  98. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/address.py +0 -0
  99. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/constant.py +0 -0
  100. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/context.py +0 -0
  101. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/date.py +0 -0
  102. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/differential_privacy.py +0 -0
  103. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/differential_privacy_constants.py +0 -0
  104. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/dp.py +0 -0
  105. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/exit_handlers.py +0 -0
  106. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/grpc.py +0 -0
  107. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/logger.py +0 -0
  108. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/message.py +0 -0
  109. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/object_ref.py +0 -0
  110. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/parameter.py +0 -0
  111. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/pyproject.py +0 -0
  112. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/record/__init__.py +0 -0
  113. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/record/configsrecord.py +0 -0
  114. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/record/conversion_utils.py +0 -0
  115. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/record/metricsrecord.py +0 -0
  116. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/record/parametersrecord.py +0 -0
  117. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/record/recordset.py +0 -0
  118. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/record/typeddict.py +0 -0
  119. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/recordset_compat.py +0 -0
  120. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/retry_invoker.py +0 -0
  121. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/__init__.py +0 -0
  122. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  123. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  124. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  125. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  126. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/quantization.py +0 -0
  127. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  128. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  129. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/serde.py +0 -0
  130. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/telemetry.py +0 -0
  131. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/typing.py +0 -0
  132. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/common/version.py +0 -0
  133. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/__init__.py +0 -0
  134. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/common_pb2.py +0 -0
  135. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/common_pb2.pyi +0 -0
  136. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/common_pb2_grpc.py +0 -0
  137. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/common_pb2_grpc.pyi +0 -0
  138. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/driver_pb2.py +0 -0
  139. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/driver_pb2.pyi +0 -0
  140. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/driver_pb2_grpc.py +0 -0
  141. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/driver_pb2_grpc.pyi +0 -0
  142. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/error_pb2.py +0 -0
  143. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/error_pb2.pyi +0 -0
  144. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/error_pb2_grpc.py +0 -0
  145. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  146. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/exec_pb2.py +0 -0
  147. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/exec_pb2.pyi +0 -0
  148. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/exec_pb2_grpc.py +0 -0
  149. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/exec_pb2_grpc.pyi +0 -0
  150. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fab_pb2.py +0 -0
  151. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fab_pb2.pyi +0 -0
  152. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fab_pb2_grpc.py +0 -0
  153. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  154. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fleet_pb2.py +0 -0
  155. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fleet_pb2.pyi +0 -0
  156. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  157. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  158. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/grpcadapter_pb2.py +0 -0
  159. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  160. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  161. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  162. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/node_pb2.py +0 -0
  163. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/node_pb2.pyi +0 -0
  164. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/node_pb2_grpc.py +0 -0
  165. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  166. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/recordset_pb2.py +0 -0
  167. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/recordset_pb2.pyi +0 -0
  168. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/recordset_pb2_grpc.py +0 -0
  169. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/recordset_pb2_grpc.pyi +0 -0
  170. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/run_pb2.py +0 -0
  171. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/run_pb2.pyi +0 -0
  172. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/run_pb2_grpc.py +0 -0
  173. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  174. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/task_pb2.py +0 -0
  175. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/task_pb2.pyi +0 -0
  176. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/task_pb2_grpc.py +0 -0
  177. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/task_pb2_grpc.pyi +0 -0
  178. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/transport_pb2.py +0 -0
  179. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/transport_pb2.pyi +0 -0
  180. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/transport_pb2_grpc.py +0 -0
  181. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  182. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/py.typed +0 -0
  183. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/__init__.py +0 -0
  184. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/app.py +0 -0
  185. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/client_manager.py +0 -0
  186. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/client_proxy.py +0 -0
  187. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/compat/__init__.py +0 -0
  188. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/compat/app.py +0 -0
  189. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/compat/app_utils.py +0 -0
  190. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/compat/driver_client_proxy.py +0 -0
  191. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/compat/legacy_context.py +0 -0
  192. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/criterion.py +0 -0
  193. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/driver/__init__.py +0 -0
  194. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/driver/driver.py +0 -0
  195. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/driver/grpc_driver.py +0 -0
  196. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/driver/inmemory_driver.py +0 -0
  197. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/history.py +0 -0
  198. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/run_serverapp.py +0 -0
  199. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/server.py +0 -0
  200. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/server_app.py +0 -0
  201. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/server_config.py +0 -0
  202. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/serverapp_components.py +0 -0
  203. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/__init__.py +0 -0
  204. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/aggregate.py +0 -0
  205. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/bulyan.py +0 -0
  206. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  207. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  208. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  209. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  210. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  211. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedadagrad.py +0 -0
  212. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedadam.py +0 -0
  213. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedavg.py +0 -0
  214. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedavg_android.py +0 -0
  215. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedavgm.py +0 -0
  216. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedmedian.py +0 -0
  217. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedopt.py +0 -0
  218. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedprox.py +0 -0
  219. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  220. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  221. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  222. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  223. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/fedyogi.py +0 -0
  224. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/krum.py +0 -0
  225. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/qfedavg.py +0 -0
  226. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/strategy/strategy.py +0 -0
  227. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/__init__.py +0 -0
  228. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/driver/__init__.py +0 -0
  229. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/driver/driver_grpc.py +0 -0
  230. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/driver/driver_servicer.py +0 -0
  231. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/__init__.py +0 -0
  232. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  233. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  234. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  235. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  236. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  237. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  238. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  239. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  240. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  241. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  242. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  243. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  244. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  245. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  246. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  247. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  248. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  249. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  250. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  251. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/state/__init__.py +0 -0
  252. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/state/in_memory_state.py +0 -0
  253. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/state/sqlite_state.py +0 -0
  254. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/state/state.py +0 -0
  255. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/state/state_factory.py +0 -0
  256. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/superlink/state/utils.py +0 -0
  257. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/typing.py +0 -0
  258. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/utils/__init__.py +0 -0
  259. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/utils/tensorboard.py +0 -0
  260. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/utils/validator.py +0 -0
  261. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/workflow/__init__.py +0 -0
  262. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/workflow/constant.py +0 -0
  263. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/workflow/default_workflows.py +0 -0
  264. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  265. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  266. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  267. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/simulation/__init__.py +0 -0
  268. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/simulation/app.py +0 -0
  269. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/simulation/ray_transport/__init__.py +0 -0
  270. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  271. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  272. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/simulation/ray_transport/utils.py +0 -0
  273. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/superexec/__init__.py +0 -0
  274. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/superexec/exec_grpc.py +0 -0
  275. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/src/py/flwr/superexec/exec_servicer.py +0 -0
  276. {flwr_nightly-1.10.0.dev20240716 → flwr_nightly-1.10.0.dev20240719}/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.dev20240716
3
+ Version: 1.10.0.dev20240719
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.dev20240716"
7
+ version = "1.10.0.dev20240719"
8
8
  description = "Flower: A Friendly Federated Learning Framework"
9
9
  license = "Apache-2.0"
10
10
  authors = ["The Flower Authors <hello@flower.ai>"]
@@ -16,6 +16,7 @@
16
16
 
17
17
 
18
18
  import shutil
19
+ import subprocess
19
20
  import tempfile
20
21
  import zipfile
21
22
  from io import BytesIO
@@ -192,6 +193,21 @@ def validate_and_install(
192
193
  else:
193
194
  shutil.copy2(item, install_dir / item.name)
194
195
 
196
+ try:
197
+ subprocess.run(
198
+ ["pip", "install", "-e", install_dir, "--no-deps"],
199
+ capture_output=True,
200
+ text=True,
201
+ check=True,
202
+ )
203
+ except subprocess.CalledProcessError as e:
204
+ typer.secho(
205
+ f"❌ Failed to `pip install` package(s) from {install_dir}:\n{e.stderr}",
206
+ fg=typer.colors.RED,
207
+ bold=True,
208
+ )
209
+ raise typer.Exit(code=1) from e
210
+
195
211
  typer.secho(
196
212
  f"🎊 Successfully installed {project_name} to {install_dir}.",
197
213
  fg=typer.colors.GREEN,
@@ -136,6 +136,7 @@ def new(
136
136
 
137
137
  framework_str = framework_str.lower()
138
138
 
139
+ llm_challenge_str = None
139
140
  if framework_str == "flowertune":
140
141
  llm_challenge_value = prompt_options(
141
142
  "Please select LLM challenge by typing in the number",
@@ -171,7 +172,7 @@ def new(
171
172
  }
172
173
 
173
174
  # List of files to render
174
- if framework_str == "flowertune":
175
+ if llm_challenge_str:
175
176
  files = {
176
177
  ".gitignore": {"template": "app/.gitignore.tpl"},
177
178
  "pyproject.toml": {"template": f"app/pyproject.{framework_str}.toml.tpl"},
@@ -228,10 +229,10 @@ def new(
228
229
  "README.md": {"template": "app/README.md.tpl"},
229
230
  "pyproject.toml": {"template": f"app/pyproject.{framework_str}.toml.tpl"},
230
231
  f"{import_name}/__init__.py": {"template": "app/code/__init__.py.tpl"},
231
- f"{import_name}/server.py": {
232
+ f"{import_name}/server_app.py": {
232
233
  "template": f"app/code/server.{framework_str}.py.tpl"
233
234
  },
234
- f"{import_name}/client.py": {
235
+ f"{import_name}/client_app.py": {
235
236
  "template": f"app/code/client.{framework_str}.py.tpl"
236
237
  },
237
238
  }
@@ -30,7 +30,11 @@ class FlowerClient(NumPyClient):
30
30
 
31
31
  def fit(self, parameters, config):
32
32
  self.set_parameters(parameters)
33
- train(self.net, self.trainloader, epochs=1)
33
+ train(
34
+ self.net,
35
+ self.trainloader,
36
+ epochs=int(self.context.run_config["local-epochs"]),
37
+ )
34
38
  return self.get_parameters(config={}), len(self.trainloader), {}
35
39
 
36
40
  def evaluate(self, parameters, config):
@@ -45,8 +49,8 @@ def client_fn(context: Context):
45
49
  CHECKPOINT, num_labels=2
46
50
  ).to(DEVICE)
47
51
 
48
- partition_id = int(context.node_config['partition-id'])
49
- num_partitions = int(context.node_config['num-partitions])
52
+ partition_id = int(context.node_config["partition-id"])
53
+ num_partitions = int(context.node_config["num-partitions"])
50
54
  trainloader, valloader = load_data(partition_id, num_partitions)
51
55
 
52
56
  # Return Client instance
@@ -20,17 +20,19 @@ from $import_name.task import (
20
20
  # Define Flower Client and client_fn
21
21
  class FlowerClient(NumPyClient):
22
22
  def __init__(self, data):
23
- num_layers = 2
24
- hidden_dim = 32
23
+ num_layers = int(self.context.run_config["num-layers"])
24
+ hidden_dim = int(self.context.run_config["hidden-dim"])
25
25
  num_classes = 10
26
- batch_size = 256
27
- num_epochs = 1
28
- learning_rate = 1e-1
26
+ batch_size = int(self.context.run_config["batch-size"])
27
+ learning_rate = float(self.context.run_config["lr"])
28
+ num_epochs = int(self.context.run_config["local-epochs"])
29
29
 
30
30
  self.train_images, self.train_labels, self.test_images, self.test_labels = data
31
- self.model = MLP(num_layers, self.train_images.shape[-1], hidden_dim, num_classes)
32
- self.optimizer = optim.SGD(learning_rate=learning_rate)
33
- self.loss_and_grad_fn = nn.value_and_grad(self.model, loss_fn)
31
+ self.model = MLP(
32
+ num_layers, self.train_images.shape[-1], hidden_dim, num_classes
33
+ )
34
+ self.optimizer = optim.SGD(learning_rate=learning_rate)
35
+ self.loss_and_grad_fn = nn.value_and_grad(self.model, loss_fn)
34
36
  self.num_epochs = num_epochs
35
37
  self.batch_size = batch_size
36
38
 
@@ -23,7 +23,13 @@ class FlowerClient(NumPyClient):
23
23
 
24
24
  def fit(self, parameters, config):
25
25
  set_weights(self.net, parameters)
26
- results = train(self.net, self.trainloader, self.valloader, 1, DEVICE)
26
+ results = train(
27
+ self.net,
28
+ self.trainloader,
29
+ self.valloader,
30
+ int(self.context.run_config["local-epochs"]),
31
+ DEVICE,
32
+ )
27
33
  return get_weights(self.net), len(self.trainloader.dataset), results
28
34
 
29
35
  def evaluate(self, parameters, config):
@@ -67,10 +67,11 @@ class FlowerClient(NumPyClient):
67
67
 
68
68
  return loss, len(self.X_test), {"accuracy": accuracy}
69
69
 
70
- fds = FederatedDataset(dataset="mnist", partitioners={"train": 2})
71
70
 
72
71
  def client_fn(context: Context):
73
72
  partition_id = int(context.node_config["partition-id"])
73
+ num_partitions = int(context.node_config["num-partitions"])
74
+ fds = FederatedDataset(dataset="mnist", partitioners={"train": num_partitions})
74
75
  dataset = fds.load_partition(partition_id, "train").with_format("numpy")
75
76
 
76
77
  X, y = dataset["image"].reshape((len(dataset), -1)), dataset["label"]
@@ -20,7 +20,13 @@ class FlowerClient(NumPyClient):
20
20
 
21
21
  def fit(self, parameters, config):
22
22
  self.model.set_weights(parameters)
23
- self.model.fit(self.x_train, self.y_train, epochs=1, batch_size=32, verbose=0)
23
+ self.model.fit(
24
+ self.x_train,
25
+ self.y_train,
26
+ epochs=int(self.context.run_config["local-epochs"]),
27
+ batch_size=int(self.context.run_config["batch-size"]),
28
+ verbose=bool(self.context.run_config.get("verbose")),
29
+ )
24
30
  return self.model.get_weights(), len(self.x_train), {}
25
31
 
26
32
  def evaluate(self, parameters, config):
@@ -34,7 +40,8 @@ def client_fn(context: Context):
34
40
  net = load_model()
35
41
 
36
42
  partition_id = int(context.node_config["partition-id"])
37
- x_train, y_train, x_test, y_test = load_data(partition_id, 2)
43
+ num_partitions = int(context.node_config["num-partitions"])
44
+ x_train, y_train, x_test, y_test = load_data(partition_id, num_partitions)
38
45
 
39
46
  # Return Client instance
40
47
  return FlowerClient(net, x_train, y_train, x_test, y_test).to_client()
@@ -12,10 +12,10 @@ from flwr.client import ClientApp
12
12
  from flwr.common import ndarrays_to_parameters
13
13
  from flwr.server import ServerApp, ServerConfig
14
14
 
15
- from $import_name.client import gen_client_fn, get_parameters
15
+ from $import_name.client_app import gen_client_fn, get_parameters
16
16
  from $import_name.dataset import get_tokenizer_and_data_collator_and_propt_formatting
17
17
  from $import_name.models import get_model
18
- from $import_name.server import fit_weighted_average, get_evaluate_fn, get_on_fit_config
18
+ from $import_name.server_app import fit_weighted_average, get_evaluate_fn, get_on_fit_config
19
19
 
20
20
  # Avoid warnings
21
21
  warnings.filterwarnings("ignore", category=UserWarning)
@@ -1,6 +1,6 @@
1
1
  """$project_name: A Flower / FlowerTune app."""
2
2
 
3
- from $import_name.client import set_parameters
3
+ from $import_name.client_app import set_parameters
4
4
  from $import_name.models import get_model
5
5
 
6
6
 
@@ -24,11 +24,12 @@ packages = ["."]
24
24
  publisher = "$username"
25
25
 
26
26
  [tool.flwr.app.components]
27
- serverapp = "$import_name.server:app"
28
- clientapp = "$import_name.client:app"
27
+ serverapp = "$import_name.server_app:app"
28
+ clientapp = "$import_name.client_app:app"
29
29
 
30
30
  [tool.flwr.app.config]
31
31
  num-server-rounds = "3"
32
+ local-epochs = "1"
32
33
 
33
34
  [tool.flwr.federations]
34
35
  default = "localhost"
@@ -21,8 +21,8 @@ packages = ["."]
21
21
  publisher = "$username"
22
22
 
23
23
  [tool.flwr.app.components]
24
- serverapp = "$import_name.server:app"
25
- clientapp = "$import_name.client:app"
24
+ serverapp = "$import_name.server_app:app"
25
+ clientapp = "$import_name.client_app:app"
26
26
 
27
27
  [tool.flwr.app.config]
28
28
  num-server-rounds = "3"
@@ -21,11 +21,16 @@ packages = ["."]
21
21
  publisher = "$username"
22
22
 
23
23
  [tool.flwr.app.components]
24
- serverapp = "$import_name.server:app"
25
- clientapp = "$import_name.client:app"
24
+ serverapp = "$import_name.server_app:app"
25
+ clientapp = "$import_name.client_app:app"
26
26
 
27
27
  [tool.flwr.app.config]
28
28
  num-server-rounds = "3"
29
+ local-epochs = "1"
30
+ num-layers = "2"
31
+ hidden-dim = "32"
32
+ batch-size = "256"
33
+ lr = "0.1"
29
34
 
30
35
  [tool.flwr.federations]
31
36
  default = "localhost"
@@ -19,8 +19,8 @@ packages = ["."]
19
19
  publisher = "$username"
20
20
 
21
21
  [tool.flwr.app.components]
22
- serverapp = "$import_name.server:app"
23
- clientapp = "$import_name.client:app"
22
+ serverapp = "$import_name.server_app:app"
23
+ clientapp = "$import_name.client_app:app"
24
24
 
25
25
  [tool.flwr.app.config]
26
26
  num-server-rounds = "3"
@@ -21,11 +21,12 @@ packages = ["."]
21
21
  publisher = "$username"
22
22
 
23
23
  [tool.flwr.app.components]
24
- serverapp = "$import_name.server:app"
25
- clientapp = "$import_name.client:app"
24
+ serverapp = "$import_name.server_app:app"
25
+ clientapp = "$import_name.client_app:app"
26
26
 
27
27
  [tool.flwr.app.config]
28
28
  num-server-rounds = "3"
29
+ local-epochs = "1"
29
30
 
30
31
  [tool.flwr.federations]
31
32
  default = "localhost"
@@ -20,8 +20,8 @@ packages = ["."]
20
20
  publisher = "$username"
21
21
 
22
22
  [tool.flwr.app.components]
23
- serverapp = "$import_name.server:app"
24
- clientapp = "$import_name.client:app"
23
+ serverapp = "$import_name.server_app:app"
24
+ clientapp = "$import_name.client_app:app"
25
25
 
26
26
  [tool.flwr.app.config]
27
27
  num-server-rounds = "3"
@@ -20,11 +20,14 @@ packages = ["."]
20
20
  publisher = "$username"
21
21
 
22
22
  [tool.flwr.app.components]
23
- serverapp = "$import_name.server:app"
24
- clientapp = "$import_name.client:app"
23
+ serverapp = "$import_name.server_app:app"
24
+ clientapp = "$import_name.client_app:app"
25
25
 
26
26
  [tool.flwr.app.config]
27
27
  num-server-rounds = "3"
28
+ local-epochs = "1"
29
+ batch-size = "32"
30
+ verbose = "" # Empty string means False
28
31
 
29
32
  [tool.flwr.federations]
30
33
  default = "localhost"
@@ -18,7 +18,7 @@ import subprocess
18
18
  import sys
19
19
  from logging import DEBUG
20
20
  from pathlib import Path
21
- from typing import Any, Dict, Optional
21
+ from typing import Any, Dict, List, Optional
22
22
 
23
23
  import typer
24
24
  from typing_extensions import Annotated
@@ -43,7 +43,7 @@ def run(
43
43
  typer.Argument(help="Name of the federation to run the app on"),
44
44
  ] = None,
45
45
  config_overrides: Annotated[
46
- Optional[str],
46
+ Optional[List[str]],
47
47
  typer.Option(
48
48
  "--run-config",
49
49
  "-c",
@@ -94,11 +94,13 @@ def run(
94
94
  # Validate the federation exists in the configuration
95
95
  federation = config["tool"]["flwr"]["federations"].get(federation_name)
96
96
  if federation is None:
97
- available_feds = list(config["tool"]["flwr"]["federations"])
97
+ available_feds = {
98
+ fed for fed in config["tool"]["flwr"]["federations"] if fed != "default"
99
+ }
98
100
  typer.secho(
99
101
  f"❌ There is no `{federation_name}` federation declared in the "
100
102
  "`pyproject.toml`.\n The following federations were found:\n\n"
101
- "\n".join(available_feds) + "\n\n",
103
+ + "\n".join(available_feds),
102
104
  fg=typer.colors.RED,
103
105
  bold=True,
104
106
  )
@@ -113,7 +115,7 @@ def run(
113
115
  def _run_with_superexec(
114
116
  federation: Dict[str, str],
115
117
  directory: Optional[Path],
116
- config_overrides: Optional[str],
118
+ config_overrides: Optional[List[str]],
117
119
  ) -> None:
118
120
 
119
121
  def on_channel_state_change(channel_connectivity: str) -> None:
@@ -172,7 +174,7 @@ def _run_without_superexec(
172
174
  app_path: Optional[Path],
173
175
  federation: Dict[str, Any],
174
176
  federation_name: str,
175
- config_overrides: Optional[str],
177
+ config_overrides: Optional[List[str]],
176
178
  ) -> None:
177
179
  try:
178
180
  num_supernodes = federation["options"]["num-supernodes"]
@@ -197,7 +199,7 @@ def _run_without_superexec(
197
199
  ]
198
200
 
199
201
  if config_overrides:
200
- command.extend(["--run-config", f"{config_overrides}"])
202
+ command.extend(["--run-config", f"{','.join(config_overrides)}"])
201
203
 
202
204
  # Run the simulation
203
205
  subprocess.run(
@@ -77,7 +77,7 @@ def run_supernode() -> None:
77
77
  authentication_keys=authentication_keys,
78
78
  max_retries=args.max_retries,
79
79
  max_wait_time=args.max_wait_time,
80
- node_config=parse_config_args(args.node_config),
80
+ node_config=parse_config_args([args.node_config]),
81
81
  flwr_path=get_flwr_dir(args.flwr_dir),
82
82
  )
83
83
 
@@ -107,7 +107,7 @@ def run_client_app() -> None:
107
107
 
108
108
  _start_client_internal(
109
109
  server_address=args.superlink,
110
- node_config=parse_config_args(args.node_config),
110
+ node_config=parse_config_args([args.node_config]),
111
111
  load_client_app_fn=load_fn,
112
112
  transport=args.transport,
113
113
  root_certificates=root_certificates,
@@ -130,7 +130,7 @@ def flatten_dict(raw_dict: Dict[str, Any], parent_key: str = "") -> Dict[str, st
130
130
 
131
131
 
132
132
  def parse_config_args(
133
- config: Optional[str],
133
+ config: Optional[List[str]],
134
134
  separator: str = ",",
135
135
  ) -> Dict[str, str]:
136
136
  """Parse separator separated list of key-value pairs separated by '='."""
@@ -139,17 +139,19 @@ def parse_config_args(
139
139
  if config is None:
140
140
  return overrides
141
141
 
142
- overrides_list = config.split(separator)
143
- if (
144
- len(overrides_list) == 1
145
- and "=" not in overrides_list
146
- and overrides_list[0].endswith(".toml")
147
- ):
148
- with Path(overrides_list[0]).open("rb") as config_file:
149
- overrides = flatten_dict(tomli.load(config_file))
150
- else:
151
- for kv_pair in overrides_list:
152
- key, value = kv_pair.split("=")
153
- overrides[key] = value
142
+ for config_line in config:
143
+ if config_line:
144
+ overrides_list = config_line.split(separator)
145
+ if (
146
+ len(overrides_list) == 1
147
+ and "=" not in overrides_list
148
+ and overrides_list[0].endswith(".toml")
149
+ ):
150
+ with Path(overrides_list[0]).open("rb") as config_file:
151
+ overrides = flatten_dict(tomli.load(config_file))
152
+ else:
153
+ for kv_pair in overrides_list:
154
+ key, value = kv_pair.split("=")
155
+ overrides[key] = value
154
156
 
155
157
  return overrides
@@ -132,7 +132,7 @@ def run_simulation_from_cli() -> None:
132
132
  client_app_attr = app_components["clientapp"]
133
133
  server_app_attr = app_components["serverapp"]
134
134
 
135
- override_config = parse_config_args(args.run_config)
135
+ override_config = parse_config_args([args.run_config])
136
136
  fused_config = get_fused_config_from_dir(app_path, override_config)
137
137
  app_dir = args.app
138
138
  is_app = True
@@ -56,7 +56,7 @@ def run_superexec() -> None:
56
56
  address=address,
57
57
  executor=_load_executor(args),
58
58
  certificates=certificates,
59
- config=parse_config_args(args.executor_config),
59
+ config=parse_config_args([args.executor_config]),
60
60
  )
61
61
 
62
62
  grpc_servers = [superexec_server]
@@ -15,7 +15,6 @@
15
15
  """Deployment engine executor."""
16
16
 
17
17
  import subprocess
18
- import sys
19
18
  from logging import ERROR, INFO
20
19
  from pathlib import Path
21
20
  from typing import Dict, Optional
@@ -131,14 +130,7 @@ class DeploymentEngine(Executor):
131
130
  try:
132
131
  # Install FAB to flwr dir
133
132
  fab_version, fab_id = get_fab_metadata(fab_file)
134
- fab_path = install_from_fab(fab_file, None, True)
135
-
136
- # Install FAB Python package
137
- subprocess.check_call(
138
- [sys.executable, "-m", "pip", "install", "--no-deps", str(fab_path)],
139
- stdout=subprocess.DEVNULL,
140
- stderr=subprocess.DEVNULL,
141
- )
133
+ install_from_fab(fab_file, None, True)
142
134
 
143
135
  # Call SuperLink to create run
144
136
  run_id: int = self._create_run(fab_id, fab_version, override_config)
@@ -82,11 +82,6 @@ class SimulationEngine(Executor):
82
82
  ) -> Optional[RunTracker]:
83
83
  """Start run using the Flower Simulation Engine."""
84
84
  try:
85
- if override_config:
86
- raise ValueError(
87
- "Overriding the run config is not yet supported with the "
88
- "simulation executor.",
89
- )
90
85
 
91
86
  # Install FAB to flwr dir
92
87
  fab_path = install_from_fab(fab_file, None, True)
@@ -111,11 +106,6 @@ class SimulationEngine(Executor):
111
106
  "Config extracted from FAB's pyproject.toml is not valid"
112
107
  )
113
108
 
114
- # Get ClientApp and SeverApp components
115
- flower_components = config["tool"]["flwr"]["app"]["components"]
116
- clientapp = flower_components["clientapp"]
117
- serverapp = flower_components["serverapp"]
118
-
119
109
  # In Simulation there is no SuperLink, still we create a run_id
120
110
  run_id = generate_rand_int_from_bytes(RUN_ID_NUM_BYTES)
121
111
  log(INFO, "Created run %s", str(run_id))
@@ -123,21 +113,21 @@ class SimulationEngine(Executor):
123
113
  # Prepare commnand
124
114
  command = [
125
115
  "flower-simulation",
126
- "--client-app",
127
- f"{clientapp}",
128
- "--server-app",
129
- f"{serverapp}",
116
+ "--app",
117
+ f"{str(fab_path)}",
130
118
  "--num-supernodes",
131
119
  f"{self.num_supernodes}",
132
120
  "--run-id",
133
121
  str(run_id),
134
122
  ]
135
123
 
124
+ if override_config:
125
+ command.extend(["--run-config", f"{override_config}"])
126
+
136
127
  # Start Simulation
137
- proc = subprocess.Popen( # pylint: disable=consider-using-with
128
+ proc = subprocess.run( # pylint: disable=consider-using-with
138
129
  command,
139
- stdout=subprocess.PIPE,
140
- stderr=subprocess.PIPE,
130
+ check=True,
141
131
  text=True,
142
132
  )
143
133
 
@@ -145,7 +135,7 @@ class SimulationEngine(Executor):
145
135
 
146
136
  return RunTracker(
147
137
  run_id=run_id,
148
- proc=proc,
138
+ proc=proc, # type:ignore
149
139
  )
150
140
 
151
141
  # pylint: disable-next=broad-except