Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Simulation of malicious clients #58

Open
gautamjajoo opened this issue Aug 28, 2024 · 1 comment
Open

Simulation of malicious clients #58

gautamjajoo opened this issue Aug 28, 2024 · 1 comment
Assignees
Labels
enhancement New feature or request research Label reserved for research questions relevant to the scope of the project

Comments

@gautamjajoo
Copy link
Collaborator

Idea

We want to add the feature to simulate malicious clients in the system.

The workflow

Initially, we thought of simulating nodes that send inf/0 values to the system.
But a better version for simulation is as follows:

  1. So each node would get the weights of the previous round.
  2. Now, to these weights the malicious clients will add some noise(maybe Gaussian noise, we can explore more things here).
    This is better than the inf/0 one because it makes the system more robust in terms of detecting the outliers.
  3. Now the various algorithms implemented to detect the malicious clients would come into play and detect these clients.

Implementation details

We need to create a class that will change the structure of Node. It will be like a map of <node, int>.
The node would represent the node_id and the int is the type of malicious client.

Types of malicious clients

We will have different classes representing the type of malicious clients. The various types can be in the form of malicious clients

  1. Outlier Addition: sending outlier weights
  2. Label Flipping: flipping the labels of their data
  3. Byzantine Attacks: sending incorrect model updates/weights
  4. Sybil Attacks: sending correlated updates to create a bias
  5. Targeted Model Poisoning: degrading performance on a particular class while maintaining overall accuracy.
  6. Free riding: not contributing any/useful updates but still receiving the global model.
  7. Large model updates: sending large or complex updates that slow down the server’s aggregation process or cause memory overflow
  8. Communication DoS: flooding the network with useless requests to create issues with the communication infrastructure
@gautamjajoo gautamjajoo self-assigned this Aug 28, 2024
@gautamjajoo gautamjajoo added enhancement New feature or request research Label reserved for research questions relevant to the scope of the project labels Aug 28, 2024
@tremblerz
Copy link
Contributor

@joyce-yuan can we close this now?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request research Label reserved for research questions relevant to the scope of the project
Projects
None yet
Development

No branches or pull requests

2 participants