2. Train the parkour policy. In this example, we use **scandot** for terrain perception, so we remove the **crawl** skill.
- Update the `"{Your trained walking model directory}"` value in the config file `legged_gym/legged_gym/envs/go2/go2_field_config.py` with the trained walking policy folder name.
- Run ```python legged_gym/scripts/train.py --headless --task go2_field```
The training logs will be saved in `logs/field_go2`.
3. Distill the parkour policy
- Update the following literals in the config file `legged_gym/legged_gym/envs/go2/go2_distill_config.py`
-`"{Your trained oracle parkour model folder}"`: The oracle parkour policy folder name in the last step.
-`"{The latest model filename in the directory}"`: The model file name in the oracle parkour policy folder in the last step.
-`"{A temporary directory to store collected trajectory}"`: A temporary directory to store the collected trajectory data.
- Calibrate your depth camera extrinsic pose and update the `position` and `rotation` field in `sensor.forward_camera` class
- Run distillation process (choose one among the two options)
1. Run the distillation process in a single process if you believe you have a powerful GPU than Nvidia RTX 3090.
Set `multi_process_` to `False` in the config file.
Run ```python legged_gym/scripts/train.py --headless --task go2_distill```
2. Run the distillation process in multiple processes with multiple GPUs
Run ```python legged_gym/scripts/train.py --headless --task go2_distill```
Find the log directory generated by the training process when prompted waiting. (e.g. **Jul18_07-22-08_Go2_10skills_fromJul16_07-38-08**)
Run ```python legged_gym/scripts/collect.py --headless --task go2_distill --log --load_run {the log directory name}``` in another terminal on another GPU. (Can run multiple collectors in parallel)
With `python legged_gym/scripts/train.py --headless --task a1_distill` you launch the trainer. The process will prompt you to launch a collector process, where the log directory is corresponding to the task.
With `python legged_gym/scripts/collect.py --headless --task a1_distill --load_run {your training run}` you lauched the collector. The process will load the training policy and start collecting the data. The collected data will be saved in the directory prompted by the trainer. Remove it after you finish distillation.
Launch the training by `python legged_gym/scripts/train.py --headless --task a1_field`. You will find the training log in `logs/a1_field`. The folder name is also the run name.
- Launch the scirpt with task `a1_climb`, `a1_leap`, `a1_crawl`, `a1_tilt`. The training log will also be saved in `logs/a1_field`.
- The default training is in soft-dynamics constraint. To train in hard-dynamics constraint, change the `virtural_terraion` value to `False` in the corresponding config file.
- Uncomment the `class sensor` part to enable the proprioception delay.
- For `a1_climb`, please update the `climb["depth"]` field when switching to hard-dynamics constraint.
1. Update the `A1FieldDistillCfgPPO.algorithm.teacher_policy.sub_policy_paths` field with the logdir of your own trained skill policy. (in `a1_field_distill_config.py`)
2. Run data collection using `python legged_gym/scripts/collect.py --headless --task a1_distill`. The data will be saved in the `logs/distill_{robot}_dagger` directory.
***You can generate multiple datasets by running this step multiple times.***
***You can use soft link to put the `logs/distill_{robot}_dagger` directoy to a faster filesystem to speed up the training and data-collecting process.***
3. Update the `A1FieldDistillCfgPPO.runner.pretrain_dataset.data_dir` field with a list of dataset directories. Comment out the `A1FieldDistillCfgPPO.runner.pretrain_dataset.scan_dir` field. (in `a1_field_distill_config.py`)
4. Run `python legged_gym/scripts/train.py --headless --task a1_distill` to start distillation. The distillation log will be saved in `logs/distill_{robot}`.
5. Comment out `A1FieldDistillCfgPPO.runner.pretrain_dataset.data_dir` field and uncomment `A1FieldDistillCfgPPO.runner.pretrain_dataset.scan_dir` field. (in `a1_field_distill_config.py`)
6. Update the `A1FieldDistillCfgPPO.runner.load_run` field with your last distillation log.
7. Run `python legged_gym/scripts/train.py --headless --task a1_distill` to start dagger. The terminal will prompt you to launch a collector process.
To run the collector process, change `RunnerCls` to `DaggerSaver` (as in lines 20-21). Run `python legged_gym/scripts/collect.py --headless --task a1_distill --load_run {the training run prompt by the training process}`.
***The collectors can be run on any other machine as long as the `logs/distill_{robot}_dagger` and `logs/distill_{robot}` directory is shared among them.***
Press Enter in the training process when you see some data is collected (prompted by the collector process). The training process will load the collected data and start training.