# Poisoning Federated Reinforcement Learning

This is an implementation of adversarial poisoning method for FRL.

Requirements: 
1. create the spinningup environment https://spinningup.openai.com/en/latest/user/installation.html
2. (optional) install mujoco-py https://github.com/openai/mujoco-py

## Run Experiments:

For example, for attacking FRL with vpg on the halfcheetah environment using budget = 1, suppose the system is composed of 10 agents where 1 agent is malicious, run it for 200 rounds and in each round do 50 local training steps, then the command is

>python main.py --rounds 200 --episodes 50 --agents 10 --Magents 1 --learner vpg --seed 0 --radius 1 --env HalfCheetah-v2


## Customize Experiments

Using command 

>  python main.py 

to preform attacking, which has options

> --env: name of gym environment
>
> --rounds: federated rounds
>
> --episodes: local training episodes
>
> --agents: number of agents in the system
>
> --Magent: number of malicious agents in the system
>
> --algo(=vpg, ppo): the learner's algorithm
