#### Hardware: 

In this project, we used an inverted pendulum as the testbed. The configurations and setup details about the pendulum can be found in [Quanser document](https://www.quanser.com/products/linear-servo-base-unit-inverted-pendulum/).

#### Software
Install requirements in a virtual environment (Tested on anaconda/miniconda environment):

```Shell
conda create --name cloudedge python==3.8.0 
```

```Shell
pip install -r requirements.txt
```

The code is tested on Python `3.8.0`, Tensorflow `2.9.0`  

### Generate a configuration template

```Shell
python main_ddpg.py --generate
```
A configuration template of .json will be generated and saved under ./config. One can change the parameter to try different configurations. 

### Training in simulation

```Shell
python main_ddpg.py --config {DIR-CONFIGURATION} --id {NAME} --weights {DIR-PRETRAINED MODEL}
```

### Training in the real world

#### On the edge device
```Shell
ssh username@ip_edge_device
cd rips
```
Training
```Shell 
python main_edgecontrol.py --config ./config/remote/remote_edgecontrol.json
```
Evaluating

```Shell 
python main_edgecontrol.py --eval {DIR-PRETRAINED MODEL}
```

#### On the cloud device

Launch training process (example)

```Shell
python main_cloudtrain.py --config ./config/remote/remote_cloud_ddpg++.json --weights ./models/pretrained_model/ --id remote_training --params trainer_params/pre_fill_exp 3500 trainer_params/actor_freeze_step_count 3500
```

Real-time streaming 
```Shell
python main_scope.py --config config/remote/remote_plant_scope.json
``
