flwr-nightly 1.10.0.dev20240717__tar.gz → 1.10.0.dev20240721__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.dev20240717 → flwr_nightly-1.10.0.dev20240721}/PKG-INFO +2 -2
  2. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/pyproject.toml +2 -2
  3. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/new.py +24 -16
  4. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/client.hf.py.tpl +7 -3
  5. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/client.mlx.py.tpl +10 -8
  6. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/client.pytorch.py.tpl +7 -1
  7. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/client.sklearn.py.tpl +2 -1
  8. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/client.tensorflow.py.tpl +9 -2
  9. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.hf.toml.tpl +5 -4
  10. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.jax.toml.tpl +3 -3
  11. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.mlx.toml.tpl +5 -0
  12. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.pytorch.toml.tpl +1 -0
  13. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.tensorflow.toml.tpl +3 -0
  14. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/run/run.py +1 -1
  15. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/simulation/run_simulation.py +6 -2
  16. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/LICENSE +0 -0
  17. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/README.md +0 -0
  18. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/__init__.py +0 -0
  19. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/__init__.py +0 -0
  20. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/app.py +0 -0
  21. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/build.py +0 -0
  22. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/config_utils.py +0 -0
  23. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/example.py +0 -0
  24. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/install.py +0 -0
  25. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/__init__.py +0 -0
  26. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/__init__.py +0 -0
  27. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/.gitignore.tpl +0 -0
  28. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/README.flowertune.md.tpl +0 -0
  29. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/README.md.tpl +0 -0
  30. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/__init__.py +0 -0
  31. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/__init__.py +0 -0
  32. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/__init__.py.tpl +0 -0
  33. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/client.jax.py.tpl +0 -0
  34. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/client.numpy.py.tpl +0 -0
  35. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/__init__.py +0 -0
  36. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/app.py.tpl +0 -0
  37. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/client.py.tpl +0 -0
  38. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/config.yaml.tpl +0 -0
  39. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/dataset.py.tpl +0 -0
  40. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/models.py.tpl +0 -0
  41. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/server.py.tpl +0 -0
  42. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/flwr_tune/static_config.yaml.tpl +0 -0
  43. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/server.hf.py.tpl +0 -0
  44. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/server.jax.py.tpl +0 -0
  45. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/server.mlx.py.tpl +0 -0
  46. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/server.numpy.py.tpl +0 -0
  47. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/server.pytorch.py.tpl +0 -0
  48. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/server.sklearn.py.tpl +0 -0
  49. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/server.tensorflow.py.tpl +0 -0
  50. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/task.hf.py.tpl +0 -0
  51. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/task.jax.py.tpl +0 -0
  52. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/task.mlx.py.tpl +0 -0
  53. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/task.pytorch.py.tpl +0 -0
  54. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/code/task.tensorflow.py.tpl +0 -0
  55. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.flowertune.toml.tpl +0 -0
  56. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.numpy.toml.tpl +0 -0
  57. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/new/templates/app/pyproject.sklearn.toml.tpl +0 -0
  58. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/run/__init__.py +0 -0
  59. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/cli/utils.py +0 -0
  60. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/__init__.py +0 -0
  61. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/app.py +0 -0
  62. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/client.py +0 -0
  63. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/client_app.py +0 -0
  64. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/dpfedavg_numpy_client.py +0 -0
  65. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_adapter_client/__init__.py +0 -0
  66. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_adapter_client/connection.py +0 -0
  67. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_client/__init__.py +0 -0
  68. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_client/connection.py +0 -0
  69. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_rere_client/__init__.py +0 -0
  70. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_rere_client/client_interceptor.py +0 -0
  71. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_rere_client/connection.py +0 -0
  72. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/grpc_rere_client/grpc_adapter.py +0 -0
  73. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/heartbeat.py +0 -0
  74. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/message_handler/__init__.py +0 -0
  75. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/message_handler/message_handler.py +0 -0
  76. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/message_handler/task_handler.py +0 -0
  77. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/__init__.py +0 -0
  78. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/centraldp_mods.py +0 -0
  79. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/comms_mods.py +0 -0
  80. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/localdp_mod.py +0 -0
  81. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/secure_aggregation/__init__.py +0 -0
  82. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/secure_aggregation/secagg_mod.py +0 -0
  83. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/secure_aggregation/secaggplus_mod.py +0 -0
  84. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/mod/utils.py +0 -0
  85. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/node_state.py +0 -0
  86. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/node_state_tests.py +0 -0
  87. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/numpy_client.py +0 -0
  88. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/rest_client/__init__.py +0 -0
  89. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/rest_client/connection.py +0 -0
  90. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/supernode/__init__.py +0 -0
  91. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/supernode/app.py +0 -0
  92. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/client/typing.py +0 -0
  93. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/__init__.py +0 -0
  94. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/address.py +0 -0
  95. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/config.py +0 -0
  96. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/constant.py +0 -0
  97. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/context.py +0 -0
  98. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/date.py +0 -0
  99. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/differential_privacy.py +0 -0
  100. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/differential_privacy_constants.py +0 -0
  101. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/dp.py +0 -0
  102. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/exit_handlers.py +0 -0
  103. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/grpc.py +0 -0
  104. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/logger.py +0 -0
  105. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/message.py +0 -0
  106. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/object_ref.py +0 -0
  107. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/parameter.py +0 -0
  108. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/pyproject.py +0 -0
  109. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/record/__init__.py +0 -0
  110. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/record/configsrecord.py +0 -0
  111. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/record/conversion_utils.py +0 -0
  112. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/record/metricsrecord.py +0 -0
  113. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/record/parametersrecord.py +0 -0
  114. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/record/recordset.py +0 -0
  115. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/record/typeddict.py +0 -0
  116. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/recordset_compat.py +0 -0
  117. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/retry_invoker.py +0 -0
  118. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/__init__.py +0 -0
  119. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/crypto/__init__.py +0 -0
  120. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/crypto/shamir.py +0 -0
  121. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/crypto/symmetric_encryption.py +0 -0
  122. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/ndarrays_arithmetic.py +0 -0
  123. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/quantization.py +0 -0
  124. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/secaggplus_constants.py +0 -0
  125. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/secure_aggregation/secaggplus_utils.py +0 -0
  126. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/serde.py +0 -0
  127. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/telemetry.py +0 -0
  128. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/typing.py +0 -0
  129. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/common/version.py +0 -0
  130. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/__init__.py +0 -0
  131. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/common_pb2.py +0 -0
  132. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/common_pb2.pyi +0 -0
  133. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/common_pb2_grpc.py +0 -0
  134. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/common_pb2_grpc.pyi +0 -0
  135. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/driver_pb2.py +0 -0
  136. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/driver_pb2.pyi +0 -0
  137. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/driver_pb2_grpc.py +0 -0
  138. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/driver_pb2_grpc.pyi +0 -0
  139. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/error_pb2.py +0 -0
  140. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/error_pb2.pyi +0 -0
  141. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/error_pb2_grpc.py +0 -0
  142. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/error_pb2_grpc.pyi +0 -0
  143. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/exec_pb2.py +0 -0
  144. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/exec_pb2.pyi +0 -0
  145. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/exec_pb2_grpc.py +0 -0
  146. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/exec_pb2_grpc.pyi +0 -0
  147. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fab_pb2.py +0 -0
  148. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fab_pb2.pyi +0 -0
  149. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fab_pb2_grpc.py +0 -0
  150. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fab_pb2_grpc.pyi +0 -0
  151. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fleet_pb2.py +0 -0
  152. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fleet_pb2.pyi +0 -0
  153. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fleet_pb2_grpc.py +0 -0
  154. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/fleet_pb2_grpc.pyi +0 -0
  155. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/grpcadapter_pb2.py +0 -0
  156. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/grpcadapter_pb2.pyi +0 -0
  157. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/grpcadapter_pb2_grpc.py +0 -0
  158. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/grpcadapter_pb2_grpc.pyi +0 -0
  159. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/node_pb2.py +0 -0
  160. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/node_pb2.pyi +0 -0
  161. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/node_pb2_grpc.py +0 -0
  162. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/node_pb2_grpc.pyi +0 -0
  163. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/recordset_pb2.py +0 -0
  164. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/recordset_pb2.pyi +0 -0
  165. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/recordset_pb2_grpc.py +0 -0
  166. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/recordset_pb2_grpc.pyi +0 -0
  167. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/run_pb2.py +0 -0
  168. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/run_pb2.pyi +0 -0
  169. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/run_pb2_grpc.py +0 -0
  170. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/run_pb2_grpc.pyi +0 -0
  171. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/task_pb2.py +0 -0
  172. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/task_pb2.pyi +0 -0
  173. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/task_pb2_grpc.py +0 -0
  174. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/task_pb2_grpc.pyi +0 -0
  175. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/transport_pb2.py +0 -0
  176. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/transport_pb2.pyi +0 -0
  177. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/transport_pb2_grpc.py +0 -0
  178. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/proto/transport_pb2_grpc.pyi +0 -0
  179. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/py.typed +0 -0
  180. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/__init__.py +0 -0
  181. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/app.py +0 -0
  182. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/client_manager.py +0 -0
  183. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/client_proxy.py +0 -0
  184. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/compat/__init__.py +0 -0
  185. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/compat/app.py +0 -0
  186. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/compat/app_utils.py +0 -0
  187. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/compat/driver_client_proxy.py +0 -0
  188. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/compat/legacy_context.py +0 -0
  189. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/criterion.py +0 -0
  190. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/driver/__init__.py +0 -0
  191. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/driver/driver.py +0 -0
  192. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/driver/grpc_driver.py +0 -0
  193. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/driver/inmemory_driver.py +0 -0
  194. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/history.py +0 -0
  195. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/run_serverapp.py +0 -0
  196. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/server.py +0 -0
  197. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/server_app.py +0 -0
  198. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/server_config.py +0 -0
  199. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/serverapp_components.py +0 -0
  200. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/__init__.py +0 -0
  201. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/aggregate.py +0 -0
  202. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/bulyan.py +0 -0
  203. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/dp_adaptive_clipping.py +0 -0
  204. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/dp_fixed_clipping.py +0 -0
  205. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/dpfedavg_adaptive.py +0 -0
  206. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/dpfedavg_fixed.py +0 -0
  207. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fault_tolerant_fedavg.py +0 -0
  208. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedadagrad.py +0 -0
  209. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedadam.py +0 -0
  210. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedavg.py +0 -0
  211. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedavg_android.py +0 -0
  212. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedavgm.py +0 -0
  213. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedmedian.py +0 -0
  214. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedopt.py +0 -0
  215. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedprox.py +0 -0
  216. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedtrimmedavg.py +0 -0
  217. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedxgb_bagging.py +0 -0
  218. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedxgb_cyclic.py +0 -0
  219. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedxgb_nn_avg.py +0 -0
  220. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/fedyogi.py +0 -0
  221. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/krum.py +0 -0
  222. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/qfedavg.py +0 -0
  223. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/strategy/strategy.py +0 -0
  224. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/__init__.py +0 -0
  225. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/driver/__init__.py +0 -0
  226. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/driver/driver_grpc.py +0 -0
  227. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/driver/driver_servicer.py +0 -0
  228. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/__init__.py +0 -0
  229. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_adapter/__init__.py +0 -0
  230. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_adapter/grpc_adapter_servicer.py +0 -0
  231. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_bidi/__init__.py +0 -0
  232. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_bidi/flower_service_servicer.py +0 -0
  233. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_bridge.py +0 -0
  234. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_client_proxy.py +0 -0
  235. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_bidi/grpc_server.py +0 -0
  236. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_rere/__init__.py +0 -0
  237. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_rere/fleet_servicer.py +0 -0
  238. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/grpc_rere/server_interceptor.py +0 -0
  239. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/message_handler/__init__.py +0 -0
  240. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/message_handler/message_handler.py +0 -0
  241. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/rest_rere/__init__.py +0 -0
  242. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/rest_rere/rest_api.py +0 -0
  243. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/vce/__init__.py +0 -0
  244. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/vce/backend/__init__.py +0 -0
  245. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/vce/backend/backend.py +0 -0
  246. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/vce/backend/raybackend.py +0 -0
  247. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/fleet/vce/vce_api.py +0 -0
  248. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/state/__init__.py +0 -0
  249. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/state/in_memory_state.py +0 -0
  250. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/state/sqlite_state.py +0 -0
  251. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/state/state.py +0 -0
  252. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/state/state_factory.py +0 -0
  253. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/superlink/state/utils.py +0 -0
  254. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/typing.py +0 -0
  255. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/utils/__init__.py +0 -0
  256. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/utils/tensorboard.py +0 -0
  257. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/utils/validator.py +0 -0
  258. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/workflow/__init__.py +0 -0
  259. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/workflow/constant.py +0 -0
  260. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/workflow/default_workflows.py +0 -0
  261. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/workflow/secure_aggregation/__init__.py +0 -0
  262. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/workflow/secure_aggregation/secagg_workflow.py +0 -0
  263. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/server/workflow/secure_aggregation/secaggplus_workflow.py +0 -0
  264. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/simulation/__init__.py +0 -0
  265. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/simulation/app.py +0 -0
  266. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/simulation/ray_transport/__init__.py +0 -0
  267. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/simulation/ray_transport/ray_actor.py +0 -0
  268. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/simulation/ray_transport/ray_client_proxy.py +0 -0
  269. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/simulation/ray_transport/utils.py +0 -0
  270. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/superexec/__init__.py +0 -0
  271. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/superexec/app.py +0 -0
  272. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/superexec/deployment.py +0 -0
  273. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/superexec/exec_grpc.py +0 -0
  274. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/superexec/exec_servicer.py +0 -0
  275. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/superexec/executor.py +0 -0
  276. {flwr_nightly-1.10.0.dev20240717 → flwr_nightly-1.10.0.dev20240721}/src/py/flwr/superexec/simulation.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: flwr-nightly
3
- Version: 1.10.0.dev20240717
3
+ Version: 1.10.0.dev20240721
4
4
  Summary: Flower: A Friendly Federated Learning Framework
5
5
  Home-page: https://flower.ai
6
6
  License: Apache-2.0
@@ -33,7 +33,7 @@ Classifier: Typing :: Typed
33
33
  Provides-Extra: rest
34
34
  Provides-Extra: simulation
35
35
  Requires-Dist: cryptography (>=42.0.4,<43.0.0)
36
- Requires-Dist: grpcio (>=1.60.0,<2.0.0,!=1.64.2,!=1.65.0)
36
+ Requires-Dist: grpcio (>=1.60.0,<2.0.0,!=1.64.2,!=1.65.1)
37
37
  Requires-Dist: iterators (>=0.0.2,<0.0.3)
38
38
  Requires-Dist: numpy (>=1.21.0,<2.0.0)
39
39
  Requires-Dist: pathspec (>=0.12.1,<0.13.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.dev20240717"
7
+ version = "1.10.0.dev20240721"
8
8
  description = "Flower: A Friendly Federated Learning Framework"
9
9
  license = "Apache-2.0"
10
10
  authors = ["The Flower Authors <hello@flower.ai>"]
@@ -64,7 +64,7 @@ flower-simulation = "flwr.simulation.run_simulation:run_simulation_from_cli"
64
64
  python = "^3.8"
65
65
  # Mandatory dependencies
66
66
  numpy = "^1.21.0"
67
- grpcio = "^1.60.0,!=1.64.2,!=1.65.0"
67
+ grpcio = "^1.60.0,!=1.64.2,!=1.65.1"
68
68
  protobuf = "^4.25.2"
69
69
  cryptography = "^42.0.4"
70
70
  pycryptodome = "^3.18.0"
@@ -14,9 +14,9 @@
14
14
  # ==============================================================================
15
15
  """Flower command line interface `new` command."""
16
16
 
17
- import os
18
17
  import re
19
18
  from enum import Enum
19
+ from pathlib import Path
20
20
  from string import Template
21
21
  from typing import Dict, Optional
22
22
 
@@ -59,10 +59,10 @@ class TemplateNotFound(Exception):
59
59
 
60
60
  def load_template(name: str) -> str:
61
61
  """Load template from template directory and return as text."""
62
- tpl_dir = os.path.abspath(os.path.join(os.path.dirname(__file__), "templates"))
63
- tpl_file_path = os.path.join(tpl_dir, name)
62
+ tpl_dir = (Path(__file__).parent / "templates").absolute()
63
+ tpl_file_path = tpl_dir / name
64
64
 
65
- if not os.path.isfile(tpl_file_path):
65
+ if not tpl_file_path.is_file():
66
66
  raise TemplateNotFound(f"Template '{name}' not found")
67
67
 
68
68
  with open(tpl_file_path, encoding="utf-8") as tpl_file:
@@ -78,14 +78,13 @@ def render_template(template: str, data: Dict[str, str]) -> str:
78
78
  return tpl.template
79
79
 
80
80
 
81
- def create_file(file_path: str, content: str) -> None:
81
+ def create_file(file_path: Path, content: str) -> None:
82
82
  """Create file including all nessecary directories and write content into file."""
83
- os.makedirs(os.path.dirname(file_path), exist_ok=True)
84
- with open(file_path, "w", encoding="utf-8") as f:
85
- f.write(content)
83
+ file_path.parent.mkdir(exist_ok=True)
84
+ file_path.write_text(content)
86
85
 
87
86
 
88
- def render_and_create(file_path: str, template: str, context: Dict[str, str]) -> None:
87
+ def render_and_create(file_path: Path, template: str, context: Dict[str, str]) -> None:
89
88
  """Render template and write to file."""
90
89
  content = render_template(template, context)
91
90
  create_file(file_path, content)
@@ -117,6 +116,21 @@ def new(
117
116
  default=sanitize_project_name(project_name),
118
117
  )
119
118
 
119
+ # Set project directory path
120
+ package_name = re.sub(r"[-_.]+", "-", project_name).lower()
121
+ import_name = package_name.replace("-", "_")
122
+ project_dir = Path.cwd() / package_name
123
+
124
+ if project_dir.exists():
125
+ if not typer.confirm(
126
+ typer.style(
127
+ f"\n💬 {project_name} already exists, do you want to override it?",
128
+ fg=typer.colors.MAGENTA,
129
+ bold=True,
130
+ )
131
+ ):
132
+ return
133
+
120
134
  if username is None:
121
135
  username = prompt_text("Please provide your Flower username")
122
136
 
@@ -158,12 +172,6 @@ def new(
158
172
  )
159
173
  )
160
174
 
161
- # Set project directory path
162
- cwd = os.getcwd()
163
- package_name = re.sub(r"[-_.]+", "-", project_name).lower()
164
- import_name = package_name.replace("-", "_")
165
- project_dir = os.path.join(cwd, package_name)
166
-
167
175
  context = {
168
176
  "project_name": project_name,
169
177
  "package_name": package_name,
@@ -252,7 +260,7 @@ def new(
252
260
 
253
261
  for file_path, value in files.items():
254
262
  render_and_create(
255
- file_path=os.path.join(project_dir, file_path),
263
+ file_path=project_dir / file_path,
256
264
  template=value["template"],
257
265
  context=context,
258
266
  )
@@ -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()
@@ -11,10 +11,10 @@ dependencies = [
11
11
  "flwr[simulation]>=1.9.0,<2.0",
12
12
  "flwr-datasets>=0.0.2,<1.0.0",
13
13
  "torch==2.2.1",
14
- "transformers>=4.30.0,<5.0"
15
- "evaluate>=0.4.0,<1.0"
16
- "datasets>=2.0.0, <3.0"
17
- "scikit-learn>=1.3.1, <2.0"
14
+ "transformers>=4.30.0,<5.0",
15
+ "evaluate>=0.4.0,<1.0",
16
+ "datasets>=2.0.0, <3.0",
17
+ "scikit-learn>=1.3.1, <2.0",
18
18
  ]
19
19
 
20
20
  [tool.hatch.build.targets.wheel]
@@ -29,6 +29,7 @@ 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"
@@ -9,9 +9,9 @@ description = ""
9
9
  license = "Apache-2.0"
10
10
  dependencies = [
11
11
  "flwr[simulation]>=1.9.0,<2.0",
12
- "jax==0.4.26",
13
- "jaxlib==0.4.26",
14
- "scikit-learn==1.4.2",
12
+ "jax==0.4.13",
13
+ "jaxlib==0.4.13",
14
+ "scikit-learn==1.3.2",
15
15
  ]
16
16
 
17
17
  [tool.hatch.build.targets.wheel]
@@ -26,6 +26,11 @@ 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"
@@ -26,6 +26,7 @@ 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"
@@ -25,6 +25,9 @@ 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"
@@ -199,7 +199,7 @@ def _run_without_superexec(
199
199
  ]
200
200
 
201
201
  if config_overrides:
202
- command.extend(["--run-config", f"{config_overrides}"])
202
+ command.extend(["--run-config", f"{','.join(config_overrides)}"])
203
203
 
204
204
  # Run the simulation
205
205
  subprocess.run(
@@ -480,8 +480,12 @@ def _run_simulation(
480
480
  if verbose_logging:
481
481
  update_console_handler(level=DEBUG, timestamps=True, colored=True)
482
482
  else:
483
- backend_config["init_args"]["logging_level"] = WARNING
484
- backend_config["init_args"]["log_to_driver"] = True
483
+ backend_config["init_args"]["logging_level"] = backend_config["init_args"].get(
484
+ "logging_level", WARNING
485
+ )
486
+ backend_config["init_args"]["log_to_driver"] = backend_config["init_args"].get(
487
+ "log_to_driver", True
488
+ )
485
489
 
486
490
  if enable_tf_gpu_growth:
487
491
  # Check that Backend config has also enabled using GPU growth